[committed] Fix newlib build failure with rx as well as several dozen testsuite failures
[official-gcc.git] / gcc / testsuite / gcc.dg / vect / vect-strided-u8-i8-gap4.c
blob9ead5a776d0b1a69bec804615ffe7639f61f993f
1 /* { dg-require-effective-target vect_int } */
3 #include <stdarg.h>
4 #include "tree-vect.h"
6 #define N 24
8 typedef struct {
9 unsigned char a;
10 unsigned char b;
11 unsigned char c;
12 unsigned char d;
13 unsigned char e;
14 unsigned char f;
15 unsigned char g;
16 unsigned char h;
17 } s;
19 __attribute__ ((noinline)) int
20 main1 (s *arr)
22 int i;
23 s *ptr = arr;
24 s res[N];
25 unsigned char x;
27 for (i = 0; i < N; i++)
29 res[i].c = ptr->b + ptr->c;
30 x = ptr->c + ptr->f;
31 res[i].a = x + ptr->b;
32 res[i].d = ptr->b + ptr->c;
33 res[i].b = ptr->c;
34 res[i].f = ptr->f + ptr->e;
35 res[i].e = ptr->b + ptr->e;
36 res[i].h = ptr->c;
37 res[i].g = ptr->b + ptr->c;
38 ptr++;
41 /* check results: */
42 #pragma GCC novector
43 for (i = 0; i < N; i++)
45 if (res[i].c != arr[i].b + arr[i].c
46 || res[i].a != arr[i].c + arr[i].f + arr[i].b
47 || res[i].d != arr[i].b + arr[i].c
48 || res[i].b != arr[i].c
49 || res[i].f != arr[i].f + arr[i].e
50 || res[i].e != arr[i].b + arr[i].e
51 || res[i].h != arr[i].c
52 || res[i].g != arr[i].b + arr[i].c)
53 abort ();
56 ptr = arr;
57 /* Vectorized as a strided SLP pair. */
58 for (i = 0; i < N; i++)
60 res[i].a = ptr->b;
61 res[i].b = ptr->c;
62 ptr++;
65 /* Check results. */
66 #pragma GCC novector
67 for (i = 0; i < N; i++)
69 if (res[i].a != arr[i].b
70 || res[i].b != arr[i].c)
71 abort ();
77 int main (void)
79 int i;
80 s arr[N];
82 check_vect ();
84 for (i = 0; i < N; i++)
86 arr[i].a = i;
87 arr[i].b = i * 2;
88 arr[i].c = 17;
89 arr[i].d = i+34;
90 arr[i].e = i * 3 + 5;
91 arr[i].f = i * 5;
92 arr[i].g = i - 3;
93 arr[i].h = 56;
94 asm volatile ("" ::: "memory");
97 main1 (arr);
99 return 0;
102 /* { dg-final { scan-tree-dump-times "vectorized 2 loops" 1 "vect" { target vect_strided8 } } } */