forked from OSchip/llvm-project
[PowerPC] Add floating point overloads for vec_sldw
These are added for compatibility with XLC.
This commit is contained in:
parent
bed58a4a58
commit
bfd60b36f8
|
@ -9091,6 +9091,11 @@ static __inline__ vector unsigned int __ATTRS_o_ai vec_sldw(
|
||||||
return vec_sld(__a, __b, ((__c << 2) & 0x0F));
|
return vec_sld(__a, __b, ((__c << 2) & 0x0F));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static __inline__ vector float __ATTRS_o_ai vec_sldw(
|
||||||
|
vector float __a, vector float __b, unsigned const int __c) {
|
||||||
|
return vec_sld(__a, __b, ((__c << 2) & 0x0F));
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef __VSX__
|
#ifdef __VSX__
|
||||||
static __inline__ vector signed long long __ATTRS_o_ai
|
static __inline__ vector signed long long __ATTRS_o_ai
|
||||||
vec_sldw(vector signed long long __a, vector signed long long __b,
|
vec_sldw(vector signed long long __a, vector signed long long __b,
|
||||||
|
@ -9103,6 +9108,11 @@ vec_sldw(vector unsigned long long __a, vector unsigned long long __b,
|
||||||
unsigned const int __c) {
|
unsigned const int __c) {
|
||||||
return vec_sld(__a, __b, ((__c << 2) & 0x0F));
|
return vec_sld(__a, __b, ((__c << 2) & 0x0F));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static __inline__ vector double __ATTRS_o_ai vec_sldw(
|
||||||
|
vector double __a, vector double __b, unsigned const int __c) {
|
||||||
|
return vec_sld(__a, __b, ((__c << 2) & 0x0F));
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef __POWER9_VECTOR__
|
#ifdef __POWER9_VECTOR__
|
||||||
|
|
|
@ -3759,6 +3759,18 @@ void test6() {
|
||||||
// CHECK-LE: sub nsw i32 31
|
// CHECK-LE: sub nsw i32 31
|
||||||
// CHECK-LE: @llvm.ppc.altivec.vperm
|
// CHECK-LE: @llvm.ppc.altivec.vperm
|
||||||
|
|
||||||
|
res_vf = vec_sldw(vf, vf, 0);
|
||||||
|
// CHECK: add nsw i32 {{[0-9a-zA-Z%.]+}}, 1
|
||||||
|
// CHECK: add nsw i32 {{[0-9a-zA-Z%.]+}}, 2
|
||||||
|
// CHECK: add nsw i32 {{[0-9a-zA-Z%.]+}}, 3
|
||||||
|
// CHECK: add nsw i32 {{[0-9a-zA-Z%.]+}}, 15
|
||||||
|
// CHECK: @llvm.ppc.altivec.vperm
|
||||||
|
// CHECK-LE: sub nsw i32 16
|
||||||
|
// CHECK-LE: sub nsw i32 17
|
||||||
|
// CHECK-LE: sub nsw i32 18
|
||||||
|
// CHECK-LE: sub nsw i32 31
|
||||||
|
// CHECK-LE: @llvm.ppc.altivec.vperm
|
||||||
|
|
||||||
res_vsc = vec_vsldoi(vsc, vsc, 0);
|
res_vsc = vec_vsldoi(vsc, vsc, 0);
|
||||||
// CHECK: add nsw i32 {{[0-9a-zA-Z%.]+}}, 1
|
// CHECK: add nsw i32 {{[0-9a-zA-Z%.]+}}, 1
|
||||||
// CHECK: add nsw i32 {{[0-9a-zA-Z%.]+}}, 2
|
// CHECK: add nsw i32 {{[0-9a-zA-Z%.]+}}, 2
|
||||||
|
|
|
@ -1888,6 +1888,18 @@ void test1() {
|
||||||
// CHECK-LE: sub nsw i32 17
|
// CHECK-LE: sub nsw i32 17
|
||||||
// CHECK-LE: sub nsw i32 18
|
// CHECK-LE: sub nsw i32 18
|
||||||
// CHECK-LE: sub nsw i32 31
|
// CHECK-LE: sub nsw i32 31
|
||||||
|
// CHECK-LE: @llvm.ppc.altivec.vperm
|
||||||
|
|
||||||
|
res_vd = vec_sldw(vd, vd, 0);
|
||||||
|
// CHECK: add nsw i32 {{[0-9a-zA-Z%.]+}}, 1
|
||||||
|
// CHECK: add nsw i32 {{[0-9a-zA-Z%.]+}}, 2
|
||||||
|
// CHECK: add nsw i32 {{[0-9a-zA-Z%.]+}}, 3
|
||||||
|
// CHECK: add nsw i32 {{[0-9a-zA-Z%.]+}}, 15
|
||||||
|
// CHECK: @llvm.ppc.altivec.vperm
|
||||||
|
// CHECK-LE: sub nsw i32 16
|
||||||
|
// CHECK-LE: sub nsw i32 17
|
||||||
|
// CHECK-LE: sub nsw i32 18
|
||||||
|
// CHECK-LE: sub nsw i32 31
|
||||||
// CHECK-LE: @llvm.ppc.altivec.vperm
|
// CHECK-LE: @llvm.ppc.altivec.vperm
|
||||||
|
|
||||||
res_vsll = vec_sll(vsll, vuc);
|
res_vsll = vec_sll(vsll, vuc);
|
||||||
|
|
Loading…
Reference in New Issue