Add a new interface to allow IR-level passes to access codegen-specific information.
[oota-llvm.git] / lib / Target / Hexagon / HexagonInstrFormats.td
1 //==- HexagonInstrFormats.td - Hexagon Instruction Formats --*- 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 //                         Hexagon Intruction Flags +
12 //
13 //                    *** Must match HexagonBaseInfo.h ***
14 //===----------------------------------------------------------------------===//
15
16 class Type<bits<5> t> {
17   bits<5> Value = t;
18 }
19 def TypePSEUDO : Type<0>;
20 def TypeALU32  : Type<1>;
21 def TypeCR     : Type<2>;
22 def TypeJR     : Type<3>;
23 def TypeJ      : Type<4>;
24 def TypeLD     : Type<5>;
25 def TypeST     : Type<6>;
26 def TypeSYSTEM : Type<7>;
27 def TypeXTYPE  : Type<8>;
28 def TypeMARKER : Type<31>;
29
30 //===----------------------------------------------------------------------===//
31 //                         Intruction Class Declaration +
32 //===----------------------------------------------------------------------===//
33
34 class InstHexagon<dag outs, dag ins, string asmstr, list<dag> pattern,
35                   string cstr, InstrItinClass itin, Type type> : Instruction {
36   field bits<32> Inst;
37
38   let Namespace = "Hexagon";
39
40   dag OutOperandList = outs;
41   dag InOperandList = ins;
42   let AsmString = asmstr;
43   let Pattern = pattern;
44   let Constraints = cstr;
45   let Itinerary = itin;
46   let Size = 4;
47
48   // *** Must match HexagonBaseInfo.h ***
49   // Instruction type according to the ISA.
50   Type HexagonType = type;
51   let TSFlags{4-0} = HexagonType.Value;
52   // Solo instructions, i.e., those that cannot be in a packet with others.
53   bits<1> isHexagonSolo = 0;
54   let TSFlags{5} = isHexagonSolo;
55   // Predicated instructions.
56   bits<1> isPredicated = 0;
57   let TSFlags{6} = isPredicated;
58
59   // *** The code above must match HexagonBaseInfo.h ***
60 }
61
62 //===----------------------------------------------------------------------===//
63 //                         Intruction Classes Definitions +
64 //===----------------------------------------------------------------------===//
65
66 // LD Instruction Class in V2/V3/V4.
67 // Definition of the instruction class NOT CHANGED.
68 class LDInst<dag outs, dag ins, string asmstr, list<dag> pattern>
69   : InstHexagon<outs, ins, asmstr, pattern, "", LD, TypeLD> {
70   bits<5> rd;
71   bits<5> rs;
72   bits<13> imm13;
73 }
74
75 class LDInst2<dag outs, dag ins, string asmstr, list<dag> pattern>
76   : InstHexagon<outs, ins, asmstr, pattern, "", LD, TypeLD> {
77   bits<5> rd;
78   bits<5> rs;
79   bits<13> imm13;
80   let mayLoad = 1;
81 }
82
83 // LD Instruction Class in V2/V3/V4.
84 // Definition of the instruction class NOT CHANGED.
85 class LDInstPost<dag outs, dag ins, string asmstr, list<dag> pattern,
86                  string cstr>
87   : InstHexagon<outs, ins, asmstr, pattern, cstr, LD, TypeLD> {
88   bits<5> rd;
89   bits<5> rs;
90   bits<5> rt;
91   bits<13> imm13;
92 }
93
94 // ST Instruction Class in V2/V3 can take SLOT0 only.
95 // ST Instruction Class in V4    can take SLOT0 & SLOT1.
96 // Definition of the instruction class CHANGED from V2/V3 to V4.
97 class STInst<dag outs, dag ins, string asmstr, list<dag> pattern>
98   : InstHexagon<outs, ins, asmstr, pattern, "", ST, TypeST> {
99   bits<5> rd;
100   bits<5> rs;
101   bits<13> imm13;
102 }
103
104 class STInst2<dag outs, dag ins, string asmstr, list<dag> pattern>
105   : InstHexagon<outs, ins, asmstr, pattern, "", ST, TypeST> {
106   bits<5> rd;
107   bits<5> rs;
108   bits<13> imm13;
109   let mayStore = 1;
110 }
111
112 // SYSTEM Instruction Class in V4 can take SLOT0 only
113 // In V2/V3 we used ST for this but in v4 ST can take SLOT0 or SLOT1.
114 class SYSInst<dag outs, dag ins, string asmstr, list<dag> pattern>
115   : InstHexagon<outs, ins, asmstr, pattern, "", SYS, TypeSYSTEM> {
116   bits<5> rd;
117   bits<5> rs;
118   bits<13> imm13;
119 }
120
121 // ST Instruction Class in V2/V3 can take SLOT0 only.
122 // ST Instruction Class in V4    can take SLOT0 & SLOT1.
123 // Definition of the instruction class CHANGED from V2/V3 to V4.
124 class STInstPost<dag outs, dag ins, string asmstr, list<dag> pattern,
125                  string cstr>
126   : InstHexagon<outs, ins, asmstr, pattern, cstr, ST, TypeST> {
127   bits<5> rd;
128   bits<5> rs;
129   bits<5> rt;
130   bits<13> imm13;
131 }
132
133 // ALU32 Instruction Class in V2/V3/V4.
134 // Definition of the instruction class NOT CHANGED.
135 class ALU32Type<dag outs, dag ins, string asmstr, list<dag> pattern>
136    : InstHexagon<outs, ins, asmstr, pattern, "", ALU32, TypeALU32> {
137   bits<5>  rd;
138   bits<5>  rs;
139   bits<5>  rt;
140   bits<16> imm16;
141   bits<16> imm16_2;
142 }
143
144 // ALU64 Instruction Class in V2/V3.
145 // XTYPE Instruction Class in V4.
146 // Definition of the instruction class NOT CHANGED.
147 // Name of the Instruction Class changed from ALU64 to XTYPE from V2/V3 to V4.
148 class ALU64Type<dag outs, dag ins, string asmstr, list<dag> pattern>
149    : InstHexagon<outs, ins, asmstr, pattern, "", ALU64, TypeXTYPE> {
150   bits<5>  rd;
151   bits<5>  rs;
152   bits<5>  rt;
153   bits<16> imm16;
154   bits<16> imm16_2;
155 }
156
157 class ALU64_acc<dag outs, dag ins, string asmstr, list<dag> pattern,
158    string cstr>
159    : InstHexagon<outs, ins, asmstr, pattern, cstr, ALU64, TypeXTYPE> {
160   bits<5>  rd;
161   bits<5>  rs;
162   bits<5>  rt;
163   bits<16> imm16;
164   bits<16> imm16_2;
165 }
166
167 // M Instruction Class in V2/V3.
168 // XTYPE Instruction Class in V4.
169 // Definition of the instruction class NOT CHANGED.
170 // Name of the Instruction Class changed from M to XTYPE from V2/V3 to V4.
171 class MInst<dag outs, dag ins, string asmstr, list<dag> pattern>
172   : InstHexagon<outs, ins, asmstr, pattern, "", M, TypeXTYPE> {
173   bits<5> rd;
174   bits<5> rs;
175   bits<5> rt;
176 }
177
178 // M Instruction Class in V2/V3.
179 // XTYPE Instruction Class in V4.
180 // Definition of the instruction class NOT CHANGED.
181 // Name of the Instruction Class changed from M to XTYPE from V2/V3 to V4.
182 class MInst_acc<dag outs, dag ins, string asmstr, list<dag> pattern,
183     string cstr>
184     : InstHexagon<outs, ins, asmstr, pattern, cstr, M, TypeXTYPE> {
185   bits<5> rd;
186   bits<5> rs;
187   bits<5> rt;
188 }
189
190 // S Instruction Class in V2/V3.
191 // XTYPE Instruction Class in V4.
192 // Definition of the instruction class NOT CHANGED.
193 // Name of the Instruction Class changed from S to XTYPE from V2/V3 to V4.
194 class SInst<dag outs, dag ins, string asmstr, list<dag> pattern>
195   : InstHexagon<outs, ins, asmstr, pattern, "", S, TypeXTYPE> {
196   bits<5> rd;
197   bits<5> rs;
198   bits<5> rt;
199 }
200
201 // S Instruction Class in V2/V3.
202 // XTYPE Instruction Class in V4.
203 // Definition of the instruction class NOT CHANGED.
204 // Name of the Instruction Class changed from S to XTYPE from V2/V3 to V4.
205 class SInst_acc<dag outs, dag ins, string asmstr, list<dag> pattern,
206    string cstr>
207   : InstHexagon<outs, ins, asmstr, pattern, cstr, S, TypeXTYPE> {
208 //  : InstHexagon<outs, ins, asmstr, pattern, cstr,  S> {
209 //  : InstHexagon<outs, ins, asmstr, pattern, cstr, !if(V4T, XTYPE_V4, S)> {
210   bits<5> rd;
211   bits<5> rs;
212   bits<5> rt;
213 }
214
215 // J Instruction Class in V2/V3/V4.
216 // Definition of the instruction class NOT CHANGED.
217 class JType<dag outs, dag ins, string asmstr, list<dag> pattern>
218   : InstHexagon<outs, ins, asmstr, pattern, "", J, TypeJ> {
219   bits<16> imm16;
220 }
221
222 // JR Instruction Class in V2/V3/V4.
223 // Definition of the instruction class NOT CHANGED.
224 class JRType<dag outs, dag ins, string asmstr, list<dag> pattern>
225   : InstHexagon<outs, ins, asmstr, pattern, "", JR, TypeJR> {
226   bits<5>  rs;
227   bits<5>  pu; // Predicate register
228 }
229
230 // CR Instruction Class in V2/V3/V4.
231 // Definition of the instruction class NOT CHANGED.
232 class CRInst<dag outs, dag ins, string asmstr, list<dag> pattern>
233   : InstHexagon<outs, ins, asmstr, pattern, "", CR, TypeCR> {
234   bits<5> rs;
235   bits<10> imm10;
236 }
237
238 class Marker<dag outs, dag ins, string asmstr, list<dag> pattern>
239   : InstHexagon<outs, ins, asmstr, pattern, "", MARKER, TypeMARKER> {
240   let isCodeGenOnly = 1;
241   let isPseudo = 1;
242 }
243
244 class Pseudo<dag outs, dag ins, string asmstr, list<dag> pattern>
245   : InstHexagon<outs, ins, asmstr, pattern, "", PSEUDO, TypePSEUDO> {
246   let isCodeGenOnly = 1;
247   let isPseudo = 1;
248 }
249
250 //===----------------------------------------------------------------------===//
251 //                         Intruction Classes Definitions -
252 //===----------------------------------------------------------------------===//
253
254
255 //
256 // ALU32 patterns
257 //.
258 class ALU32_rr<dag outs, dag ins, string asmstr, list<dag> pattern>
259    : ALU32Type<outs, ins, asmstr, pattern> {
260 }
261
262 class ALU32_ir<dag outs, dag ins, string asmstr, list<dag> pattern>
263    : ALU32Type<outs, ins, asmstr, pattern> {
264    let rt{0-4} = 0;
265 }
266
267 class ALU32_ri<dag outs, dag ins, string asmstr, list<dag> pattern>
268    : ALU32Type<outs, ins, asmstr, pattern> {
269   let rt{0-4} = 0;
270 }
271
272 class ALU32_ii<dag outs, dag ins, string asmstr, list<dag> pattern>
273    : ALU32Type<outs, ins, asmstr, pattern> {
274   let rt{0-4} = 0;
275 }
276
277 //
278 // ALU64 patterns.
279 //
280 class ALU64_rr<dag outs, dag ins, string asmstr, list<dag> pattern>
281    : ALU64Type<outs, ins, asmstr, pattern> {
282 }
283
284 class ALU64_ri<dag outs, dag ins, string asmstr, list<dag> pattern>
285    : ALU64Type<outs, ins, asmstr, pattern> {
286   let rt{0-4} = 0;
287 }
288
289 // J Type Instructions.
290 class JInst<dag outs, dag ins, string asmstr, list<dag> pattern>
291   : JType<outs, ins, asmstr, pattern> {
292 }
293
294 // JR type Instructions.
295 class JRInst<dag outs, dag ins, string asmstr, list<dag> pattern>
296   : JRType<outs, ins, asmstr, pattern> {
297 }
298
299
300 // Post increment ST Instruction.
301 class STInstPI<dag outs, dag ins, string asmstr, list<dag> pattern,
302                string cstr>
303   : STInstPost<outs, ins, asmstr, pattern, cstr> {
304   let rt{0-4} = 0;
305 }
306
307 class STInst2PI<dag outs, dag ins, string asmstr, list<dag> pattern,
308                 string cstr>
309   : STInstPost<outs, ins, asmstr, pattern, cstr> {
310   let rt{0-4} = 0;
311   let mayStore = 1;
312 }
313
314 // Post increment LD Instruction.
315 class LDInstPI<dag outs, dag ins, string asmstr, list<dag> pattern,
316                string cstr>
317   : LDInstPost<outs, ins, asmstr, pattern, cstr> {
318   let rt{0-4} = 0;
319 }
320
321 class LDInst2PI<dag outs, dag ins, string asmstr, list<dag> pattern,
322                 string cstr>
323   : LDInstPost<outs, ins, asmstr, pattern, cstr> {
324   let rt{0-4} = 0;
325   let mayLoad = 1;
326 }
327
328 //===----------------------------------------------------------------------===//
329 // V4 Instruction Format Definitions +
330 //===----------------------------------------------------------------------===//
331
332 include "HexagonInstrFormatsV4.td"
333
334 //===----------------------------------------------------------------------===//
335 // V4 Instruction Format Definitions +
336 //===----------------------------------------------------------------------===//