Rebase.
[official-gcc.git] / gcc / testsuite / gcc.target / aarch64 / scalar_shift_1.c
blob826bafcb574e92671998cdf7b63b1cf4cfa3e4b0
1 /* { dg-do run } */
2 /* { dg-options "-O2 -fno-inline -save-temps" } */
4 extern void abort ();
6 #define force_simd_di(v) asm volatile ("mov %d0, %1.d[0]" :"=w" (v) :"w" (v) :)
7 #define force_simd_si(v) asm volatile ("mov %s0, %1.s[0]" :"=w" (v) :"w" (v) :)
9 typedef unsigned long long int UInt64x1;
10 typedef long long int Int64x1;
11 typedef unsigned int UInt32x1;
12 typedef int Int32x1;
14 UInt64x1
15 test_lshift_left_sisd_di (UInt64x1 b, UInt64x1 c)
17 UInt64x1 a;
19 force_simd_di (b);
20 force_simd_di (c);
21 a = b << 8;
22 a = a << c;
23 force_simd_di (a);
24 return a;
26 /* { dg-final { scan-assembler "shl\td\[0-9\]+,\ d\[0-9\]+,\ 8" } } */
27 /* { dg-final { scan-assembler "ushl\td\[0-9\]+,\ d\[0-9\]+,\ d\[0-9\]+" } } */
29 UInt32x1
30 test_lshift_left_sisd_si (UInt32x1 b, UInt32x1 c)
32 UInt32x1 a;
34 force_simd_si (b);
35 force_simd_si (c);
36 a = b << 4;
37 a = a << c;
38 force_simd_si (a);
39 return a;
41 /* { dg-final { scan-assembler "shl\tv\[0-9\]+\.2s,\ v\[0-9\]+\.2s,\ 4" } } */
42 /* "ushl\tv\[0-9\]+\.2s,\ v\[0-9\]+\.2s,\ v\[0-9\]+\.2s" (counted later) */
44 UInt64x1
45 test_lshift_right_sisd_di (UInt64x1 b, UInt64x1 c)
47 UInt64x1 a;
49 force_simd_di (b);
50 force_simd_di (c);
51 a = b >> 8;
52 a = a >> c;
53 force_simd_di (a);
54 return a;
56 /* { dg-final { scan-assembler "ushr\td\[0-9\]+,\ d\[0-9\]+,\ 8" } } */
57 /* "neg\td\[0-9\]+,\ d\[0-9\]+" (counted later) */
58 /* { dg-final { scan-assembler "ushl\td\[0-9\]+,\ d\[0-9\]+,\ d\[0-9\]+" } } */
60 UInt64x1
61 test_lshift_right_sisd_si (UInt32x1 b, UInt32x1 c)
63 UInt32x1 a;
65 force_simd_si (b);
66 force_simd_si (c);
67 a = b >> 4;
68 a = a >> c;
69 force_simd_si (a);
70 return a;
72 /* { dg-final { scan-assembler "ushr\tv\[0-9\]+\.2s,\ v\[0-9\]+\.2s,\ 4" } } */
73 /* "neg\td\[0-9\]+,\ d\[0-9\]+" (counted later) */
74 /* { dg-final { scan-assembler-times "ushl\tv\[0-9\]+\.2s,\ v\[0-9\]+\.2s,\ v\[0-9\]+\.2s" 2 } } */
76 Int64x1
77 test_ashift_right_sisd_di (Int64x1 b, Int64x1 c)
79 Int64x1 a;
81 force_simd_di (b);
82 force_simd_di (c);
83 a = b >> 8;
84 a = a >> c;
85 force_simd_di (a);
86 return a;
88 /* { dg-final { scan-assembler "sshr\td\[0-9\]+,\ d\[0-9\]+,\ 8" } } */
89 /* "neg\td\[0-9\]+,\ d\[0-9\]+" (counted later) */
90 /* { dg-final { scan-assembler "sshl\td\[0-9\]+,\ d\[0-9\]+,\ d\[0-9\]+" } } */
92 Int32x1
93 test_ashift_right_sisd_si (Int32x1 b, Int32x1 c)
95 Int32x1 a;
97 force_simd_si (b);
98 force_simd_si (c);
99 a = b >> 4;
100 a = a >> c;
101 force_simd_si (a);
102 return a;
104 /* { dg-final { scan-assembler "sshr\tv\[0-9\]+\.2s,\ v\[0-9\]+\.2s,\ 4" } } */
105 /* { dg-final { scan-assembler-times "neg\td\[0-9\]+,\ d\[0-9\]+" 4 } } */
106 /* { dg-final { scan-assembler "sshl\tv\[0-9\]+\.2s,\ v\[0-9\]+\.2s,\ v\[0-9\]+\.2s" } } */
109 /* The following are to make sure if the integer instructions lsl/lsr/asr are
110 generated in non-vector scenarios */
112 UInt64x1
113 test_lshift_left_int_di (UInt64x1 b, UInt64x1 c)
115 UInt64x1 a;
117 a = b << 8;
118 a = a << c;
119 return a;
121 /* { dg-final { scan-assembler "lsl\tx\[0-9\]+,\ x\[0-9\]+,\ 8" } } */
122 /* { dg-final { scan-assembler "lsl\tx\[0-9\]+,\ x\[0-9\]+,\ x\[0-9\]+" } } */
124 UInt32x1
125 test_lshift_left_int_si (UInt32x1 b, UInt32x1 c)
127 UInt32x1 a;
129 a = b << 4;
130 a = a << c;
131 return a;
133 /* { dg-final { scan-assembler "lsl\tw\[0-9\]+,\ w\[0-9\]+,\ 4" } } */
134 /* { dg-final { scan-assembler "lsl\tw\[0-9\]+,\ w\[0-9\]+,\ w\[0-9\]+" } } */
136 UInt64x1
137 test_lshift_right_int_di (UInt64x1 b, UInt64x1 c)
139 UInt64x1 a;
141 a = b >> 8;
142 a = a >> c;
143 return a;
145 /* { dg-final { scan-assembler "lsr\tx\[0-9\]+,\ x\[0-9\]+,\ 8" } } */
146 /* { dg-final { scan-assembler "lsr\tx\[0-9\]+,\ x\[0-9\]+,\ x\[0-9\]+" } } */
148 UInt32x1
149 test_lshift_right_int_si (UInt32x1 b, UInt32x1 c)
151 UInt32x1 a;
153 a = b >> 4;
154 a = a >> c;
155 return a;
157 /* { dg-final { scan-assembler "lsr\tw\[0-9\]+,\ w\[0-9\]+,\ 4" } } */
158 /* { dg-final { scan-assembler "lsr\tw\[0-9\]+,\ w\[0-9\]+,\ w\[0-9\]+" } } */
160 Int64x1
161 test_ashift_right_int_di (Int64x1 b, Int64x1 c)
163 Int64x1 a;
165 a = b >> 8;
166 a = a >> c;
167 return a;
169 /* { dg-final { scan-assembler "asr\tx\[0-9\]+,\ x\[0-9\]+,\ 8" } } */
170 /* { dg-final { scan-assembler "asr\tx\[0-9\]+,\ x\[0-9\]+,\ x\[0-9\]+" } } */
172 Int32x1
173 test_ashift_right_int_si (Int32x1 b, Int32x1 c)
175 Int32x1 a;
177 a = b >> 4;
178 a = a >> c;
179 return a;
181 /* { dg-final { scan-assembler "asr\tw\[0-9\]+,\ w\[0-9\]+,\ 4" } } */
182 /* { dg-final { scan-assembler "asr\tw\[0-9\]+,\ w\[0-9\]+,\ w\[0-9\]+" } } */
184 Int64x1
185 test_corners_sisd_di (Int64x1 b)
187 force_simd_di (b);
188 b = b >> 63;
189 b = b >> 0;
190 b += b >> 65; /* { dg-warning "right shift count >= width of type" } */
191 force_simd_di (b);
193 return b;
195 /* { dg-final { scan-assembler "sshr\td\[0-9\]+,\ d\[0-9\]+,\ 63" } } */
197 Int32x1
198 test_corners_sisd_si (Int32x1 b)
200 force_simd_si (b);
201 b = b >> 31;
202 b = b >> 0;
203 b += b >> 33; /* { dg-warning "right shift count >= width of type" } */
204 force_simd_si (b);
206 return b;
208 /* { dg-final { scan-assembler "sshr\tv\[0-9\]+\.2s,\ v\[0-9\]+\.2s,\ 31" } } */
212 #define CHECK(var,val) \
213 do \
215 if (var != val) \
216 abort(); \
218 while(0)
220 UInt64x1 x = 0xC01dDeadBeefFaceull;
221 UInt32x1 y = 0xDeadBeef;
224 main ()
226 x = test_lshift_left_sisd_di (x, 8);
227 CHECK (x, 0xdeadbeefface0000ull);
228 x = test_lshift_right_int_di (x, 8);
229 CHECK (x, 0x0000deadbeeffaceull);
230 x = test_lshift_right_sisd_di (x, 8);
231 CHECK (x, 0x00000000deadbeefull);
232 x = test_lshift_left_int_di (x, 8);
233 CHECK (x, 0x0000deadbeef0000ull);
234 x = ~x;
235 x = test_ashift_right_int_di (x, 8);
236 CHECK (x, 0xffffffff21524110ull);
237 x = test_ashift_right_sisd_di (x, 8);
238 CHECK (x, 0xffffffffffff2152ull);
239 x = test_corners_sisd_di (x);
240 CHECK (x, 0xfffffffffffffffeull);
242 y = test_lshift_left_sisd_si (y, 4);
243 CHECK (y, 0xadbeef00);
244 y = test_lshift_right_int_si (y, 4);
245 CHECK (y, 0x00adbeef);
246 y = test_lshift_right_sisd_si (y, 4);
247 CHECK (y, 0x0000adbe);
248 y = test_lshift_left_int_si (y, 4);
249 CHECK (y, 0x00adbe00);
250 y = ~y;
251 y = test_ashift_right_int_si (y, 4);
252 CHECK (y, 0xffff5241);
253 y = test_ashift_right_sisd_si (y, 4);
254 CHECK (y, 0xffffff52);
255 y = test_corners_sisd_si (y);
256 CHECK (y, 0xfffffffe);
258 return 0;
261 /* { dg-final { cleanup-saved-temps } } */