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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
|
/* Generated automatically by the program `genconstants'
from the machine description file `md'. */
#ifndef GCC_INSN_CONSTANTS_H
#define GCC_INSN_CONSTANTS_H
#define MM7_REG 35
#define XMM27_REG 63
#define ST6_REG 14
#define R13_REG 41
#define XMM14_REG 50
#define XMM19_REG 55
#define ARGP_REG 16
#define PCOM_TRUE 1
#define PPERM_ZERO 0x80
#define XMM6_REG 26
#define ST3_REG 11
#define R10_REG 38
#define XMM11_REG 47
#define XMM24_REG 60
#define DX_REG 1
#define FLAGS_REG 17
#define ST1_REG 9
#define MM5_REG 33
#define MASK7_REG 75
#define PPERM_SRC 0x00
#define MM4_REG 32
#define ST7_REG 15
#define COM_FALSE_P 3
#define XMM3_REG 23
#define ST0_REG 8
#define COM_FALSE_S 2
#define SP_REG 7
#define AX_REG 0
#define MM1_REG 29
#define MM3_REG 31
#define XMM1_REG 21
#define MASK5_REG 73
#define ROUND_ZERO 3
#define PPERM_SRC1 0x00
#define XMM16_REG 52
#define PCOM_FALSE 0
#define XMM8_REG 44
#define XMM4_REG 24
#define ST5_REG 13
#define XMM29_REG 65
#define XMM23_REG 59
#define R12_REG 40
#define R9_REG 37
#define XMM20_REG 56
#define ROUND_MXCSR 0x4
#define MASK4_REG 72
#define PPERM_INVERT 0x20
#define MM6_REG 34
#define XMM26_REG 62
#define PPERM_SRC2 0x10
#define ST2_REG 10
#define MASK1_REG 69
#define ABI_VZEROUPPER 1
#define NO_ROUND 4
#define XMM10_REG 46
#define ROUND_TRUNC 0x3
#define PPERM_SIGN 0xc0
#define R8_REG 36
#define XMM9_REG 45
#define XMM18_REG 54
#define MASK3_REG 71
#define DI_REG 5
#define XMM25_REG 61
#define ABI_DEFAULT 0
#define BP_REG 6
#define ROUND_ROUNDEVEN 0x0
#define XMM12_REG 48
#define XMM5_REG 25
#define COM_TRUE_S 4
#define ROUND_FLOOR 0x1
#define FPSR_REG 18
#define MASK6_REG 74
#define R14_REG 42
#define XMM15_REG 51
#define XMM28_REG 64
#define R15_REG 43
#define XMM13_REG 49
#define ROUND_NEAREST_INT 0
#define ROUND_CEIL 0x2
#define MM0_REG 28
#define XMM31_REG 67
#define BX_REG 3
#define XMM7_REG 27
#define XMM30_REG 66
#define ST4_REG 12
#define PPERM_INV_SIGN 0xe0
#define R11_REG 39
#define FIRST_PSEUDO_REG 76
#define PPERM_REVERSE 0x40
#define CX_REG 2
#define ABI_UNKNOWN 2
#define MASK0_REG 68
#define COM_TRUE_P 5
#define SI_REG 4
#define XMM22_REG 58
#define XMM0_REG 20
#define XMM17_REG 53
#define ROUND_NEG_INF 1
#define ROUND_POS_INF 2
#define XMM2_REG 22
#define FRAME_REG 19
#define PPERM_ONES 0xa0
#define XMM21_REG 57
#define ROUND_NO_EXC 0x8
#define MM2_REG 30
#define ROUND_SAE 8
#define MASK2_REG 70
#define PPERM_REV_INV 0x60
enum unspec {
UNSPEC_GOT = 0,
UNSPEC_GOTOFF = 1,
UNSPEC_GOTPCREL = 2,
UNSPEC_GOTTPOFF = 3,
UNSPEC_TPOFF = 4,
UNSPEC_NTPOFF = 5,
UNSPEC_DTPOFF = 6,
UNSPEC_GOTNTPOFF = 7,
UNSPEC_INDNTPOFF = 8,
UNSPEC_PLTOFF = 9,
UNSPEC_MACHOPIC_OFFSET = 10,
UNSPEC_PCREL = 11,
UNSPEC_SIZEOF = 12,
UNSPEC_STACK_ALLOC = 13,
UNSPEC_SET_GOT = 14,
UNSPEC_SET_RIP = 15,
UNSPEC_SET_GOT_OFFSET = 16,
UNSPEC_MEMORY_BLOCKAGE = 17,
UNSPEC_PROBE_STACK = 18,
UNSPEC_TP = 19,
UNSPEC_TLS_GD = 20,
UNSPEC_TLS_LD_BASE = 21,
UNSPEC_TLSDESC = 22,
UNSPEC_TLS_IE_SUN = 23,
UNSPEC_SCAS = 24,
UNSPEC_FNSTSW = 25,
UNSPEC_SAHF = 26,
UNSPEC_NOTRAP = 27,
UNSPEC_PARITY = 28,
UNSPEC_FSTCW = 29,
UNSPEC_REP = 30,
UNSPEC_LD_MPIC = 31,
UNSPEC_TRUNC_NOOP = 32,
UNSPEC_DIV_ALREADY_SPLIT = 33,
UNSPEC_PAUSE = 34,
UNSPEC_LEA_ADDR = 35,
UNSPEC_XBEGIN_ABORT = 36,
UNSPEC_STOS = 37,
UNSPEC_PEEPSIB = 38,
UNSPEC_INSN_FALSE_DEP = 39,
UNSPEC_SBB = 40,
UNSPEC_FIX_NOTRUNC = 41,
UNSPEC_MASKMOV = 42,
UNSPEC_MOVCC_MASK = 43,
UNSPEC_MOVMSK = 44,
UNSPEC_BLENDV = 45,
UNSPEC_PSHUFB = 46,
UNSPEC_XOP_PERMUTE = 47,
UNSPEC_RCP = 48,
UNSPEC_RSQRT = 49,
UNSPEC_PSADBW = 50,
UNSPEC_SCALEF = 51,
UNSPEC_PCMP = 52,
UNSPEC_IEEE_MIN = 53,
UNSPEC_IEEE_MAX = 54,
UNSPEC_SIN = 55,
UNSPEC_COS = 56,
UNSPEC_FPATAN = 57,
UNSPEC_FYL2X = 58,
UNSPEC_FYL2XP1 = 59,
UNSPEC_FRNDINT = 60,
UNSPEC_FIST = 61,
UNSPEC_F2XM1 = 62,
UNSPEC_TAN = 63,
UNSPEC_FXAM = 64,
UNSPEC_FRNDINT_ROUNDEVEN = 65,
UNSPEC_FRNDINT_FLOOR = 66,
UNSPEC_FRNDINT_CEIL = 67,
UNSPEC_FRNDINT_TRUNC = 68,
UNSPEC_FIST_FLOOR = 69,
UNSPEC_FIST_CEIL = 70,
UNSPEC_SINCOS_COS = 71,
UNSPEC_SINCOS_SIN = 72,
UNSPEC_XTRACT_FRACT = 73,
UNSPEC_XTRACT_EXP = 74,
UNSPEC_FSCALE_FRACT = 75,
UNSPEC_FSCALE_EXP = 76,
UNSPEC_FPREM_F = 77,
UNSPEC_FPREM_U = 78,
UNSPEC_FPREM1_F = 79,
UNSPEC_FPREM1_U = 80,
UNSPEC_C2_FLAG = 81,
UNSPEC_FXAM_MEM = 82,
UNSPEC_SP_SET = 83,
UNSPEC_SP_TEST = 84,
UNSPEC_ROUND = 85,
UNSPEC_CRC32 = 86,
UNSPEC_LZCNT = 87,
UNSPEC_TZCNT = 88,
UNSPEC_BEXTR = 89,
UNSPEC_PDEP = 90,
UNSPEC_PEXT = 91,
UNSPEC_INTERRUPT_RETURN = 92,
UNSPEC_MOVDIRI = 93,
UNSPEC_MOVDIR64B = 94,
UNSPEC_CALLEE_ABI = 95
};
#define NUM_UNSPEC_VALUES 96
extern const char *const unspec_strings[];
enum unspecv {
UNSPECV_UD2 = 0,
UNSPECV_BLOCKAGE = 1,
UNSPECV_STACK_PROBE = 2,
UNSPECV_PROBE_STACK_RANGE = 3,
UNSPECV_ALIGN = 4,
UNSPECV_PROLOGUE_USE = 5,
UNSPECV_SPLIT_STACK_RETURN = 6,
UNSPECV_CLD = 7,
UNSPECV_NOPS = 8,
UNSPECV_RDTSC = 9,
UNSPECV_RDTSCP = 10,
UNSPECV_RDPMC = 11,
UNSPECV_LLWP_INTRINSIC = 12,
UNSPECV_SLWP_INTRINSIC = 13,
UNSPECV_LWPVAL_INTRINSIC = 14,
UNSPECV_LWPINS_INTRINSIC = 15,
UNSPECV_RDFSBASE = 16,
UNSPECV_RDGSBASE = 17,
UNSPECV_WRFSBASE = 18,
UNSPECV_WRGSBASE = 19,
UNSPECV_FXSAVE = 20,
UNSPECV_FXRSTOR = 21,
UNSPECV_FXSAVE64 = 22,
UNSPECV_FXRSTOR64 = 23,
UNSPECV_XSAVE = 24,
UNSPECV_XRSTOR = 25,
UNSPECV_XSAVE64 = 26,
UNSPECV_XRSTOR64 = 27,
UNSPECV_XSAVEOPT = 28,
UNSPECV_XSAVEOPT64 = 29,
UNSPECV_XSAVES = 30,
UNSPECV_XRSTORS = 31,
UNSPECV_XSAVES64 = 32,
UNSPECV_XRSTORS64 = 33,
UNSPECV_XSAVEC = 34,
UNSPECV_XSAVEC64 = 35,
UNSPECV_XGETBV = 36,
UNSPECV_XSETBV = 37,
UNSPECV_WBINVD = 38,
UNSPECV_WBNOINVD = 39,
UNSPECV_FNSTENV = 40,
UNSPECV_FLDENV = 41,
UNSPECV_FNSTSW = 42,
UNSPECV_FNCLEX = 43,
UNSPECV_RDRAND = 44,
UNSPECV_RDSEED = 45,
UNSPECV_XBEGIN = 46,
UNSPECV_XEND = 47,
UNSPECV_XABORT = 48,
UNSPECV_XTEST = 49,
UNSPECV_NLGR = 50,
UNSPECV_CLWB = 51,
UNSPECV_CLFLUSHOPT = 52,
UNSPECV_MONITORX = 53,
UNSPECV_MWAITX = 54,
UNSPECV_CLZERO = 55,
UNSPECV_PKU = 56,
UNSPECV_RDPID = 57,
UNSPECV_NOP_ENDBR = 58,
UNSPECV_NOP_RDSSP = 59,
UNSPECV_INCSSP = 60,
UNSPECV_SAVEPREVSSP = 61,
UNSPECV_RSTORSSP = 62,
UNSPECV_WRSS = 63,
UNSPECV_WRUSS = 64,
UNSPECV_SETSSBSY = 65,
UNSPECV_CLRSSBSY = 66,
UNSPECV_XSUSLDTRK = 67,
UNSPECV_XRESLDTRK = 68,
UNSPECV_UMWAIT = 69,
UNSPECV_UMONITOR = 70,
UNSPECV_TPAUSE = 71,
UNSPECV_CLUI = 72,
UNSPECV_STUI = 73,
UNSPECV_TESTUI = 74,
UNSPECV_SENDUIPI = 75,
UNSPECV_CLDEMOTE = 76,
UNSPECV_SPECULATION_BARRIER = 77,
UNSPECV_PTWRITE = 78,
UNSPECV_ENQCMD = 79,
UNSPECV_ENQCMDS = 80,
UNSPECV_SERIALIZE = 81,
UNSPECV_PATCHABLE_AREA = 82,
UNSPECV_HRESET = 83
};
#define NUM_UNSPECV_VALUES 84
extern const char *const unspecv_strings[];
#endif /* GCC_INSN_CONSTANTS_H */
|