annotate gcc/testsuite/gcc.target/i386/pr92658-sse4.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 -msse4.1" } */
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 long long v2di __attribute__((vector_size (16)));
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 (v8hi * dst, v16qi * __restrict src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
12 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
13 unsigned short tem[8];
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 dst[0] = *(v8hi *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
23 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
24
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
25 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
26 bar_u8_u16 (v8hi * dst, v16qi src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
27 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
28 unsigned short tem[8];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
29 tem[0] = src[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
30 tem[1] = src[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
31 tem[2] = src[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
32 tem[3] = src[3];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
33 tem[4] = src[4];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
34 tem[5] = src[5];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
35 tem[6] = src[6];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
36 tem[7] = src[7];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
37 dst[0] = *(v8hi *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
38 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
39
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
40 /* { dg-final { scan-assembler-times "pmovzxbw" 2 } } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
41
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
42 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
43 foo_u8_u32 (v4si * dst, v16qi * __restrict src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
44 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
45 unsigned int tem[4];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
46 tem[0] = (*src)[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
47 tem[1] = (*src)[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
48 tem[2] = (*src)[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
49 tem[3] = (*src)[3];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
50 dst[0] = *(v4si *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
51 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
52
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
53 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
54 bar_u8_u32 (v4si * dst, v16qi src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
55 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
56 unsigned int tem[4];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
57 tem[0] = src[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
58 tem[1] = src[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
59 tem[2] = src[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
60 tem[3] = src[3];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
61 dst[0] = *(v4si *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
62 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
63
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
64 /* { dg-final { scan-assembler-times "pmovzxbd" 2 { xfail *-*-* } } } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
65
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
66 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
67 foo_u8_u64 (v2di * dst, v16qi * __restrict src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
68 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
69 unsigned long long tem[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
70 tem[0] = (*src)[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
71 tem[1] = (*src)[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
72 dst[0] = *(v2di *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
73 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
74
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
75 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
76 bar_u8_u64 (v2di * dst, v16qi src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
77 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
78 unsigned long long tem[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
79 tem[0] = src[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
80 tem[1] = src[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
81 dst[0] = *(v2di *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
82 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
83
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
84 /* { dg-final { scan-assembler-times "pmovzxbq" 2 { xfail *-*-* } } } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
85
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
86 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
87 foo_u16_u32 (v4si * dst, v8hi * __restrict src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
88 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
89 unsigned int tem[4];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
90 tem[0] = (*src)[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
91 tem[1] = (*src)[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
92 tem[2] = (*src)[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
93 tem[3] = (*src)[3];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
94 dst[0] = *(v4si *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
95 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
96
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
97 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
98 bar_u16_u32 (v4si * dst, v8hi src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
99 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
100 unsigned int tem[4];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
101 tem[0] = src[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
102 tem[1] = src[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
103 tem[2] = src[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
104 tem[3] = src[3];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
105 dst[0] = *(v4si *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
106 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
107
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
108 /* { dg-final { scan-assembler-times "pmovzxwd" 2 } } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
109
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
110 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
111 foo_u16_u64 (v2di * dst, v8hi * __restrict src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
112 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
113 unsigned long long tem[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
114 tem[0] = (*src)[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
115 tem[1] = (*src)[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
116 dst[0] = *(v2di *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
117 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
118
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
119 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
120 bar_u16_u64 (v2di * dst, v8hi src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
121 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
122 unsigned long long tem[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
123 tem[0] = src[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
124 tem[1] = src[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
125 dst[0] = *(v2di *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
126 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
127
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
128 /* { dg-final { scan-assembler-times "pmovzxwq" 2 { xfail *-*-* } } } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
129
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
130 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
131 foo_u32_u64 (v2di * dst, v4si * __restrict src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
132 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
133 unsigned long long tem[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
134 tem[0] = (*src)[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
135 tem[1] = (*src)[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
136 dst[0] = *(v2di *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
137 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
138
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
139 void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
140 bar_u32_u64 (v2di * dst, v4si src)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
141 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
142 unsigned long long tem[2];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
143 tem[0] = src[0];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
144 tem[1] = src[1];
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
145 dst[0] = *(v2di *) tem;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
146 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
147
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
148 /* { dg-final { scan-assembler-times "pmovzxdq" 2 } } */