PR middle-end/77357 - strlen of constant strings not folded
[official-gcc.git] / gcc / testsuite / gcc.dg / vect / bb-slp-pr81635-4.c
blob1aa3c8d1bac48ac81d33b201a282fad0f56041ef
1 /* { dg-do compile } */
2 /* { dg-additional-options "-fno-tree-loop-vectorize" } */
3 /* { dg-require-effective-target lp64 } */
5 void
6 f1 (double *p, double *q, unsigned int n)
8 p = (double *) __builtin_assume_aligned (p, sizeof (double) * 2);
9 q = (double *) __builtin_assume_aligned (q, sizeof (double) * 2);
10 for (unsigned int i = 0; i < n; i += 1)
12 double a = q[i] + p[i];
13 double b = q[i + 1] + p[i + 1];
14 q[i] = a;
15 q[i + 1] = b;
19 void
20 f2 (double *p, double *q, unsigned int n)
22 p = (double *) __builtin_assume_aligned (p, sizeof (double) * 2);
23 q = (double *) __builtin_assume_aligned (q, sizeof (double) * 2);
24 for (unsigned int i = 0; i < n; i += 3)
26 double a = q[i] + p[i];
27 double b = q[i + 1] + p[i + 1];
28 q[i] = a;
29 q[i + 1] = b;
33 void
34 f3 (double *p, double *q, unsigned int start, unsigned int n)
36 p = (double *) __builtin_assume_aligned (p, sizeof (double) * 2);
37 q = (double *) __builtin_assume_aligned (q, sizeof (double) * 2);
38 for (unsigned int i = start; i < n; i += 2)
40 double a = q[i] + p[i];
41 double b = q[i + 1] + p[i + 1];
42 q[i] = a;
43 q[i + 1] = b;
47 /* { dg-final { scan-tree-dump-not "basic block vectorized" "slp1" } } */