2018-03-27 01:46:25 +08:00
|
|
|
; RUN: llc -mcpu=pwr9 -mtriple=powerpc64le-unknown-unknown \
|
2018-07-13 04:18:57 +08:00
|
|
|
; RUN: -enable-ppc-quad-precision -verify-machineinstrs \
|
|
|
|
; RUN: -ppc-asm-full-reg-names -ppc-vsr-nums-as-vr < %s | FileCheck %s
|
2018-03-20 02:52:20 +08:00
|
|
|
|
|
|
|
; Function Attrs: norecurse nounwind
|
|
|
|
define void @qpAdd(fp128* nocapture readonly %a, fp128* nocapture %res) {
|
|
|
|
entry:
|
|
|
|
%0 = load fp128, fp128* %a, align 16
|
|
|
|
%add = fadd fp128 %0, %0
|
|
|
|
store fp128 %add, fp128* %res, align 16
|
|
|
|
ret void
|
|
|
|
; CHECK-LABEL: qpAdd
|
2018-03-22 04:59:45 +08:00
|
|
|
; CHECK-NOT: bl __addtf3
|
|
|
|
; CHECK: xsaddqp
|
|
|
|
; CHECK: stxv
|
|
|
|
; CHECK: blr
|
2018-03-20 02:52:20 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
; Function Attrs: norecurse nounwind
|
|
|
|
define void @qpSub(fp128* nocapture readonly %a, fp128* nocapture %res) {
|
|
|
|
entry:
|
|
|
|
%0 = load fp128, fp128* %a, align 16
|
|
|
|
%sub = fsub fp128 %0, %0
|
|
|
|
store fp128 %sub, fp128* %res, align 16
|
|
|
|
ret void
|
|
|
|
; CHECK-LABEL: qpSub
|
2018-03-22 04:59:45 +08:00
|
|
|
; CHECK-NOT: bl __subtf3
|
|
|
|
; CHECK: xssubqp
|
|
|
|
; CHECK: stxv
|
|
|
|
; CHECK: blr
|
2018-03-20 02:52:20 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
; Function Attrs: norecurse nounwind
|
|
|
|
define void @qpMul(fp128* nocapture readonly %a, fp128* nocapture %res) {
|
|
|
|
entry:
|
|
|
|
%0 = load fp128, fp128* %a, align 16
|
|
|
|
%mul = fmul fp128 %0, %0
|
|
|
|
store fp128 %mul, fp128* %res, align 16
|
|
|
|
ret void
|
|
|
|
; CHECK-LABEL: qpMul
|
2018-03-22 04:59:45 +08:00
|
|
|
; CHECK-NOT: bl __multf3
|
|
|
|
; CHECK: xsmulqp
|
|
|
|
; CHECK: stxv
|
|
|
|
; CHECK: blr
|
2018-03-20 02:52:20 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
; Function Attrs: norecurse nounwind
|
|
|
|
define void @qpDiv(fp128* nocapture readonly %a, fp128* nocapture %res) {
|
|
|
|
entry:
|
|
|
|
%0 = load fp128, fp128* %a, align 16
|
|
|
|
%div = fdiv fp128 %0, %0
|
|
|
|
store fp128 %div, fp128* %res, align 16
|
|
|
|
ret void
|
|
|
|
; CHECK-LABEL: qpDiv
|
2018-03-22 04:59:45 +08:00
|
|
|
; CHECK-NOT: bl __divtf3
|
|
|
|
; CHECK: xsdivqp
|
|
|
|
; CHECK: stxv
|
|
|
|
; CHECK: blr
|
2018-03-20 02:52:20 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define void @testLdNSt(i8* nocapture readonly %PtrC, fp128* nocapture %PtrF) {
|
|
|
|
entry:
|
|
|
|
%add.ptr = getelementptr inbounds i8, i8* %PtrC, i64 4
|
|
|
|
%0 = bitcast i8* %add.ptr to fp128*
|
|
|
|
%1 = load fp128, fp128* %0, align 16
|
|
|
|
%2 = bitcast fp128* %PtrF to i8*
|
|
|
|
%add.ptr1 = getelementptr inbounds i8, i8* %2, i64 8
|
|
|
|
%3 = bitcast i8* %add.ptr1 to fp128*
|
|
|
|
store fp128 %1, fp128* %3, align 16
|
|
|
|
ret void
|
|
|
|
; CHECK-LABEL: testLdNSt
|
2018-03-22 04:59:45 +08:00
|
|
|
; CHECK: lxvx
|
|
|
|
; CHECK: stxvx
|
2018-03-20 02:52:20 +08:00
|
|
|
; CHECK-NEXT blr
|
|
|
|
}
|
2018-03-20 03:22:52 +08:00
|
|
|
|
|
|
|
define void @qpSqrt(fp128* nocapture readonly %a, fp128* nocapture %res) {
|
|
|
|
entry:
|
|
|
|
%0 = load fp128, fp128* %a, align 16
|
|
|
|
%1 = tail call fp128 @llvm.sqrt.f128(fp128 %0)
|
|
|
|
store fp128 %1, fp128* %res, align 16
|
|
|
|
ret void
|
|
|
|
|
|
|
|
; CHECK-LABEL: qpSqrt
|
2018-03-22 04:59:45 +08:00
|
|
|
; CHECK-NOT: bl sqrtl
|
|
|
|
; CHECK: xssqrtqp
|
|
|
|
; CHECK: stxv
|
|
|
|
; CHECK: blr
|
2018-03-20 03:22:52 +08:00
|
|
|
}
|
|
|
|
declare fp128 @llvm.sqrt.f128(fp128 %Val)
|
|
|
|
|
|
|
|
define void @qpCpsgn(fp128* nocapture readonly %a, fp128* nocapture readonly %b,
|
|
|
|
fp128* nocapture %res) {
|
|
|
|
entry:
|
|
|
|
%0 = load fp128, fp128* %a, align 16
|
|
|
|
%1 = load fp128, fp128* %b, align 16
|
|
|
|
%2 = tail call fp128 @llvm.copysign.f128(fp128 %0, fp128 %1)
|
|
|
|
store fp128 %2, fp128* %res, align 16
|
|
|
|
ret void
|
|
|
|
|
2018-03-22 04:59:45 +08:00
|
|
|
; CHECK-LABEL: qpCpsgn
|
|
|
|
; CHECK-NOT: rldimi
|
|
|
|
; CHECK: xscpsgnqp
|
|
|
|
; CHECK: stxv
|
|
|
|
; CHECK: blr
|
2018-03-20 03:22:52 +08:00
|
|
|
}
|
|
|
|
declare fp128 @llvm.copysign.f128(fp128 %Mag, fp128 %Sgn)
|
|
|
|
|
|
|
|
define void @qpAbs(fp128* nocapture readonly %a, fp128* nocapture %res) {
|
|
|
|
entry:
|
|
|
|
%0 = load fp128, fp128* %a, align 16
|
|
|
|
%1 = tail call fp128 @llvm.fabs.f128(fp128 %0)
|
|
|
|
store fp128 %1, fp128* %res, align 16
|
|
|
|
ret void
|
|
|
|
|
|
|
|
; CHECK-LABEL: qpAbs
|
2018-03-22 04:59:45 +08:00
|
|
|
; CHECK-NOT: clrldi
|
|
|
|
; CHECK: xsabsqp
|
|
|
|
; CHECK: stxv
|
|
|
|
; CHECK: blr
|
2018-03-20 03:22:52 +08:00
|
|
|
}
|
|
|
|
declare fp128 @llvm.fabs.f128(fp128 %Val)
|
|
|
|
|
|
|
|
define void @qpNAbs(fp128* nocapture readonly %a, fp128* nocapture %res) {
|
|
|
|
entry:
|
|
|
|
%0 = load fp128, fp128* %a, align 16
|
|
|
|
%1 = tail call fp128 @llvm.fabs.f128(fp128 %0)
|
|
|
|
%neg = fsub fp128 0xL00000000000000008000000000000000, %1
|
|
|
|
store fp128 %neg, fp128* %res, align 16
|
|
|
|
ret void
|
|
|
|
|
|
|
|
; CHECK-LABEL: qpNAbs
|
2018-03-22 04:59:45 +08:00
|
|
|
; CHECK-NOT: bl __subtf3
|
|
|
|
; CHECK: xsnabsqp
|
|
|
|
; CHECK: stxv
|
|
|
|
; CHECK: blr
|
2018-03-20 03:22:52 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define void @qpNeg(fp128* nocapture readonly %a, fp128* nocapture %res) {
|
|
|
|
entry:
|
|
|
|
%0 = load fp128, fp128* %a, align 16
|
|
|
|
%sub = fsub fp128 0xL00000000000000008000000000000000, %0
|
|
|
|
store fp128 %sub, fp128* %res, align 16
|
|
|
|
ret void
|
|
|
|
|
|
|
|
; CHECK-LABEL: qpNeg
|
2018-03-22 04:59:45 +08:00
|
|
|
; CHECK-NOT: bl __subtf3
|
|
|
|
; CHECK: xsnegqp
|
|
|
|
; CHECK: stxv
|
|
|
|
; CHECK: blr
|
2018-03-20 03:22:52 +08:00
|
|
|
}
|
2018-07-05 23:21:37 +08:00
|
|
|
|
|
|
|
define fp128 @qp_sin(fp128* nocapture readonly %a) {
|
|
|
|
; CHECK-LABEL: qp_sin:
|
2018-07-13 04:18:57 +08:00
|
|
|
; CHECK: lxv v2, 0(r3)
|
2018-07-05 23:21:37 +08:00
|
|
|
; CHECK: bl sinf128
|
|
|
|
; CHECK: blr
|
|
|
|
entry:
|
|
|
|
%0 = load fp128, fp128* %a, align 16
|
|
|
|
%1 = tail call fp128 @llvm.sin.f128(fp128 %0)
|
|
|
|
ret fp128 %1
|
|
|
|
}
|
|
|
|
declare fp128 @llvm.sin.f128(fp128 %Val)
|
|
|
|
|
|
|
|
define fp128 @qp_cos(fp128* nocapture readonly %a) {
|
|
|
|
; CHECK-LABEL: qp_cos:
|
2018-07-13 04:18:57 +08:00
|
|
|
; CHECK: lxv v2, 0(r3)
|
2018-07-05 23:21:37 +08:00
|
|
|
; CHECK: bl cosf128
|
|
|
|
; CHECK: blr
|
|
|
|
entry:
|
|
|
|
%0 = load fp128, fp128* %a, align 16
|
|
|
|
%1 = tail call fp128 @llvm.cos.f128(fp128 %0)
|
|
|
|
ret fp128 %1
|
|
|
|
}
|
|
|
|
declare fp128 @llvm.cos.f128(fp128 %Val)
|
|
|
|
|
|
|
|
define fp128 @qp_log(fp128* nocapture readonly %a) {
|
|
|
|
; CHECK-LABEL: qp_log:
|
2018-07-13 04:18:57 +08:00
|
|
|
; CHECK: lxv v2, 0(r3)
|
2018-07-05 23:21:37 +08:00
|
|
|
; CHECK: bl logf128
|
|
|
|
; CHECK: blr
|
|
|
|
entry:
|
|
|
|
%0 = load fp128, fp128* %a, align 16
|
|
|
|
%1 = tail call fp128 @llvm.log.f128(fp128 %0)
|
|
|
|
ret fp128 %1
|
|
|
|
}
|
|
|
|
declare fp128 @llvm.log.f128(fp128 %Val)
|
|
|
|
|
|
|
|
define fp128 @qp_log10(fp128* nocapture readonly %a) {
|
|
|
|
; CHECK-LABEL: qp_log10:
|
2018-07-13 04:18:57 +08:00
|
|
|
; CHECK: lxv v2, 0(r3)
|
2018-07-05 23:21:37 +08:00
|
|
|
; CHECK: bl log10f128
|
|
|
|
; CHECK: blr
|
|
|
|
entry:
|
|
|
|
%0 = load fp128, fp128* %a, align 16
|
|
|
|
%1 = tail call fp128 @llvm.log10.f128(fp128 %0)
|
|
|
|
ret fp128 %1
|
|
|
|
}
|
|
|
|
declare fp128 @llvm.log10.f128(fp128 %Val)
|
|
|
|
|
|
|
|
define fp128 @qp_log2(fp128* nocapture readonly %a) {
|
|
|
|
; CHECK-LABEL: qp_log2:
|
2018-07-13 04:18:57 +08:00
|
|
|
; CHECK: lxv v2, 0(r3)
|
2018-07-05 23:21:37 +08:00
|
|
|
; CHECK: bl log2f128
|
|
|
|
; CHECK: blr
|
|
|
|
entry:
|
|
|
|
%0 = load fp128, fp128* %a, align 16
|
|
|
|
%1 = tail call fp128 @llvm.log2.f128(fp128 %0)
|
|
|
|
ret fp128 %1
|
|
|
|
}
|
|
|
|
declare fp128 @llvm.log2.f128(fp128 %Val)
|
|
|
|
|
|
|
|
define fp128 @qp_minnum(fp128* nocapture readonly %a,
|
|
|
|
fp128* nocapture readonly %b) {
|
|
|
|
; CHECK-LABEL: qp_minnum:
|
2018-07-13 04:18:57 +08:00
|
|
|
; CHECK: lxv v2, 0(r3)
|
|
|
|
; CHECK: lxv v3, 0(r4)
|
2018-07-05 23:21:37 +08:00
|
|
|
; CHECK: bl fminf128
|
|
|
|
; CHECK: blr
|
|
|
|
entry:
|
|
|
|
%0 = load fp128, fp128* %a, align 16
|
|
|
|
%1 = load fp128, fp128* %b, align 16
|
|
|
|
%2 = tail call fp128 @llvm.minnum.f128(fp128 %0, fp128 %1)
|
|
|
|
ret fp128 %2
|
|
|
|
}
|
|
|
|
declare fp128 @llvm.minnum.f128(fp128 %Val0, fp128 %Val1)
|
|
|
|
|
|
|
|
define fp128 @qp_maxnum(fp128* nocapture readonly %a,
|
|
|
|
fp128* nocapture readonly %b) {
|
|
|
|
; CHECK-LABEL: qp_maxnum:
|
2018-07-13 04:18:57 +08:00
|
|
|
; CHECK: lxv v2, 0(r3)
|
|
|
|
; CHECK: lxv v3, 0(r4)
|
2018-07-05 23:21:37 +08:00
|
|
|
; CHECK: bl fmaxf128
|
|
|
|
; CHECK: blr
|
|
|
|
entry:
|
|
|
|
%0 = load fp128, fp128* %a, align 16
|
|
|
|
%1 = load fp128, fp128* %b, align 16
|
|
|
|
%2 = tail call fp128 @llvm.maxnum.f128(fp128 %0, fp128 %1)
|
|
|
|
ret fp128 %2
|
|
|
|
}
|
|
|
|
declare fp128 @llvm.maxnum.f128(fp128 %Val0, fp128 %Val1)
|
|
|
|
|
|
|
|
define fp128 @qp_pow(fp128* nocapture readonly %a,
|
|
|
|
fp128* nocapture readonly %b) {
|
|
|
|
; CHECK-LABEL: qp_pow:
|
2018-07-13 04:18:57 +08:00
|
|
|
; CHECK: lxv v2, 0(r3)
|
|
|
|
; CHECK: lxv v3, 0(r4)
|
2018-07-05 23:21:37 +08:00
|
|
|
; CHECK: bl powf128
|
|
|
|
; CHECK: blr
|
|
|
|
entry:
|
|
|
|
%0 = load fp128, fp128* %a, align 16
|
|
|
|
%1 = load fp128, fp128* %b, align 16
|
|
|
|
%2 = tail call fp128 @llvm.pow.f128(fp128 %0, fp128 %1)
|
|
|
|
ret fp128 %2
|
|
|
|
}
|
|
|
|
declare fp128 @llvm.pow.f128(fp128 %Val, fp128 %Power)
|
|
|
|
|
|
|
|
define fp128 @qp_exp(fp128* nocapture readonly %a) {
|
|
|
|
; CHECK-LABEL: qp_exp:
|
2018-07-13 04:18:57 +08:00
|
|
|
; CHECK: lxv v2, 0(r3)
|
2018-07-05 23:21:37 +08:00
|
|
|
; CHECK: bl expf128
|
|
|
|
; CHECK: blr
|
|
|
|
entry:
|
|
|
|
%0 = load fp128, fp128* %a, align 16
|
|
|
|
%1 = tail call fp128 @llvm.exp.f128(fp128 %0)
|
|
|
|
ret fp128 %1
|
|
|
|
}
|
|
|
|
declare fp128 @llvm.exp.f128(fp128 %Val)
|
|
|
|
|
|
|
|
define fp128 @qp_exp2(fp128* nocapture readonly %a) {
|
|
|
|
; CHECK-LABEL: qp_exp2:
|
2018-07-13 04:18:57 +08:00
|
|
|
; CHECK: lxv v2, 0(r3)
|
2018-07-05 23:21:37 +08:00
|
|
|
; CHECK: bl exp2f128
|
|
|
|
; CHECK: blr
|
|
|
|
entry:
|
|
|
|
%0 = load fp128, fp128* %a, align 16
|
|
|
|
%1 = tail call fp128 @llvm.exp2.f128(fp128 %0)
|
|
|
|
ret fp128 %1
|
|
|
|
}
|
|
|
|
declare fp128 @llvm.exp2.f128(fp128 %Val)
|
|
|
|
|
|
|
|
define void @qp_powi(fp128* nocapture readonly %a, i32* nocapture readonly %b,
|
|
|
|
fp128* nocapture %res) {
|
|
|
|
; CHECK-LABEL: qp_powi:
|
2018-07-13 04:18:57 +08:00
|
|
|
; CHECK: lxv v2, 0(r3)
|
|
|
|
; CHECK: lwz r3, 0(r4)
|
2018-07-05 23:21:37 +08:00
|
|
|
; CHECK: bl __powikf2
|
|
|
|
; CHECK: blr
|
|
|
|
entry:
|
|
|
|
%0 = load fp128, fp128* %a, align 16
|
|
|
|
%1 = load i32, i32* %b, align 8
|
|
|
|
%2 = tail call fp128 @llvm.powi.f128(fp128 %0, i32 %1)
|
|
|
|
store fp128 %2, fp128* %res, align 16
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
declare fp128 @llvm.powi.f128(fp128 %Val, i32 %power)
|
2018-07-06 10:47:02 +08:00
|
|
|
|
|
|
|
@a = common global fp128 0xL00000000000000000000000000000000, align 16
|
|
|
|
@b = common global fp128 0xL00000000000000000000000000000000, align 16
|
|
|
|
|
|
|
|
define fp128 @qp_frem() #0 {
|
|
|
|
entry:
|
|
|
|
%0 = load fp128, fp128* @a, align 16
|
|
|
|
%1 = load fp128, fp128* @b, align 16
|
|
|
|
%rem = frem fp128 %0, %1
|
|
|
|
ret fp128 %rem
|
|
|
|
; CHECK-LABEL: qp_frem
|
|
|
|
; CHECK: bl fmodf128
|
|
|
|
; CHECK: blr
|
|
|
|
}
|