diff options
author | Avi Kivity <avi@redhat.com> | 2010-07-29 08:11:35 -0400 |
---|---|---|
committer | Avi Kivity <avi@redhat.com> | 2010-10-24 04:50:07 -0400 |
commit | d65b1dee408243daa45110ee494d204508d31657 (patch) | |
tree | 014d0da04dc4871a9a414af057b50a2d000ffe4e /arch/x86/kvm/emulate.c | |
parent | ea9ef04e19c7c441b1ce9fe28ff6d9522c848baa (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.c | 20 |
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 | ||
111 | static u32 opcode_table[256] = { | 111 | struct opcode { |
112 | u32 flags; | ||
113 | }; | ||
114 | |||
115 | static 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 | ||
225 | static u32 twobyte_table[256] = { | 229 | static 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 | ||
287 | static u32 group_table[] = { | 291 | static 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 | ||
316 | static u32 group2_table[] = { | 320 | static 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? */ |