libcpp, c, middle-end: Optimize initializers using #embed in C
[official-gcc.git] / gcc / testsuite / gcc.dg / vect / vect-align-1.c
blob9630fc0738cdf4aa5db67effdd5eb47de4459f6f
1 /* { dg-require-effective-target vect_int } */
2 /* { dg-add-options bind_pic_locally } */
4 #include <stdlib.h>
5 #include <stdarg.h>
6 #include "tree-vect.h"
8 /* Compile time known misalignment. Cannot use loop peeling to align
9 the store. */
11 #define N 16
13 struct foo {
14 char x;
15 int y[N];
16 } __attribute__((packed));
18 int x[N] = {0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15};
20 __attribute__ ((noinline)) int
21 main1 (struct foo * __restrict__ p)
23 int i;
25 for (i = 0; i < N; i++)
27 p->y[i] = x[i];
30 /* check results: */
31 #pragma GCC novector
32 for (i = 0; i < N; i++)
34 if (p->y[i] != x[i])
35 abort ();
37 return 0;
41 int main (void)
43 int i;
44 struct foo *p = malloc (2*sizeof (struct foo));
45 check_vect ();
47 main1 (p);
48 return 0;
51 /* { dg-final { scan-tree-dump-times "Vectorizing an unaligned access" 1 "vect" { target { vect_hw_misalign && { arm_vect_no_misalign } } } } } */
52 /* { dg-final { scan-tree-dump-times "Alignment of access forced using versioning" 1 "vect" { target { vect_hw_misalign && arm_vect_no_misalign } } } } */
53 /* { dg-final { scan-tree-dump-times "vectorized 1 loops" 1 "vect" } } */