aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/kvm
diff options
context:
space:
mode:
authorGuillaume Thouvenin <guillaume.thouvenin@ext.bull.net>2008-12-04 08:27:38 -0500
committerAvi Kivity <avi@redhat.com>2008-12-31 09:55:42 -0500
commitbfcadf83ec5aafe600e73dd427d997db7bcc1d12 (patch)
tree955241dfdd3cc4c9cee5c67a04aa0a75f2a91bb8 /arch/x86/kvm
parent0dc8d10f7d848b63c8d32cf6fd31ba7def792ac9 (diff)
KVM: x86 emulator: add a new "implied 1" Src decode type
Add SrcOne operand type when we need to decode an implied '1' like with regular shift instruction Signed-off-by: Guillaume Thouvenin <guillaume.thouvenin@ext.bull.net> Signed-off-by: Avi Kivity <avi@redhat.com>
Diffstat (limited to 'arch/x86/kvm')
-rw-r--r--arch/x86/kvm/x86_emulate.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/arch/x86/kvm/x86_emulate.c b/arch/x86/kvm/x86_emulate.c
index 7f5cd62362c..0c75306e7a0 100644
--- a/arch/x86/kvm/x86_emulate.c
+++ b/arch/x86/kvm/x86_emulate.c
@@ -58,6 +58,7 @@
58#define SrcMem32 (4<<4) /* Memory operand (32-bit). */ 58#define SrcMem32 (4<<4) /* Memory operand (32-bit). */
59#define SrcImm (5<<4) /* Immediate operand. */ 59#define SrcImm (5<<4) /* Immediate operand. */
60#define SrcImmByte (6<<4) /* 8-bit sign-extended immediate operand. */ 60#define SrcImmByte (6<<4) /* 8-bit sign-extended immediate operand. */
61#define SrcOne (7<<4) /* Implied '1' */
61#define SrcMask (7<<4) 62#define SrcMask (7<<4)
62/* Generic ModRM decode. */ 63/* Generic ModRM decode. */
63#define ModRM (1<<7) 64#define ModRM (1<<7)
@@ -1004,6 +1005,10 @@ done_prefixes:
1004 c->src.bytes = 1; 1005 c->src.bytes = 1;
1005 c->src.val = insn_fetch(s8, 1, c->eip); 1006 c->src.val = insn_fetch(s8, 1, c->eip);
1006 break; 1007 break;
1008 case SrcOne:
1009 c->src.bytes = 1;
1010 c->src.val = 1;
1011 break;
1007 } 1012 }
1008 1013
1009 /* 1014 /*