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