aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/kvm/emulate.c
diff options
context:
space:
mode:
authorAvi Kivity <avi@redhat.com>2010-07-29 08:11:35 -0400
committerAvi Kivity <avi@redhat.com>2010-10-24 04:50:07 -0400
commitd65b1dee408243daa45110ee494d204508d31657 (patch)
tree014d0da04dc4871a9a414af057b50a2d000ffe4e /arch/x86/kvm/emulate.c
parentea9ef04e19c7c441b1ce9fe28ff6d9522c848baa (diff)
KVM: x86 emulator: introduce 'struct opcode'
This will hold all the information known about the opcode. Currently, this is just the decode flags. Signed-off-by: Avi Kivity <avi@redhat.com> Signed-off-by: Marcelo Tosatti <mtosatti@redhat.com>
Diffstat (limited to 'arch/x86/kvm/emulate.c')
-rw-r--r--arch/x86/kvm/emulate.c20
1 files changed, 12 insertions, 8 deletions
diff --git a/arch/x86/kvm/emulate.c b/arch/x86/kvm/emulate.c
index 3bfba9480975..da7df34036ca 100644
--- a/arch/x86/kvm/emulate.c
+++ b/arch/x86/kvm/emulate.c
@@ -108,7 +108,11 @@ enum {
108 Group1, Group1A, Group3, Group4, Group5, Group7, Group8, Group9, 108 Group1, Group1A, Group3, Group4, Group5, Group7, Group8, Group9,
109}; 109};
110 110
111static u32 opcode_table[256] = { 111struct opcode {
112 u32 flags;
113};
114
115static struct opcode opcode_table[256] = {
112 /* 0x00 - 0x07 */ 116 /* 0x00 - 0x07 */
113 ByteOp | DstMem | SrcReg | ModRM | Lock, DstMem | SrcReg | ModRM | Lock, 117 ByteOp | DstMem | SrcReg | ModRM | Lock, DstMem | SrcReg | ModRM | Lock,
114 ByteOp | DstReg | SrcMem | ModRM, DstReg | SrcMem | ModRM, 118 ByteOp | DstReg | SrcMem | ModRM, DstReg | SrcMem | ModRM,
@@ -222,7 +226,7 @@ static u32 opcode_table[256] = {
222 ImplicitOps, ImplicitOps, Group | Group4, Group | Group5, 226 ImplicitOps, ImplicitOps, Group | Group4, Group | Group5,
223}; 227};
224 228
225static u32 twobyte_table[256] = { 229static struct opcode twobyte_table[256] = {
226 /* 0x00 - 0x0F */ 230 /* 0x00 - 0x0F */
227 0, Group | GroupDual | Group7, 0, 0, 231 0, Group | GroupDual | Group7, 0, 0,
228 0, ImplicitOps, ImplicitOps | Priv, 0, 232 0, ImplicitOps, ImplicitOps | Priv, 0,
@@ -284,7 +288,7 @@ static u32 twobyte_table[256] = {
284 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 288 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
285}; 289};
286 290
287static u32 group_table[] = { 291static struct opcode group_table[] = {
288 [Group1*8] = 292 [Group1*8] =
289 X7(Lock), 0, 293 X7(Lock), 0,
290 [Group1A*8] = 294 [Group1A*8] =
@@ -313,7 +317,7 @@ static u32 group_table[] = {
313 0, DstMem64 | ModRM | Lock, 0, 0, 0, 0, 0, 0, 317 0, DstMem64 | ModRM | Lock, 0, 0, 0, 0, 0, 0,
314}; 318};
315 319
316static u32 group2_table[] = { 320static struct opcode group2_table[] = {
317 [Group7*8] = 321 [Group7*8] =
318 SrcNone | ModRM | Priv, 0, 0, SrcNone | ModRM | Priv, 322 SrcNone | ModRM | Priv, 0, 0, SrcNone | ModRM | Priv,
319 SrcNone | ModRM | DstMem | Mov, 0, 323 SrcNone | ModRM | DstMem | Mov, 0,
@@ -1008,13 +1012,13 @@ done_prefixes:
1008 c->op_bytes = 8; /* REX.W */ 1012 c->op_bytes = 8; /* REX.W */
1009 1013
1010 /* Opcode byte(s). */ 1014 /* Opcode byte(s). */
1011 c->d = opcode_table[c->b]; 1015 c->d = opcode_table[c->b].flags;
1012 if (c->d == 0) { 1016 if (c->d == 0) {
1013 /* Two-byte opcode? */ 1017 /* Two-byte opcode? */
1014 if (c->b == 0x0f) { 1018 if (c->b == 0x0f) {
1015 c->twobyte = 1; 1019 c->twobyte = 1;
1016 c->b = insn_fetch(u8, 1, c->eip); 1020 c->b = insn_fetch(u8, 1, c->eip);
1017 c->d = twobyte_table[c->b]; 1021 c->d = twobyte_table[c->b].flags;
1018 } 1022 }
1019 } 1023 }
1020 1024
@@ -1027,9 +1031,9 @@ done_prefixes:
1027 group = (group << 3) + ((c->modrm >> 3) & 7); 1031 group = (group << 3) + ((c->modrm >> 3) & 7);
1028 c->d &= ~(Group | GroupDual | GroupMask); 1032 c->d &= ~(Group | GroupDual | GroupMask);
1029 if (dual && (c->modrm >> 6) == 3) 1033 if (dual && (c->modrm >> 6) == 3)
1030 c->d |= group2_table[group]; 1034 c->d |= group2_table[group].flags;
1031 else 1035 else
1032 c->d |= group_table[group]; 1036 c->d |= group_table[group].flags;
1033 } 1037 }
1034 1038
1035 /* Unrecognised? */ 1039 /* Unrecognised? */