[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] [xen-unstable] x86_emulate: Certain opcodes are only valid with a memory operand.
# HG changeset patch # User Keir Fraser <keir.fraser@xxxxxxxxxx> # Date 1200005560 0 # Node ID c86025f569cbeece7561898f2a81b2979e1c93a9 # Parent 850ec55df0dc9f831091155012bba0c613759470 x86_emulate: Certain opcodes are only valid with a memory operand. Signed-off-by: Keir Fraser <keir.fraser@xxxxxxxxxx> --- xen/arch/x86/x86_emulate.c | 4 ++++ 1 files changed, 4 insertions(+) diff -r 850ec55df0dc -r c86025f569cb xen/arch/x86/x86_emulate.c --- a/xen/arch/x86/x86_emulate.c Thu Jan 10 15:30:46 2008 +0000 +++ b/xen/arch/x86/x86_emulate.c Thu Jan 10 22:52:40 2008 +0000 @@ -1751,6 +1751,8 @@ x86_emulate( case 5: /* jmp (far, absolute indirect) */ { unsigned long sel; + generate_exception_if(dst.type != OP_MEM, EXC_UD); + if ( (rc = ops->read(dst.mem.seg, dst.mem.off+dst.bytes, &sel, 2, ctxt)) ) goto done; @@ -2981,6 +2983,7 @@ x86_emulate( { unsigned long old_lo, old_hi; generate_exception_if((modrm_reg & 7) != 1, EXC_UD); + generate_exception_if(ea.type != OP_MEM, EXC_UD); if ( (rc = ops->read(ea.mem.seg, ea.mem.off+0, &old_lo, 4, ctxt)) || (rc = ops->read(ea.mem.seg, ea.mem.off+4, &old_hi, 4, ctxt)) ) goto done; @@ -3008,6 +3011,7 @@ x86_emulate( { unsigned long old, new; generate_exception_if((modrm_reg & 7) != 1, EXC_UD); + generate_exception_if(ea.type != OP_MEM, EXC_UD); if ( (rc = ops->read(ea.mem.seg, ea.mem.off, &old, 8, ctxt)) != 0 ) goto done; if ( ((uint32_t)(old>>0) != (uint32_t)_regs.eax) || _______________________________________________ Xen-changelog mailing list Xen-changelog@xxxxxxxxxxxxxxxxxxx http://lists.xensource.com/xen-changelog
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |