annotate gcc/testsuite/gcc.dg/vect/vect-live-2.c @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children 1830386684a0
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* { dg-require-effective-target vect_long } */
kono
parents:
diff changeset
2 /* { dg-require-effective-target vect_shift } */
kono
parents:
diff changeset
3 /* { dg-additional-options "-fno-tree-scev-cprop" } */
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 #include "tree-vect.h"
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 /* Statement used outside the loop.
kono
parents:
diff changeset
8 NOTE: SCEV disabled to ensure the live operation is not removed before
kono
parents:
diff changeset
9 vectorization. */
kono
parents:
diff changeset
10 __attribute__ ((noinline)) int
kono
parents:
diff changeset
11 liveloop (int start, int n, int *x, int *y)
kono
parents:
diff changeset
12 {
kono
parents:
diff changeset
13 int i = start;
kono
parents:
diff changeset
14 int j;
kono
parents:
diff changeset
15 int ret;
kono
parents:
diff changeset
16
kono
parents:
diff changeset
17 for (j = 0; j < n; ++j)
kono
parents:
diff changeset
18 {
kono
parents:
diff changeset
19 i += 1;
kono
parents:
diff changeset
20 x[j] = i;
kono
parents:
diff changeset
21 ret = y[j];
kono
parents:
diff changeset
22 }
kono
parents:
diff changeset
23 return ret;
kono
parents:
diff changeset
24 }
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 #define MAX 97
kono
parents:
diff changeset
27 #define START 13
kono
parents:
diff changeset
28
kono
parents:
diff changeset
29 int
kono
parents:
diff changeset
30 main (void)
kono
parents:
diff changeset
31 {
kono
parents:
diff changeset
32 int a[MAX];
kono
parents:
diff changeset
33 int b[MAX];
kono
parents:
diff changeset
34 int i;
kono
parents:
diff changeset
35
kono
parents:
diff changeset
36 check_vect ();
kono
parents:
diff changeset
37
kono
parents:
diff changeset
38 for (i=0; i<MAX; i++)
kono
parents:
diff changeset
39 {
kono
parents:
diff changeset
40 __asm__ volatile ("");
kono
parents:
diff changeset
41 b[i] = i;
kono
parents:
diff changeset
42 }
kono
parents:
diff changeset
43
kono
parents:
diff changeset
44 int ret = liveloop (START, MAX, a, b);
kono
parents:
diff changeset
45
kono
parents:
diff changeset
46 if (ret != MAX - 1)
kono
parents:
diff changeset
47 abort ();
kono
parents:
diff changeset
48
kono
parents:
diff changeset
49 for (i=0; i<MAX; i++)
kono
parents:
diff changeset
50 {
kono
parents:
diff changeset
51 __asm__ volatile ("");
kono
parents:
diff changeset
52 if (a[i] != i+START+1)
kono
parents:
diff changeset
53 abort ();
kono
parents:
diff changeset
54 }
kono
parents:
diff changeset
55 }
kono
parents:
diff changeset
56
kono
parents:
diff changeset
57 /* { dg-final { scan-tree-dump-times "vectorized 1 loops" 1 "vect" } } */
kono
parents:
diff changeset
58 /* { dg-final { scan-tree-dump-times "vec_stmt_relevant_p: stmt live but not relevant" 1 "vect" } } */