[S390] kvm: make sigp emerg smp capable
authorChristian Ehrhardt <ehrhardt@linux.vnet.ibm.com>
Sun, 24 Jul 2011 08:48:31 +0000 (10:48 +0200)
committerMartin Schwidefsky <schwidefsky@de.ibm.com>
Sun, 24 Jul 2011 08:48:22 +0000 (10:48 +0200)
SIGP emerg needs to pass the source vpu adress into __LC_CPU_ADDRESS of the
target guest.

Signed-off-by: Christian Ehrhardt <ehrhardt@linux.vnet.ibm.com>
Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
arch/s390/include/asm/kvm_host.h
arch/s390/kvm/interrupt.c

index e5d082c4f3aaca4473eefa69a83cad94c5a5f117..00ff00dfb24ce34917772a231d9607a56e15e9e9 100644 (file)
@@ -174,6 +174,10 @@ struct kvm_s390_prefix_info {
        __u32 address;
 };
 
+struct kvm_s390_emerg_info {
+       __u16 code;
+};
+
 struct kvm_s390_interrupt_info {
        struct list_head list;
        u64     type;
@@ -181,6 +185,7 @@ struct kvm_s390_interrupt_info {
                struct kvm_s390_io_info io;
                struct kvm_s390_ext_info ext;
                struct kvm_s390_pgm_info pgm;
+               struct kvm_s390_emerg_info emerg;
                struct kvm_s390_prefix_info prefix;
        };
 };
index 35c21bf910c55bff4e1ee45ee968eb69726dd182..c9aeb4b4d0b84e67c9cc5ae1bf6648d31ea7c6dd 100644 (file)
@@ -128,6 +128,10 @@ static void __do_deliver_interrupt(struct kvm_vcpu *vcpu,
                if (rc == -EFAULT)
                        exception = 1;
 
+               rc = put_guest_u16(vcpu, __LC_CPU_ADDRESS, inti->emerg.code);
+               if (rc == -EFAULT)
+                       exception = 1;
+
                rc = copy_to_guest(vcpu, __LC_EXT_OLD_PSW,
                         &vcpu->arch.sie_block->gpsw, sizeof(psw_t));
                if (rc == -EFAULT)