]> xenbits.xensource.com Git - xen.git/commitdiff
svm: decode-assists feature must depend on nextrip feature.
authorKeir Fraser <keir@xen.org>
Mon, 18 Apr 2011 09:10:02 +0000 (10:10 +0100)
committerKeir Fraser <keir@xen.org>
Mon, 18 Apr 2011 09:10:02 +0000 (10:10 +0100)
...since the decode-assist fast paths assume nextrip vmcb field is
valid.

Signed-off-by: Keir Fraser <keir@xen.org>
xen/arch/x86/hvm/svm/svm.c

index e76509b23478c82bd10dfce930f7b6713a516ffd..8753cafa3e2d7df61cb251d4cdb0f47705bdbb65 100644 (file)
@@ -995,6 +995,10 @@ struct hvm_function_table * __init start_svm(void)
 
     printk("SVM: Supported advanced features:\n");
 
+    /* DecodeAssists fast paths assume nextrip is valid for fast rIP update. */
+    if ( !cpu_has_svm_nrips )
+        clear_bit(SVM_FEATURE_DECODEASSISTS, &svm_feature_flags);
+
 #define P(p,s) if ( p ) { printk(" - %s\n", s); printed = 1; }
     P(cpu_has_svm_npt, "Nested Page Tables (NPT)");
     P(cpu_has_svm_lbrv, "Last Branch Record (LBR) Virtualisation");
@@ -1142,7 +1146,6 @@ static void svm_vmexit_do_cr_access(
 
     rc = dir ? hvm_mov_to_cr(cr, gp) : hvm_mov_from_cr(cr, gp);
 
-    ASSERT(cpu_has_svm_nrips);
     if ( rc == X86EMUL_OKAY )
         __update_guest_eip(regs, vmcb->nextrip - vmcb->rip);
 }