]> xenbits.xensource.com Git - people/royger/xen.git/commitdiff
x86/hvm: remove emulation context setting from hvmemul_cmpxchg()
authorRazvan Cojocaru <rcojocaru@bitdefender.com>
Fri, 7 Oct 2016 09:35:58 +0000 (11:35 +0200)
committerJan Beulich <jbeulich@suse.com>
Fri, 7 Oct 2016 09:35:58 +0000 (11:35 +0200)
hvmemul_cmpxchg() sets the read emulation context in p_new instead
of p_old, which is inconsistent (and wrong). Since p_old is
unused in any case and cmpxchg() semantics would be altered even
if it wasn't, remove the emulation context setting code.

Suggested-by: Jan Beulich <jbeulich@suse.com>
Signed-off-by: Razvan Cojocaru <rcojocaru@bitdefender.com>
xen/arch/x86/hvm/emulate.c

index d759d3f7d19d1023a54bf8d5e833a687ef99ac5a..6ed74866deb2447a35835bbb9ad09ec6ed73a6b2 100644 (file)
@@ -1026,17 +1026,6 @@ static int hvmemul_cmpxchg(
     unsigned int bytes,
     struct x86_emulate_ctxt *ctxt)
 {
-    struct hvm_emulate_ctxt *hvmemul_ctxt =
-        container_of(ctxt, struct hvm_emulate_ctxt, ctxt);
-
-    if ( unlikely(hvmemul_ctxt->set_context) )
-    {
-        int rc = set_context_data(p_new, bytes);
-
-        if ( rc != X86EMUL_OKAY )
-            return rc;
-    }
-
     /* Fix this in case the guest is really relying on r-m-w atomicity. */
     return hvmemul_write(seg, offset, p_new, bytes, ctxt);
 }