libcpp, c, middle-end: Optimize initializers using #embed in C
[official-gcc.git] / gcc / testsuite / gcc.dg / vect / vect-11.c
blob296dae5ed818af9bb05d8188ee58ba8b337451e2
1 /* { dg-require-effective-target vect_int } */
2 /* { dg-require-effective-target vect_int_mult } */
3 /* { dg-additional-options "-fdump-tree-optimized-details-blocks" } */
5 #include <stdarg.h>
6 #include "tree-vect.h"
8 #define N 16
10 int ia[N];
11 int ic[N] = {0,3,6,9,12,15,18,21,24,27,30,33,36,39,42,45};
12 int ib[N] = {0,3,6,9,12,15,18,21,24,27,30,33,36,39,42,45};
14 __attribute__ ((noinline))
15 int main1 ()
17 int i;
19 /* Not vectorizable yet (integer mult). */
20 for (i = 0; i < N; i++)
22 ia[i] = ib[i] * ic[i];
25 /* check results: */
26 #pragma GCC novector
27 for (i = 0; i < N; i++)
29 if (ia[i] != ib[i] * ic[i])
30 abort ();
33 return 0;
36 int main (void)
38 check_vect ();
40 return main1 ();
43 /* { dg-final { scan-tree-dump-times "vectorized 1 loops" 1 "vect" } } */
44 /* { dg-final { scan-tree-dump-not "Invalid sum" "optimized" } } */