annotate gcc/testsuite/gcc.dg/vect/pr61194.c @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* { dg-require-effective-target vect_cond_mixed } */
kono
parents:
diff changeset
2 /* { dg-require-effective-target vect_float } */
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 #include "tree-vect.h"
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 static float x[1024];
kono
parents:
diff changeset
7 static float y[1024];
kono
parents:
diff changeset
8 static float z[1024];
kono
parents:
diff changeset
9 static float w[1024];
kono
parents:
diff changeset
10
kono
parents:
diff changeset
11 void __attribute__((noinline,noclone)) barX()
kono
parents:
diff changeset
12 {
kono
parents:
diff changeset
13 int i;
kono
parents:
diff changeset
14 for (i=0; i<1024; ++i)
kono
parents:
diff changeset
15 z[i] = ((x[i]>0) & (w[i]<0)) ? z[i] : y[i];
kono
parents:
diff changeset
16 }
kono
parents:
diff changeset
17
kono
parents:
diff changeset
18 int main()
kono
parents:
diff changeset
19 {
kono
parents:
diff changeset
20 int i;
kono
parents:
diff changeset
21
kono
parents:
diff changeset
22 check_vect ();
kono
parents:
diff changeset
23
kono
parents:
diff changeset
24 for (i = 0; i < 1024; ++i)
kono
parents:
diff changeset
25 {
kono
parents:
diff changeset
26 x[i] = -10 + i;
kono
parents:
diff changeset
27 w[i] = 100 - i;
kono
parents:
diff changeset
28 z[i] = 0.;
kono
parents:
diff changeset
29 y[i] = 1.;
kono
parents:
diff changeset
30 __asm__ volatile ("" : : : "memory");
kono
parents:
diff changeset
31 }
kono
parents:
diff changeset
32
kono
parents:
diff changeset
33 barX();
kono
parents:
diff changeset
34
kono
parents:
diff changeset
35 for (i = 0; i < 1024; ++i)
kono
parents:
diff changeset
36 if (z[i] != ((x[i]>0 && w[i]<0) ? 0. : 1.))
kono
parents:
diff changeset
37 abort ();
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39 return 0;
kono
parents:
diff changeset
40 }
kono
parents:
diff changeset
41
kono
parents:
diff changeset
42 /* { dg-final { scan-tree-dump-times "vectorized 1 loops" 1 "vect" } } */