xref: /aosp_15_r20/external/llvm/lib/Target/X86/X86Schedule.td (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker//===-- X86Schedule.td - X86 Scheduling Definitions --------*- tablegen -*-===//
2*9880d681SAndroid Build Coastguard Worker//
3*9880d681SAndroid Build Coastguard Worker//                     The LLVM Compiler Infrastructure
4*9880d681SAndroid Build Coastguard Worker//
5*9880d681SAndroid Build Coastguard Worker// This file is distributed under the University of Illinois Open Source
6*9880d681SAndroid Build Coastguard Worker// License. See LICENSE.TXT for details.
7*9880d681SAndroid Build Coastguard Worker//
8*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===//
9*9880d681SAndroid Build Coastguard Worker
10*9880d681SAndroid Build Coastguard Worker// InstrSchedModel annotations for out-of-order CPUs.
11*9880d681SAndroid Build Coastguard Worker//
12*9880d681SAndroid Build Coastguard Worker// These annotations are independent of the itinerary classes defined below.
13*9880d681SAndroid Build Coastguard Worker
14*9880d681SAndroid Build Coastguard Worker// Instructions with folded loads need to read the memory operand immediately,
15*9880d681SAndroid Build Coastguard Worker// but other register operands don't have to be read until the load is ready.
16*9880d681SAndroid Build Coastguard Worker// These operands are marked with ReadAfterLd.
17*9880d681SAndroid Build Coastguard Workerdef ReadAfterLd : SchedRead;
18*9880d681SAndroid Build Coastguard Worker
19*9880d681SAndroid Build Coastguard Worker// Instructions with both a load and a store folded are modeled as a folded
20*9880d681SAndroid Build Coastguard Worker// load + WriteRMW.
21*9880d681SAndroid Build Coastguard Workerdef WriteRMW : SchedWrite;
22*9880d681SAndroid Build Coastguard Worker
23*9880d681SAndroid Build Coastguard Worker// Most instructions can fold loads, so almost every SchedWrite comes in two
24*9880d681SAndroid Build Coastguard Worker// variants: With and without a folded load.
25*9880d681SAndroid Build Coastguard Worker// An X86FoldableSchedWrite holds a reference to the corresponding SchedWrite
26*9880d681SAndroid Build Coastguard Worker// with a folded load.
27*9880d681SAndroid Build Coastguard Workerclass X86FoldableSchedWrite : SchedWrite {
28*9880d681SAndroid Build Coastguard Worker  // The SchedWrite to use when a load is folded into the instruction.
29*9880d681SAndroid Build Coastguard Worker  SchedWrite Folded;
30*9880d681SAndroid Build Coastguard Worker}
31*9880d681SAndroid Build Coastguard Worker
32*9880d681SAndroid Build Coastguard Worker// Multiclass that produces a linked pair of SchedWrites.
33*9880d681SAndroid Build Coastguard Workermulticlass X86SchedWritePair {
34*9880d681SAndroid Build Coastguard Worker  // Register-Memory operation.
35*9880d681SAndroid Build Coastguard Worker  def Ld : SchedWrite;
36*9880d681SAndroid Build Coastguard Worker  // Register-Register operation.
37*9880d681SAndroid Build Coastguard Worker  def NAME : X86FoldableSchedWrite {
38*9880d681SAndroid Build Coastguard Worker    let Folded = !cast<SchedWrite>(NAME#"Ld");
39*9880d681SAndroid Build Coastguard Worker  }
40*9880d681SAndroid Build Coastguard Worker}
41*9880d681SAndroid Build Coastguard Worker
42*9880d681SAndroid Build Coastguard Worker// Arithmetic.
43*9880d681SAndroid Build Coastguard Workerdefm WriteALU  : X86SchedWritePair; // Simple integer ALU op.
44*9880d681SAndroid Build Coastguard Workerdefm WriteIMul : X86SchedWritePair; // Integer multiplication.
45*9880d681SAndroid Build Coastguard Workerdef  WriteIMulH : SchedWrite;       // Integer multiplication, high part.
46*9880d681SAndroid Build Coastguard Workerdefm WriteIDiv : X86SchedWritePair; // Integer division.
47*9880d681SAndroid Build Coastguard Workerdef  WriteLEA  : SchedWrite;        // LEA instructions can't fold loads.
48*9880d681SAndroid Build Coastguard Worker
49*9880d681SAndroid Build Coastguard Worker// Integer shifts and rotates.
50*9880d681SAndroid Build Coastguard Workerdefm WriteShift : X86SchedWritePair;
51*9880d681SAndroid Build Coastguard Worker
52*9880d681SAndroid Build Coastguard Worker// Loads, stores, and moves, not folded with other operations.
53*9880d681SAndroid Build Coastguard Workerdef WriteLoad  : SchedWrite;
54*9880d681SAndroid Build Coastguard Workerdef WriteStore : SchedWrite;
55*9880d681SAndroid Build Coastguard Workerdef WriteMove  : SchedWrite;
56*9880d681SAndroid Build Coastguard Worker
57*9880d681SAndroid Build Coastguard Worker// Idioms that clear a register, like xorps %xmm0, %xmm0.
58*9880d681SAndroid Build Coastguard Worker// These can often bypass execution ports completely.
59*9880d681SAndroid Build Coastguard Workerdef WriteZero : SchedWrite;
60*9880d681SAndroid Build Coastguard Worker
61*9880d681SAndroid Build Coastguard Worker// Branches don't produce values, so they have no latency, but they still
62*9880d681SAndroid Build Coastguard Worker// consume resources. Indirect branches can fold loads.
63*9880d681SAndroid Build Coastguard Workerdefm WriteJump : X86SchedWritePair;
64*9880d681SAndroid Build Coastguard Worker
65*9880d681SAndroid Build Coastguard Worker// Floating point. This covers both scalar and vector operations.
66*9880d681SAndroid Build Coastguard Workerdefm WriteFAdd   : X86SchedWritePair; // Floating point add/sub/compare.
67*9880d681SAndroid Build Coastguard Workerdefm WriteFMul   : X86SchedWritePair; // Floating point multiplication.
68*9880d681SAndroid Build Coastguard Workerdefm WriteFDiv   : X86SchedWritePair; // Floating point division.
69*9880d681SAndroid Build Coastguard Workerdefm WriteFSqrt  : X86SchedWritePair; // Floating point square root.
70*9880d681SAndroid Build Coastguard Workerdefm WriteFRcp   : X86SchedWritePair; // Floating point reciprocal estimate.
71*9880d681SAndroid Build Coastguard Workerdefm WriteFRsqrt : X86SchedWritePair; // Floating point reciprocal square root estimate.
72*9880d681SAndroid Build Coastguard Workerdefm WriteFMA    : X86SchedWritePair; // Fused Multiply Add.
73*9880d681SAndroid Build Coastguard Workerdefm WriteFShuffle  : X86SchedWritePair; // Floating point vector shuffles.
74*9880d681SAndroid Build Coastguard Workerdefm WriteFBlend  : X86SchedWritePair; // Floating point vector blends.
75*9880d681SAndroid Build Coastguard Workerdefm WriteFVarBlend  : X86SchedWritePair; // Fp vector variable blends.
76*9880d681SAndroid Build Coastguard Worker
77*9880d681SAndroid Build Coastguard Worker// FMA Scheduling helper class.
78*9880d681SAndroid Build Coastguard Workerclass FMASC { X86FoldableSchedWrite Sched = WriteFAdd; }
79*9880d681SAndroid Build Coastguard Worker
80*9880d681SAndroid Build Coastguard Worker// Vector integer operations.
81*9880d681SAndroid Build Coastguard Workerdefm WriteVecALU   : X86SchedWritePair; // Vector integer ALU op, no logicals.
82*9880d681SAndroid Build Coastguard Workerdefm WriteVecShift : X86SchedWritePair; // Vector integer shifts.
83*9880d681SAndroid Build Coastguard Workerdefm WriteVecIMul  : X86SchedWritePair; // Vector integer multiply.
84*9880d681SAndroid Build Coastguard Workerdefm WriteShuffle  : X86SchedWritePair; // Vector shuffles.
85*9880d681SAndroid Build Coastguard Workerdefm WriteBlend  : X86SchedWritePair; // Vector blends.
86*9880d681SAndroid Build Coastguard Workerdefm WriteVarBlend  : X86SchedWritePair; // Vector variable blends.
87*9880d681SAndroid Build Coastguard Workerdefm WriteMPSAD : X86SchedWritePair; // Vector MPSAD.
88*9880d681SAndroid Build Coastguard Worker
89*9880d681SAndroid Build Coastguard Worker// Vector bitwise operations.
90*9880d681SAndroid Build Coastguard Worker// These are often used on both floating point and integer vectors.
91*9880d681SAndroid Build Coastguard Workerdefm WriteVecLogic : X86SchedWritePair; // Vector and/or/xor.
92*9880d681SAndroid Build Coastguard Worker
93*9880d681SAndroid Build Coastguard Worker// Conversion between integer and float.
94*9880d681SAndroid Build Coastguard Workerdefm WriteCvtF2I : X86SchedWritePair; // Float -> Integer.
95*9880d681SAndroid Build Coastguard Workerdefm WriteCvtI2F : X86SchedWritePair; // Integer -> Float.
96*9880d681SAndroid Build Coastguard Workerdefm WriteCvtF2F : X86SchedWritePair; // Float -> Float size conversion.
97*9880d681SAndroid Build Coastguard Worker
98*9880d681SAndroid Build Coastguard Worker// Strings instructions.
99*9880d681SAndroid Build Coastguard Worker// Packed Compare Implicit Length Strings, Return Mask
100*9880d681SAndroid Build Coastguard Workerdefm WritePCmpIStrM : X86SchedWritePair;
101*9880d681SAndroid Build Coastguard Worker// Packed Compare Explicit Length Strings, Return Mask
102*9880d681SAndroid Build Coastguard Workerdefm WritePCmpEStrM : X86SchedWritePair;
103*9880d681SAndroid Build Coastguard Worker// Packed Compare Implicit Length Strings, Return Index
104*9880d681SAndroid Build Coastguard Workerdefm WritePCmpIStrI : X86SchedWritePair;
105*9880d681SAndroid Build Coastguard Worker// Packed Compare Explicit Length Strings, Return Index
106*9880d681SAndroid Build Coastguard Workerdefm WritePCmpEStrI : X86SchedWritePair;
107*9880d681SAndroid Build Coastguard Worker
108*9880d681SAndroid Build Coastguard Worker// AES instructions.
109*9880d681SAndroid Build Coastguard Workerdefm WriteAESDecEnc : X86SchedWritePair; // Decryption, encryption.
110*9880d681SAndroid Build Coastguard Workerdefm WriteAESIMC : X86SchedWritePair; // InvMixColumn.
111*9880d681SAndroid Build Coastguard Workerdefm WriteAESKeyGen : X86SchedWritePair; // Key Generation.
112*9880d681SAndroid Build Coastguard Worker
113*9880d681SAndroid Build Coastguard Worker// Carry-less multiplication instructions.
114*9880d681SAndroid Build Coastguard Workerdefm WriteCLMul : X86SchedWritePair;
115*9880d681SAndroid Build Coastguard Worker
116*9880d681SAndroid Build Coastguard Worker// Catch-all for expensive system instructions.
117*9880d681SAndroid Build Coastguard Workerdef WriteSystem : SchedWrite;
118*9880d681SAndroid Build Coastguard Worker
119*9880d681SAndroid Build Coastguard Worker// AVX2.
120*9880d681SAndroid Build Coastguard Workerdefm WriteFShuffle256 : X86SchedWritePair; // Fp 256-bit width vector shuffles.
121*9880d681SAndroid Build Coastguard Workerdefm WriteShuffle256 : X86SchedWritePair; // 256-bit width vector shuffles.
122*9880d681SAndroid Build Coastguard Workerdefm WriteVarVecShift : X86SchedWritePair; // Variable vector shifts.
123*9880d681SAndroid Build Coastguard Worker
124*9880d681SAndroid Build Coastguard Worker// Old microcoded instructions that nobody use.
125*9880d681SAndroid Build Coastguard Workerdef WriteMicrocoded : SchedWrite;
126*9880d681SAndroid Build Coastguard Worker
127*9880d681SAndroid Build Coastguard Worker// Fence instructions.
128*9880d681SAndroid Build Coastguard Workerdef WriteFence : SchedWrite;
129*9880d681SAndroid Build Coastguard Worker
130*9880d681SAndroid Build Coastguard Worker// Nop, not very useful expect it provides a model for nops!
131*9880d681SAndroid Build Coastguard Workerdef WriteNop : SchedWrite;
132*9880d681SAndroid Build Coastguard Worker
133*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===//
134*9880d681SAndroid Build Coastguard Worker// Instruction Itinerary classes used for X86
135*9880d681SAndroid Build Coastguard Workerdef IIC_ALU_MEM     : InstrItinClass;
136*9880d681SAndroid Build Coastguard Workerdef IIC_ALU_NONMEM  : InstrItinClass;
137*9880d681SAndroid Build Coastguard Workerdef IIC_LEA         : InstrItinClass;
138*9880d681SAndroid Build Coastguard Workerdef IIC_LEA_16      : InstrItinClass;
139*9880d681SAndroid Build Coastguard Workerdef IIC_MUL8        : InstrItinClass;
140*9880d681SAndroid Build Coastguard Workerdef IIC_MUL16_MEM   : InstrItinClass;
141*9880d681SAndroid Build Coastguard Workerdef IIC_MUL16_REG   : InstrItinClass;
142*9880d681SAndroid Build Coastguard Workerdef IIC_MUL32_MEM   : InstrItinClass;
143*9880d681SAndroid Build Coastguard Workerdef IIC_MUL32_REG   : InstrItinClass;
144*9880d681SAndroid Build Coastguard Workerdef IIC_MUL64       : InstrItinClass;
145*9880d681SAndroid Build Coastguard Worker// imul by al, ax, eax, tax
146*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL8       : InstrItinClass;
147*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL16_MEM  : InstrItinClass;
148*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL16_REG  : InstrItinClass;
149*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL32_MEM  : InstrItinClass;
150*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL32_REG  : InstrItinClass;
151*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL64      : InstrItinClass;
152*9880d681SAndroid Build Coastguard Worker// imul reg by reg|mem
153*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL16_RM   : InstrItinClass;
154*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL16_RR   : InstrItinClass;
155*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL32_RM   : InstrItinClass;
156*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL32_RR   : InstrItinClass;
157*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL64_RM   : InstrItinClass;
158*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL64_RR   : InstrItinClass;
159*9880d681SAndroid Build Coastguard Worker// imul reg = reg/mem * imm
160*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL16_RMI  : InstrItinClass;
161*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL16_RRI  : InstrItinClass;
162*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL32_RMI  : InstrItinClass;
163*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL32_RRI  : InstrItinClass;
164*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL64_RMI  : InstrItinClass;
165*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL64_RRI  : InstrItinClass;
166*9880d681SAndroid Build Coastguard Worker// div
167*9880d681SAndroid Build Coastguard Workerdef IIC_DIV8_MEM    : InstrItinClass;
168*9880d681SAndroid Build Coastguard Workerdef IIC_DIV8_REG    : InstrItinClass;
169*9880d681SAndroid Build Coastguard Workerdef IIC_DIV16       : InstrItinClass;
170*9880d681SAndroid Build Coastguard Workerdef IIC_DIV32       : InstrItinClass;
171*9880d681SAndroid Build Coastguard Workerdef IIC_DIV64       : InstrItinClass;
172*9880d681SAndroid Build Coastguard Worker// idiv
173*9880d681SAndroid Build Coastguard Workerdef IIC_IDIV8       : InstrItinClass;
174*9880d681SAndroid Build Coastguard Workerdef IIC_IDIV16      : InstrItinClass;
175*9880d681SAndroid Build Coastguard Workerdef IIC_IDIV32      : InstrItinClass;
176*9880d681SAndroid Build Coastguard Workerdef IIC_IDIV64      : InstrItinClass;
177*9880d681SAndroid Build Coastguard Worker// neg/not/inc/dec
178*9880d681SAndroid Build Coastguard Workerdef IIC_UNARY_REG   : InstrItinClass;
179*9880d681SAndroid Build Coastguard Workerdef IIC_UNARY_MEM   : InstrItinClass;
180*9880d681SAndroid Build Coastguard Worker// add/sub/and/or/xor/sbc/cmp/test
181*9880d681SAndroid Build Coastguard Workerdef IIC_BIN_MEM     : InstrItinClass;
182*9880d681SAndroid Build Coastguard Workerdef IIC_BIN_NONMEM  : InstrItinClass;
183*9880d681SAndroid Build Coastguard Worker// adc/sbc
184*9880d681SAndroid Build Coastguard Workerdef IIC_BIN_CARRY_MEM     : InstrItinClass;
185*9880d681SAndroid Build Coastguard Workerdef IIC_BIN_CARRY_NONMEM  : InstrItinClass;
186*9880d681SAndroid Build Coastguard Worker// shift/rotate
187*9880d681SAndroid Build Coastguard Workerdef IIC_SR          : InstrItinClass;
188*9880d681SAndroid Build Coastguard Worker// shift double
189*9880d681SAndroid Build Coastguard Workerdef IIC_SHD16_REG_IM : InstrItinClass;
190*9880d681SAndroid Build Coastguard Workerdef IIC_SHD16_REG_CL : InstrItinClass;
191*9880d681SAndroid Build Coastguard Workerdef IIC_SHD16_MEM_IM : InstrItinClass;
192*9880d681SAndroid Build Coastguard Workerdef IIC_SHD16_MEM_CL : InstrItinClass;
193*9880d681SAndroid Build Coastguard Workerdef IIC_SHD32_REG_IM : InstrItinClass;
194*9880d681SAndroid Build Coastguard Workerdef IIC_SHD32_REG_CL : InstrItinClass;
195*9880d681SAndroid Build Coastguard Workerdef IIC_SHD32_MEM_IM : InstrItinClass;
196*9880d681SAndroid Build Coastguard Workerdef IIC_SHD32_MEM_CL : InstrItinClass;
197*9880d681SAndroid Build Coastguard Workerdef IIC_SHD64_REG_IM : InstrItinClass;
198*9880d681SAndroid Build Coastguard Workerdef IIC_SHD64_REG_CL : InstrItinClass;
199*9880d681SAndroid Build Coastguard Workerdef IIC_SHD64_MEM_IM : InstrItinClass;
200*9880d681SAndroid Build Coastguard Workerdef IIC_SHD64_MEM_CL : InstrItinClass;
201*9880d681SAndroid Build Coastguard Worker// cmov
202*9880d681SAndroid Build Coastguard Workerdef IIC_CMOV16_RM : InstrItinClass;
203*9880d681SAndroid Build Coastguard Workerdef IIC_CMOV16_RR : InstrItinClass;
204*9880d681SAndroid Build Coastguard Workerdef IIC_CMOV32_RM : InstrItinClass;
205*9880d681SAndroid Build Coastguard Workerdef IIC_CMOV32_RR : InstrItinClass;
206*9880d681SAndroid Build Coastguard Workerdef IIC_CMOV64_RM : InstrItinClass;
207*9880d681SAndroid Build Coastguard Workerdef IIC_CMOV64_RR : InstrItinClass;
208*9880d681SAndroid Build Coastguard Worker// set
209*9880d681SAndroid Build Coastguard Workerdef IIC_SET_R : InstrItinClass;
210*9880d681SAndroid Build Coastguard Workerdef IIC_SET_M : InstrItinClass;
211*9880d681SAndroid Build Coastguard Worker// jmp/jcc/jcxz
212*9880d681SAndroid Build Coastguard Workerdef IIC_Jcc : InstrItinClass;
213*9880d681SAndroid Build Coastguard Workerdef IIC_JCXZ : InstrItinClass;
214*9880d681SAndroid Build Coastguard Workerdef IIC_JMP_REL : InstrItinClass;
215*9880d681SAndroid Build Coastguard Workerdef IIC_JMP_REG : InstrItinClass;
216*9880d681SAndroid Build Coastguard Workerdef IIC_JMP_MEM : InstrItinClass;
217*9880d681SAndroid Build Coastguard Workerdef IIC_JMP_FAR_MEM : InstrItinClass;
218*9880d681SAndroid Build Coastguard Workerdef IIC_JMP_FAR_PTR : InstrItinClass;
219*9880d681SAndroid Build Coastguard Worker// loop
220*9880d681SAndroid Build Coastguard Workerdef IIC_LOOP : InstrItinClass;
221*9880d681SAndroid Build Coastguard Workerdef IIC_LOOPE : InstrItinClass;
222*9880d681SAndroid Build Coastguard Workerdef IIC_LOOPNE : InstrItinClass;
223*9880d681SAndroid Build Coastguard Worker// call
224*9880d681SAndroid Build Coastguard Workerdef IIC_CALL_RI : InstrItinClass;
225*9880d681SAndroid Build Coastguard Workerdef IIC_CALL_MEM : InstrItinClass;
226*9880d681SAndroid Build Coastguard Workerdef IIC_CALL_FAR_MEM : InstrItinClass;
227*9880d681SAndroid Build Coastguard Workerdef IIC_CALL_FAR_PTR : InstrItinClass;
228*9880d681SAndroid Build Coastguard Worker// ret
229*9880d681SAndroid Build Coastguard Workerdef IIC_RET : InstrItinClass;
230*9880d681SAndroid Build Coastguard Workerdef IIC_RET_IMM : InstrItinClass;
231*9880d681SAndroid Build Coastguard Worker//sign extension movs
232*9880d681SAndroid Build Coastguard Workerdef IIC_MOVSX : InstrItinClass;
233*9880d681SAndroid Build Coastguard Workerdef IIC_MOVSX_R16_R8 : InstrItinClass;
234*9880d681SAndroid Build Coastguard Workerdef IIC_MOVSX_R16_M8 : InstrItinClass;
235*9880d681SAndroid Build Coastguard Workerdef IIC_MOVSX_R16_R16 : InstrItinClass;
236*9880d681SAndroid Build Coastguard Workerdef IIC_MOVSX_R32_R32 : InstrItinClass;
237*9880d681SAndroid Build Coastguard Worker//zero extension movs
238*9880d681SAndroid Build Coastguard Workerdef IIC_MOVZX : InstrItinClass;
239*9880d681SAndroid Build Coastguard Workerdef IIC_MOVZX_R16_R8 : InstrItinClass;
240*9880d681SAndroid Build Coastguard Workerdef IIC_MOVZX_R16_M8 : InstrItinClass;
241*9880d681SAndroid Build Coastguard Worker
242*9880d681SAndroid Build Coastguard Workerdef IIC_REP_MOVS : InstrItinClass;
243*9880d681SAndroid Build Coastguard Workerdef IIC_REP_STOS : InstrItinClass;
244*9880d681SAndroid Build Coastguard Worker
245*9880d681SAndroid Build Coastguard Worker// SSE scalar/parallel binary operations
246*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_ALU_F32S_RR : InstrItinClass;
247*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_ALU_F32S_RM : InstrItinClass;
248*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_ALU_F64S_RR : InstrItinClass;
249*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_ALU_F64S_RM : InstrItinClass;
250*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MUL_F32S_RR : InstrItinClass;
251*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MUL_F32S_RM : InstrItinClass;
252*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MUL_F64S_RR : InstrItinClass;
253*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MUL_F64S_RM : InstrItinClass;
254*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_DIV_F32S_RR : InstrItinClass;
255*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_DIV_F32S_RM : InstrItinClass;
256*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_DIV_F64S_RR : InstrItinClass;
257*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_DIV_F64S_RM : InstrItinClass;
258*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_ALU_F32P_RR : InstrItinClass;
259*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_ALU_F32P_RM : InstrItinClass;
260*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_ALU_F64P_RR : InstrItinClass;
261*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_ALU_F64P_RM : InstrItinClass;
262*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MUL_F32P_RR : InstrItinClass;
263*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MUL_F32P_RM : InstrItinClass;
264*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MUL_F64P_RR : InstrItinClass;
265*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MUL_F64P_RM : InstrItinClass;
266*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_DIV_F32P_RR : InstrItinClass;
267*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_DIV_F32P_RM : InstrItinClass;
268*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_DIV_F64P_RR : InstrItinClass;
269*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_DIV_F64P_RM : InstrItinClass;
270*9880d681SAndroid Build Coastguard Worker
271*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_COMIS_RR : InstrItinClass;
272*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_COMIS_RM : InstrItinClass;
273*9880d681SAndroid Build Coastguard Worker
274*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_HADDSUB_RR : InstrItinClass;
275*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_HADDSUB_RM : InstrItinClass;
276*9880d681SAndroid Build Coastguard Worker
277*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_BIT_P_RR  : InstrItinClass;
278*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_BIT_P_RM  : InstrItinClass;
279*9880d681SAndroid Build Coastguard Worker
280*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_INTALU_P_RR  : InstrItinClass;
281*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_INTALU_P_RM  : InstrItinClass;
282*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_INTALUQ_P_RR  : InstrItinClass;
283*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_INTALUQ_P_RM  : InstrItinClass;
284*9880d681SAndroid Build Coastguard Worker
285*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_INTMUL_P_RR : InstrItinClass;
286*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_INTMUL_P_RM : InstrItinClass;
287*9880d681SAndroid Build Coastguard Worker
288*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_INTSH_P_RR : InstrItinClass;
289*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_INTSH_P_RM : InstrItinClass;
290*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_INTSH_P_RI : InstrItinClass;
291*9880d681SAndroid Build Coastguard Worker
292*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_INTSHDQ_P_RI : InstrItinClass;
293*9880d681SAndroid Build Coastguard Worker
294*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_SHUFP : InstrItinClass;
295*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PSHUF_RI : InstrItinClass;
296*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PSHUF_MI : InstrItinClass;
297*9880d681SAndroid Build Coastguard Worker
298*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_UNPCK : InstrItinClass;
299*9880d681SAndroid Build Coastguard Worker
300*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOVMSK : InstrItinClass;
301*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MASKMOV : InstrItinClass;
302*9880d681SAndroid Build Coastguard Worker
303*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PEXTRW : InstrItinClass;
304*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PINSRW : InstrItinClass;
305*9880d681SAndroid Build Coastguard Worker
306*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PABS_RR : InstrItinClass;
307*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PABS_RM : InstrItinClass;
308*9880d681SAndroid Build Coastguard Worker
309*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_SQRTPS_RR : InstrItinClass;
310*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_SQRTPS_RM : InstrItinClass;
311*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_SQRTSS_RR : InstrItinClass;
312*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_SQRTSS_RM : InstrItinClass;
313*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_SQRTPD_RR : InstrItinClass;
314*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_SQRTPD_RM : InstrItinClass;
315*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_SQRTSD_RR : InstrItinClass;
316*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_SQRTSD_RM : InstrItinClass;
317*9880d681SAndroid Build Coastguard Worker
318*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_RSQRTPS_RR : InstrItinClass;
319*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_RSQRTPS_RM : InstrItinClass;
320*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_RSQRTSS_RR : InstrItinClass;
321*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_RSQRTSS_RM : InstrItinClass;
322*9880d681SAndroid Build Coastguard Worker
323*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_RCPP_RR : InstrItinClass;
324*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_RCPP_RM : InstrItinClass;
325*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_RCPS_RR : InstrItinClass;
326*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_RCPS_RM : InstrItinClass;
327*9880d681SAndroid Build Coastguard Worker
328*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOV_S_RR : InstrItinClass;
329*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOV_S_RM : InstrItinClass;
330*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOV_S_MR : InstrItinClass;
331*9880d681SAndroid Build Coastguard Worker
332*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOVA_P_RR : InstrItinClass;
333*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOVA_P_RM : InstrItinClass;
334*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOVA_P_MR : InstrItinClass;
335*9880d681SAndroid Build Coastguard Worker
336*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOVU_P_RR : InstrItinClass;
337*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOVU_P_RM : InstrItinClass;
338*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOVU_P_MR : InstrItinClass;
339*9880d681SAndroid Build Coastguard Worker
340*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOVDQ : InstrItinClass;
341*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOVD_ToGP : InstrItinClass;
342*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOVQ_RR : InstrItinClass;
343*9880d681SAndroid Build Coastguard Worker
344*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOV_LH : InstrItinClass;
345*9880d681SAndroid Build Coastguard Worker
346*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_LDDQU : InstrItinClass;
347*9880d681SAndroid Build Coastguard Worker
348*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOVNT : InstrItinClass;
349*9880d681SAndroid Build Coastguard Worker
350*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PHADDSUBD_RR : InstrItinClass;
351*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PHADDSUBD_RM : InstrItinClass;
352*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PHADDSUBSW_RR : InstrItinClass;
353*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PHADDSUBSW_RM : InstrItinClass;
354*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PHADDSUBW_RR : InstrItinClass;
355*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PHADDSUBW_RM : InstrItinClass;
356*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PSHUFB_RR : InstrItinClass;
357*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PSHUFB_RM : InstrItinClass;
358*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PSIGN_RR : InstrItinClass;
359*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PSIGN_RM : InstrItinClass;
360*9880d681SAndroid Build Coastguard Worker
361*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PMADD : InstrItinClass;
362*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PMULHRSW : InstrItinClass;
363*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PALIGNRR : InstrItinClass;
364*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PALIGNRM : InstrItinClass;
365*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MWAIT : InstrItinClass;
366*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MONITOR : InstrItinClass;
367*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MWAITX : InstrItinClass;
368*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MONITORX : InstrItinClass;
369*9880d681SAndroid Build Coastguard Worker
370*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PREFETCH : InstrItinClass;
371*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PAUSE : InstrItinClass;
372*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_LFENCE : InstrItinClass;
373*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MFENCE : InstrItinClass;
374*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_SFENCE : InstrItinClass;
375*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_LDMXCSR : InstrItinClass;
376*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_STMXCSR : InstrItinClass;
377*9880d681SAndroid Build Coastguard Worker
378*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_PD_RR : InstrItinClass;
379*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_PD_RM : InstrItinClass;
380*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_PS_RR : InstrItinClass;
381*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_PS_RM : InstrItinClass;
382*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_PI2PS_RR : InstrItinClass;
383*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_PI2PS_RM : InstrItinClass;
384*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_Scalar_RR : InstrItinClass;
385*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_Scalar_RM : InstrItinClass;
386*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_SS2SI32_RM : InstrItinClass;
387*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_SS2SI32_RR : InstrItinClass;
388*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_SS2SI64_RM : InstrItinClass;
389*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_SS2SI64_RR : InstrItinClass;
390*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_SD2SI_RM : InstrItinClass;
391*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_SD2SI_RR : InstrItinClass;
392*9880d681SAndroid Build Coastguard Worker
393*9880d681SAndroid Build Coastguard Worker// MMX
394*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_MOV_MM_RM : InstrItinClass;
395*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_MOV_REG_MM : InstrItinClass;
396*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_MOVQ_RM : InstrItinClass;
397*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_MOVQ_RR : InstrItinClass;
398*9880d681SAndroid Build Coastguard Worker
399*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_ALU_RM : InstrItinClass;
400*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_ALU_RR : InstrItinClass;
401*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_ALUQ_RM : InstrItinClass;
402*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_ALUQ_RR : InstrItinClass;
403*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_PHADDSUBW_RM : InstrItinClass;
404*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_PHADDSUBW_RR : InstrItinClass;
405*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_PHADDSUBD_RM : InstrItinClass;
406*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_PHADDSUBD_RR : InstrItinClass;
407*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_PMUL : InstrItinClass;
408*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_MISC_FUNC_MEM : InstrItinClass;
409*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_MISC_FUNC_REG : InstrItinClass;
410*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_PSADBW : InstrItinClass;
411*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_SHIFT_RI : InstrItinClass;
412*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_SHIFT_RM : InstrItinClass;
413*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_SHIFT_RR : InstrItinClass;
414*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_UNPCK_H_RM : InstrItinClass;
415*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_UNPCK_H_RR : InstrItinClass;
416*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_UNPCK_L : InstrItinClass;
417*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_PCK_RM : InstrItinClass;
418*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_PCK_RR : InstrItinClass;
419*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_PSHUF : InstrItinClass;
420*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_PEXTR : InstrItinClass;
421*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_PINSRW : InstrItinClass;
422*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_MASKMOV : InstrItinClass;
423*9880d681SAndroid Build Coastguard Worker
424*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_CVT_PD_RR : InstrItinClass;
425*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_CVT_PD_RM : InstrItinClass;
426*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_CVT_PS_RR : InstrItinClass;
427*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_CVT_PS_RM : InstrItinClass;
428*9880d681SAndroid Build Coastguard Worker
429*9880d681SAndroid Build Coastguard Workerdef IIC_CMPX_LOCK : InstrItinClass;
430*9880d681SAndroid Build Coastguard Workerdef IIC_CMPX_LOCK_8 : InstrItinClass;
431*9880d681SAndroid Build Coastguard Workerdef IIC_CMPX_LOCK_8B : InstrItinClass;
432*9880d681SAndroid Build Coastguard Workerdef IIC_CMPX_LOCK_16B : InstrItinClass;
433*9880d681SAndroid Build Coastguard Worker
434*9880d681SAndroid Build Coastguard Workerdef IIC_XADD_LOCK_MEM : InstrItinClass;
435*9880d681SAndroid Build Coastguard Workerdef IIC_XADD_LOCK_MEM8 : InstrItinClass;
436*9880d681SAndroid Build Coastguard Worker
437*9880d681SAndroid Build Coastguard Workerdef IIC_FILD : InstrItinClass;
438*9880d681SAndroid Build Coastguard Workerdef IIC_FLD : InstrItinClass;
439*9880d681SAndroid Build Coastguard Workerdef IIC_FLD80 : InstrItinClass;
440*9880d681SAndroid Build Coastguard Workerdef IIC_FST : InstrItinClass;
441*9880d681SAndroid Build Coastguard Workerdef IIC_FST80 : InstrItinClass;
442*9880d681SAndroid Build Coastguard Workerdef IIC_FIST : InstrItinClass;
443*9880d681SAndroid Build Coastguard Workerdef IIC_FLDZ : InstrItinClass;
444*9880d681SAndroid Build Coastguard Workerdef IIC_FUCOM : InstrItinClass;
445*9880d681SAndroid Build Coastguard Workerdef IIC_FUCOMI : InstrItinClass;
446*9880d681SAndroid Build Coastguard Workerdef IIC_FCOMI : InstrItinClass;
447*9880d681SAndroid Build Coastguard Workerdef IIC_FNSTSW : InstrItinClass;
448*9880d681SAndroid Build Coastguard Workerdef IIC_FNSTCW : InstrItinClass;
449*9880d681SAndroid Build Coastguard Workerdef IIC_FLDCW : InstrItinClass;
450*9880d681SAndroid Build Coastguard Workerdef IIC_FNINIT : InstrItinClass;
451*9880d681SAndroid Build Coastguard Workerdef IIC_FFREE : InstrItinClass;
452*9880d681SAndroid Build Coastguard Workerdef IIC_FNCLEX : InstrItinClass;
453*9880d681SAndroid Build Coastguard Workerdef IIC_WAIT : InstrItinClass;
454*9880d681SAndroid Build Coastguard Workerdef IIC_FXAM : InstrItinClass;
455*9880d681SAndroid Build Coastguard Workerdef IIC_FNOP : InstrItinClass;
456*9880d681SAndroid Build Coastguard Workerdef IIC_FLDL : InstrItinClass;
457*9880d681SAndroid Build Coastguard Workerdef IIC_F2XM1 : InstrItinClass;
458*9880d681SAndroid Build Coastguard Workerdef IIC_FYL2X : InstrItinClass;
459*9880d681SAndroid Build Coastguard Workerdef IIC_FPTAN : InstrItinClass;
460*9880d681SAndroid Build Coastguard Workerdef IIC_FPATAN : InstrItinClass;
461*9880d681SAndroid Build Coastguard Workerdef IIC_FXTRACT : InstrItinClass;
462*9880d681SAndroid Build Coastguard Workerdef IIC_FPREM1 : InstrItinClass;
463*9880d681SAndroid Build Coastguard Workerdef IIC_FPSTP : InstrItinClass;
464*9880d681SAndroid Build Coastguard Workerdef IIC_FPREM : InstrItinClass;
465*9880d681SAndroid Build Coastguard Workerdef IIC_FYL2XP1 : InstrItinClass;
466*9880d681SAndroid Build Coastguard Workerdef IIC_FSINCOS : InstrItinClass;
467*9880d681SAndroid Build Coastguard Workerdef IIC_FRNDINT : InstrItinClass;
468*9880d681SAndroid Build Coastguard Workerdef IIC_FSCALE : InstrItinClass;
469*9880d681SAndroid Build Coastguard Workerdef IIC_FCOMPP : InstrItinClass;
470*9880d681SAndroid Build Coastguard Workerdef IIC_FXSAVE : InstrItinClass;
471*9880d681SAndroid Build Coastguard Workerdef IIC_FXRSTOR : InstrItinClass;
472*9880d681SAndroid Build Coastguard Worker
473*9880d681SAndroid Build Coastguard Workerdef IIC_FXCH : InstrItinClass;
474*9880d681SAndroid Build Coastguard Worker
475*9880d681SAndroid Build Coastguard Worker// System instructions
476*9880d681SAndroid Build Coastguard Workerdef IIC_CPUID : InstrItinClass;
477*9880d681SAndroid Build Coastguard Workerdef IIC_INT : InstrItinClass;
478*9880d681SAndroid Build Coastguard Workerdef IIC_INT3 : InstrItinClass;
479*9880d681SAndroid Build Coastguard Workerdef IIC_INVD : InstrItinClass;
480*9880d681SAndroid Build Coastguard Workerdef IIC_INVLPG : InstrItinClass;
481*9880d681SAndroid Build Coastguard Workerdef IIC_IRET : InstrItinClass;
482*9880d681SAndroid Build Coastguard Workerdef IIC_HLT : InstrItinClass;
483*9880d681SAndroid Build Coastguard Workerdef IIC_LXS : InstrItinClass;
484*9880d681SAndroid Build Coastguard Workerdef IIC_LTR : InstrItinClass;
485*9880d681SAndroid Build Coastguard Workerdef IIC_RDTSC : InstrItinClass;
486*9880d681SAndroid Build Coastguard Workerdef IIC_RSM : InstrItinClass;
487*9880d681SAndroid Build Coastguard Workerdef IIC_SIDT : InstrItinClass;
488*9880d681SAndroid Build Coastguard Workerdef IIC_SGDT : InstrItinClass;
489*9880d681SAndroid Build Coastguard Workerdef IIC_SLDT : InstrItinClass;
490*9880d681SAndroid Build Coastguard Workerdef IIC_STR : InstrItinClass;
491*9880d681SAndroid Build Coastguard Workerdef IIC_SWAPGS : InstrItinClass;
492*9880d681SAndroid Build Coastguard Workerdef IIC_SYSCALL : InstrItinClass;
493*9880d681SAndroid Build Coastguard Workerdef IIC_SYS_ENTER_EXIT : InstrItinClass;
494*9880d681SAndroid Build Coastguard Workerdef IIC_IN_RR : InstrItinClass;
495*9880d681SAndroid Build Coastguard Workerdef IIC_IN_RI : InstrItinClass;
496*9880d681SAndroid Build Coastguard Workerdef IIC_OUT_RR : InstrItinClass;
497*9880d681SAndroid Build Coastguard Workerdef IIC_OUT_IR : InstrItinClass;
498*9880d681SAndroid Build Coastguard Workerdef IIC_INS : InstrItinClass;
499*9880d681SAndroid Build Coastguard Workerdef IIC_MOV_REG_DR : InstrItinClass;
500*9880d681SAndroid Build Coastguard Workerdef IIC_MOV_DR_REG : InstrItinClass;
501*9880d681SAndroid Build Coastguard Workerdef IIC_MOV_REG_CR : InstrItinClass;
502*9880d681SAndroid Build Coastguard Workerdef IIC_MOV_CR_REG : InstrItinClass;
503*9880d681SAndroid Build Coastguard Workerdef IIC_MOV_REG_SR : InstrItinClass;
504*9880d681SAndroid Build Coastguard Workerdef IIC_MOV_MEM_SR : InstrItinClass;
505*9880d681SAndroid Build Coastguard Workerdef IIC_MOV_SR_REG : InstrItinClass;
506*9880d681SAndroid Build Coastguard Workerdef IIC_MOV_SR_MEM : InstrItinClass;
507*9880d681SAndroid Build Coastguard Workerdef IIC_LAR_RM : InstrItinClass;
508*9880d681SAndroid Build Coastguard Workerdef IIC_LAR_RR : InstrItinClass;
509*9880d681SAndroid Build Coastguard Workerdef IIC_LSL_RM : InstrItinClass;
510*9880d681SAndroid Build Coastguard Workerdef IIC_LSL_RR : InstrItinClass;
511*9880d681SAndroid Build Coastguard Workerdef IIC_LGDT : InstrItinClass;
512*9880d681SAndroid Build Coastguard Workerdef IIC_LIDT : InstrItinClass;
513*9880d681SAndroid Build Coastguard Workerdef IIC_LLDT_REG : InstrItinClass;
514*9880d681SAndroid Build Coastguard Workerdef IIC_LLDT_MEM : InstrItinClass;
515*9880d681SAndroid Build Coastguard Workerdef IIC_PUSH_CS : InstrItinClass;
516*9880d681SAndroid Build Coastguard Workerdef IIC_PUSH_SR : InstrItinClass;
517*9880d681SAndroid Build Coastguard Workerdef IIC_POP_SR : InstrItinClass;
518*9880d681SAndroid Build Coastguard Workerdef IIC_POP_SR_SS : InstrItinClass;
519*9880d681SAndroid Build Coastguard Workerdef IIC_VERR : InstrItinClass;
520*9880d681SAndroid Build Coastguard Workerdef IIC_VERW_REG : InstrItinClass;
521*9880d681SAndroid Build Coastguard Workerdef IIC_VERW_MEM : InstrItinClass;
522*9880d681SAndroid Build Coastguard Workerdef IIC_WRMSR : InstrItinClass;
523*9880d681SAndroid Build Coastguard Workerdef IIC_RDMSR : InstrItinClass;
524*9880d681SAndroid Build Coastguard Workerdef IIC_RDPMC : InstrItinClass;
525*9880d681SAndroid Build Coastguard Workerdef IIC_SMSW : InstrItinClass;
526*9880d681SAndroid Build Coastguard Workerdef IIC_LMSW_REG : InstrItinClass;
527*9880d681SAndroid Build Coastguard Workerdef IIC_LMSW_MEM : InstrItinClass;
528*9880d681SAndroid Build Coastguard Workerdef IIC_ENTER : InstrItinClass;
529*9880d681SAndroid Build Coastguard Workerdef IIC_LEAVE : InstrItinClass;
530*9880d681SAndroid Build Coastguard Workerdef IIC_POP_MEM : InstrItinClass;
531*9880d681SAndroid Build Coastguard Workerdef IIC_POP_REG16 : InstrItinClass;
532*9880d681SAndroid Build Coastguard Workerdef IIC_POP_REG : InstrItinClass;
533*9880d681SAndroid Build Coastguard Workerdef IIC_POP_F : InstrItinClass;
534*9880d681SAndroid Build Coastguard Workerdef IIC_POP_FD : InstrItinClass;
535*9880d681SAndroid Build Coastguard Workerdef IIC_POP_A : InstrItinClass;
536*9880d681SAndroid Build Coastguard Workerdef IIC_PUSH_IMM : InstrItinClass;
537*9880d681SAndroid Build Coastguard Workerdef IIC_PUSH_MEM : InstrItinClass;
538*9880d681SAndroid Build Coastguard Workerdef IIC_PUSH_REG : InstrItinClass;
539*9880d681SAndroid Build Coastguard Workerdef IIC_PUSH_F : InstrItinClass;
540*9880d681SAndroid Build Coastguard Workerdef IIC_PUSH_A : InstrItinClass;
541*9880d681SAndroid Build Coastguard Workerdef IIC_BSWAP : InstrItinClass;
542*9880d681SAndroid Build Coastguard Workerdef IIC_BIT_SCAN_MEM : InstrItinClass;
543*9880d681SAndroid Build Coastguard Workerdef IIC_BIT_SCAN_REG : InstrItinClass;
544*9880d681SAndroid Build Coastguard Workerdef IIC_MOVS : InstrItinClass;
545*9880d681SAndroid Build Coastguard Workerdef IIC_STOS : InstrItinClass;
546*9880d681SAndroid Build Coastguard Workerdef IIC_SCAS : InstrItinClass;
547*9880d681SAndroid Build Coastguard Workerdef IIC_CMPS : InstrItinClass;
548*9880d681SAndroid Build Coastguard Workerdef IIC_MOV : InstrItinClass;
549*9880d681SAndroid Build Coastguard Workerdef IIC_MOV_MEM : InstrItinClass;
550*9880d681SAndroid Build Coastguard Workerdef IIC_AHF : InstrItinClass;
551*9880d681SAndroid Build Coastguard Workerdef IIC_BT_MI : InstrItinClass;
552*9880d681SAndroid Build Coastguard Workerdef IIC_BT_MR : InstrItinClass;
553*9880d681SAndroid Build Coastguard Workerdef IIC_BT_RI : InstrItinClass;
554*9880d681SAndroid Build Coastguard Workerdef IIC_BT_RR : InstrItinClass;
555*9880d681SAndroid Build Coastguard Workerdef IIC_BTX_MI : InstrItinClass;
556*9880d681SAndroid Build Coastguard Workerdef IIC_BTX_MR : InstrItinClass;
557*9880d681SAndroid Build Coastguard Workerdef IIC_BTX_RI : InstrItinClass;
558*9880d681SAndroid Build Coastguard Workerdef IIC_BTX_RR : InstrItinClass;
559*9880d681SAndroid Build Coastguard Workerdef IIC_XCHG_REG : InstrItinClass;
560*9880d681SAndroid Build Coastguard Workerdef IIC_XCHG_MEM : InstrItinClass;
561*9880d681SAndroid Build Coastguard Workerdef IIC_XADD_REG : InstrItinClass;
562*9880d681SAndroid Build Coastguard Workerdef IIC_XADD_MEM : InstrItinClass;
563*9880d681SAndroid Build Coastguard Workerdef IIC_CMPXCHG_MEM : InstrItinClass;
564*9880d681SAndroid Build Coastguard Workerdef IIC_CMPXCHG_REG : InstrItinClass;
565*9880d681SAndroid Build Coastguard Workerdef IIC_CMPXCHG_MEM8 : InstrItinClass;
566*9880d681SAndroid Build Coastguard Workerdef IIC_CMPXCHG_REG8 : InstrItinClass;
567*9880d681SAndroid Build Coastguard Workerdef IIC_CMPXCHG_8B : InstrItinClass;
568*9880d681SAndroid Build Coastguard Workerdef IIC_CMPXCHG_16B : InstrItinClass;
569*9880d681SAndroid Build Coastguard Workerdef IIC_LODS : InstrItinClass;
570*9880d681SAndroid Build Coastguard Workerdef IIC_OUTS : InstrItinClass;
571*9880d681SAndroid Build Coastguard Workerdef IIC_CLC : InstrItinClass;
572*9880d681SAndroid Build Coastguard Workerdef IIC_CLD : InstrItinClass;
573*9880d681SAndroid Build Coastguard Workerdef IIC_CLI : InstrItinClass;
574*9880d681SAndroid Build Coastguard Workerdef IIC_CMC : InstrItinClass;
575*9880d681SAndroid Build Coastguard Workerdef IIC_CLTS : InstrItinClass;
576*9880d681SAndroid Build Coastguard Workerdef IIC_STC : InstrItinClass;
577*9880d681SAndroid Build Coastguard Workerdef IIC_STI : InstrItinClass;
578*9880d681SAndroid Build Coastguard Workerdef IIC_STD : InstrItinClass;
579*9880d681SAndroid Build Coastguard Workerdef IIC_XLAT : InstrItinClass;
580*9880d681SAndroid Build Coastguard Workerdef IIC_AAA : InstrItinClass;
581*9880d681SAndroid Build Coastguard Workerdef IIC_AAD : InstrItinClass;
582*9880d681SAndroid Build Coastguard Workerdef IIC_AAM : InstrItinClass;
583*9880d681SAndroid Build Coastguard Workerdef IIC_AAS : InstrItinClass;
584*9880d681SAndroid Build Coastguard Workerdef IIC_DAA : InstrItinClass;
585*9880d681SAndroid Build Coastguard Workerdef IIC_DAS : InstrItinClass;
586*9880d681SAndroid Build Coastguard Workerdef IIC_BOUND : InstrItinClass;
587*9880d681SAndroid Build Coastguard Workerdef IIC_ARPL_REG : InstrItinClass;
588*9880d681SAndroid Build Coastguard Workerdef IIC_ARPL_MEM : InstrItinClass;
589*9880d681SAndroid Build Coastguard Workerdef IIC_MOVBE : InstrItinClass;
590*9880d681SAndroid Build Coastguard Workerdef IIC_AES   : InstrItinClass;
591*9880d681SAndroid Build Coastguard Workerdef IIC_BLEND_MEM : InstrItinClass;
592*9880d681SAndroid Build Coastguard Workerdef IIC_BLEND_NOMEM : InstrItinClass;
593*9880d681SAndroid Build Coastguard Workerdef IIC_CBW   : InstrItinClass;
594*9880d681SAndroid Build Coastguard Workerdef IIC_CRC32_REG : InstrItinClass;
595*9880d681SAndroid Build Coastguard Workerdef IIC_CRC32_MEM : InstrItinClass;
596*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_DPPD_RR : InstrItinClass;
597*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_DPPD_RM : InstrItinClass;
598*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_DPPS_RR : InstrItinClass;
599*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_DPPS_RM : InstrItinClass;
600*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_EMMS : InstrItinClass;
601*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_EXTRACTPS_RR : InstrItinClass;
602*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_EXTRACTPS_RM : InstrItinClass;
603*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_INSERTPS_RR : InstrItinClass;
604*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_INSERTPS_RM : InstrItinClass;
605*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MPSADBW_RR : InstrItinClass;
606*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MPSADBW_RM : InstrItinClass;
607*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PMULLD_RR : InstrItinClass;
608*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PMULLD_RM : InstrItinClass;
609*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_ROUNDPS_REG : InstrItinClass;
610*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_ROUNDPS_MEM : InstrItinClass;
611*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_ROUNDPD_REG : InstrItinClass;
612*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_ROUNDPD_MEM : InstrItinClass;
613*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_POPCNT_RR : InstrItinClass;
614*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_POPCNT_RM : InstrItinClass;
615*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PCLMULQDQ_RR : InstrItinClass;
616*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PCLMULQDQ_RM : InstrItinClass;
617*9880d681SAndroid Build Coastguard Worker
618*9880d681SAndroid Build Coastguard Workerdef IIC_NOP : InstrItinClass;
619*9880d681SAndroid Build Coastguard Worker
620*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===//
621*9880d681SAndroid Build Coastguard Worker// Processor instruction itineraries.
622*9880d681SAndroid Build Coastguard Worker
623*9880d681SAndroid Build Coastguard Worker// IssueWidth is analogous to the number of decode units. Core and its
624*9880d681SAndroid Build Coastguard Worker// descendents, including Nehalem and SandyBridge have 4 decoders.
625*9880d681SAndroid Build Coastguard Worker// Resources beyond the decoder operate on micro-ops and are bufferred
626*9880d681SAndroid Build Coastguard Worker// so adjacent micro-ops don't directly compete.
627*9880d681SAndroid Build Coastguard Worker//
628*9880d681SAndroid Build Coastguard Worker// MicroOpBufferSize > 1 indicates that RAW dependencies can be
629*9880d681SAndroid Build Coastguard Worker// decoded in the same cycle. The value 32 is a reasonably arbitrary
630*9880d681SAndroid Build Coastguard Worker// number of in-flight instructions.
631*9880d681SAndroid Build Coastguard Worker//
632*9880d681SAndroid Build Coastguard Worker// HighLatency=10 is optimistic. X86InstrInfo::isHighLatencyDef
633*9880d681SAndroid Build Coastguard Worker// indicates high latency opcodes. Alternatively, InstrItinData
634*9880d681SAndroid Build Coastguard Worker// entries may be included here to define specific operand
635*9880d681SAndroid Build Coastguard Worker// latencies. Since these latencies are not used for pipeline hazards,
636*9880d681SAndroid Build Coastguard Worker// they do not need to be exact.
637*9880d681SAndroid Build Coastguard Worker//
638*9880d681SAndroid Build Coastguard Worker// The GenericX86Model contains no instruction itineraries
639*9880d681SAndroid Build Coastguard Worker// and disables PostRAScheduler.
640*9880d681SAndroid Build Coastguard Workerclass GenericX86Model : SchedMachineModel {
641*9880d681SAndroid Build Coastguard Worker  let IssueWidth = 4;
642*9880d681SAndroid Build Coastguard Worker  let MicroOpBufferSize = 32;
643*9880d681SAndroid Build Coastguard Worker  let LoadLatency = 4;
644*9880d681SAndroid Build Coastguard Worker  let HighLatency = 10;
645*9880d681SAndroid Build Coastguard Worker  let PostRAScheduler = 0;
646*9880d681SAndroid Build Coastguard Worker  let CompleteModel = 0;
647*9880d681SAndroid Build Coastguard Worker}
648*9880d681SAndroid Build Coastguard Worker
649*9880d681SAndroid Build Coastguard Workerdef GenericModel : GenericX86Model;
650*9880d681SAndroid Build Coastguard Worker
651*9880d681SAndroid Build Coastguard Worker// Define a model with the PostRAScheduler enabled.
652*9880d681SAndroid Build Coastguard Workerdef GenericPostRAModel : GenericX86Model {
653*9880d681SAndroid Build Coastguard Worker  let PostRAScheduler = 1;
654*9880d681SAndroid Build Coastguard Worker}
655*9880d681SAndroid Build Coastguard Worker
656*9880d681SAndroid Build Coastguard Workerinclude "X86ScheduleAtom.td"
657*9880d681SAndroid Build Coastguard Workerinclude "X86SchedSandyBridge.td"
658*9880d681SAndroid Build Coastguard Workerinclude "X86SchedHaswell.td"
659*9880d681SAndroid Build Coastguard Workerinclude "X86ScheduleSLM.td"
660*9880d681SAndroid Build Coastguard Workerinclude "X86ScheduleBtVer2.td"
661*9880d681SAndroid Build Coastguard Worker
662