[testsuite] require sqrt_insn effective target where needed
[official-gcc.git] / gcc / testsuite / gcc.target / powerpc / p8vector-vectorize-1.c
bloba2dd1a4f55fc70a59e509c9de79ef69b4e64d975
1 /* { dg-do compile { target { powerpc*-*-* } } } */
2 /* { dg-skip-if "" { powerpc*-*-darwin* } } */
3 /* { dg-require-effective-target powerpc_vsx_ok } */
4 /* { dg-options "-mdejagnu-cpu=power8 -mvsx -O2 -ftree-vectorize -fvect-cost-model=dynamic -fno-unroll-loops -fno-unroll-all-loops" } */
6 #ifndef SIZE
7 #define SIZE 1024
8 #endif
10 #ifndef ALIGN
11 #define ALIGN 32
12 #endif
14 #ifndef TYPE
15 #define TYPE long long
16 #endif
18 #ifndef SIGN_TYPE
19 #define SIGN_TYPE signed TYPE
20 #endif
22 #ifndef UNS_TYPE
23 #define UNS_TYPE unsigned TYPE
24 #endif
26 #define ALIGN_ATTR __attribute__((__aligned__(ALIGN)))
28 SIGN_TYPE sa[SIZE] ALIGN_ATTR;
29 SIGN_TYPE sb[SIZE] ALIGN_ATTR;
30 SIGN_TYPE sc[SIZE] ALIGN_ATTR;
32 UNS_TYPE ua[SIZE] ALIGN_ATTR;
33 UNS_TYPE ub[SIZE] ALIGN_ATTR;
34 UNS_TYPE uc[SIZE] ALIGN_ATTR;
36 void
37 sign_add (void)
39 unsigned long i;
41 for (i = 0; i < SIZE; i++)
42 sa[i] = sb[i] + sc[i];
45 void
46 sign_sub (void)
48 unsigned long i;
50 for (i = 0; i < SIZE; i++)
51 sa[i] = sb[i] - sc[i];
54 void
55 sign_shift_left (void)
57 unsigned long i;
59 for (i = 0; i < SIZE; i++)
60 sa[i] = sb[i] << sc[i];
63 void
64 sign_shift_right (void)
66 unsigned long i;
68 for (i = 0; i < SIZE; i++)
69 sa[i] = sb[i] >> sc[i];
72 void
73 sign_max (void)
75 unsigned long i;
77 for (i = 0; i < SIZE; i++)
78 sa[i] = (sb[i] > sc[i]) ? sb[i] : sc[i];
81 void
82 sign_min (void)
84 unsigned long i;
86 for (i = 0; i < SIZE; i++)
87 sa[i] = (sb[i] < sc[i]) ? sb[i] : sc[i];
90 void
91 sign_abs (void)
93 unsigned long i;
95 for (i = 0; i < SIZE; i++)
96 sa[i] = (sb[i] < 0) ? -sb[i] : sb[i]; /* xor, vsubudm, vmaxsd. */
99 void
100 sign_eq (SIGN_TYPE val1, SIGN_TYPE val2)
102 unsigned long i;
104 for (i = 0; i < SIZE; i++)
105 sa[i] = (sb[i] == sc[i]) ? val1 : val2;
108 void
109 sign_lt (SIGN_TYPE val1, SIGN_TYPE val2)
111 unsigned long i;
113 for (i = 0; i < SIZE; i++)
114 sa[i] = (sb[i] < sc[i]) ? val1 : val2;
117 void
118 uns_add (void)
120 unsigned long i;
122 for (i = 0; i < SIZE; i++)
123 ua[i] = ub[i] + uc[i];
126 void
127 uns_sub (void)
129 unsigned long i;
131 for (i = 0; i < SIZE; i++)
132 ua[i] = ub[i] - uc[i];
135 void
136 uns_shift_left (void)
138 unsigned long i;
140 for (i = 0; i < SIZE; i++)
141 ua[i] = ub[i] << uc[i];
144 void
145 uns_shift_right (void)
147 unsigned long i;
149 for (i = 0; i < SIZE; i++)
150 ua[i] = ub[i] >> uc[i];
153 void
154 uns_max (void)
156 unsigned long i;
158 for (i = 0; i < SIZE; i++)
159 ua[i] = (ub[i] > uc[i]) ? ub[i] : uc[i];
162 void
163 uns_min (void)
165 unsigned long i;
167 for (i = 0; i < SIZE; i++)
168 ua[i] = (ub[i] < uc[i]) ? ub[i] : uc[i];
171 void
172 uns_eq (UNS_TYPE val1, UNS_TYPE val2)
174 unsigned long i;
176 for (i = 0; i < SIZE; i++)
177 ua[i] = (ub[i] == uc[i]) ? val1 : val2;
180 void
181 uns_lt (UNS_TYPE val1, UNS_TYPE val2)
183 unsigned long i;
185 for (i = 0; i < SIZE; i++)
186 ua[i] = (ub[i] < uc[i]) ? val1 : val2;
189 /* { dg-final { scan-assembler-times "\[\t \]vaddudm\[\t \]" 2 } } */
190 /* { dg-final { scan-assembler-times "\[\t \]vsubudm\[\t \]" 3 } } */
191 /* { dg-final { scan-assembler-times "\[\t \]vmaxsd\[\t \]" 2 } } */
192 /* { dg-final { scan-assembler-times "\[\t \]vmaxud\[\t \]" 1 } } */
193 /* { dg-final { scan-assembler-times "\[\t \]vminsd\[\t \]" 1 } } */
194 /* { dg-final { scan-assembler-times "\[\t \]vminud\[\t \]" 1 } } */
195 /* { dg-final { scan-assembler-times "\[\t \]vsld\[\t \]" 2 } } */
196 /* { dg-final { scan-assembler-times "\[\t \]vsrad\[\t \]" 1 } } */
197 /* { dg-final { scan-assembler-times "\[\t \]vsrd\[\t \]" 1 } } */
198 /* { dg-final { scan-assembler-times "\[\t \]vcmpequd\[\t \]" 2 } } */
199 /* { dg-final { scan-assembler-times "\[\t \]vcmpgtsd\[\t \]" 1 } } */
200 /* { dg-final { scan-assembler-times "\[\t \]vcmpgtud\[\t \]" 1 } } */