From: Claudio Imbrenda <imbrenda@linux.ibm.com>
To: kvm@vger.kernel.org
Cc: linux-kernel@vger.kernel.org, linux-s390@vger.kernel.org,
borntraeger@de.ibm.com, frankja@linux.ibm.com, nsg@linux.ibm.com,
nrb@linux.ibm.com, seiden@linux.ibm.com, gra@linux.ibm.com,
schlameuss@linux.ibm.com, hca@linux.ibm.com, svens@linux.ibm.com,
agordeev@linux.ibm.com, gor@linux.ibm.com, david@redhat.com,
gerald.schaefer@linux.ibm.com
Subject: [PATCH v4 00/23] KVM: s390: gmap rewrite, the real deal
Date: Thu, 20 Nov 2025 18:15:21 +0100 [thread overview]
Message-ID: <20251120171544.96841-1-imbrenda@linux.ibm.com> (raw)
This series is the last big series of the gmap rewrite. It introduces
the new code and actually uses it. The old code is then removed.
The insertions/deletions balance is negative both for this series, and
for the whole rewrite, also considering all the preparatory patches.
KVM on s390 will now use the mmu_notifier, like most other
architectures. The gmap address space is now completely separate from
userspace; no level of the page tables is shared between guest mapping
and userspace.
One of the biggest advantages is that the page size of userspace is
completely independent of the page size used by the guest. Userspace
can mix normal pages, THPs, hugetlbfs, and more.
It's now possible to have nested guests and guests with huge pages
running on the same host. In fact, it's possible to have a nested
guest on a guest with huge pages. Transparent hugepages are also
possible.
Patches 1 to 6 are mostly preparations; introducing some new bits and
functions, and moving code around.
Patches 7 to 16 are the meat of the new gmap code; page table management
functions and gmap management. This is the code that will be used to
manage guest memory.
Patch 19 is unfortunately big; the existing code is converted to use
the new gmap and all references to the old gmap are removed. This needs
to be done all at once, unfortunately, hence the size of the patch.
Patch 20 and 21 remove all the now unused code.
Patch 22 and 23 allow for 1M pages to be used to back guests, and add
some more functions that are useful for testing.
v3->v4:
* dat_link() can now return -ENOMEM when appropriate
* fixed a few vSIE races that led to use-after-free or deadlocks
* split part of the previous patch 23 and move it after patch 17, merge
the rest of the patch into patch 19
* fix -ENOMEM handling in handle_pfmf() and handle_sske()
v2->v3:
* Add lots of small comments and cosmetic fixes
* Rename some functions to improve clarity
* Remove unused helper functions and macros
* Rename inline asm constraints labels to make them more understandable
* Refactor the code to pre-allocate the page tables (using custom
caches) when sleeping is allowed, use the cached pages when holding
spinlocks and handle gracefully allocation failures (i.e. retry
instead of killing the guest)
* Refactor the code for fault handling; it's now in a separate file,
and it takes a callback that can be optionally called when all the
relevant locks are still held
* Use assembler mnemonics instead of manually specifying the opcode
where appropriate
* Remove the LEVEL_* enum, and use TABLE_TYPE_* macros instead;
introduce new TABLE_TYPE_PAGE_TABLE
* Remove usage of cpu_has_idte() since it is being removed from the
kernel
* Improve storage key handling and PGSTE locking
* Introduce struct guest_fault to represent the state of a guest fault
that is being resolved
* Minor CMMA fixes
Claudio Imbrenda (23):
KVM: s390: Refactor pgste lock and unlock functions
KVM: s390: add P bit in table entry bitfields, move union vaddress
s390: Move sske_frame() to a header
KVM: s390: Add gmap_helper_set_unused()
KVM: s390: Enable KVM_GENERIC_MMU_NOTIFIER
KVM: s390: Rename some functions in gaccess.c
KVM: s390: KVM-specific bitfields and helper functions
KVM: s390: KVM page table management functions: allocation
KVM: s390: KVM page table management functions: clear and replace
KVM: s390: KVM page table management functions: walks
KVM: s390: KVM page table management functions: storage keys
KVM: s390: KVM page table management functions: lifecycle management
KVM: s390: KVM page table management functions: CMMA
KVM: s390: New gmap code
KVM: s390: Add helper functions for fault handling
KVM: s390: Add some helper functions needed for vSIE
KVM: s390: Stop using CONFIG_PGSTE
KVM: s390: Storage key functions refactoring
KVM: s390: Switch to new gmap
KVM: s390: Remove gmap from s390/mm
KVM: S390: Remove PGSTE code from linux/s390 mm
KVM: s390: Enable 1M pages for gmap
KVM: s390: Storage key manipulation IOCTL
MAINTAINERS | 2 -
arch/s390/Kconfig | 3 -
arch/s390/include/asm/dat-bits.h | 32 +-
arch/s390/include/asm/gmap.h | 174 --
arch/s390/include/asm/gmap_helpers.h | 1 +
arch/s390/include/asm/kvm_host.h | 5 +
arch/s390/include/asm/mmu.h | 13 -
arch/s390/include/asm/mmu_context.h | 6 +-
arch/s390/include/asm/page.h | 4 -
arch/s390/include/asm/pgalloc.h | 4 -
arch/s390/include/asm/pgtable.h | 163 +-
arch/s390/include/asm/tlb.h | 3 -
arch/s390/include/asm/uaccess.h | 70 +-
arch/s390/kvm/Kconfig | 3 +-
arch/s390/kvm/Makefile | 3 +-
arch/s390/kvm/dat.c | 1364 ++++++++++++++
arch/s390/kvm/dat.h | 965 ++++++++++
arch/s390/kvm/diag.c | 2 +-
arch/s390/kvm/faultin.c | 148 ++
arch/s390/kvm/faultin.h | 92 +
arch/s390/kvm/gaccess.c | 937 +++++-----
arch/s390/kvm/gaccess.h | 20 +-
arch/s390/kvm/gmap-vsie.c | 141 --
arch/s390/kvm/gmap.c | 1131 ++++++++++++
arch/s390/kvm/gmap.h | 165 ++
arch/s390/kvm/intercept.c | 15 +-
arch/s390/kvm/interrupt.c | 2 +-
arch/s390/kvm/kvm-s390.c | 927 ++++------
arch/s390/kvm/kvm-s390.h | 28 +-
arch/s390/kvm/priv.c | 211 +--
arch/s390/kvm/pv.c | 67 +-
arch/s390/kvm/vsie.c | 153 +-
arch/s390/lib/uaccess.c | 184 +-
arch/s390/mm/Makefile | 1 -
arch/s390/mm/fault.c | 4 +-
arch/s390/mm/gmap.c | 2453 --------------------------
arch/s390/mm/gmap_helpers.c | 87 +-
arch/s390/mm/hugetlbpage.c | 24 -
arch/s390/mm/page-states.c | 1 +
arch/s390/mm/pageattr.c | 7 -
arch/s390/mm/pgalloc.c | 24 -
arch/s390/mm/pgtable.c | 818 +--------
include/uapi/linux/kvm.h | 10 +
mm/khugepaged.c | 9 -
44 files changed, 5162 insertions(+), 5314 deletions(-)
delete mode 100644 arch/s390/include/asm/gmap.h
create mode 100644 arch/s390/kvm/dat.c
create mode 100644 arch/s390/kvm/dat.h
create mode 100644 arch/s390/kvm/faultin.c
create mode 100644 arch/s390/kvm/faultin.h
delete mode 100644 arch/s390/kvm/gmap-vsie.c
create mode 100644 arch/s390/kvm/gmap.c
create mode 100644 arch/s390/kvm/gmap.h
delete mode 100644 arch/s390/mm/gmap.c
--
2.51.1
next reply other threads:[~2025-11-20 17:15 UTC|newest]
Thread overview: 24+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-11-20 17:15 Claudio Imbrenda [this message]
2025-11-20 17:15 ` [PATCH v4 01/23] KVM: s390: Refactor pgste lock and unlock functions Claudio Imbrenda
2025-11-20 17:15 ` [PATCH v4 02/23] KVM: s390: add P bit in table entry bitfields, move union vaddress Claudio Imbrenda
2025-11-20 17:15 ` [PATCH v4 03/23] s390: Move sske_frame() to a header Claudio Imbrenda
2025-11-20 17:15 ` [PATCH v4 04/23] KVM: s390: Add gmap_helper_set_unused() Claudio Imbrenda
2025-11-20 17:15 ` [PATCH v4 05/23] KVM: s390: Enable KVM_GENERIC_MMU_NOTIFIER Claudio Imbrenda
2025-11-20 17:15 ` [PATCH v4 06/23] KVM: s390: Rename some functions in gaccess.c Claudio Imbrenda
2025-11-20 17:15 ` [PATCH v4 07/23] KVM: s390: KVM-specific bitfields and helper functions Claudio Imbrenda
2025-11-20 17:15 ` [PATCH v4 08/23] KVM: s390: KVM page table management functions: allocation Claudio Imbrenda
2025-11-20 17:15 ` [PATCH v4 09/23] KVM: s390: KVM page table management functions: clear and replace Claudio Imbrenda
2025-11-20 17:15 ` [PATCH v4 10/23] KVM: s390: KVM page table management functions: walks Claudio Imbrenda
2025-11-20 17:15 ` [PATCH v4 11/23] KVM: s390: KVM page table management functions: storage keys Claudio Imbrenda
2025-11-20 17:15 ` [PATCH v4 12/23] KVM: s390: KVM page table management functions: lifecycle management Claudio Imbrenda
2025-11-20 17:15 ` [PATCH v4 13/23] KVM: s390: KVM page table management functions: CMMA Claudio Imbrenda
2025-11-20 17:15 ` [PATCH v4 14/23] KVM: s390: New gmap code Claudio Imbrenda
2025-11-20 17:15 ` [PATCH v4 15/23] KVM: s390: Add helper functions for fault handling Claudio Imbrenda
2025-11-20 17:15 ` [PATCH v4 16/23] KVM: s390: Add some helper functions needed for vSIE Claudio Imbrenda
2025-11-20 17:15 ` [PATCH v4 17/23] KVM: s390: Stop using CONFIG_PGSTE Claudio Imbrenda
2025-11-20 17:15 ` [PATCH v4 18/23] KVM: s390: Storage key functions refactoring Claudio Imbrenda
2025-11-20 17:15 ` [PATCH v4 19/23] KVM: s390: Switch to new gmap Claudio Imbrenda
2025-11-20 17:15 ` [PATCH v4 20/23] KVM: s390: Remove gmap from s390/mm Claudio Imbrenda
2025-11-20 17:15 ` [PATCH v4 21/23] KVM: S390: Remove PGSTE code from linux/s390 mm Claudio Imbrenda
2025-11-20 17:15 ` [PATCH v4 22/23] KVM: s390: Enable 1M pages for gmap Claudio Imbrenda
2025-11-20 17:15 ` [PATCH v4 23/23] KVM: s390: Storage key manipulation IOCTL Claudio Imbrenda
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20251120171544.96841-1-imbrenda@linux.ibm.com \
--to=imbrenda@linux.ibm.com \
--cc=agordeev@linux.ibm.com \
--cc=borntraeger@de.ibm.com \
--cc=david@redhat.com \
--cc=frankja@linux.ibm.com \
--cc=gerald.schaefer@linux.ibm.com \
--cc=gor@linux.ibm.com \
--cc=gra@linux.ibm.com \
--cc=hca@linux.ibm.com \
--cc=kvm@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-s390@vger.kernel.org \
--cc=nrb@linux.ibm.com \
--cc=nsg@linux.ibm.com \
--cc=schlameuss@linux.ibm.com \
--cc=seiden@linux.ibm.com \
--cc=svens@linux.ibm.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox