aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/libs/llvm12/lib/Target/X86/X86InstrTDX.td
blob: e21028c8a3b0a5421bc12f36680ccf11e5ea527e (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
//===- X86InstrTDX.td - TDX Instruction Set Extension -*- tablegen -*===// 
// 
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 
// See https://llvm.org/LICENSE.txt for license information. 
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 
// 
//===----------------------------------------------------------------------===// 
// 
// This file describes the instructions that make up the Intel TDX instruction 
// set. 
// 
//===----------------------------------------------------------------------===// 
 
//===----------------------------------------------------------------------===// 
// TDX instructions 
 
// 64-bit only instructions 
let SchedRW = [WriteSystem], Predicates = [In64BitMode] in { 
// SEAMCALL - Call to SEAM VMX-root Operation Module 
def SEAMCALL : I<0x01, MRM_CF, (outs), (ins), 
             "seamcall", []>, PD; 
 
// SEAMRET - Return to Legacy VMX-root Operation 
def SEAMRET : I<0x01, MRM_CD, (outs), (ins), 
             "seamret", []>, PD; 
 
// SEAMOPS - SEAM Operations 
def SEAMOPS : I<0x01, MRM_CE, (outs), (ins), 
             "seamops", []>, PD; 
 
} // SchedRW 
 
// common instructions 
let SchedRW = [WriteSystem] in { 
// TDCALL - Call SEAM Module Functions 
def TDCALL : I<0x01, MRM_CC, (outs), (ins), 
             "tdcall", []>, PD; 
 
} // SchedRW