2 /* { dg-options "-O2 --save-temps -fno-inline" } */
4 extern void abort (void);
7 bics_si_test1 (int a
, int b
, int c
)
11 /* { dg-final { scan-assembler-times "bics\tw\[0-9\]+, w\[0-9\]+, w\[0-9\]+" 2 } } */
19 bics_si_test2 (int a
, int b
, int c
)
21 int d
= a
& ~(b
<< 3);
23 /* { dg-final { scan-assembler "bics\tw\[0-9\]+, w\[0-9\]+, w\[0-9\]+, lsl 3" } } */
30 typedef long long s64
;
33 bics_di_test1 (s64 a
, s64 b
, s64 c
)
37 /* { dg-final { scan-assembler-times "bics\tx\[0-9\]+, x\[0-9\]+, x\[0-9\]+" 2 } } */
45 bics_di_test2 (s64 a
, s64 b
, s64 c
)
47 s64 d
= a
& ~(b
<< 3);
49 /* { dg-final { scan-assembler "bics\tx\[0-9\]+, x\[0-9\]+, x\[0-9\]+, lsl 3" } } */
62 x
= bics_si_test1 (29, ~4, 5);
63 if (x
!= ((29 & 4) + ~4 + 5))
66 x
= bics_si_test1 (5, ~2, 20);
70 x
= bics_si_test2 (35, ~4, 5);
71 if (x
!= ((35 & ~(~4 << 3)) + ~4 + 5))
74 x
= bics_si_test2 (96, ~2, 20);
78 y
= bics_di_test1 (0x130000029ll
,
82 if (y
!= ((0x130000029ll
& 0x320000004ll
) + ~0x320000004ll
+ 0x505050505ll
))
85 y
= bics_di_test1 (0x5000500050005ll
,
88 if (y
!= 0x5000500052025ll
)
91 y
= bics_di_test2 (0x130000029ll
,
94 if (y
!= ((0x130000029ll
& ~(~0x064000008ll
<< 3))
95 + ~0x064000008ll
+ 0x505050505ll
))
98 y
= bics_di_test2 (0x130002900ll
,
101 if (y
!= (0x130002900ll
+ 0x505050505ll
))
107 /* { dg-final { cleanup-saved-temps } } */