The NoAccess flag will prevent memory from being accessed.

Signed-off-by: Avi Kivity <[email protected]>
---
 arch/x86/kvm/emulate.c |    4 ++--
 1 files changed, 2 insertions(+), 2 deletions(-)

diff --git a/arch/x86/kvm/emulate.c b/arch/x86/kvm/emulate.c
index 29312a0..46a5d75 100644
--- a/arch/x86/kvm/emulate.c
+++ b/arch/x86/kvm/emulate.c
@@ -2148,7 +2148,7 @@ static struct opcode opcode_table[256] = {
        /* 0x88 - 0x8F */
        D(ByteOp | DstMem | SrcReg | ModRM | Mov), D(DstMem | SrcReg | ModRM | 
Mov),
        D(ByteOp | DstReg | SrcMem | ModRM | Mov), D(DstReg | SrcMem | ModRM | 
Mov),
-       D(DstMem | SrcNone | ModRM | Mov), D(ModRM | DstReg),
+       D(DstMem | SrcNone | ModRM | Mov), D(ModRM | SrcMem | NoAccess | 
DstReg),
        D(ImplicitOps | SrcMem16 | ModRM), G(0, group1A),
        /* 0x90 - 0x97 */
        X8(D(SrcAcc | DstReg)),
@@ -2883,7 +2883,7 @@ special_insn:
                c->dst.val = ops->get_segment_selector(c->modrm_reg, 
ctxt->vcpu);
                break;
        case 0x8d: /* lea r16/r32, m */
-               c->dst.val = c->modrm_ea;
+               c->dst.val = c->src.addr.mem;
                break;
        case 0x8e: { /* mov seg, r/m16 */
                uint16_t sel;
-- 
1.7.1

--
To unsubscribe from this list: send the line "unsubscribe kvm" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to