KVM: x86 emulator: fix mov r/m, sreg emulation.
mov r/m, sreg generates #UD ins sreg is incorrect. Signed-off-by: Gleb Natapov <gleb@redhat.com> Signed-off-by: Marcelo Tosatti <mtosatti@redhat.com>
This commit is contained in:
@@ -2126,12 +2126,11 @@ special_insn:
|
|||||||
case 0x8c: { /* mov r/m, sreg */
|
case 0x8c: { /* mov r/m, sreg */
|
||||||
struct kvm_segment segreg;
|
struct kvm_segment segreg;
|
||||||
|
|
||||||
if (c->modrm_reg <= 5)
|
if (c->modrm_reg <= VCPU_SREG_GS)
|
||||||
kvm_get_segment(ctxt->vcpu, &segreg, c->modrm_reg);
|
kvm_get_segment(ctxt->vcpu, &segreg, c->modrm_reg);
|
||||||
else {
|
else {
|
||||||
printk(KERN_INFO "0x8c: Invalid segreg in modrm byte 0x%02x\n",
|
kvm_queue_exception(ctxt->vcpu, UD_VECTOR);
|
||||||
c->modrm);
|
goto done;
|
||||||
goto cannot_emulate;
|
|
||||||
}
|
}
|
||||||
c->dst.val = segreg.selector;
|
c->dst.val = segreg.selector;
|
||||||
break;
|
break;
|
||||||
|
Reference in New Issue
Block a user