1234353Sdim//===-- X86InstrVMX.td - VMX Instruction Set Extension -----*- tablegen -*-===//
2234353Sdim//
3218885Sdim//                     The LLVM Compiler Infrastructure
4218885Sdim//
5218885Sdim// This file is distributed under the University of Illinois Open Source
6218885Sdim// License. See LICENSE.TXT for details.
7234353Sdim//
8218885Sdim//===----------------------------------------------------------------------===//
9218885Sdim//
10218885Sdim// This file describes the instructions that make up the Intel VMX instruction
11218885Sdim// set.
12218885Sdim//
13218885Sdim//===----------------------------------------------------------------------===//
14218885Sdim
15218885Sdim//===----------------------------------------------------------------------===//
16218885Sdim// VMX instructions
17218885Sdim
18218885Sdim// 66 0F 38 80
19226633Sdimdef INVEPT32 : I<0x80, MRMSrcMem, (outs), (ins GR32:$src1, i128mem:$src2),
20239462Sdim               "invept\t{$src2, $src1|$src1, $src2}", []>, OpSize, T8,
21234353Sdim               Requires<[In32BitMode]>;
22226633Sdimdef INVEPT64 : I<0x80, MRMSrcMem, (outs), (ins GR64:$src1, i128mem:$src2),
23239462Sdim               "invept\t{$src2, $src1|$src1, $src2}", []>, OpSize, T8,
24234353Sdim               Requires<[In64BitMode]>;
25218885Sdim// 66 0F 38 81
26226633Sdimdef INVVPID32 : I<0x81, MRMSrcMem, (outs), (ins GR32:$src1, i128mem:$src2),
27239462Sdim                "invvpid\t{$src2, $src1|$src1, $src2}", []>, OpSize, T8,
28234353Sdim                Requires<[In32BitMode]>;
29226633Sdimdef INVVPID64 : I<0x81, MRMSrcMem, (outs), (ins GR64:$src1, i128mem:$src2),
30239462Sdim                "invvpid\t{$src2, $src1|$src1, $src2}", []>, OpSize, T8,
31234353Sdim                Requires<[In64BitMode]>;
32218885Sdim// 0F 01 C1
33218885Sdimdef VMCALL : I<0x01, MRM_C1, (outs), (ins), "vmcall", []>, TB;
34218885Sdimdef VMCLEARm : I<0xC7, MRM6m, (outs), (ins i64mem:$vmcs),
35218885Sdim  "vmclear\t$vmcs", []>, OpSize, TB;
36234353Sdim// OF 01 D4
37234353Sdimdef VMFUNC : I<0x01, MRM_D4, (outs), (ins), "vmfunc", []>, TB;
38218885Sdim// 0F 01 C2
39218885Sdimdef VMLAUNCH : I<0x01, MRM_C2, (outs), (ins), "vmlaunch", []>, TB;
40218885Sdim// 0F 01 C3
41218885Sdimdef VMRESUME : I<0x01, MRM_C3, (outs), (ins), "vmresume", []>, TB;
42218885Sdimdef VMPTRLDm : I<0xC7, MRM6m, (outs), (ins i64mem:$vmcs),
43218885Sdim  "vmptrld\t$vmcs", []>, TB;
44218885Sdimdef VMPTRSTm : I<0xC7, MRM7m, (outs i64mem:$vmcs), (ins),
45218885Sdim  "vmptrst\t$vmcs", []>, TB;
46218885Sdimdef VMREAD64rm : I<0x78, MRMDestMem, (outs i64mem:$dst), (ins GR64:$src),
47234353Sdim  "vmread{q}\t{$src, $dst|$dst, $src}", []>, TB, Requires<[In64BitMode]>;
48218885Sdimdef VMREAD64rr : I<0x78, MRMDestReg, (outs GR64:$dst), (ins GR64:$src),
49234353Sdim  "vmread{q}\t{$src, $dst|$dst, $src}", []>, TB, Requires<[In64BitMode]>;
50218885Sdimdef VMREAD32rm : I<0x78, MRMDestMem, (outs i32mem:$dst), (ins GR32:$src),
51234353Sdim  "vmread{l}\t{$src, $dst|$dst, $src}", []>, TB, Requires<[In32BitMode]>;
52218885Sdimdef VMREAD32rr : I<0x78, MRMDestReg, (outs GR32:$dst), (ins GR32:$src),
53234353Sdim  "vmread{l}\t{$src, $dst|$dst, $src}", []>, TB, Requires<[In32BitMode]>;
54218885Sdimdef VMWRITE64rm : I<0x79, MRMSrcMem, (outs GR64:$dst), (ins i64mem:$src),
55234353Sdim  "vmwrite{q}\t{$src, $dst|$dst, $src}", []>, TB, Requires<[In64BitMode]>;
56218885Sdimdef VMWRITE64rr : I<0x79, MRMSrcReg, (outs GR64:$dst), (ins GR64:$src),
57234353Sdim  "vmwrite{q}\t{$src, $dst|$dst, $src}", []>, TB, Requires<[In64BitMode]>;
58218885Sdimdef VMWRITE32rm : I<0x79, MRMSrcMem, (outs GR32:$dst), (ins i32mem:$src),
59234353Sdim  "vmwrite{l}\t{$src, $dst|$dst, $src}", []>, TB, Requires<[In32BitMode]>;
60218885Sdimdef VMWRITE32rr : I<0x79, MRMSrcReg, (outs GR32:$dst), (ins GR32:$src),
61234353Sdim  "vmwrite{l}\t{$src, $dst|$dst, $src}", []>, TB, Requires<[In32BitMode]>;
62218885Sdim// 0F 01 C4
63218885Sdimdef VMXOFF : I<0x01, MRM_C4, (outs), (ins), "vmxoff", []>, TB;
64218885Sdimdef VMXON : I<0xC7, MRM6m, (outs), (ins i64mem:$vmxon),
65234353Sdim  "vmxon\t$vmxon", []>, XS;
66218885Sdim
67