aboutsummaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
Diffstat (limited to 'arch')
-rw-r--r--arch/x86/kvm/x86_emulate.c25
1 files changed, 24 insertions, 1 deletions
diff --git a/arch/x86/kvm/x86_emulate.c b/arch/x86/kvm/x86_emulate.c
index 21d7ff6a8ecd..b049b6bf9a71 100644
--- a/arch/x86/kvm/x86_emulate.c
+++ b/arch/x86/kvm/x86_emulate.c
@@ -138,7 +138,8 @@ static u16 opcode_table[256] = {
138 /* 0x88 - 0x8F */ 138 /* 0x88 - 0x8F */
139 ByteOp | DstMem | SrcReg | ModRM | Mov, DstMem | SrcReg | ModRM | Mov, 139 ByteOp | DstMem | SrcReg | ModRM | Mov, DstMem | SrcReg | ModRM | Mov,
140 ByteOp | DstReg | SrcMem | ModRM | Mov, DstReg | SrcMem | ModRM | Mov, 140 ByteOp | DstReg | SrcMem | ModRM | Mov, DstReg | SrcMem | ModRM | Mov,
141 0, ModRM | DstReg, 0, Group | Group1A, 141 0, ModRM | DstReg,
142 DstReg | SrcMem | ModRM | Mov, Group | Group1A,
142 /* 0x90 - 0x9F */ 143 /* 0x90 - 0x9F */
143 0, 0, 0, 0, 0, 0, 0, 0, 144 0, 0, 0, 0, 0, 0, 0, 0,
144 0, 0, 0, 0, ImplicitOps | Stack, ImplicitOps | Stack, 0, 0, 145 0, 0, 0, 0, ImplicitOps | Stack, ImplicitOps | Stack, 0, 0,
@@ -1520,6 +1521,28 @@ special_insn:
1520 case 0x8d: /* lea r16/r32, m */ 1521 case 0x8d: /* lea r16/r32, m */
1521 c->dst.val = c->modrm_ea; 1522 c->dst.val = c->modrm_ea;
1522 break; 1523 break;
1524 case 0x8e: { /* mov seg, r/m16 */
1525 uint16_t sel;
1526 int type_bits;
1527 int err;
1528
1529 sel = c->src.val;
1530 if (c->modrm_reg <= 5) {
1531 type_bits = (c->modrm_reg == 1) ? 9 : 1;
1532 err = kvm_load_segment_descriptor(ctxt->vcpu, sel,
1533 type_bits, c->modrm_reg);
1534 } else {
1535 printk(KERN_INFO "Invalid segreg in modrm byte 0x%02x\n",
1536 c->modrm);
1537 goto cannot_emulate;
1538 }
1539
1540 if (err < 0)
1541 goto cannot_emulate;
1542
1543 c->dst.type = OP_NONE; /* Disable writeback. */
1544 break;
1545 }
1523 case 0x8f: /* pop (sole member of Grp1a) */ 1546 case 0x8f: /* pop (sole member of Grp1a) */
1524 rc = emulate_grp1a(ctxt, ops); 1547 rc = emulate_grp1a(ctxt, ops);
1525 if (rc != 0) 1548 if (rc != 0)