]> xenbits.xensource.com Git - people/royger/xen.git/commitdiff
x86/HVM: correct repeat count update in linear->phys translation
authorJan Beulich <jbeulich@suse.com>
Fri, 8 Sep 2017 14:23:46 +0000 (16:23 +0200)
committerJan Beulich <jbeulich@suse.com>
Fri, 8 Sep 2017 14:23:46 +0000 (16:23 +0200)
For the insn emulator's fallback logic in REP INS/OUTS handling
to work correctly, *reps must not be set to zero when returning
X86EMUL_UNHANDLEABLE.

Signed-off-by: Jan Beulich <jbeulich@suse.com>
Reviewed-by: Andrew Cooper <andrew.cooper3@citrix.com>
Acked-by: Paul Durrant <paul.durrant@citrix.com>
xen/arch/x86/hvm/emulate.c

index 64454c7825f82e36edb8f6f15d484776a77c8812..54811c192a2d85eb2f9251b9ac17f379c2b199d9 100644 (file)
@@ -566,15 +566,16 @@ static int hvmemul_linear_to_phys(
             if ( pfec & (PFEC_page_paged | PFEC_page_shared) )
                 return X86EMUL_RETRY;
             done /= bytes_per_rep;
-            *reps = done;
             if ( done == 0 )
             {
                 ASSERT(!reverse);
                 if ( npfn != gfn_x(INVALID_GFN) )
                     return X86EMUL_UNHANDLEABLE;
+                *reps = 0;
                 x86_emul_pagefault(pfec, addr & PAGE_MASK, &hvmemul_ctxt->ctxt);
                 return X86EMUL_EXCEPTION;
             }
+            *reps = done;
             break;
         }