linux-stable/arch/s390
Christian Borntraeger 28bb27824f KVM: s390: vsie: fix race during shadow creation
commit fe752331d4 upstream.

Right now it is possible to see gmap->private being zero in
kvm_s390_vsie_gmap_notifier resulting in a crash.  This is due to the
fact that we add gmap->private == kvm after creation:

static int acquire_gmap_shadow(struct kvm_vcpu *vcpu,
                               struct vsie_page *vsie_page)
{
[...]
        gmap = gmap_shadow(vcpu->arch.gmap, asce, edat);
        if (IS_ERR(gmap))
                return PTR_ERR(gmap);
        gmap->private = vcpu->kvm;

Let children inherit the private field of the parent.

Reported-by: Marc Hartmayer <mhartmay@linux.ibm.com>
Fixes: a3508fbe9d ("KVM: s390: vsie: initial support for nested virtualization")
Cc: <stable@vger.kernel.org>
Cc: David Hildenbrand <david@redhat.com>
Reviewed-by: Janosch Frank <frankja@linux.ibm.com>
Reviewed-by: David Hildenbrand <david@redhat.com>
Reviewed-by: Claudio Imbrenda <imbrenda@linux.ibm.com>
Signed-off-by: Christian Borntraeger <borntraeger@linux.ibm.com>
Link: https://lore.kernel.org/r/20231220125317.4258-1-borntraeger@linux.ibm.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2024-02-23 09:51:53 +01:00
..
appldata S390: Remove now superfluous sentinel elem from ctl_table arrays 2023-10-10 15:22:02 -07:00
boot s390/boot: always align vmalloc area on segment boundary 2024-02-05 20:16:47 +00:00
configs s390 updates for 6.7-rc7 2023-12-20 16:12:39 -08:00
crypto crypto: s390/aes - Fix buffer overread in CTR mode 2024-01-31 16:20:54 -08:00
hypfs hypfs: convert to new timestamp accessors 2023-10-18 13:26:15 +02:00
include work around gcc bugs with 'asm goto' with outputs 2024-02-23 09:51:20 +01:00
kernel s390/ptrace: handle setting of fpc register correctly 2024-02-05 20:16:48 +00:00
kvm KVM: s390: vsie: fix race during shadow creation 2024-02-23 09:51:53 +01:00
lib s390/ctlreg: add struct ctlreg 2023-09-19 13:26:56 +02:00
mm KVM: s390: vsie: fix race during shadow creation 2024-02-23 09:51:53 +01:00
net s390/bpf: Fix gotol with large offsets 2024-01-25 15:44:56 -08:00
pci s390/pci: fix max size calculation in zpci_memcpy_toio() 2024-01-25 15:45:26 -08:00
purgatory s390 updates for 6.5 merge window part 2 2023-07-06 13:18:30 -07:00
tools KVM: s390: Add facility 197 to the allow list 2022-07-13 15:25:25 +02:00
Kbuild - An extensive rework of kexec and crash Kconfig from Eric DeVolder 2023-08-29 14:53:51 -07:00
Kconfig kexec: fix KEXEC_FILE dependencies 2023-12-20 13:46:19 -08:00
Kconfig.debug s390/Kconfig.debug: fix indentation 2022-06-01 12:03:15 +02:00
Makefile kbuild: unify vdso_install rules 2023-10-28 21:09:02 +09:00