1 /* { dg-require-effective-target vect_int } */
2 /* { dg-add-options bind_pic_locally } */
3 /* { dg-additional-options "--param vect-max-peeling-for-alignment=0" } */
9 #define NINTS (VECTOR_BITS / 32)
27 struct s a
; /* array a.n is unaligned */
29 struct s e
; /* array e.n is aligned */
33 struct s2 a
; /* array a.n is unaligned */
36 struct s2 e
; /* array e.n is aligned */
43 __attribute__ ((noinline
))
48 /* 1. unaligned (known misalignment) */
49 for (i
= 0; i
< N
; i
++)
51 tmp1
[2].a
.n
[1][2][i
] = 5;
55 for (i
= 0; i
<N
; i
++)
57 if (tmp1
[2].a
.n
[1][2][i
] != 5)
62 for (i
= NINTS
- 1; i
< N
- 1; i
++)
64 tmp1
[2].a
.n
[1][2][i
] = 6;
68 for (i
= NINTS
; i
< N
- 1; i
++)
70 if (tmp1
[2].a
.n
[1][2][i
] != 6)
75 for (i
= 0; i
< N
; i
++)
77 for (j
= 0; j
< N
; j
++)
79 tmp1
[2].e
.n
[1][i
][j
] = 8;
84 for (i
= 0; i
< N
; i
++)
86 for (j
= 0; j
< N
; j
++)
88 if (tmp1
[2].e
.n
[1][i
][j
] != 8)
93 /* 4. unaligned (unknown misalignment) */
94 for (i
= 0; i
< N
- NINTS
; i
++)
96 for (j
= 0; j
< N
- NINTS
; j
++)
98 tmp2
[2].e
.n
[1][i
][j
] = 8;
103 for (i
= 0; i
< N
- NINTS
; i
++)
105 for (j
= 0; j
< N
- NINTS
; j
++)
107 if (tmp2
[2].e
.n
[1][i
][j
] != 8)
122 /* { dg-final { scan-tree-dump-times "vectorized 4 loops" 1 "vect" } } */
123 /* { dg-final { scan-tree-dump-times "Alignment of access forced using versioning" 1 "vect" { target { {! vector_alignment_reachable} && {! vect_hw_misalign} } } } } */