1 /* { dg-require-effective-target vect_int } */
21 __attribute__ ((noinline
)) int
29 for (i
= 0; i
< N
; i
++)
31 res
[i
].c
= ptr
->b
+ ptr
->c
;
33 res
[i
].a
= x
+ ptr
->b
;
34 res
[i
].d
= ptr
->b
+ ptr
->c
;
36 res
[i
].f
= ptr
->f
+ ptr
->e
;
37 res
[i
].e
= ptr
->b
+ ptr
->e
;
39 res
[i
].g
= ptr
->b
+ ptr
->c
;
45 for (i
= 0; i
< N
; i
++)
47 if (res
[i
].a
!= check_res
[i
].a
48 || res
[i
].b
!= check_res
[i
].b
49 || res
[i
].c
!= check_res
[i
].c
50 || res
[i
].d
!= check_res
[i
].d
51 || res
[i
].e
!= check_res
[i
].e
52 || res
[i
].f
!= check_res
[i
].f
53 || res
[i
].g
!= check_res
[i
].g
54 || res
[i
].h
!= check_res
[i
].h
)
59 /* Vectorized as a strided SLP pair. */
60 for (i
= 0; i
< N
; i
++)
69 for (i
= 0; i
< N
; i
++)
71 if (res
[i
].a
!= arr
[i
].b
72 || res
[i
].b
!= arr
[i
].c
)
87 for (i
= 0; i
< N
; i
++)
98 check_res
[i
].c
= arr
[i
].b
+ arr
[i
].c
;
99 x
= arr
[i
].c
+ arr
[i
].f
;
100 check_res
[i
].a
= x
+ arr
[i
].b
;
101 check_res
[i
].d
= arr
[i
].b
+ arr
[i
].c
;
102 check_res
[i
].b
= arr
[i
].c
;
103 check_res
[i
].f
= arr
[i
].f
+ arr
[i
].e
;
104 check_res
[i
].e
= arr
[i
].b
+ arr
[i
].e
;
105 check_res
[i
].h
= arr
[i
].c
;
106 check_res
[i
].g
= arr
[i
].b
+ arr
[i
].c
;
108 asm volatile ("" ::: "memory");
115 /* { dg-final { scan-tree-dump-times "vectorized 2 loops" 1 "vect" { target vect_strided8 } } } */