Vect: Optimize truncation for .SAT_SUB operands
[official-gcc.git] / gcc / testsuite / gcc.dg / vect / slp-37.c
blobcaee2bb508f1824fa549568dd09911c8624222f4
1 /* { dg-require-effective-target vect_int } */
3 #include <stdarg.h>
4 #include "tree-vect.h"
6 #define N 128
8 typedef struct {
9 int a;
10 int b;
11 void *c;
12 } s1;
14 int
15 foo1 (s1 *arr)
17 int i;
18 s1 *ptr = arr;
20 /* Vectorized as a strided SLP pair of accesses to <a, b> and a single
21 strided access to c. */
22 for (i = 0; i < N; i++)
24 ptr->a = 6;
25 ptr->b = 7;
26 ptr->c = 0;
27 ptr++;
30 /* check results: */
31 #pragma GCC novector
32 for (i = 0; i < N; i++)
34 if (arr[i].a != 6
35 || arr[i].b != 7
36 || arr[i].c != 0)
37 abort();
41 int main (void)
43 int i;
44 s1 arr1[N];
46 check_vect ();
48 for (i = 0; i < N; i++)
50 arr1[i].a = i;
51 arr1[i].b = i * 2;
52 arr1[i].c = (void *)arr1;
53 asm volatile ("" ::: "memory");
57 foo1 (arr1);
59 return 0;
62 /* { dg-final { scan-tree-dump-times "vectorized 1 loops" 1 "vect" { target vect_hw_misalign } } } */
63 /* { dg-final { scan-tree-dump-times "vectorizing stmts using SLP" 1 "vect" { target vect_hw_misalign } } } */