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