annotate gcc/testsuite/gcc.target/i386/pr92658-avx512vl.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 -mavx512f -mavx512vl" } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
4
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
5 typedef unsigned char v16qi __attribute__((vector_size (16)));
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
6 typedef unsigned short v8hi __attribute__((vector_size (16)));
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
7 typedef unsigned int v4si __attribute__((vector_size (16)));
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
8 typedef unsigned int v8si __attribute__((vector_size (32)));
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
9 typedef unsigned long long v2di __attribute__((vector_size (16)));
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
10 typedef unsigned long long v4di __attribute__((vector_size (32)));
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
11
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
12 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
13 truncqd_256 (v4si * dst, v4di * __restrict src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
14 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
15 unsigned tem[4];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
16 tem[0] = (*src)[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
17 tem[1] = (*src)[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
18 tem[2] = (*src)[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
19 tem[3] = (*src)[3];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
20 dst[0] = *(v4si *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
21 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
22
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
23 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
24 truncqw_256 (v8hi * dst, v4di * __restrict src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
25 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
26 unsigned short tem[4];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
27 tem[0] = (*src)[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
28 tem[1] = (*src)[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
29 tem[2] = (*src)[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
30 tem[3] = (*src)[3];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
31 dst[0] = *(v8hi *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
32 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
33
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
34 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
35 truncqb_256 (v16qi * dst, v4di * __restrict src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
36 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
37 unsigned char tem[4];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
38 tem[0] = (*src)[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
39 tem[1] = (*src)[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
40 tem[2] = (*src)[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
41 tem[3] = (*src)[3];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
42 dst[0] = *(v16qi *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
43 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
44
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
45 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
46 truncqd_128 (v4si * dst, v2di * __restrict src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
47 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
48 unsigned tem[4];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
49 tem[0] = (*src)[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
50 tem[1] = (*src)[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
51 dst[0] = *(v4si *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
52 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
53
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
54 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
55 truncqw_128 (v8hi * dst, v2di * __restrict src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
56 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
57 unsigned short tem[4];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
58 tem[0] = (*src)[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
59 tem[1] = (*src)[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
60 dst[0] = *(v8hi *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
61 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
62
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
63 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
64 truncqb_128 (v16qi * dst, v2di * __restrict src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
65 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
66 unsigned char tem[4];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
67 tem[0] = (*src)[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
68 tem[1] = (*src)[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
69 dst[0] = *(v16qi *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
70 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
71
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
72 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
73 truncdw_256 (v8hi * dst, v8si * __restrict src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
74 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
75 unsigned short tem[8];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
76 tem[0] = (*src)[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
77 tem[1] = (*src)[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
78 tem[2] = (*src)[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
79 tem[3] = (*src)[3];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
80 tem[4] = (*src)[4];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
81 tem[5] = (*src)[5];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
82 tem[6] = (*src)[6];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
83 tem[7] = (*src)[7];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
84 dst[0] = *(v8hi *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
85 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
86
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
87 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
88 truncdb_256 (v16qi * dst, v8si * __restrict src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
89 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
90 unsigned char tem[8];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
91 tem[0] = (*src)[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
92 tem[1] = (*src)[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
93 tem[2] = (*src)[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
94 tem[3] = (*src)[3];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
95 tem[4] = (*src)[4];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
96 tem[5] = (*src)[5];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
97 tem[6] = (*src)[6];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
98 tem[7] = (*src)[7];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
99 dst[0] = *(v16qi *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
100 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
101
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
102 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
103 truncdw_128 (v8hi * dst, v4si * __restrict src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
104 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
105 unsigned short tem[8];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
106 tem[0] = (*src)[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
107 tem[1] = (*src)[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
108 tem[2] = (*src)[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
109 tem[3] = (*src)[3];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
110 dst[0] = *(v8hi *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
111 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
112
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
113 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
114 truncdb_128 (v16qi * dst, v4si * __restrict src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
115 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
116 unsigned char tem[8];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
117 tem[0] = (*src)[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
118 tem[1] = (*src)[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
119 tem[2] = (*src)[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
120 tem[3] = (*src)[3];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
121 dst[0] = *(v16qi *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
122 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
123
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
124 /* { dg-final { scan-assembler-times "vpmovqd" 2 } } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
125 /* { dg-final { scan-assembler-times "vpmovqw" 2 { xfail *-*-* } } } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
126 /* { dg-final { scan-assembler-times "vpmovqb" 2 { xfail *-*-* } } } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
127 /* { dg-final { scan-assembler-times "vpmovdw" 1 } } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
128 /* { dg-final { scan-assembler-times "vpmovdw" 2 { xfail *-*-* } } } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
129 /* { dg-final { scan-assembler-times "vpmovdb" 2 { xfail *-*-* } } } */