1 /* { dg-do compile } */
2 /* { dg-require-effective-target powerpc_p8vector_ok } */
3 /* { dg-options "-maltivec -mdejagnu-cpu=power8" } */
4 
5 #include <altivec.h>
6 
7 vector bool long long
test_eq_long_long(vector bool long long x,vector bool long long y)8 test_eq_long_long (vector bool long long x, vector bool long long y)
9 {
10 	return vec_cmpeq (x, y);
11 }
12 
13 vector unsigned char
test_vsi_packs_vusi_vusi(vector unsigned short x,vector unsigned short y)14 test_vsi_packs_vusi_vusi (vector unsigned short x,
15                           vector unsigned short y)
16 {
17   return vec_packs (x, y);
18 }
19 
20 vector signed char
test_vsi_packs_vssi_vssi(vector signed short x,vector signed short y)21 test_vsi_packs_vssi_vssi (vector signed short x,
22                           vector signed short y)
23 {
24   return vec_packs (x, y);
25 }
26 
27 vector signed short int
test_vsi_packs_vsi_vsi(vector signed int x,vector signed int y)28 test_vsi_packs_vsi_vsi (vector signed int x,
29 			vector signed int y)
30 {
31   return vec_packs (x, y);
32 }
33 
34 vector unsigned short int
test_vsi_packs_vui_vui(vector unsigned int x,vector unsigned int y)35 test_vsi_packs_vui_vui (vector unsigned int x,
36 			vector unsigned int y)
37 {
38   return vec_packs (x, y);
39 }
40 
41 vector signed int
test_vsi_packs_vsll_vsll(vector signed long long x,vector signed long long y)42 test_vsi_packs_vsll_vsll (vector signed long long x,
43                           vector signed long long y)
44 {
45   return vec_packs (x, y);
46 }
47 
48 vector unsigned int
test_vui_packs_vull_vull(vector unsigned long long x,vector unsigned long long y)49 test_vui_packs_vull_vull (vector unsigned long long x,
50                           vector unsigned long long y)
51 {
52   return vec_packs (x, y);
53 }
54 
55 vector unsigned char
test_vsi_packsu_vssi_vssi(vector signed short x,vector signed short y)56 test_vsi_packsu_vssi_vssi (vector signed short x,
57 			   vector signed short y)
58 {
59   return vec_packsu (x, y);
60 }
61 
62 vector unsigned char
test_vsi_packsu_vusi_vusi(vector unsigned short x,vector unsigned short y)63 test_vsi_packsu_vusi_vusi (vector unsigned short x,
64 			   vector unsigned short y)
65 {
66   return vec_packsu (x, y);
67 }
68 
69 vector unsigned int
test_vsi_packsu_vsll_vsll(vector signed long long x,vector signed long long y)70 test_vsi_packsu_vsll_vsll (vector signed long long x,
71 			   vector signed long long y)
72 {
73   return vec_packsu (x, y);
74 }
75 
76 vector unsigned int
test_vsi_packsu_vull_vull(vector unsigned long long x,vector unsigned long long y)77 test_vsi_packsu_vull_vull (vector unsigned long long x,
78 			   vector unsigned long long y)
79 {
80   return vec_packsu (x, y);
81 }
82 
83 vector unsigned short int
test_vsi_packsu_vsi_vsi(vector signed int x,vector signed int y)84 test_vsi_packsu_vsi_vsi (vector signed int x,
85 			 vector signed int y)
86 {
87   return vec_packsu (x, y);
88 }
89 
90 vector unsigned short int
test_vsi_packsu_vui_vui(vector unsigned int x,vector unsigned int y)91 test_vsi_packsu_vui_vui (vector unsigned int x,
92 			 vector unsigned int y)
93 {
94   return vec_packsu (x, y);
95 }
96 
97 vector unsigned char
test_unsigned_char_popcnt_signed_char(vector signed char x)98 test_unsigned_char_popcnt_signed_char (vector signed char x)
99 {
100 	return vec_popcnt (x);
101 }
102 
103 vector unsigned char
test_unsigned_char_popcnt_unsigned_char(vector unsigned char x)104 test_unsigned_char_popcnt_unsigned_char (vector unsigned char x)
105 {
106 	return vec_popcnt (x);
107 }
108 
109 vector unsigned short
test_unsigned_short_popcnt_signed_short(vector short x)110 test_unsigned_short_popcnt_signed_short (vector short x)
111 {
112 	return vec_popcnt (x);
113 }
114 
115 vector unsigned short
test_unsigned_short_popcnt_unsigned_short(vector unsigned short x)116 test_unsigned_short_popcnt_unsigned_short (vector unsigned short x)
117 {
118 	return vec_popcnt (x);
119 }
120 
121 vector unsigned int
test_unsigned_int_popcnt_signed_int(vector int x)122 test_unsigned_int_popcnt_signed_int (vector int x)
123 {
124 	return vec_popcnt (x);
125 }
126 
127 vector unsigned int
test_unsigned_int_popcnt_unsigned_int(vector unsigned x)128 test_unsigned_int_popcnt_unsigned_int (vector unsigned x)
129 {
130    return vec_popcnt (x);
131 }
132 
133 vector unsigned long long
test_unsigned_long_lont_popcnt_signed_long(vector long long x)134 test_unsigned_long_lont_popcnt_signed_long (vector long long x)
135 {
136 	return vec_popcnt (x);
137 }
138 
139 vector unsigned long long
test_unsigned_long_long_popcnt_unsigned_long(vector unsigned long long x)140 test_unsigned_long_long_popcnt_unsigned_long (vector unsigned long long x)
141 {
142 	return vec_popcnt (x);
143 }
144 
145 vector signed short
test_vss_mradds_vss_vss(vector signed short x,vector signed short y,vector signed short z)146 test_vss_mradds_vss_vss (vector signed short x, vector signed short y,
147                          vector signed short z)
148 {
149 	return vec_mradds (x, y, z);
150 }
151 
152 vector signed long long
test_vsll_mule_vsi_vsi(vector signed int x,vector signed int y)153 test_vsll_mule_vsi_vsi (vector signed int x, vector signed int y)
154 {
155 	return vec_mule (x, y);
156 }
157 
158 vector unsigned long long
test_vull_mule_vui_vui(vector unsigned int x,vector unsigned int y)159 test_vull_mule_vui_vui (vector unsigned int x, vector unsigned int y)
160 {
161 	return vec_mule (x, y);
162 }
163 
164 vector signed long long
test_vsll_mulo_vsi_vsi(vector signed int x,vector signed int y)165 test_vsll_mulo_vsi_vsi (vector signed int x, vector signed int y)
166 {
167 	return vec_mulo (x, y);
168 }
169 
170 vector unsigned long long
test_vull_mulo_vui_vui(vector unsigned int x,vector unsigned int y)171 test_vull_mulo_vui_vui (vector unsigned int x, vector unsigned int y)
172 {
173 	return vec_mulo (x, y);
174 }
175 
176 vector signed char
test_neg_char(vector signed char x)177 test_neg_char (vector signed char x)
178 {
179 	return vec_neg (x);
180 }
181 
182 vector short
test_neg_short(vector short x)183 test_neg_short (vector short x)
184 {
185 	return vec_neg (x);
186 }
187 
188 vector int
test_neg_int(vector int x)189 test_neg_int (vector int x)
190 {
191 	return vec_neg (x);
192 }
193 
194 vector float
test_neg_float(vector float x)195 test_neg_float (vector float x)
196 {
197 	return vec_neg (x);
198 }
199 
200 vector double
test_neg_double(vector double x)201 test_neg_double (vector double x)
202 {
203 	return vec_neg (x);
204 }
205 
206 
207 /* Expected test results:
208 
209      test_eq_long_long                         1 vcmpequd inst
210      test_vsi_packs_vsll_vsll                  1 vpksdss
211      test_vui_packs_vull_vull                  1 vpkudus
212      test_vui_packs_vssi_vssi                  1 vpkshss
213      test_vsi_packsu_vssi_vssi                 1 vpkshus
214      test_vsi_packsu_vsll_vsll                 1 vpksdus
215      test_vsi_packsu_vull_vull                 1 vpkudus
216      test_unsigned_char_popcnt_signed_char     1 vpopcntb
217      test_unsigned_char_popcnt_unsigned_char   1 vpopcntb
218      test_unsigned_short_popcnt_signed_short   1 vpopcnth
219      test_unsigned_short_popcnt_unsigned_short 1 vpopcnth
220      test_unsigned_int_popcnt_signed_int       2 vpopcntw
221      test_unsigned_int_popcnt_unsigned_int     1 vpopcntd
222      test_unsigned_long_long_popcnt_unsigned_long 1 vpopcntd
223      test_vss_mradds_vss_vsss                  1 vmhraddshs
224      test_vsll_mulo_vsi_vsi                    1 vmulosw
225      test_vull_mulo_vui_vui                    1 vmulouw
226      test_vsll_mule_vsi_vsi                    1 vmulesw
227      test_vull_mule_vui_vui                    1 vmuleuw
228      test_neg_char                             1 vspltisw, 1 vsububm
229      test_neg_short                            1 vspltisw, 1 vsubuhm
230      test_neg_int                              1 vspltisw, 1 vsubuwm
231      test_neg_float                            1 xvnegsp
232      test_neg_float                            1 xvnegdp
233  */
234 
235 /* { dg-final { scan-assembler-times "vcmpequd" 1 } } */
236 /* { dg-final { scan-assembler-times "vpksdss"  1 } } */
237 /* { dg-final { scan-assembler-times "vpkudus"  2 } } */
238 /* { dg-final { scan-assembler-times "vpkuhus"  2 } } */
239 /* { dg-final { scan-assembler-times "vpkshss"  1 } } */
240 /* { dg-final { scan-assembler-times "vpkshus"  1 } } */
241 /* { dg-final { scan-assembler-times "vpksdus"  1 } } */
242 /* { dg-final { scan-assembler-times "vpkuwus"  2 } } */
243 /* { dg-final { scan-assembler-times "vpopcntb" 2 } } */
244 /* { dg-final { scan-assembler-times "vpopcnth" 2 } } */
245 /* { dg-final { scan-assembler-times "vpopcntw" 2 } } */
246 /* { dg-final { scan-assembler-times "vpopcntd" 2 } } */
247 /* { dg-final { scan-assembler-times "vmhraddshs"  1 } } */
248 /* { dg-final { scan-assembler-times "vmulosw"  1 } } */
249 /* { dg-final { scan-assembler-times "vmulouw"  1 } } */
250 /* { dg-final { scan-assembler-times "vmulesw"  1 } } */
251 /* { dg-final { scan-assembler-times "vmuleuw"  1 } } */
252 /* { dg-final { scan-assembler-times "vspltisw" 3 } } */
253 /* { dg-final { scan-assembler-times "vsububm"  1 } } */
254 /* { dg-final { scan-assembler-times "vsubuhm"  1 } } */
255 /* { dg-final { scan-assembler-times "vsubuwm"  1 } } */
256 /* { dg-final { scan-assembler-times "xvnegsp"  1 } } */
257 /* { dg-final { scan-assembler-times "xvnegdp"  1 } } */
258 
259