Add execution + assembler tests of AArch64 TRN Intrinsics.
[official-gcc.git] / gcc / testsuite / gcc.target / aarch64 / adds1.c
blobeb19bbfd61645107373931d5bc748e53117726a7
1 /* { dg-do run } */
2 /* { dg-options "-O2 --save-temps -fno-inline" } */
4 extern void abort (void);
6 int
7 adds_si_test1 (int a, int b, int c)
9 int d = a + b;
11 /* { dg-final { scan-assembler "adds\tw\[0-9\]+, w\[0-9\]+, w\[0-9\]+" } } */
12 if (d == 0)
13 return a + c;
14 else
15 return b + d + c;
18 int
19 adds_si_test2 (int a, int b, int c)
21 int d = a + 0xff;
23 /* { dg-final { scan-assembler "adds\tw\[0-9\]+, w\[0-9\]+, 255" } } */
24 if (d == 0)
25 return a + c;
26 else
27 return b + d + c;
30 int
31 adds_si_test3 (int a, int b, int c)
33 int d = a + (b << 3);
35 /* { dg-final { scan-assembler "adds\tw\[0-9\]+, w\[0-9\]+, w\[0-9\]+, lsl 3" } } */
36 if (d == 0)
37 return a + c;
38 else
39 return b + d + c;
42 typedef long long s64;
44 s64
45 adds_di_test1 (s64 a, s64 b, s64 c)
47 s64 d = a + b;
49 /* { dg-final { scan-assembler "adds\tx\[0-9\]+, x\[0-9\]+, x\[0-9\]+" } } */
50 if (d == 0)
51 return a + c;
52 else
53 return b + d + c;
56 s64
57 adds_di_test2 (s64 a, s64 b, s64 c)
59 s64 d = a + 0xff;
61 /* { dg-final { scan-assembler "adds\tx\[0-9\]+, x\[0-9\]+, 255" } } */
62 if (d == 0)
63 return a + c;
64 else
65 return b + d + c;
68 s64
69 adds_di_test3 (s64 a, s64 b, s64 c)
71 s64 d = a + (b << 3);
73 /* { dg-final { scan-assembler "adds\tx\[0-9\]+, x\[0-9\]+, x\[0-9\]+, lsl 3" } } */
74 if (d == 0)
75 return a + c;
76 else
77 return b + d + c;
80 int main ()
82 int x;
83 s64 y;
85 x = adds_si_test1 (29, 4, 5);
86 if (x != 42)
87 abort ();
89 x = adds_si_test1 (5, 2, 20);
90 if (x != 29)
91 abort ();
93 x = adds_si_test2 (29, 4, 5);
94 if (x != 293)
95 abort ();
97 x = adds_si_test2 (1024, 2, 20);
98 if (x != 1301)
99 abort ();
101 x = adds_si_test3 (35, 4, 5);
102 if (x != 76)
103 abort ();
105 x = adds_si_test3 (5, 2, 20);
106 if (x != 43)
107 abort ();
109 y = adds_di_test1 (0x130000029ll,
110 0x320000004ll,
111 0x505050505ll);
113 if (y != 0xc75050536)
114 abort ();
116 y = adds_di_test1 (0x5000500050005ll,
117 0x2111211121112ll,
118 0x0000000002020ll);
119 if (y != 0x9222922294249)
120 abort ();
122 y = adds_di_test2 (0x130000029ll,
123 0x320000004ll,
124 0x505050505ll);
125 if (y != 0x955050631)
126 abort ();
128 y = adds_di_test2 (0x130002900ll,
129 0x320000004ll,
130 0x505050505ll);
131 if (y != 0x955052f08)
132 abort ();
134 y = adds_di_test3 (0x130000029ll,
135 0x064000008ll,
136 0x505050505ll);
137 if (y != 0x9b9050576)
138 abort ();
140 y = adds_di_test3 (0x130002900ll,
141 0x088000008ll,
142 0x505050505ll);
143 if (y != 0xafd052e4d)
144 abort ();
146 return 0;
149 /* { dg-final { cleanup-saved-temps } } */