annotate gcc/testsuite/gcc.target/i386/pr92658-avx2.c @ 152:2b5abeee2509

update gcc11
author anatofuz
date Mon, 25 May 2020 07:50:57 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
152
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
1 /* PR target/92658 */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
2 /* { dg-do compile } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
3 /* { dg-options "-O2 -ftree-vectorize -mavx2" } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
4
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
5 typedef unsigned char v32qi __attribute__((vector_size (32)));
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
6 typedef unsigned short v16hi __attribute__((vector_size (32)));
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
7 typedef unsigned int v8si __attribute__((vector_size (32)));
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
8 typedef unsigned long long v4di __attribute__((vector_size (32)));
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
9
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
10 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
11 foo_u8_u16 (v16hi * dst, v32qi * __restrict src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
12 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
13 unsigned short tem[16];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
14 tem[0] = (*src)[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
15 tem[1] = (*src)[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
16 tem[2] = (*src)[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
17 tem[3] = (*src)[3];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
18 tem[4] = (*src)[4];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
19 tem[5] = (*src)[5];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
20 tem[6] = (*src)[6];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
21 tem[7] = (*src)[7];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
22 tem[8] = (*src)[8];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
23 tem[9] = (*src)[9];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
24 tem[10] = (*src)[10];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
25 tem[11] = (*src)[11];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
26 tem[12] = (*src)[12];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
27 tem[13] = (*src)[13];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
28 tem[14] = (*src)[14];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
29 tem[15] = (*src)[15];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
30 dst[0] = *(v16hi *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
31 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
32
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
33 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
34 bar_u8_u16 (v16hi * dst, v32qi src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
35 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
36 unsigned short tem[16];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
37 tem[0] = src[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
38 tem[1] = src[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
39 tem[2] = src[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
40 tem[3] = src[3];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
41 tem[4] = src[4];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
42 tem[5] = src[5];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
43 tem[6] = src[6];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
44 tem[7] = src[7];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
45 tem[8] = src[8];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
46 tem[9] = src[9];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
47 tem[10] = src[10];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
48 tem[11] = src[11];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
49 tem[12] = src[12];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
50 tem[13] = src[13];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
51 tem[14] = src[14];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
52 tem[15] = src[15];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
53 dst[0] = *(v16hi *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
54 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
55
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
56 /* { dg-final { scan-assembler-times "pmovzxbw" 2 } } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
57
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
58 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
59 foo_u8_u32 (v8si * dst, v32qi * __restrict src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
60 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
61 unsigned int tem[8];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
62 tem[0] = (*src)[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
63 tem[1] = (*src)[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
64 tem[2] = (*src)[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
65 tem[3] = (*src)[3];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
66 tem[4] = (*src)[4];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
67 tem[5] = (*src)[5];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
68 tem[6] = (*src)[6];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
69 tem[7] = (*src)[7];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
70 dst[0] = *(v8si *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
71 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
72
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
73 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
74 bar_u8_u32 (v8si * dst, v32qi src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
75 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
76 unsigned int tem[8];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
77 tem[0] = src[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
78 tem[1] = src[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
79 tem[2] = src[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
80 tem[3] = src[3];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
81 tem[4] = src[4];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
82 tem[5] = src[5];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
83 tem[6] = src[6];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
84 tem[7] = src[7];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
85 dst[0] = *(v8si *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
86 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
87
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
88 /* { dg-final { scan-assembler-times "pmovzxbd" 2 } } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
89
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
90 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
91 foo_u8_u64 (v4di * dst, v32qi * __restrict src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
92 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
93 unsigned long long tem[4];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
94 tem[0] = (*src)[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
95 tem[1] = (*src)[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
96 tem[2] = (*src)[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
97 tem[3] = (*src)[3];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
98 dst[0] = *(v4di *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
99 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
100
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
101 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
102 bar_u8_u64 (v4di * dst, v32qi src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
103 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
104 unsigned long long tem[4];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
105 tem[0] = src[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
106 tem[1] = src[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
107 tem[2] = src[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
108 tem[3] = src[3];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
109 dst[0] = *(v4di *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
110 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
111
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
112 /* { dg-final { scan-assembler-times "pmovzxbq" 2 { xfail *-*-* } } } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
113
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
114 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
115 foo_u16_u32 (v8si * dst, v16hi * __restrict src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
116 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
117 unsigned int tem[8];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
118 tem[0] = (*src)[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
119 tem[1] = (*src)[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
120 tem[2] = (*src)[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
121 tem[3] = (*src)[3];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
122 tem[4] = (*src)[4];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
123 tem[5] = (*src)[5];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
124 tem[6] = (*src)[6];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
125 tem[7] = (*src)[7];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
126 dst[0] = *(v8si *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
127 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
128
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
129 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
130 bar_u16_u32 (v8si * dst, v16hi src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
131 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
132 unsigned int tem[8];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
133 tem[0] = src[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
134 tem[1] = src[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
135 tem[2] = src[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
136 tem[3] = src[3];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
137 tem[4] = src[4];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
138 tem[5] = src[5];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
139 tem[6] = src[6];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
140 tem[7] = src[7];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
141 dst[0] = *(v8si *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
142 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
143
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
144 /* { dg-final { scan-assembler-times "pmovzxwd" 2 } } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
145
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
146 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
147 foo_u16_u64 (v4di * dst, v16hi * __restrict src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
148 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
149 unsigned long long tem[4];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
150 tem[0] = (*src)[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
151 tem[1] = (*src)[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
152 tem[2] = (*src)[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
153 tem[3] = (*src)[3];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
154 dst[0] = *(v4di *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
155 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
156
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
157 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
158 bar_u16_u64 (v4di * dst, v16hi src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
159 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
160 unsigned long long tem[4];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
161 tem[0] = src[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
162 tem[1] = src[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
163 tem[2] = src[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
164 tem[3] = src[3];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
165 dst[0] = *(v4di *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
166 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
167
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
168 /* { dg-final { scan-assembler-times "pmovzxwq" 2 } } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
169
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
170 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
171 foo_u32_u64 (v4di * dst, v8si * __restrict src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
172 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
173 unsigned long long tem[4];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
174 tem[0] = (*src)[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
175 tem[1] = (*src)[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
176 tem[2] = (*src)[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
177 tem[3] = (*src)[3];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
178 dst[0] = *(v4di *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
179 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
180
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
181 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
182 bar_u32_u64 (v4di * dst, v8si src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
183 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
184 unsigned long long tem[4];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
185 tem[0] = src[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
186 tem[1] = src[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
187 tem[2] = src[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
188 tem[3] = src[3];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
189 dst[0] = *(v4di *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
190 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
191
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
192 /* { dg-final { scan-assembler-times "pmovzxdq" 2 } } */