diff options
author | Avi Kivity <avi@qumranet.com> | 2008-05-29 07:38:38 -0400 |
---|---|---|
committer | Avi Kivity <avi@qumranet.com> | 2008-07-20 05:42:29 -0400 |
commit | 91ed7a0e15c6f6ff57f5cf70feabdba56a999863 (patch) | |
tree | 312ac50ec1ab0ddcf0727fb4af364bd0889f8359 /arch/x86/kvm/x86_emulate.c | |
parent | 19e43636b5af1c8b9cc8406af674835284abab0c (diff) |
KVM: x86 emulator: implement 'push imm' (opcode 0x68)
Encountered in FC6 boot sequence, now that we don't force ss.rpl = 0 during
the protected mode transition. Not really necessary, but nice to have.
Signed-off-by: Avi Kivity <avi@qumranet.com>
Diffstat (limited to 'arch/x86/kvm/x86_emulate.c')
-rw-r--r-- | arch/x86/kvm/x86_emulate.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/arch/x86/kvm/x86_emulate.c b/arch/x86/kvm/x86_emulate.c index 4e037ea8fe6..b90857c7656 100644 --- a/arch/x86/kvm/x86_emulate.c +++ b/arch/x86/kvm/x86_emulate.c | |||
@@ -121,7 +121,7 @@ static u16 opcode_table[256] = { | |||
121 | 0, 0, 0, DstReg | SrcMem32 | ModRM | Mov /* movsxd (x86/64) */ , | 121 | 0, 0, 0, DstReg | SrcMem32 | ModRM | Mov /* movsxd (x86/64) */ , |
122 | 0, 0, 0, 0, | 122 | 0, 0, 0, 0, |
123 | /* 0x68 - 0x6F */ | 123 | /* 0x68 - 0x6F */ |
124 | 0, 0, SrcImmByte | Mov | Stack, 0, | 124 | SrcImm | Mov | Stack, 0, SrcImmByte | Mov | Stack, 0, |
125 | SrcNone | ByteOp | ImplicitOps, SrcNone | ImplicitOps, /* insb, insw/insd */ | 125 | SrcNone | ByteOp | ImplicitOps, SrcNone | ImplicitOps, /* insb, insw/insd */ |
126 | SrcNone | ByteOp | ImplicitOps, SrcNone | ImplicitOps, /* outsb, outsw/outsd */ | 126 | SrcNone | ByteOp | ImplicitOps, SrcNone | ImplicitOps, /* outsb, outsw/outsd */ |
127 | /* 0x70 - 0x77 */ | 127 | /* 0x70 - 0x77 */ |
@@ -1424,6 +1424,7 @@ special_insn: | |||
1424 | goto cannot_emulate; | 1424 | goto cannot_emulate; |
1425 | c->dst.val = (s32) c->src.val; | 1425 | c->dst.val = (s32) c->src.val; |
1426 | break; | 1426 | break; |
1427 | case 0x68: /* push imm */ | ||
1427 | case 0x6a: /* push imm8 */ | 1428 | case 0x6a: /* push imm8 */ |
1428 | emulate_push(ctxt); | 1429 | emulate_push(ctxt); |
1429 | break; | 1430 | break; |