]> xenbits.xensource.com Git - people/vhanquez/xen.git/commitdiff
x86: Fix HVM hypercall preemption causing guest crash.
authorKeir Fraser <keir.fraser@citrix.com>
Tue, 29 Jan 2008 15:27:44 +0000 (15:27 +0000)
committerKeir Fraser <keir.fraser@citrix.com>
Tue, 29 Jan 2008 15:27:44 +0000 (15:27 +0000)
Signed-off-by: Yu Zhao <yu.zhao@intel.com>
xen-unstable changeset:   16929:128f7bc0a277375571b4817fc65bfcd14e00a7ec
xen-unstable date:        Tue Jan 29 11:47:42 2008 +0000

xen/arch/x86/domain.c

index b90079688599b16c6ca11a0527bdd06b471ccc86..b4170cc2b19ef516ae12e7149c55fa36430b7722 100644 (file)
@@ -1388,7 +1388,12 @@ unsigned long hypercall_create_continuation(
     {
         regs       = guest_cpu_user_regs();
         regs->eax  = op;
-        regs->eip -= 2;  /* re-execute 'syscall' / 'int 0x82' */
+        /*
+         * For PV guest, we update EIP to re-execute 'syscall' / 'int 0x82';
+         * HVM does not need this since 'vmcall' / 'vmmcall' is fault-like.
+         */
+        if ( !is_hvm_vcpu(current) )
+            regs->eip -= 2;  /* re-execute 'syscall' / 'int 0x82' */
 
 #ifdef __x86_64__
         if ( !is_hvm_vcpu(current) ?