From 0015e2af1f13b17ffeadf2e8e784afd2020ad8eb Mon Sep 17 00:00:00 2001 From: Avi Kivity Date: Tue, 21 Aug 2012 17:07:05 +0300 Subject: [PATCH] --- yaml --- r: 329883 b: refs/heads/master c: a5625189f6810ef79ced53989c794acfa10d3370 h: refs/heads/master i: 329881: 2eda737d2dc1a3fc08c5085dd51d9d07000c243e 329879: 206abe40ae04888cee2085ab023377447ead9471 v: v3 --- [refs] | 2 +- trunk/arch/x86/kvm/emulate.c | 7 ++++--- 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/[refs] b/[refs] index 591bc6022c59..01f182f74c8f 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 03ebebeb1ff5d1d6209fd8df4ffc9204df82bd55 +refs/heads/master: a5625189f6810ef79ced53989c794acfa10d3370 diff --git a/trunk/arch/x86/kvm/emulate.c b/trunk/arch/x86/kvm/emulate.c index f8b27cd2a6cb..5b1c701cd6d0 100644 --- a/trunk/arch/x86/kvm/emulate.c +++ b/trunk/arch/x86/kvm/emulate.c @@ -668,8 +668,6 @@ static int __linearize(struct x86_emulate_ctxt *ctxt, la = seg_base(ctxt, addr.seg) + addr.ea; switch (ctxt->mode) { - case X86EMUL_MODE_REAL: - break; case X86EMUL_MODE_PROT64: if (((signed long)la << 16) >> 16 != la) return emulate_gp(ctxt, 0); @@ -699,7 +697,10 @@ static int __linearize(struct x86_emulate_ctxt *ctxt, goto bad; } cpl = ctxt->ops->cpl(ctxt); - rpl = sel & 3; + if (ctxt->mode == X86EMUL_MODE_REAL) + rpl = 0; + else + rpl = sel & 3; cpl = max(cpl, rpl); if (!(desc.type & 8)) { /* data segment */