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;
56 for (i
= 0; i
<N
; i
++)
58 if (tmp1
[2].a
.n
[1][2][i
] != 5)
63 for (i
= NINTS
- 1; i
< N
- 1; i
++)
65 tmp1
[2].a
.n
[1][2][i
] = 6;
70 for (i
= NINTS
; i
< N
- 1; i
++)
72 if (tmp1
[2].a
.n
[1][2][i
] != 6)
77 for (i
= 0; i
< N
; i
++)
79 for (j
= 0; j
< N
; j
++)
81 tmp1
[2].e
.n
[1][i
][j
] = 8;
86 for (i
= 0; i
< N
; i
++)
89 for (j
= 0; j
< N
; j
++)
91 if (tmp1
[2].e
.n
[1][i
][j
] != 8)
96 /* 4. unaligned (unknown misalignment) */
97 for (i
= 0; i
< N
- NINTS
; i
++)
99 for (j
= 0; j
< N
- NINTS
; j
++)
101 tmp2
[2].e
.n
[1][i
][j
] = 8;
106 for (i
= 0; i
< N
- NINTS
; i
++)
109 for (j
= 0; j
< N
- NINTS
; j
++)
111 if (tmp2
[2].e
.n
[1][i
][j
] != 8)
126 /* { dg-final { scan-tree-dump-times "vectorized 4 loops" 1 "vect" { target vect_hw_misalign } } } */
127 /* { dg-final { scan-tree-dump-times "vectorized 3 loops" 1 "vect" { target { ! vect_hw_misalign } } } } */
128 /* { dg-final { scan-tree-dump-times "Alignment of access forced using versioning" 1 "vect" { target { { ! vector_alignment_reachable } && { ! vect_hw_misalign } } } } } */