diff options
author | Guillaume Thouvenin <guillaume.thouvenin@ext.bull.net> | 2008-12-04 08:27:38 -0500 |
---|---|---|
committer | Avi Kivity <avi@redhat.com> | 2008-12-31 09:55:42 -0500 |
commit | bfcadf83ec5aafe600e73dd427d997db7bcc1d12 (patch) | |
tree | 955241dfdd3cc4c9cee5c67a04aa0a75f2a91bb8 | |
parent | 0dc8d10f7d848b63c8d32cf6fd31ba7def792ac9 (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>
-rw-r--r-- | arch/x86/kvm/x86_emulate.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/arch/x86/kvm/x86_emulate.c b/arch/x86/kvm/x86_emulate.c index 7f5cd62362c5..0c75306e7a07 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 | /* |