2 /* { dg-options "-O2 --save-temps -fno-inline" } */
4 extern void abort (void);
7 adds_si_test1 (int a
, int b
, int c
)
11 /* { dg-final { scan-assembler-not "adds\tw\[0-9\]+, w\[0-9\]+, w\[0-9\]+" } } */
12 /* { dg-final { scan-assembler "add\tw\[0-9\]+, w\[0-9\]+, w\[0-9\]+" } } */
20 adds_si_test2 (int a
, int b
, int c
)
24 /* { dg-final { scan-assembler-not "adds\tw\[0-9\]+, w\[0-9\]+, 4095" } } */
25 /* { dg-final { scan-assembler "add\tw\[0-9\]+, w\[0-9\]+, 4095" } } */
33 adds_si_test3 (int a
, int b
, int c
)
37 /* { dg-final { scan-assembler-not "adds\tw\[0-9\]+, w\[0-9\]+, w\[0-9\]+, lsl 3" } } */
38 /* { dg-final { scan-assembler "add\tw\[0-9\]+, w\[0-9\]+, w\[0-9\]+, lsl 3" } } */
45 typedef long long s64
;
48 adds_di_test1 (s64 a
, s64 b
, s64 c
)
52 /* { dg-final { scan-assembler-not "adds\tx\[0-9\]+, x\[0-9\]+, x\[0-9\]+" } } */
53 /* { dg-final { scan-assembler "add\tx\[0-9\]+, x\[0-9\]+, x\[0-9\]+" } } */
61 adds_di_test2 (s64 a
, s64 b
, s64 c
)
65 /* { dg-final { scan-assembler-not "adds\tx\[0-9\]+, x\[0-9\]+, 4096" } } */
66 /* { dg-final { scan-assembler "add\tx\[0-9\]+, x\[0-9\]+, 4096" } } */
74 adds_di_test3 (s64 a
, s64 b
, s64 c
)
78 /* { dg-final { scan-assembler-not "adds\tx\[0-9\]+, x\[0-9\]+, x\[0-9\]+, lsl 3" } } */
79 /* { dg-final { scan-assembler "add\tx\[0-9\]+, x\[0-9\]+, x\[0-9\]+, lsl 3" } } */
91 x
= adds_si_test1 (29, 4, 5);
95 x
= adds_si_test1 (5, 2, 20);
99 x
= adds_si_test2 (29, 4, 5);
103 x
= adds_si_test2 (1024, 2, 20);
107 x
= adds_si_test3 (35, 4, 5);
111 x
= adds_si_test3 (5, 2, 20);
115 y
= adds_di_test1 (0x130000029ll
,
119 if (y
!= 0xc75050536)
122 y
= adds_di_test1 (0x5000500050005ll
,
125 if (y
!= 0x9222922294249)
128 y
= adds_di_test2 (0x130000029ll
,
131 if (y
!= 0x955051532)
134 y
= adds_di_test2 (0x540004100ll
,
137 if (y
!= 0x1065055309)
140 y
= adds_di_test3 (0x130000029ll
,
143 if (y
!= 0x9b9050576)
146 y
= adds_di_test3 (0x130002900ll
,
149 if (y
!= 0xafd052e4d)