summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAvi Kivity <avi@redhat.com>2010-07-29 12:11:40 (GMT)
committerAvi Kivity <avi@redhat.com>2010-10-24 08:50:11 (GMT)
commit5b92b5faff8ec66c75f3716ae7c4bf1e2b99d7e6 (patch)
treef37c123715ed0e1d824229cf4c199f75ff8b925a
parent120df8902dbe91cc1b3b7886481e350fae7334fe (diff)
downloadlinux-fsl-qoriq-5b92b5faff8ec66c75f3716ae7c4bf1e2b99d7e6.tar.xz
KVM: x86 emulator: convert group 1 to new style
Signed-off-by: Avi Kivity <avi@redhat.com> Signed-off-by: Marcelo Tosatti <mtosatti@redhat.com>
-rw-r--r--arch/x86/kvm/emulate.c16
1 files changed, 9 insertions, 7 deletions
diff --git a/arch/x86/kvm/emulate.c b/arch/x86/kvm/emulate.c
index f3b9844..6cc4af1 100644
--- a/arch/x86/kvm/emulate.c
+++ b/arch/x86/kvm/emulate.c
@@ -105,7 +105,7 @@
#define X16(x) X8(x), X8(x)
enum {
- NoGrp, Group1, Group1A, Group3, Group4, Group5, Group7, Group8, Group9,
+ NoGrp, Group1A, Group3, Group4, Group5, Group7, Group8, Group9,
};
struct opcode {
@@ -126,9 +126,11 @@ struct group_dual {
#define G(_f, _g) { .flags = ((_f) | Group), .u.group = (_g) }
#define GD(_f, _g) { .flags = ((_f) | Group | GroupDual), .u.gdual = (_g) }
+static struct opcode group1[] = {
+ X7(D(Lock)), N
+};
+
static struct opcode group_table[] = {
- [Group1*8] =
- X7(D(Lock)), N,
[Group1A*8] =
D(DstMem | SrcNone | ModRM | Mov | Stack), N, N, N, N, N, N, N,
[Group3*8] =
@@ -219,10 +221,10 @@ static struct opcode opcode_table[256] = {
/* 0x70 - 0x7F */
X16(D(SrcImmByte)),
/* 0x80 - 0x87 */
- D(ByteOp | DstMem | SrcImm | ModRM | Group | Group1),
- D(DstMem | SrcImm | ModRM | Group | Group1),
- D(ByteOp | DstMem | SrcImm | ModRM | No64 | Group | Group1),
- D(DstMem | SrcImmByte | ModRM | Group | Group1),
+ G(ByteOp | DstMem | SrcImm | ModRM | Group, group1),
+ G(DstMem | SrcImm | ModRM | Group, group1),
+ G(ByteOp | DstMem | SrcImm | ModRM | No64 | Group, group1),
+ G(DstMem | SrcImmByte | ModRM | Group, group1),
D(ByteOp | DstMem | SrcReg | ModRM), D(DstMem | SrcReg | ModRM),
D(ByteOp | DstMem | SrcReg | ModRM | Lock), D(DstMem | SrcReg | ModRM | Lock),
/* 0x88 - 0x8F */