blob: ac3194e62c3efa1a769e049f707100e42cb8886a [file] [log] [blame]
/* { dg-require-effective-target vect_int } */
#include <stdarg.h>
#include "tree-vect.h"
#define N 16
struct tmp
{
int x;
int ia[N];
};
int main1 (int off)
{
struct tmp sb[N];
struct tmp *pp = &sb[off];
int i, ib[N];
for (i = 0; i < N; i++)
pp->ia[i] = ib[i];
/* check results: */
for (i = 0; i < N; i++)
{
if (pp->ia[i] != ib[i])
abort();
}
return 0;
}
int main (void)
{
check_vect ();
return main1 (8);
}
/* The store is unaligned, the load is aligned. For targets that support unaligned
loads, peel to align the store and generated unaligned access for the loads.
For targets that don't support unaligned loads, version for the store. */
/* { dg-final { scan-tree-dump-times "vectorized 1 loops" 1 "vect" } } */
/* { dg-final { scan-tree-dump-times "Vectorizing an unaligned access" 1 "vect" { xfail vect_no_align } } } */
/* { dg-final { scan-tree-dump-times "Alignment of access forced using peeling" 1 "vect" { xfail vect_no_align } } } */
/* { dg-final { scan-tree-dump-times "Alignment of access forced using versioning." 1 "vect" { target vect_no_align } } } */
/* { dg-final { cleanup-tree-dump "vect" } } */