[DAGCombiner] Add target hook function to decide folding (mul (add x, c1), c2)
[llvm-project.git] / llvm / test / MC / ARM / mve-reductions.s
blob8906617aa57497e2fd4ea55663f8facf9a8620cf
1 # RUN: not llvm-mc -triple=thumbv8.1m.main-none-eabi -mattr=+mve -show-encoding < %s 2>%t \
2 # RUN: | FileCheck --check-prefix=CHECK %s
3 # RUN: FileCheck --check-prefix=ERROR < %t %s
4 # RUN: not llvm-mc -triple=thumbv8.1m.main-none-eabi -mattr=+mve.fp,+fp64 -show-encoding < %s 2>%t \
5 # RUN: | FileCheck --check-prefix=CHECK %s
6 # RUN: FileCheck --check-prefix=ERROR < %t %s
8 # CHECK: vabav.s8 r0, q1, q3 @ encoding: [0x82,0xee,0x07,0x0f]
9 vabav.s8 r0, q1, q3
11 # CHECK: vabav.s16 r0, q1, q3 @ encoding: [0x92,0xee,0x07,0x0f]
12 vabav.s16 r0, q1, q3
14 # CHECK: vabav.s32 r0, q1, q3 @ encoding: [0xa2,0xee,0x07,0x0f]
15 vabav.s32 r0, q1, q3
17 # CHECK: vabav.u8 r0, q1, q3 @ encoding: [0x82,0xfe,0x07,0x0f]
18 vabav.u8 r0, q1, q3
20 # CHECK: vabav.u16 r0, q1, q3 @ encoding: [0x92,0xfe,0x07,0x0f]
21 vabav.u16 r0, q1, q3
23 # CHECK: vabav.u32 r0, q1, q3 @ encoding: [0xa2,0xfe,0x07,0x0f]
24 vabav.u32 r0, q1, q3
26 # CHECK: vaddv.s16 lr, q0 @ encoding: [0xf5,0xee,0x00,0xef]
27 vaddv.s16 lr, q0
29 # ERROR: [[@LINE+1]]:11: {{error|note}}: operand must be an even-numbered register
30 vaddv.s16 r1, q0
32 # CHECK: vpte.i8 eq, q0, q0
33 # CHECK: vaddvt.s16 r0, q6 @ encoding: [0xf5,0xee,0x0c,0x0f]
34 # CHECK: vaddve.s16 r0, q6 @ encoding: [0xf5,0xee,0x0c,0x0f]
35 vpte.i8 eq, q0, q0
36 vaddvt.s16 r0, q6
37 vaddve.s16 r0, q6
39 # CHECK: vaddva.s16 lr, q0 @ encoding: [0xf5,0xee,0x20,0xef]
40 vaddva.s16 lr, q0
42 # CHECK: vpte.i8 eq, q0, q0
43 # CHECK: vaddvat.s16 lr, q0 @ encoding: [0xf5,0xee,0x20,0xef]
44 # CHECK: vaddvae.s16 lr, q0 @ encoding: [0xf5,0xee,0x20,0xef]
45 vpte.i8 eq, q0, q0
46 vaddvat.s16 lr, q0
47 vaddvae.s16 lr, q0
49 # CHECK: vaddlv.s32 r0, r9, q2 @ encoding: [0xc9,0xee,0x04,0x0f]
50 vaddlv.s32 r0, r9, q2
52 # ERROR: [[@LINE+1]]:{{[0-9]+}}: {{error|note}}: operand must be an odd-numbered register in range [r1,r11]
53 vaddlv.s32 r0, r2, q2
55 # ERROR: [[@LINE+1]]:{{[0-9]+}}: {{error|note}}: operand must be an even-numbered register
56 vaddlv.s32 r1, r3, q2
58 # CHECK: vaddlv.u32 r0, r1, q1 @ encoding: [0x89,0xfe,0x02,0x0f]
59 vaddlv.u32 r0, r1, q1
61 # CHECK: vminv.s8 lr, q0 @ encoding: [0xe2,0xee,0x80,0xef]
62 vminv.s8 lr, q0
64 # CHECK: vminv.s16 lr, q0 @ encoding: [0xe6,0xee,0x80,0xef]
65 vminv.s16 lr, q0
67 # CHECK: vminv.s32 lr, q2 @ encoding: [0xea,0xee,0x84,0xef]
68 vminv.s32 lr, q2
70 # CHECK: vminv.u8 r0, q0 @ encoding: [0xe2,0xfe,0x80,0x0f]
71 vminv.u8 r0, q0
73 # CHECK: vminv.u32 r10, q3 @ encoding: [0xea,0xfe,0x86,0xaf]
74 vminv.u32 r10, q3
76 # CHECK: vminav.s16 r0, q0 @ encoding: [0xe4,0xee,0x80,0x0f]
77 vminav.s16 r0, q0
79 # CHECK: vminav.s8 r0, q1 @ encoding: [0xe0,0xee,0x82,0x0f]
80 vminav.s8 r0, q1
82 # CHECK: vminav.s32 lr, q1 @ encoding: [0xe8,0xee,0x82,0xef]
83 vminav.s32 lr, q1
85 # CHECK: vmaxv.s8 lr, q4 @ encoding: [0xe2,0xee,0x08,0xef]
86 vmaxv.s8 lr, q4
88 # CHECK: vmaxv.s16 lr, q0 @ encoding: [0xe6,0xee,0x00,0xef]
89 vmaxv.s16 lr, q0
91 # CHECK: vmaxv.s32 r1, q1 @ encoding: [0xea,0xee,0x02,0x1f]
92 vmaxv.s32 r1, q1
94 # CHECK: vmaxv.u8 r0, q4 @ encoding: [0xe2,0xfe,0x08,0x0f]
95 vmaxv.u8 r0, q4
97 # CHECK: vmaxv.u16 r0, q1 @ encoding: [0xe6,0xfe,0x02,0x0f]
98 vmaxv.u16 r0, q1
100 # CHECK: vmaxv.u32 r1, q0 @ encoding: [0xea,0xfe,0x00,0x1f]
101 vmaxv.u32 r1, q0
103 # CHECK: vmaxav.s8 lr, q6 @ encoding: [0xe0,0xee,0x0c,0xef]
104 vmaxav.s8 lr, q6
106 # CHECK: vmaxav.s16 r0, q6 @ encoding: [0xe4,0xee,0x0c,0x0f]
107 vmaxav.s16 r0, q6
109 # CHECK: vmaxav.s32 r10, q7 @ encoding: [0xe8,0xee,0x0e,0xaf]
110 vmaxav.s32 r10, q7
112 # CHECK: vmlav.s16 lr, q0, q7 @ encoding: [0xf0,0xee,0x0e,0xee]
113 vmladav.s16 lr, q0, q7
115 # CHECK: vmlav.s32 lr, q0, q4 @ encoding: [0xf1,0xee,0x08,0xee]
116 vmladav.s32 lr, q0, q4
118 # CHECK: vmlav.u16 lr, q0, q7 @ encoding: [0xf0,0xfe,0x0e,0xee]
119 vmladav.u16 lr, q0, q7
121 # CHECK: vmlav.u32 lr, q0, q0 @ encoding: [0xf1,0xfe,0x00,0xee]
122 vmladav.u32 lr, q0, q0
124 # CHECK: vmlava.s16 lr, q0, q4 @ encoding: [0xf0,0xee,0x28,0xee]
125 vmladava.s16 lr, q0, q4
127 # CHECK: vmladavx.s16 r0, q0, q7 @ encoding: [0xf0,0xee,0x0e,0x1e]
128 vmladavx.s16 r0, q0, q7
130 # CHECK: vmladavax.s16 lr, q0, q7 @ encoding: [0xf0,0xee,0x2e,0xfe]
131 vmladavax.s16 lr, q0, q7
133 # ERROR: [[@LINE+1]]:{{[0-9]+}}: {{error|note}}: invalid operand for instruction
134 vmladavax.u16 r0, q4, q5
136 # ERROR: [[@LINE+1]]:{{[0-9]+}}: {{error|note}}: invalid operand for instruction
137 vmladavx.u16 r0, q4, q5
139 # ERROR: [[@LINE+1]]:{{[0-9]+}}: {{error|note}}: invalid operand for instruction
140 vmladavax.u32 r0, q4, q5
142 # ERROR: [[@LINE+1]]:{{[0-9]+}}: {{error|note}}: invalid operand for instruction
143 vmladavx.u32 r0, q4, q5
145 # ERROR: [[@LINE+1]]:{{[0-9]+}}: {{error|note}}: invalid operand for instruction
146 vmladavax.u8 r0, q4, q5
148 # ERROR: [[@LINE+1]]:{{[0-9]+}}: {{error|note}}: invalid operand for instruction
149 vmladavx.u8 r0, q4, q5
151 # ERROR: [[@LINE+1]]:{{[0-9]+}}: {{error|note}}: invalid operand for instruction
152 vmlaldavax.u16 r2, r3, q4, q5
154 # ERROR: [[@LINE+1]]:{{[0-9]+}}: {{error|note}}: invalid operand for instruction
155 vmlaldavx.u16 r2, r3, q4, q5
157 # ERROR: [[@LINE+1]]:{{[0-9]+}}: {{error|note}}: invalid operand for instruction
158 vmlaldavax.u32 r2, r3, q4, q5
160 # ERROR: [[@LINE+1]]:{{[0-9]+}}: {{error|note}}: invalid operand for instruction
161 vmlaldavx.u32 r2, r3, q4, q5
163 # ERROR: [[@LINE+1]]:{{[0-9]+}}: {{error|note}}: invalid operand for instruction
164 vrmlaldavhax.u32 r2, r3, q4, q5
166 # ERROR: [[@LINE+1]]:{{[0-9]+}}: {{error|note}}: invalid operand for instruction
167 vrmlaldavhx.u32 r2, r3, q4, q5
169 # CHECK: vmlav.s8 lr, q3, q0 @ encoding: [0xf6,0xee,0x00,0xef]
170 vmladav.s8 lr, q3, q0
172 # CHECK: vmlav.u8 lr, q1, q7 @ encoding: [0xf2,0xfe,0x0e,0xef]
173 vmladav.u8 lr, q1, q7
175 # CHECK: vrmlalvh.s32 lr, r1, q6, q2 @ encoding: [0x8c,0xee,0x04,0xef]
176 vrmlaldavh.s32 lr, r1, q6, q2
178 # CHECK: vrmlalvh.u32 lr, r1, q5, q2 @ encoding: [0x8a,0xfe,0x04,0xef]
179 vrmlaldavh.u32 lr, r1, q5, q2
181 # CHECK: vrmlalvh.u32 lr, r1, q5, q2 @ encoding: [0x8a,0xfe,0x04,0xef]
182 vrmlaldavh.u32 lr, r1, q5, q2
184 # ERROR: [[@LINE+1]]:{{[0-9]+}}: {{error|note}}: operand must be an even-numbered register
185 vrmlaldavh.u32 r1, r3, q5, q2
187 # ERROR: [[@LINE+1]]:{{[0-9]+}}: {{error|note}}: operand must be an odd-numbered register in range [r1,r11]
188 vrmlaldavh.u32 r2, r4, q5, q2
190 # CHECK: vrmlaldavhax.s32 lr, r1, q3, q0 @ encoding: [0x86,0xee,0x20,0xff]
191 vrmlaldavhax.s32 lr, r1, q3, q0
193 # CHECK: vrmlsldavh.s32 lr, r11, q6, q5 @ encoding: [0xdc,0xfe,0x0b,0xee]
194 vrmlsldavh.s32 lr, r11, q6, q5
196 # CHECK: vmlsdav.s16 lr, q0, q3 @ encoding: [0xf0,0xee,0x07,0xee]
197 vmlsdav.s16 lr, q0, q3
199 # CHECK: vrmlalvh.s32 lr, r1, q6, q2 @ encoding: [0x8c,0xee,0x04,0xef]
200 vrmlalvh.s32 lr, r1, q6, q2
202 # CHECK: vrmlalvh.u32 lr, r1, q5, q2 @ encoding: [0x8a,0xfe,0x04,0xef]
203 vrmlalvh.u32 lr, r1, q5, q2
205 # CHECK: vrmlalvha.s32 lr, r1, q3, q6 @ encoding: [0x86,0xee,0x2c,0xef]
206 vrmlalvha.s32 lr, r1, q3, q6
208 # CHECK: vrmlalvha.u32 lr, r1, q7, q1 @ encoding: [0x8e,0xfe,0x22,0xef]
209 vrmlalvha.u32 lr, r1, q7, q1
211 # CHECK: vmlsdav.s16 lr, q0, q3 @ encoding: [0xf0,0xee,0x07,0xee]
212 vmlsdav.s16 lr, q0, q3
214 # CHECK: vmlsdav.s32 lr, q2, q6 @ encoding: [0xf5,0xee,0x0d,0xee]
215 vmlsdav.s32 lr, q2, q6
217 # CHECK: vpte.i8 eq, q0, q0
218 # CHECK: vmlsdavaxt.s16 lr, q1, q4 @ encoding: [0xf2,0xee,0x29,0xfe]
219 # CHECK: vmlsdavaxe.s16 lr, q1, q4 @ encoding: [0xf2,0xee,0x29,0xfe]
220 vpte.i8 eq, q0, q0
221 vmlsdavaxt.s16 lr, q1, q4
222 vmlsdavaxe.s16 lr, q1, q4
224 # CHECK: vmlav.s16 lr, q0, q7 @ encoding: [0xf0,0xee,0x0e,0xee]
225 vmlav.s16 lr, q0, q7
227 # CHECK: vmlalv.s16 lr, r1, q4, q1 @ encoding: [0x88,0xee,0x02,0xee]
228 vmlaldav.s16 lr, r1, q4, q1
230 # CHECK: vmlalv.s32 lr, r11, q4, q1 @ encoding: [0xd9,0xee,0x02,0xee]
231 vmlaldav.s32 lr, r11, q4, q1
233 # CHECK: vmlalv.s32 r0, r1, q7, q6 @ encoding: [0x8f,0xee,0x0c,0x0e]
234 vmlalv.s32 r0, r1, q7, q6
236 # CHECK: vmlalv.u16 lr, r11, q5, q4 @ encoding: [0xda,0xfe,0x08,0xee]
237 vmlalv.u16 lr, r11, q5, q4