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
|
/* { dg-do compile } */
/* { dg-require-effective-target powerpc_p8vector_ok } */
/* { dg-options "-mcpu=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 float
test_pack_float (vector double x, vector double y)
{
return vec_pack (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_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);
}
/* Expected test results:
test_eq_long_long 1 vcmpequd inst
test_pack_float 1 vpkudum inst
test_vsi_packs_vsll_vsll 1 vpksdss
test_vui_packs_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 */
/* { dg-final { scan-assembler-times "vcmpequd" 1 } } */
/* { dg-final { scan-assembler-times "vpkudum" 1 } } */
/* { dg-final { scan-assembler-times "vpksdss" 1 } } */
/* { dg-final { scan-assembler-times "vpkudus" 1 } } */
/* { 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 } } */
|