annotate gcc/testsuite/gcc.dg/vect/vect-multitypes-4.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_int } */
kono
parents:
diff changeset
2 /* { dg-add-options bind_pic_locally } */
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
kono
parents:
diff changeset
7 #define N 32
kono
parents:
diff changeset
8
kono
parents:
diff changeset
9 unsigned short sa[N];
kono
parents:
diff changeset
10 unsigned short sc[N] = {0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,
kono
parents:
diff changeset
11 16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31};
kono
parents:
diff changeset
12 unsigned short sb[N] = {0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,
kono
parents:
diff changeset
13 16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31};
kono
parents:
diff changeset
14 unsigned int ia[N];
kono
parents:
diff changeset
15 unsigned int ic[N] = {0,3,6,9,12,15,18,21,24,27,30,33,36,39,42,45,
kono
parents:
diff changeset
16 0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15};
kono
parents:
diff changeset
17 unsigned int ib[N] = {0,3,6,9,12,15,18,21,24,27,30,33,36,39,42,45,
kono
parents:
diff changeset
18 0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15};
kono
parents:
diff changeset
19
kono
parents:
diff changeset
20 /* Current peeling-for-alignment scheme will consider the 'sa[i+7]'
kono
parents:
diff changeset
21 access for peeling, and therefore will examine the option of
kono
parents:
diff changeset
22 using a peeling factor = VF-7%VF. This will result in a peeling factor 1,
kono
parents:
diff changeset
23 which will also align the access to 'ia[i+3]', and the loop could be
kono
parents:
diff changeset
24 vectorized on all targets that support unaligned loads.
kono
parents:
diff changeset
25 Without cost model on targets that support misaligned stores, no peeling
kono
parents:
diff changeset
26 will be applied since we want to keep the four loads aligned. */
kono
parents:
diff changeset
27
kono
parents:
diff changeset
28 __attribute__ ((noinline))
kono
parents:
diff changeset
29 int main1 (int n)
kono
parents:
diff changeset
30 {
kono
parents:
diff changeset
31 int i;
kono
parents:
diff changeset
32
kono
parents:
diff changeset
33 /* Multiple types with different sizes, used in independent
kono
parents:
diff changeset
34 copmutations. Vectorizable. */
kono
parents:
diff changeset
35 for (i = 0; i < n; i++)
kono
parents:
diff changeset
36 {
kono
parents:
diff changeset
37 sa[i+7] = sb[i] + sc[i];
kono
parents:
diff changeset
38 ia[i+3] = ib[i] + ic[i];
kono
parents:
diff changeset
39 }
kono
parents:
diff changeset
40
kono
parents:
diff changeset
41 /* check results: */
kono
parents:
diff changeset
42 for (i = 0; i < n; i++)
kono
parents:
diff changeset
43 {
kono
parents:
diff changeset
44 if (sa[i+7] != sb[i] + sc[i] || ia[i+3] != ib[i] + ic[i])
kono
parents:
diff changeset
45 abort ();
kono
parents:
diff changeset
46 }
kono
parents:
diff changeset
47
kono
parents:
diff changeset
48 return 0;
kono
parents:
diff changeset
49 }
kono
parents:
diff changeset
50
kono
parents:
diff changeset
51 /* Current peeling-for-alignment scheme will consider the 'ia[i+3]'
kono
parents:
diff changeset
52 access for peeling, and therefore will examine the option of
kono
parents:
diff changeset
53 using a peeling factor = VF-3%VF. This will result in a peeling factor
kono
parents:
diff changeset
54 1 if VF=4,2. This will not align the access to 'sa[i+3]', for which we
kono
parents:
diff changeset
55 need to peel 5,1 iterations for VF=4,2 respectively, so the loop can not
kono
parents:
diff changeset
56 be vectorized. However, 'ia[i+3]' also gets aligned if we peel 5
kono
parents:
diff changeset
57 iterations, so the loop is vectorizable on all targets that support
kono
parents:
diff changeset
58 unaligned loads.
kono
parents:
diff changeset
59 Without cost model on targets that support misaligned stores, no peeling
kono
parents:
diff changeset
60 will be applied since we want to keep the four loads aligned. */
kono
parents:
diff changeset
61
kono
parents:
diff changeset
62 __attribute__ ((noinline))
kono
parents:
diff changeset
63 int main2 (int n)
kono
parents:
diff changeset
64 {
kono
parents:
diff changeset
65 int i;
kono
parents:
diff changeset
66
kono
parents:
diff changeset
67 /* Multiple types with different sizes, used in independent
kono
parents:
diff changeset
68 copmutations. Vectorizable. */
kono
parents:
diff changeset
69 for (i = 0; i < n; i++)
kono
parents:
diff changeset
70 {
kono
parents:
diff changeset
71 ia[i+3] = ib[i] + ic[i];
kono
parents:
diff changeset
72 sa[i+3] = sb[i] + sc[i];
kono
parents:
diff changeset
73 }
kono
parents:
diff changeset
74
kono
parents:
diff changeset
75 /* check results: */
kono
parents:
diff changeset
76 for (i = 0; i < n; i++)
kono
parents:
diff changeset
77 {
kono
parents:
diff changeset
78 if (sa[i+3] != sb[i] + sc[i] || ia[i+3] != ib[i] + ic[i])
kono
parents:
diff changeset
79 abort ();
kono
parents:
diff changeset
80 }
kono
parents:
diff changeset
81
kono
parents:
diff changeset
82 return 0;
kono
parents:
diff changeset
83 }
kono
parents:
diff changeset
84
kono
parents:
diff changeset
85 int main (void)
kono
parents:
diff changeset
86 {
kono
parents:
diff changeset
87 check_vect ();
kono
parents:
diff changeset
88
kono
parents:
diff changeset
89 main1 (N-7);
kono
parents:
diff changeset
90 main2 (N-3);
kono
parents:
diff changeset
91
kono
parents:
diff changeset
92 return 0;
kono
parents:
diff changeset
93 }
kono
parents:
diff changeset
94
kono
parents:
diff changeset
95 /* { dg-final { scan-tree-dump-times "vectorized 1 loops" 2 "vect" { xfail { vect_no_align && { ! vect_hw_misalign } } } } } */
kono
parents:
diff changeset
96 /* { dg-final { scan-tree-dump-times "Alignment of access forced using peeling" 0 "vect" { target { vect_element_align} } } } */
kono
parents:
diff changeset
97 /* { dg-final { scan-tree-dump-times "Alignment of access forced using peeling" 2 "vect" { xfail { vect_no_align || vect_element_align } } } } */
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
98 /* { dg-final { scan-tree-dump-times "Vectorizing an unaligned access" 8 "vect" { target { ! vect_element_align } xfail { ! vect_unaligned_possible } } } } */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
99 /* { dg-final { scan-tree-dump-times "Vectorizing an unaligned access" 4 "vect" { target { vect_element_align } xfail { ! vect_unaligned_possible } } } } */
111
kono
parents:
diff changeset
100