• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1//===-- X86Schedule.td - X86 Scheduling Definitions --------*- tablegen -*-===//
2//
3//                     The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
10//===----------------------------------------------------------------------===//
11// Instruction Itinerary classes used for X86
12def IIC_DEFAULT     : InstrItinClass;
13def IIC_ALU_MEM     : InstrItinClass;
14def IIC_ALU_NONMEM  : InstrItinClass;
15def IIC_LEA         : InstrItinClass;
16def IIC_LEA_16      : InstrItinClass;
17def IIC_MUL8        : InstrItinClass;
18def IIC_MUL16_MEM   : InstrItinClass;
19def IIC_MUL16_REG   : InstrItinClass;
20def IIC_MUL32_MEM   : InstrItinClass;
21def IIC_MUL32_REG   : InstrItinClass;
22def IIC_MUL64       : InstrItinClass;
23// imul by al, ax, eax, tax
24def IIC_IMUL8       : InstrItinClass;
25def IIC_IMUL16_MEM  : InstrItinClass;
26def IIC_IMUL16_REG  : InstrItinClass;
27def IIC_IMUL32_MEM  : InstrItinClass;
28def IIC_IMUL32_REG  : InstrItinClass;
29def IIC_IMUL64      : InstrItinClass;
30// imul reg by reg|mem
31def IIC_IMUL16_RM   : InstrItinClass;
32def IIC_IMUL16_RR   : InstrItinClass;
33def IIC_IMUL32_RM   : InstrItinClass;
34def IIC_IMUL32_RR   : InstrItinClass;
35def IIC_IMUL64_RM   : InstrItinClass;
36def IIC_IMUL64_RR   : InstrItinClass;
37// imul reg = reg/mem * imm
38def IIC_IMUL16_RMI  : InstrItinClass;
39def IIC_IMUL16_RRI  : InstrItinClass;
40def IIC_IMUL32_RMI  : InstrItinClass;
41def IIC_IMUL32_RRI  : InstrItinClass;
42def IIC_IMUL64_RMI  : InstrItinClass;
43def IIC_IMUL64_RRI  : InstrItinClass;
44// div
45def IIC_DIV8_MEM    : InstrItinClass;
46def IIC_DIV8_REG    : InstrItinClass;
47def IIC_DIV16       : InstrItinClass;
48def IIC_DIV32       : InstrItinClass;
49def IIC_DIV64       : InstrItinClass;
50// idiv
51def IIC_IDIV8       : InstrItinClass;
52def IIC_IDIV16      : InstrItinClass;
53def IIC_IDIV32      : InstrItinClass;
54def IIC_IDIV64      : InstrItinClass;
55// neg/not/inc/dec
56def IIC_UNARY_REG   : InstrItinClass;
57def IIC_UNARY_MEM   : InstrItinClass;
58// add/sub/and/or/xor/adc/sbc/cmp/test
59def IIC_BIN_MEM     : InstrItinClass;
60def IIC_BIN_NONMEM  : InstrItinClass;
61// shift/rotate
62def IIC_SR          : InstrItinClass;
63// shift double
64def IIC_SHD16_REG_IM : InstrItinClass;
65def IIC_SHD16_REG_CL : InstrItinClass;
66def IIC_SHD16_MEM_IM : InstrItinClass;
67def IIC_SHD16_MEM_CL : InstrItinClass;
68def IIC_SHD32_REG_IM : InstrItinClass;
69def IIC_SHD32_REG_CL : InstrItinClass;
70def IIC_SHD32_MEM_IM : InstrItinClass;
71def IIC_SHD32_MEM_CL : InstrItinClass;
72def IIC_SHD64_REG_IM : InstrItinClass;
73def IIC_SHD64_REG_CL : InstrItinClass;
74def IIC_SHD64_MEM_IM : InstrItinClass;
75def IIC_SHD64_MEM_CL : InstrItinClass;
76// cmov
77def IIC_CMOV16_RM : InstrItinClass;
78def IIC_CMOV16_RR : InstrItinClass;
79def IIC_CMOV32_RM : InstrItinClass;
80def IIC_CMOV32_RR : InstrItinClass;
81def IIC_CMOV64_RM : InstrItinClass;
82def IIC_CMOV64_RR : InstrItinClass;
83// set
84def IIC_SET_R : InstrItinClass;
85def IIC_SET_M : InstrItinClass;
86// jmp/jcc/jcxz
87def IIC_Jcc : InstrItinClass;
88def IIC_JCXZ : InstrItinClass;
89def IIC_JMP_REL : InstrItinClass;
90def IIC_JMP_REG : InstrItinClass;
91def IIC_JMP_MEM : InstrItinClass;
92def IIC_JMP_FAR_MEM : InstrItinClass;
93def IIC_JMP_FAR_PTR : InstrItinClass;
94// loop
95def IIC_LOOP : InstrItinClass;
96def IIC_LOOPE : InstrItinClass;
97def IIC_LOOPNE : InstrItinClass;
98// call
99def IIC_CALL_RI : InstrItinClass;
100def IIC_CALL_MEM : InstrItinClass;
101def IIC_CALL_FAR_MEM : InstrItinClass;
102def IIC_CALL_FAR_PTR : InstrItinClass;
103// ret
104def IIC_RET : InstrItinClass;
105def IIC_RET_IMM : InstrItinClass;
106//sign extension movs
107def IIC_MOVSX : InstrItinClass;
108def IIC_MOVSX_R16_R8 : InstrItinClass;
109def IIC_MOVSX_R16_M8 : InstrItinClass;
110def IIC_MOVSX_R16_R16 : InstrItinClass;
111def IIC_MOVSX_R32_R32 : InstrItinClass;
112//zero extension movs
113def IIC_MOVZX : InstrItinClass;
114def IIC_MOVZX_R16_R8 : InstrItinClass;
115def IIC_MOVZX_R16_M8 : InstrItinClass;
116
117def IIC_REP_MOVS : InstrItinClass;
118def IIC_REP_STOS : InstrItinClass;
119
120// SSE scalar/parallel binary operations
121def IIC_SSE_ALU_F32S_RR : InstrItinClass;
122def IIC_SSE_ALU_F32S_RM : InstrItinClass;
123def IIC_SSE_ALU_F64S_RR : InstrItinClass;
124def IIC_SSE_ALU_F64S_RM : InstrItinClass;
125def IIC_SSE_MUL_F32S_RR : InstrItinClass;
126def IIC_SSE_MUL_F32S_RM : InstrItinClass;
127def IIC_SSE_MUL_F64S_RR : InstrItinClass;
128def IIC_SSE_MUL_F64S_RM : InstrItinClass;
129def IIC_SSE_DIV_F32S_RR : InstrItinClass;
130def IIC_SSE_DIV_F32S_RM : InstrItinClass;
131def IIC_SSE_DIV_F64S_RR : InstrItinClass;
132def IIC_SSE_DIV_F64S_RM : InstrItinClass;
133def IIC_SSE_ALU_F32P_RR : InstrItinClass;
134def IIC_SSE_ALU_F32P_RM : InstrItinClass;
135def IIC_SSE_ALU_F64P_RR : InstrItinClass;
136def IIC_SSE_ALU_F64P_RM : InstrItinClass;
137def IIC_SSE_MUL_F32P_RR : InstrItinClass;
138def IIC_SSE_MUL_F32P_RM : InstrItinClass;
139def IIC_SSE_MUL_F64P_RR : InstrItinClass;
140def IIC_SSE_MUL_F64P_RM : InstrItinClass;
141def IIC_SSE_DIV_F32P_RR : InstrItinClass;
142def IIC_SSE_DIV_F32P_RM : InstrItinClass;
143def IIC_SSE_DIV_F64P_RR : InstrItinClass;
144def IIC_SSE_DIV_F64P_RM : InstrItinClass;
145
146def IIC_SSE_COMIS_RR : InstrItinClass;
147def IIC_SSE_COMIS_RM : InstrItinClass;
148
149def IIC_SSE_HADDSUB_RR : InstrItinClass;
150def IIC_SSE_HADDSUB_RM : InstrItinClass;
151
152def IIC_SSE_BIT_P_RR  : InstrItinClass;
153def IIC_SSE_BIT_P_RM  : InstrItinClass;
154
155def IIC_SSE_INTALU_P_RR  : InstrItinClass;
156def IIC_SSE_INTALU_P_RM  : InstrItinClass;
157def IIC_SSE_INTALUQ_P_RR  : InstrItinClass;
158def IIC_SSE_INTALUQ_P_RM  : InstrItinClass;
159
160def IIC_SSE_INTMUL_P_RR : InstrItinClass;
161def IIC_SSE_INTMUL_P_RM : InstrItinClass;
162
163def IIC_SSE_INTSH_P_RR : InstrItinClass;
164def IIC_SSE_INTSH_P_RM : InstrItinClass;
165def IIC_SSE_INTSH_P_RI : InstrItinClass;
166
167def IIC_SSE_CMPP_RR : InstrItinClass;
168def IIC_SSE_CMPP_RM : InstrItinClass;
169
170def IIC_SSE_SHUFP : InstrItinClass;
171def IIC_SSE_PSHUF : InstrItinClass;
172
173def IIC_SSE_UNPCK : InstrItinClass;
174
175def IIC_SSE_MOVMSK : InstrItinClass;
176def IIC_SSE_MASKMOV : InstrItinClass;
177
178def IIC_SSE_PEXTRW : InstrItinClass;
179def IIC_SSE_PINSRW : InstrItinClass;
180
181def IIC_SSE_PABS_RR : InstrItinClass;
182def IIC_SSE_PABS_RM : InstrItinClass;
183
184def IIC_SSE_SQRTP_RR : InstrItinClass;
185def IIC_SSE_SQRTP_RM : InstrItinClass;
186def IIC_SSE_SQRTS_RR : InstrItinClass;
187def IIC_SSE_SQRTS_RM : InstrItinClass;
188
189def IIC_SSE_RCPP_RR : InstrItinClass;
190def IIC_SSE_RCPP_RM : InstrItinClass;
191def IIC_SSE_RCPS_RR : InstrItinClass;
192def IIC_SSE_RCPS_RM : InstrItinClass;
193
194def IIC_SSE_MOV_S_RR : InstrItinClass;
195def IIC_SSE_MOV_S_RM : InstrItinClass;
196def IIC_SSE_MOV_S_MR : InstrItinClass;
197
198def IIC_SSE_MOVA_P_RR : InstrItinClass;
199def IIC_SSE_MOVA_P_RM : InstrItinClass;
200def IIC_SSE_MOVA_P_MR : InstrItinClass;
201
202def IIC_SSE_MOVU_P_RR : InstrItinClass;
203def IIC_SSE_MOVU_P_RM : InstrItinClass;
204def IIC_SSE_MOVU_P_MR : InstrItinClass;
205
206def IIC_SSE_MOVDQ : InstrItinClass;
207def IIC_SSE_MOVD_ToGP : InstrItinClass;
208def IIC_SSE_MOVQ_RR : InstrItinClass;
209
210def IIC_SSE_MOV_LH : InstrItinClass;
211
212def IIC_SSE_LDDQU : InstrItinClass;
213
214def IIC_SSE_MOVNT : InstrItinClass;
215
216def IIC_SSE_PHADDSUBD_RR : InstrItinClass;
217def IIC_SSE_PHADDSUBD_RM : InstrItinClass;
218def IIC_SSE_PHADDSUBSW_RR : InstrItinClass;
219def IIC_SSE_PHADDSUBSW_RM : InstrItinClass;
220def IIC_SSE_PHADDSUBW_RR : InstrItinClass;
221def IIC_SSE_PHADDSUBW_RM : InstrItinClass;
222def IIC_SSE_PSHUFB_RR : InstrItinClass;
223def IIC_SSE_PSHUFB_RM : InstrItinClass;
224def IIC_SSE_PSIGN_RR : InstrItinClass;
225def IIC_SSE_PSIGN_RM : InstrItinClass;
226
227def IIC_SSE_PMADD : InstrItinClass;
228def IIC_SSE_PMULHRSW : InstrItinClass;
229def IIC_SSE_PALIGNR : InstrItinClass;
230def IIC_SSE_MWAIT : InstrItinClass;
231def IIC_SSE_MONITOR : InstrItinClass;
232
233def IIC_SSE_PREFETCH : InstrItinClass;
234def IIC_SSE_PAUSE : InstrItinClass;
235def IIC_SSE_LFENCE : InstrItinClass;
236def IIC_SSE_MFENCE : InstrItinClass;
237def IIC_SSE_SFENCE : InstrItinClass;
238def IIC_SSE_LDMXCSR : InstrItinClass;
239def IIC_SSE_STMXCSR : InstrItinClass;
240
241def IIC_SSE_CVT_PD_RR : InstrItinClass;
242def IIC_SSE_CVT_PD_RM : InstrItinClass;
243def IIC_SSE_CVT_PS_RR : InstrItinClass;
244def IIC_SSE_CVT_PS_RM : InstrItinClass;
245def IIC_SSE_CVT_PI2PS_RR : InstrItinClass;
246def IIC_SSE_CVT_PI2PS_RM : InstrItinClass;
247def IIC_SSE_CVT_Scalar_RR : InstrItinClass;
248def IIC_SSE_CVT_Scalar_RM : InstrItinClass;
249def IIC_SSE_CVT_SS2SI32_RM : InstrItinClass;
250def IIC_SSE_CVT_SS2SI32_RR : InstrItinClass;
251def IIC_SSE_CVT_SS2SI64_RM : InstrItinClass;
252def IIC_SSE_CVT_SS2SI64_RR : InstrItinClass;
253def IIC_SSE_CVT_SD2SI_RM : InstrItinClass;
254def IIC_SSE_CVT_SD2SI_RR : InstrItinClass;
255
256def IIC_CMPX_LOCK : InstrItinClass;
257def IIC_CMPX_LOCK_8 : InstrItinClass;
258def IIC_CMPX_LOCK_8B : InstrItinClass;
259def IIC_CMPX_LOCK_16B : InstrItinClass;
260
261def IIC_XADD_LOCK_MEM : InstrItinClass;
262def IIC_XADD_LOCK_MEM8 : InstrItinClass;
263
264
265//===----------------------------------------------------------------------===//
266// Processor instruction itineraries.
267
268def GenericItineraries : ProcessorItineraries<[], [], []>;
269
270include "X86ScheduleAtom.td"
271
272
273
274