blob: 761ff15d04fc5171f707872348f768a6c9580a41 [file] [log] [blame]
Jia Liub22310f2012-02-18 12:03:15 +00001//===-- SparcInstrFormats.td - Sparc Instruction Formats ---*- tablegen -*-===//
2//
Chris Lattner158e1f52006-02-05 05:50:24 +00003// The LLVM Compiler Infrastructure
4//
Chris Lattnerf3ebc3f2007-12-29 20:36:04 +00005// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
Jia Liub22310f2012-02-18 12:03:15 +00007//
Chris Lattner158e1f52006-02-05 05:50:24 +00008//===----------------------------------------------------------------------===//
9
Venkatraman Govindarajua54533ed2013-06-04 18:33:25 +000010class InstSP<dag outs, dag ins, string asmstr, list<dag> pattern>
11 : Instruction {
Chris Lattner158e1f52006-02-05 05:50:24 +000012 field bits<32> Inst;
13
14 let Namespace = "SP";
Venkatraman Govindarajudfcccc72014-01-06 08:08:58 +000015 let Size = 4;
Chris Lattner158e1f52006-02-05 05:50:24 +000016
17 bits<2> op;
18 let Inst{31-30} = op; // Top two bits are the 'op' field
Venkatraman Govindarajua54533ed2013-06-04 18:33:25 +000019
Evan Cheng94b5a802007-07-19 01:14:50 +000020 dag OutOperandList = outs;
21 dag InOperandList = ins;
Chris Lattner158e1f52006-02-05 05:50:24 +000022 let AsmString = asmstr;
23 let Pattern = pattern;
Venkatraman Govindarajudfcccc72014-01-06 08:08:58 +000024
25 let DecoderNamespace = "Sparc";
26 field bits<32> SoftFail = 0;
Chris Lattner158e1f52006-02-05 05:50:24 +000027}
28
29//===----------------------------------------------------------------------===//
30// Format #2 instruction classes in the Sparc
31//===----------------------------------------------------------------------===//
32
33// Format 2 instructions
Evan Cheng94b5a802007-07-19 01:14:50 +000034class F2<dag outs, dag ins, string asmstr, list<dag> pattern>
35 : InstSP<outs, ins, asmstr, pattern> {
Chris Lattner158e1f52006-02-05 05:50:24 +000036 bits<3> op2;
37 bits<22> imm22;
38 let op = 0; // op = 0
39 let Inst{24-22} = op2;
40 let Inst{21-0} = imm22;
41}
42
43// Specific F2 classes: SparcV8 manual, page 44
44//
Evan Cheng94b5a802007-07-19 01:14:50 +000045class F2_1<bits<3> op2Val, dag outs, dag ins, string asmstr, list<dag> pattern>
46 : F2<outs, ins, asmstr, pattern> {
Chris Lattner158e1f52006-02-05 05:50:24 +000047 bits<5> rd;
48
49 let op2 = op2Val;
50
51 let Inst{29-25} = rd;
52}
53
Venkatraman Govindaraju22868742014-03-01 20:08:48 +000054class F2_2<bits<3> op2Val, bit annul, dag outs, dag ins, string asmstr,
Evan Cheng94b5a802007-07-19 01:14:50 +000055 list<dag> pattern> : F2<outs, ins, asmstr, pattern> {
Chris Lattner158e1f52006-02-05 05:50:24 +000056 bits<4> cond;
Chris Lattner158e1f52006-02-05 05:50:24 +000057 let op2 = op2Val;
58
59 let Inst{29} = annul;
60 let Inst{28-25} = cond;
61}
62
Venkatraman Govindarajuc86e0f32014-03-01 22:03:07 +000063class F2_3<bits<3> op2Val, bit annul, bit pred,
64 dag outs, dag ins, string asmstr, list<dag> pattern>
65 : InstSP<outs, ins, asmstr, pattern> {
66 bits<2> cc;
Venkatraman Govindarajudfcccc72014-01-06 08:08:58 +000067 bits<4> cond;
Venkatraman Govindarajudfcccc72014-01-06 08:08:58 +000068 bits<19> imm19;
69
70 let op = 0; // op = 0
71
Venkatraman Govindarajudfcccc72014-01-06 08:08:58 +000072 let Inst{29} = annul;
73 let Inst{28-25} = cond;
74 let Inst{24-22} = op2Val;
Venkatraman Govindarajuc86e0f32014-03-01 22:03:07 +000075 let Inst{21-20} = cc;
Venkatraman Govindarajudfcccc72014-01-06 08:08:58 +000076 let Inst{19} = pred;
77 let Inst{18-0} = imm19;
78}
79
Chris Lattner158e1f52006-02-05 05:50:24 +000080//===----------------------------------------------------------------------===//
81// Format #3 instruction classes in the Sparc
82//===----------------------------------------------------------------------===//
83
Evan Cheng94b5a802007-07-19 01:14:50 +000084class F3<dag outs, dag ins, string asmstr, list<dag> pattern>
85 : InstSP<outs, ins, asmstr, pattern> {
Chris Lattner158e1f52006-02-05 05:50:24 +000086 bits<5> rd;
87 bits<6> op3;
88 bits<5> rs1;
89 let op{1} = 1; // Op = 2 or 3
90 let Inst{29-25} = rd;
91 let Inst{24-19} = op3;
92 let Inst{18-14} = rs1;
93}
94
95// Specific F3 classes: SparcV8 manual, page 44
96//
Venkatraman Govindarajuced92262014-02-07 07:34:49 +000097class F3_1_asi<bits<2> opVal, bits<6> op3val, bits<8> asi, dag outs, dag ins,
Evan Cheng94b5a802007-07-19 01:14:50 +000098 string asmstr, list<dag> pattern> : F3<outs, ins, asmstr, pattern> {
Chris Lattner158e1f52006-02-05 05:50:24 +000099 bits<5> rs2;
100
101 let op = opVal;
102 let op3 = op3val;
103
104 let Inst{13} = 0; // i field = 0
105 let Inst{12-5} = asi; // address space identifier
106 let Inst{4-0} = rs2;
107}
108
Venkatraman Govindarajuced92262014-02-07 07:34:49 +0000109class F3_1<bits<2> opVal, bits<6> op3val, dag outs, dag ins, string asmstr,
110 list<dag> pattern> : F3_1_asi<opVal, op3val, 0, outs, ins,
111 asmstr, pattern>;
112
Venkatraman Govindarajua54533ed2013-06-04 18:33:25 +0000113class F3_2<bits<2> opVal, bits<6> op3val, dag outs, dag ins,
Evan Cheng94b5a802007-07-19 01:14:50 +0000114 string asmstr, list<dag> pattern> : F3<outs, ins, asmstr, pattern> {
Chris Lattner158e1f52006-02-05 05:50:24 +0000115 bits<13> simm13;
116
117 let op = opVal;
118 let op3 = op3val;
119
120 let Inst{13} = 1; // i field = 1
121 let Inst{12-0} = simm13;
122}
123
124// floating-point
Evan Cheng94b5a802007-07-19 01:14:50 +0000125class F3_3<bits<2> opVal, bits<6> op3val, bits<9> opfval, dag outs, dag ins,
126 string asmstr, list<dag> pattern> : F3<outs, ins, asmstr, pattern> {
Chris Lattner158e1f52006-02-05 05:50:24 +0000127 bits<5> rs2;
128
129 let op = opVal;
130 let op3 = op3val;
131
132 let Inst{13-5} = opfval; // fp opcode
133 let Inst{4-0} = rs2;
134}
Chris Lattnerbad9d2e2006-09-01 22:28:02 +0000135
Venkatraman Govindaraju51270832013-09-22 09:54:42 +0000136// floating-point unary operations.
137class F3_3u<bits<2> opVal, bits<6> op3val, bits<9> opfval, dag outs, dag ins,
138 string asmstr, list<dag> pattern> : F3<outs, ins, asmstr, pattern> {
139 bits<5> rs2;
140
141 let op = opVal;
142 let op3 = op3val;
143 let rs1 = 0;
144
145 let Inst{13-5} = opfval; // fp opcode
146 let Inst{4-0} = rs2;
147}
148
149// floating-point compares.
150class F3_3c<bits<2> opVal, bits<6> op3val, bits<9> opfval, dag outs, dag ins,
151 string asmstr, list<dag> pattern> : F3<outs, ins, asmstr, pattern> {
152 bits<5> rs2;
153
154 let op = opVal;
155 let op3 = op3val;
156 let rd = 0;
157
158 let Inst{13-5} = opfval; // fp opcode
159 let Inst{4-0} = rs2;
160}
161
Jakob Stoklund Olesenc1d1a482013-04-02 04:09:12 +0000162// Shift by register rs2.
163class F3_Sr<bits<2> opVal, bits<6> op3val, bit xVal, dag outs, dag ins,
164 string asmstr, list<dag> pattern> : F3<outs, ins, asmstr, pattern> {
165 bit x = xVal; // 1 for 64-bit shifts.
166 bits<5> rs2;
Chris Lattnerbad9d2e2006-09-01 22:28:02 +0000167
Jakob Stoklund Olesenc1d1a482013-04-02 04:09:12 +0000168 let op = opVal;
169 let op3 = op3val;
170
171 let Inst{13} = 0; // i field = 0
172 let Inst{12} = x; // extended registers.
173 let Inst{4-0} = rs2;
174}
175
176// Shift by immediate.
177class F3_Si<bits<2> opVal, bits<6> op3val, bit xVal, dag outs, dag ins,
178 string asmstr, list<dag> pattern> : F3<outs, ins, asmstr, pattern> {
179 bit x = xVal; // 1 for 64-bit shifts.
180 bits<6> shcnt; // shcnt32 / shcnt64.
181
182 let op = opVal;
183 let op3 = op3val;
184
185 let Inst{13} = 1; // i field = 1
186 let Inst{12} = x; // extended registers.
187 let Inst{5-0} = shcnt;
188}
189
190// Define rr and ri shift instructions with patterns.
191multiclass F3_S<string OpcStr, bits<6> Op3Val, bit XVal, SDNode OpNode,
192 ValueType VT, RegisterClass RC> {
Venkatraman Govindarajub7c69652014-01-08 07:47:57 +0000193 def rr : F3_Sr<2, Op3Val, XVal, (outs RC:$rd), (ins RC:$rs1, IntRegs:$rs2),
194 !strconcat(OpcStr, " $rs1, $rs2, $rd"),
195 [(set VT:$rd, (OpNode VT:$rs1, i32:$rs2))]>;
196 def ri : F3_Si<2, Op3Val, XVal, (outs RC:$rd), (ins RC:$rs1, i32imm:$shcnt),
197 !strconcat(OpcStr, " $rs1, $shcnt, $rd"),
198 [(set VT:$rd, (OpNode VT:$rs1, (i32 imm:$shcnt)))]>;
Jakob Stoklund Olesenc1d1a482013-04-02 04:09:12 +0000199}
Venkatraman Govindaraju709d1542013-09-22 09:18:26 +0000200
201class F4<bits<6> op3, dag outs, dag ins, string asmstr, list<dag> pattern>
202 : InstSP<outs, ins, asmstr, pattern> {
203 bits<5> rd;
204
205 let op = 2;
206 let Inst{29-25} = rd;
207 let Inst{24-19} = op3;
208}
209
210
211class F4_1<bits<6> op3, dag outs, dag ins,
212 string asmstr, list<dag> pattern>
213 : F4<op3, outs, ins, asmstr, pattern> {
214
215 bits<3> cc;
216 bits<4> cond;
217 bits<5> rs2;
218
219 let Inst{4-0} = rs2;
220 let Inst{11} = cc{0};
221 let Inst{12} = cc{1};
222 let Inst{13} = 0;
223 let Inst{17-14} = cond;
224 let Inst{18} = cc{2};
225
226}
227
228class F4_2<bits<6> op3, dag outs, dag ins,
229 string asmstr, list<dag> pattern>
230 : F4<op3, outs, ins, asmstr, pattern> {
231 bits<3> cc;
232 bits<4> cond;
233 bits<11> simm11;
234
235 let Inst{10-0} = simm11;
236 let Inst{11} = cc{0};
237 let Inst{12} = cc{1};
238 let Inst{13} = 1;
239 let Inst{17-14} = cond;
240 let Inst{18} = cc{2};
241}
242
243class F4_3<bits<6> op3, bits<6> opf_low, dag outs, dag ins,
244 string asmstr, list<dag> pattern>
245 : F4<op3, outs, ins, asmstr, pattern> {
246 bits<4> cond;
247 bits<3> opf_cc;
248 bits<5> rs2;
249
250 let Inst{18} = 0;
251 let Inst{17-14} = cond;
252 let Inst{13-11} = opf_cc;
253 let Inst{10-5} = opf_low;
254 let Inst{4-0} = rs2;
255}