annotate gcc/testsuite/gcc.dg/vect/vect-93.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_float } */
kono
parents:
diff changeset
2 /* { dg-additional-options "--param vect-max-peeling-for-alignment=0" } */
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 #include <stdarg.h>
kono
parents:
diff changeset
5 #include "tree-vect.h"
kono
parents:
diff changeset
6
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
7 #define N1 3001
111
kono
parents:
diff changeset
8
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
9 #if VECTOR_BITS > 256
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
10 #define N2 (VECTOR_BITS / 32 + 2)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
11 #else
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
12 #define N2 10
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
13 #endif
111
kono
parents:
diff changeset
14
kono
parents:
diff changeset
15 __attribute__ ((noinline)) int
kono
parents:
diff changeset
16 main1 (float *pa)
kono
parents:
diff changeset
17 {
kono
parents:
diff changeset
18 int i;
kono
parents:
diff changeset
19
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
20 for (i = 0; i < N1; i++)
111
kono
parents:
diff changeset
21 {
kono
parents:
diff changeset
22 pa[i] = 2.0;
kono
parents:
diff changeset
23 }
kono
parents:
diff changeset
24
kono
parents:
diff changeset
25 /* check results: */
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
26 for (i = 0; i < N1; i++)
111
kono
parents:
diff changeset
27 {
kono
parents:
diff changeset
28 if (pa[i] != 2.0)
kono
parents:
diff changeset
29 abort ();
kono
parents:
diff changeset
30 }
kono
parents:
diff changeset
31
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
32 for (i = 1; i <= N2; i++)
111
kono
parents:
diff changeset
33 {
kono
parents:
diff changeset
34 pa[i] = 3.0;
kono
parents:
diff changeset
35 }
kono
parents:
diff changeset
36
kono
parents:
diff changeset
37 /* check results: */
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
38 for (i = 1; i <= N2; i++)
111
kono
parents:
diff changeset
39 {
kono
parents:
diff changeset
40 if (pa[i] != 3.0)
kono
parents:
diff changeset
41 abort ();
kono
parents:
diff changeset
42 }
kono
parents:
diff changeset
43
kono
parents:
diff changeset
44 return 0;
kono
parents:
diff changeset
45 }
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 int main (void)
kono
parents:
diff changeset
48 {
kono
parents:
diff changeset
49 int i;
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
50 float a[N1] __attribute__ ((__aligned__(__BIGGEST_ALIGNMENT__)));
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
51 float b[N1] __attribute__ ((__aligned__(__BIGGEST_ALIGNMENT__)));
111
kono
parents:
diff changeset
52
kono
parents:
diff changeset
53 check_vect ();
kono
parents:
diff changeset
54
kono
parents:
diff changeset
55 /* from bzip2: */
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
56 for (i = 0; i < N1; i++)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
57 b[i] = i;
111
kono
parents:
diff changeset
58 a[0] = 0;
kono
parents:
diff changeset
59 for (i = 1; i <= 256; i++) a[i] = b[i-1];
kono
parents:
diff changeset
60
kono
parents:
diff changeset
61 /* check results: */
kono
parents:
diff changeset
62 for (i = 1; i <= 256; i++)
kono
parents:
diff changeset
63 {
kono
parents:
diff changeset
64 if (a[i] != i-1)
kono
parents:
diff changeset
65 abort ();
kono
parents:
diff changeset
66 }
kono
parents:
diff changeset
67 if (a[0] != 0)
kono
parents:
diff changeset
68 abort ();
kono
parents:
diff changeset
69
kono
parents:
diff changeset
70 main1 (a);
kono
parents:
diff changeset
71
kono
parents:
diff changeset
72 return 0;
kono
parents:
diff changeset
73 }
kono
parents:
diff changeset
74
kono
parents:
diff changeset
75 /* 2 loops vectorized in main1, 2 loops vectorized in main:
kono
parents:
diff changeset
76 the first loop in main requires vectorization of conversions,
kono
parents:
diff changeset
77 the second loop in main requires vectorization of misaligned load. */
kono
parents:
diff changeset
78
kono
parents:
diff changeset
79 /* main && main1 together: */
kono
parents:
diff changeset
80 /* { dg-final { scan-tree-dump-times "vectorized 2 loops" 2 "vect" { target powerpc*-*-* i?86-*-* x86_64-*-* } } } */
kono
parents:
diff changeset
81
kono
parents:
diff changeset
82 /* in main1: */
kono
parents:
diff changeset
83 /* { dg-final { scan-tree-dump-times "vectorized 2 loops" 1 "vect" { target !powerpc*-*-* !i?86-*-* !x86_64-*-* } } } */
kono
parents:
diff changeset
84 /* { dg-final { scan-tree-dump-times "vectorized 2 loops" 1 "vect" { target { vect_no_align && { ! vect_hw_misalign } } } } } */
kono
parents:
diff changeset
85
kono
parents:
diff changeset
86 /* in main: */
kono
parents:
diff changeset
87 /* { dg-final { scan-tree-dump-times "vectorized 1 loops" 1 "vect" { target { vect_no_align && { ! vect_hw_misalign } } } } } */
kono
parents:
diff changeset
88