* gcc.target/powerpc/builtins-1-be.c <vclzb>: Rename duplicate test
[official-gcc.git] / gcc / testsuite / gcc.target / powerpc / p8vector-vectorize-1.c
blobf7599dc3ec94f412e0d75ab707bcd9bf32f2151c
1 /* { dg-do compile { target { powerpc*-*-* } } } */
2 /* { dg-skip-if "" { powerpc*-*-darwin* } } */
3 /* { dg-require-effective-target powerpc_p8vector_ok } */
4 /* { dg-skip-if "do not override -mcpu" { powerpc*-*-* } { "-mcpu=*" } { "-mcpu=power8" } } */
5 /* { dg-options "-mcpu=power8 -O2 -ftree-vectorize -fvect-cost-model=dynamic -fno-unroll-loops -fno-unroll-all-loops" } */
7 #ifndef SIZE
8 #define SIZE 1024
9 #endif
11 #ifndef ALIGN
12 #define ALIGN 32
13 #endif
15 #ifndef TYPE
16 #define TYPE long long
17 #endif
19 #ifndef SIGN_TYPE
20 #define SIGN_TYPE signed TYPE
21 #endif
23 #ifndef UNS_TYPE
24 #define UNS_TYPE unsigned TYPE
25 #endif
27 #define ALIGN_ATTR __attribute__((__aligned__(ALIGN)))
29 SIGN_TYPE sa[SIZE] ALIGN_ATTR;
30 SIGN_TYPE sb[SIZE] ALIGN_ATTR;
31 SIGN_TYPE sc[SIZE] ALIGN_ATTR;
33 UNS_TYPE ua[SIZE] ALIGN_ATTR;
34 UNS_TYPE ub[SIZE] ALIGN_ATTR;
35 UNS_TYPE uc[SIZE] ALIGN_ATTR;
37 void
38 sign_add (void)
40 unsigned long i;
42 for (i = 0; i < SIZE; i++)
43 sa[i] = sb[i] + sc[i];
46 void
47 sign_sub (void)
49 unsigned long i;
51 for (i = 0; i < SIZE; i++)
52 sa[i] = sb[i] - sc[i];
55 void
56 sign_shift_left (void)
58 unsigned long i;
60 for (i = 0; i < SIZE; i++)
61 sa[i] = sb[i] << sc[i];
64 void
65 sign_shift_right (void)
67 unsigned long i;
69 for (i = 0; i < SIZE; i++)
70 sa[i] = sb[i] >> sc[i];
73 void
74 sign_max (void)
76 unsigned long i;
78 for (i = 0; i < SIZE; i++)
79 sa[i] = (sb[i] > sc[i]) ? sb[i] : sc[i];
82 void
83 sign_min (void)
85 unsigned long i;
87 for (i = 0; i < SIZE; i++)
88 sa[i] = (sb[i] < sc[i]) ? sb[i] : sc[i];
91 void
92 sign_abs (void)
94 unsigned long i;
96 for (i = 0; i < SIZE; i++)
97 sa[i] = (sb[i] < 0) ? -sb[i] : sb[i]; /* xor, vsubudm, vmaxsd. */
100 void
101 sign_eq (SIGN_TYPE val1, SIGN_TYPE val2)
103 unsigned long i;
105 for (i = 0; i < SIZE; i++)
106 sa[i] = (sb[i] == sc[i]) ? val1 : val2;
109 void
110 sign_lt (SIGN_TYPE val1, SIGN_TYPE val2)
112 unsigned long i;
114 for (i = 0; i < SIZE; i++)
115 sa[i] = (sb[i] < sc[i]) ? val1 : val2;
118 void
119 uns_add (void)
121 unsigned long i;
123 for (i = 0; i < SIZE; i++)
124 ua[i] = ub[i] + uc[i];
127 void
128 uns_sub (void)
130 unsigned long i;
132 for (i = 0; i < SIZE; i++)
133 ua[i] = ub[i] - uc[i];
136 void
137 uns_shift_left (void)
139 unsigned long i;
141 for (i = 0; i < SIZE; i++)
142 ua[i] = ub[i] << uc[i];
145 void
146 uns_shift_right (void)
148 unsigned long i;
150 for (i = 0; i < SIZE; i++)
151 ua[i] = ub[i] >> uc[i];
154 void
155 uns_max (void)
157 unsigned long i;
159 for (i = 0; i < SIZE; i++)
160 ua[i] = (ub[i] > uc[i]) ? ub[i] : uc[i];
163 void
164 uns_min (void)
166 unsigned long i;
168 for (i = 0; i < SIZE; i++)
169 ua[i] = (ub[i] < uc[i]) ? ub[i] : uc[i];
172 void
173 uns_eq (UNS_TYPE val1, UNS_TYPE val2)
175 unsigned long i;
177 for (i = 0; i < SIZE; i++)
178 ua[i] = (ub[i] == uc[i]) ? val1 : val2;
181 void
182 uns_lt (UNS_TYPE val1, UNS_TYPE val2)
184 unsigned long i;
186 for (i = 0; i < SIZE; i++)
187 ua[i] = (ub[i] < uc[i]) ? val1 : val2;
190 /* { dg-final { scan-assembler-times "\[\t \]vaddudm\[\t \]" 2 } } */
191 /* { dg-final { scan-assembler-times "\[\t \]vsubudm\[\t \]" 3 } } */
192 /* { dg-final { scan-assembler-times "\[\t \]vmaxsd\[\t \]" 2 } } */
193 /* { dg-final { scan-assembler-times "\[\t \]vmaxud\[\t \]" 1 } } */
194 /* { dg-final { scan-assembler-times "\[\t \]vminsd\[\t \]" 1 } } */
195 /* { dg-final { scan-assembler-times "\[\t \]vminud\[\t \]" 1 } } */
196 /* { dg-final { scan-assembler-times "\[\t \]vsld\[\t \]" 2 } } */
197 /* { dg-final { scan-assembler-times "\[\t \]vsrad\[\t \]" 1 } } */
198 /* { dg-final { scan-assembler-times "\[\t \]vsrd\[\t \]" 1 } } */
199 /* { dg-final { scan-assembler-times "\[\t \]vcmpequd\[\t \]" 2 } } */
200 /* { dg-final { scan-assembler-times "\[\t \]vcmpgtsd\[\t \]" 1 } } */
201 /* { dg-final { scan-assembler-times "\[\t \]vcmpgtud\[\t \]" 1 } } */