1 // RUN
: not llvm-mc
-triple
=amdgcn
-mcpu
=fiji
-show-encoding
%s | FileCheck
%s
--check-prefix
=VI
2 // RUN
: not llvm-mc
-triple
=amdgcn
-mcpu
=fiji
%s
2>&1 | FileCheck
%s
--check-prefix
=NOVI
--implicit-check-
not=error
:
4 //===----------------------------------------------------------------------===//
5 // Floating-point expressions are
not supported
6 //===----------------------------------------------------------------------===//
8 s_sub_u32 s0
, s0
, -1.0 + 10000000000
9 // NOVI
: :[[@LINE-
1]]:{{[0-9]+}}: error
: invalid operand for instruction
12 s_sub_u32 s0
, s0
, 1.0 + t
13 // NOVI
: :[[@LINE-
1]]:{{[0-9]+}}: error
: invalid operand for instruction
15 v_ceil_f32 v1
, 1.0 + 1.0
16 // NOVI
: :[[@LINE-
1]]:{{[0-9]+}}: error
: invalid operand for instruction
18 v_ceil_f32 v1
, -1.0 + 1.0
19 // NOVI
: :[[@LINE-
1]]:{{[0-9]+}}: error
: invalid operand for instruction
21 //===----------------------------------------------------------------------===//
22 // Constant expressions may
be used with SP3
'abs' modifiers |
...|
23 // These expressions must
be primary expressions to avoid incorrect
24 // interpretation of closing
"|".
25 //===----------------------------------------------------------------------===//
28 fm1
=0xBF800000 // -1.0f
32 // VI
: v_ceil_f32_e32 v1
, 1 ; encoding
: [0x81,0x3a,0x02,0x7e]
34 v_ceil_f32 v1
, |
(i1+
1)|
35 // VI
: v_ceil_f32_e32 v1
, 2 ; encoding
: [0x82,0x3a,0x02,0x7e]
37 v_ceil_f32 v1
, |
-(i1+
1)|
38 // VI
: v_ceil_f32_e32 v1
, 0x7ffffffe ; encoding
: [0xff,0x3a,0x02,0x7e,0xfe,0xff,0xff,0x7f]
41 // VI
: v_ceil_f32_e32 v1
, 1.0 ; encoding
: [0xf2,0x3a,0x02,0x7e]
43 v_mad_f16 v5
, v1
, v2
, |i1|
44 // VI
: v_mad_f16 v5
, v1
, v2
, |
1| ; encoding
: [0x05,0x04,0xea,0xd1,0x01,0x05,0x06,0x02]
46 v_mad_f16 v5
, v1
, v2
, |
(i1+
1)|
47 // VI
: v_mad_f16 v5
, v1
, v2
, |
2| ; encoding
: [0x05,0x04,0xea,0xd1,0x01,0x05,0x0a,0x02]
49 v_mad_f16 v5
, v1
, v2
, |hm1|
50 // VI
: v_mad_f16 v5
, v1
, v2
, |
-1.0| ; encoding
: [0x05,0x04,0xea,0xd1,0x01,0x05,0xce,0x03]
52 // Only primary expressions are allowed
55 // NOVI
: :[[@LINE-
1]]:{{[0-9]+}}: error
: expected vertical bar
58 // NOVI
: :[[@LINE-
1]]:{{[0-9]+}}: error
: expected vertical bar
60 //===----------------------------------------------------------------------===//
61 // Constant expressions may
be used with
'abs' and 'neg' modifiers.
62 //===----------------------------------------------------------------------===//
64 v_ceil_f32 v1
, abs(i1
)
65 // VI
: v_ceil_f32_e32 v1
, 1 ; encoding
: [0x81,0x3a,0x02,0x7e]
67 v_ceil_f32 v1
, abs(i1+
1)
68 // VI
: v_ceil_f32_e32 v1
, 2 ; encoding
: [0x82,0x3a,0x02,0x7e]
70 v_ceil_f32 v1
, abs(-(i1+
1))
71 // VI
: v_ceil_f32_e32 v1
, 0x7ffffffe ; encoding
: [0xff,0x3a,0x02,0x7e,0xfe,0xff,0xff,0x7f]
73 v_ceil_f32 v1
, abs(fm1
)
74 // VI
: v_ceil_f32_e32 v1
, 1.0 ; encoding
: [0xf2,0x3a,0x02,0x7e]
76 v_mad_f16 v5
, v1
, v2
, abs(i1
)
77 // VI
: v_mad_f16 v5
, v1
, v2
, |
1| ; encoding
: [0x05,0x04,0xea,0xd1,0x01,0x05,0x06,0x02]
79 v_mad_f16 v5
, v1
, v2
, abs(i1+
1)
80 // VI
: v_mad_f16 v5
, v1
, v2
, |
2| ; encoding
: [0x05,0x04,0xea,0xd1,0x01,0x05,0x0a,0x02]
82 v_mad_f16 v5
, v1
, v2
, abs(hm1
)
83 // VI
: v_mad_f16 v5
, v1
, v2
, |
-1.0| ; encoding
: [0x05,0x04,0xea,0xd1,0x01,0x05,0xce,0x03]
85 v_ceil_f32 v1
, neg(i1+
1)
86 // VI
: v_ceil_f32_e32 v1
, 0x80000002 ; encoding
: [0xff,0x3a,0x02,0x7e,0x02,0x00,0x00,0x80]
88 v_ceil_f32 v1
, neg(1+i1
)
89 // VI
: v_ceil_f32_e32 v1
, 0x80000002 ; encoding
: [0xff,0x3a,0x02,0x7e,0x02,0x00,0x00,0x80]
91 v_ceil_f32 v1
, neg(-i1+
3)
92 // VI
: v_ceil_f32_e32 v1
, 0x80000002 ; encoding
: [0xff,0x3a,0x02,0x7e,0x02,0x00,0x00,0x80]
94 v_ceil_f32 v1
, neg(-(i1+
1))
95 // VI
: v_ceil_f32_e32 v1
, 0x7ffffffe ; encoding
: [0xff,0x3a,0x02,0x7e,0xfe,0xff,0xff,0x7f]
97 v_ceil_f32 v1
, neg(fm1
)
98 // VI
: v_ceil_f32_e32 v1
, 1.0 ; encoding
: [0xf2,0x3a,0x02,0x7e]
100 v_mad_f16 v5
, v1
, v2
, neg(hm1
)
101 // VI
: v_mad_f16 v5
, v1
, v2
, neg(-1.0) ; encoding
: [0x05,0x00,0xea,0xd1,0x01,0x05,0xce,0x83]
103 //===----------------------------------------------------------------------===//
104 // Constant expressions may
be used where inline constants are accepted.
105 //===----------------------------------------------------------------------===//
107 v_ceil_f64 v
[0:1], i1+
1
108 // VI
: v_ceil_f64_e32 v
[0:1], 2 ; encoding
: [0x82,0x30,0x00,0x7e]
110 v_and_b32 v0
, i1+
1, v0
111 // VI
: v_and_b32_e32 v0
, 2, v0 ; encoding
: [0x82,0x00,0x00,0x26]
113 v_and_b32 v0
, 1+i1
, v0
114 // VI
: v_and_b32_e32 v0
, 2, v0 ; encoding
: [0x82,0x00,0x00,0x26]
116 v_and_b32 v0
, -i1+
3, v0
117 // VI
: v_and_b32_e32 v0
, 2, v0 ; encoding
: [0x82,0x00,0x00,0x26]
119 v_and_b32 v0
, -(i1+
1), v0
120 // VI
: v_and_b32_e32 v0
, -2, v0 ; encoding
: [0xc2,0x00,0x00,0x26]
122 v_add_u16 v0
, (i1+
4)/2, v1
123 // VI
: v_add_u16_e32 v0
, 2, v1 ; encoding
: [0x82,0x02,0x00,0x4c]
125 buffer_atomic_inc v1
, off
, s
[8:11], i1+
1 glc
126 // VI
: buffer_atomic_inc v1
, off
, s
[8:11], 2 glc ; encoding
: [0x00,0x40,0x2c,0xe1,0x00,0x01,0x02,0x82]
129 // VI
: s_addk_i32 s2
, 0x2 ; encoding
: [0x02,0x00,0x02,0xb7]
131 s_cmpk_eq_i32 s2
, i1+
1
132 // VI
: s_cmpk_eq_i32 s2
, 0x2 ; encoding
: [0x02,0x00,0x02,0xb1]
134 s_setreg_imm32_b32
0x6, i1+
1
135 // VI
: s_setreg_imm32_b32 hwreg
(HW_REG_LDS_ALLOC
, 0, 1), 2 ; encoding
: [0x06,0x00,0x00,0xba,0x02,0x00,0x00,0x00]
137 v_madak_f16 v1
, v2
, v3
, i1+
1
138 // VI
: v_madak_f16 v1
, v2
, v3
, 0x2 ; encoding
: [0x02,0x07,0x02,0x4a,0x02,0x00,0x00,0x00]
140 s_set_gpr_idx_on s0
, i1+
1
141 // VI
: s_set_gpr_idx_on s0
, gpr_idx
(SRC1
) ; encoding
: [0x00,0x02,0x11,0xbf]
143 s_atc_probe i1-
1, s
[4:5], i1+
1
144 // VI
: s_atc_probe
0, s
[4:5], 0x2 ; encoding
: [0x02,0x00,0x9a,0xc0,0x02,0x00,0x00,0x00]
146 s_load_dword s1
, s
[2:3], i1+
1 glc
147 // VI
: s_load_dword s1
, s
[2:3], 0x2 glc ; encoding
: [0x41,0x00,0x03,0xc0,0x02,0x00,0x00,0x00]
149 //===----------------------------------------------------------------------===//
150 // Constant expressions may
be used where literals are accepted.
151 //===----------------------------------------------------------------------===//
153 v_ceil_f64 v
[0:1], i1+
100
154 // VI
: v_ceil_f64_e32 v
[0:1], 0x65 ; encoding
: [0xff,0x30,0x00,0x7e,0x65,0x00,0x00,0x00]
156 v_and_b32 v0
, i1+
100, v0
157 // VI
: v_and_b32_e32 v0
, 0x65, v0 ; encoding
: [0xff,0x00,0x00,0x26,0x65,0x00,0x00,0x00]
159 v_and_b32 v0
, -i1+
102, v0
160 // VI
: v_and_b32_e32 v0
, 0x65, v0 ; encoding
: [0xff,0x00,0x00,0x26,0x65,0x00,0x00,0x00]
162 v_add_u16 v0
, (i1+
100)*2, v0
163 // VI
: v_add_u16_e32 v0
, 0xca, v0 ; encoding
: [0xff,0x00,0x00,0x4c,0xca,0x00,0x00,0x00]
165 //===----------------------------------------------------------------------===//
166 // Constant expressions may
be used with Name
:Value modifiers.
167 //===----------------------------------------------------------------------===//
169 buffer_load_dword v1
, off
, s
[4:7], s1 offset
:-1+1
170 // VI
: buffer_load_dword v1
, off
, s
[4:7], s1 ; encoding
: [0x00,0x00,0x50,0xe0,0x00,0x01,0x01,0x01]
172 buffer_load_dword v1
, off
, s
[4:7], s1 offset
:i1+
4
173 // VI
: buffer_load_dword v1
, off
, s
[4:7], s1 offset
:5 ; encoding
: [0x05,0x00,0x50,0xe0,0x00,0x01,0x01,0x01]
175 buffer_load_dword v1
, off
, s
[4:7], s1 offset
:4+i1
176 // VI
: buffer_load_dword v1
, off
, s
[4:7], s1 offset
:5 ; encoding
: [0x05,0x00,0x50,0xe0,0x00,0x01,0x01,0x01]
178 buffer_load_dword v1
, off
, s
[4:7], s1 offset
:-i1+
4
179 // VI
: buffer_load_dword v1
, off
, s
[4:7], s1 offset
:3 ; encoding
: [0x03,0x00,0x50,0xe0,0x00,0x01,0x01,0x01]
181 //===----------------------------------------------------------------------===//
182 // Relocatable expressions can
be used with
32-bit instructions.
183 //===----------------------------------------------------------------------===//
186 // VI
: v_ceil_f32_e32 v1
, -u ; encoding
: [0xff,0x3a,0x02,0x7e,A,A,A,A]
187 // VI-NEXT
: ; fixup
A - offset
: 4, value
: -u
, kind
: FK_PCRel_4
189 v_and_b32 v0
, u+
1, v0
190 // VI
: v_and_b32_e32 v0
, u+
1, v0 ; encoding
: [0xff,0x00,0x00,0x26,A,A,A,A]
191 // VI-NEXT
: ; fixup
A - offset
: 4, value
: u+
1, kind
: FK_PCRel_4
193 //===----------------------------------------------------------------------===//
194 // Relocatable expressions cannot
be used as
16/20/21/64-bit operands.
195 //===----------------------------------------------------------------------===//
198 // NOVI
: :[[@LINE-
1]]:{{[0-9]+}}: error
: invalid operand for instruction
201 // NOVI
: :[[@LINE-
1]]:{{[0-9]+}}: error
: invalid operand for instruction
204 // NOVI
: :[[@LINE-
1]]:{{[0-9]+}}: error
: invalid operand for instruction
206 s_load_dword s1
, s
[2:3], u glc
207 // NOVI
: :[[@LINE-
1]]:{{[0-9]+}}: error
: invalid operand for instruction
209 //===----------------------------------------------------------------------===//
210 // Relocatable expressions cannot
be used with VOP3 modifiers.
211 //===----------------------------------------------------------------------===//
214 // NOVI
: :[[@LINE-
1]]:{{[0-9]+}}: error
: expected an absolute expression
216 v_ceil_f32 v1
, neg(u
)
217 // NOVI
: :[[@LINE-
1]]:{{[0-9]+}}: error
: expected an absolute expression
219 v_ceil_f32 v1
, abs(u
)
220 // NOVI
: :[[@LINE-
1]]:{{[0-9]+}}: error
: expected an absolute expression
222 //===----------------------------------------------------------------------===//
223 // Misc tests with symbols.
224 //===----------------------------------------------------------------------===//
229 // Parse
a global expression
231 // VI
: s_mov_b32 s0
, global ; encoding
: [0xff,0x00,0x80,0xbe,A,A,A,A]
232 // VI-NEXT
: ; fixup
A - offset
: 4, value
: global
, kind
: FK_PCRel_4
234 // Use
a token with the same name as
a global
236 // VI
: ds_gws_init v2 gds ; encoding
: [0x00,0x00,0x33,0xd9,0x02,0x00,0x00,0x00]
238 // Use
a global with the same name as
a token
240 // VI
: s_mov_b32 s0
, gds ; encoding
: [0xff,0x00,0x80,0xbe,A,A,A,A]
241 // VI-NEXT
: ; fixup
A - offset
: 4, value
: gds
, kind
: FK_PCRel_4
243 // Use
a binary expression
245 // VI
: s_mov_b32 s0
, gds+
4 ; encoding
: [0xff,0x00,0x80,0xbe,A,A,A,A]
246 // VI-NEXT
: ; fixup
A - offset
: 4, value
: gds+
4, kind
: FK_PCRel_4
248 // Consecutive instructions with no blank line in between to make sure we
249 // don
't call Lex() too many times.
250 s_add_u32 s0, s0, global+4
252 // VI: s_add_u32 s0, s0, global+4
253 // VI: s_addc_u32 s1, s1, 0
255 // Use a computed expression that results in an inline immediate.
258 // VI: s_mov_b32 s0, 6 ; encoding: [0x86,0x00,0x80,0xbe]
260 // Use a computed expression that results in a non-inline immediate.
263 // VI: s_mov_b32 s0, 0x202 ; encoding: [0xff,0x00,0x80,0xbe,0x02,0x02,0x00,0x00]
265 v_mul_f32 v0, foo+2, v2
266 // VI: v_mul_f32_e32 v0, 0x202, v2 ; encoding: [0xff,0x04,0x00,0x0a,0x02,0x02,0x00,0x00]
271 s_sub_u32 vcc_lo, vcc_lo, (BB2+4)-BB1
272 // VI: s_sub_u32 vcc_lo, vcc_lo, (BB2+4)-BB1 ; encoding: [0x6a,0xff,0xea,0x80,A,A,A,A]
273 // VI-NEXT: ; fixup A - offset: 4, value: (BB2+4)-BB1, kind: FK_Data_4
274 s_add_u32 vcc_lo, vcc_lo, (BB2-BB1)&4294967295
275 // VI: s_add_u32 vcc_lo, vcc_lo, (BB2-BB1)&4294967295 ; encoding: [0x6a,0xff,0x6a,0x80,A,A,A,A]
276 // VI-NEXT: ; fixup A - offset: 4, value: (BB2-BB1)&4294967295, kind: FK_Data_4
277 s_addc_u32 vcc_hi, vcc_hi, (BB2-BB1)>>32
278 // VI: s_addc_u32 vcc_hi, vcc_hi, (BB2-BB1)>>32 ; encoding: [0x6b,0xff,0x6b,0x82,A,A,A,A]
279 // VI-NEXT: ; fixup A - offset: 4, value: (BB2-BB1)>>32, kind: FK_Data_4
283 // VI: s_sub_u32 s0, s0, -1 ; encoding: [0x00,0xc1,0x80,0x80]
287 // VI: s_sub_u32 s0, s0, 1 ; encoding: [0x00,0x81,0x80,0x80]
289 s_sub_u32 s0, s0, -2+1
290 // VI: s_sub_u32 s0, s0, -1 ; encoding: [0x00,0xc1,0x80,0x80]
293 s_sub_u32 s0, s0, -2+t
294 // VI: s_sub_u32 s0, s0, -1 ; encoding: [0x00,0xc1,0x80,0x80]
296 //===----------------------------------------------------------------------===//
297 // Symbols may look like registers.
298 // They should be allowed in expressions if there is no ambiguity.
299 //===----------------------------------------------------------------------===//
303 // VI: v_sin_f32_e32 v0, -1 ; encoding: [0xc1,0x52,0x00,0x7e]
307 // VI: s_not_b32 s0, -1 ; encoding: [0xc1,0x04,0x80,0xbe]
311 // VI: s_not_b32 s0, -1 ; encoding: [0xc1,0x04,0x80,0xbe]
313 //===----------------------------------------------------------------------===//
314 // Registers have priority over symbols.
315 //===----------------------------------------------------------------------===//
319 // VI: v_sin_f32_e64 v0, -v0 ; encoding: [0x00,0x00,0x69,0xd1,0x00,0x01,0x00,0x20]
323 // VI: v_sin_f32_e64 v0, -s0 ; encoding: [0x00,0x00,0x69,0xd1,0x00,0x00,0x00,0x20]
326 v_sin_f32 v0, -[ttmp0]
327 // VI: v_sin_f32_e64 v0, -ttmp0 ; encoding: [0x00,0x00,0x69,0xd1,0x70,0x00,0x00,0x20]
329 //===----------------------------------------------------------------------===//
330 // Incorrect register names and unsupported registers should not be interpreted
331 // as expressions, rather they should trigger errors.
332 //===----------------------------------------------------------------------===//
336 // NOVI: :[[@LINE-1]]:{{[0-9]+}}: error: register index is out of range
339 v_sin_f32 v0, xnack_mask_lo
340 // NOVI: :[[@LINE-1]]:{{[0-9]+}}: error: register not available on this GPU