forked from OSchip/llvm-project
494 lines
18 KiB
LLVM
494 lines
18 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
|
|
; RUN: llc -verify-machineinstrs -ppc-asm-full-reg-names -ppc-vsr-nums-as-vr < %s -mtriple=powerpc-unknown-linux -mattr=spe | FileCheck %s -check-prefix=SPE
|
|
|
|
define i32 @test_f32_oeq_s(i32 %a, i32 %b, float %f1, float %f2) #0 {
|
|
; SPE-LABEL: test_f32_oeq_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: efscmpeq cr0, r5, r6
|
|
; SPE-NEXT: bclr 12, gt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f32(float %f1, float %f2, metadata !"oeq", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f32_ogt_s(i32 %a, i32 %b, float %f1, float %f2) #0 {
|
|
; SPE-LABEL: test_f32_ogt_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: efscmpgt cr0, r5, r6
|
|
; SPE-NEXT: bclr 12, gt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f32(float %f1, float %f2, metadata !"ogt", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f32_oge_s(i32 %a, i32 %b, float %f1, float %f2) #0 {
|
|
; SPE-LABEL: test_f32_oge_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: efscmplt cr0, r5, r6
|
|
; SPE-NEXT: efscmplt cr1, r5, r6
|
|
; SPE-NEXT: crnor 4*cr5+lt, gt, 4*cr1+gt
|
|
; SPE-NEXT: efscmpeq cr0, r6, r6
|
|
; SPE-NEXT: efscmpeq cr1, r5, r5
|
|
; SPE-NEXT: crand 4*cr5+gt, 4*cr1+gt, gt
|
|
; SPE-NEXT: crand 4*cr5+lt, 4*cr5+lt, 4*cr5+gt
|
|
; SPE-NEXT: bclr 12, 4*cr5+lt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f32(float %f1, float %f2, metadata !"oge", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f32_olt_s(i32 %a, i32 %b, float %f1, float %f2) #0 {
|
|
; SPE-LABEL: test_f32_olt_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: efscmplt cr0, r5, r6
|
|
; SPE-NEXT: bclr 12, gt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f32(float %f1, float %f2, metadata !"olt", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f32_ole_s(i32 %a, i32 %b, float %f1, float %f2) #0 {
|
|
; SPE-LABEL: test_f32_ole_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: efscmpgt cr0, r5, r6
|
|
; SPE-NEXT: efscmpgt cr1, r5, r6
|
|
; SPE-NEXT: crnor 4*cr5+lt, gt, 4*cr1+gt
|
|
; SPE-NEXT: efscmpeq cr0, r6, r6
|
|
; SPE-NEXT: efscmpeq cr1, r5, r5
|
|
; SPE-NEXT: crand 4*cr5+gt, 4*cr1+gt, gt
|
|
; SPE-NEXT: crand 4*cr5+lt, 4*cr5+lt, 4*cr5+gt
|
|
; SPE-NEXT: bclr 12, 4*cr5+lt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f32(float %f1, float %f2, metadata !"ole", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f32_one_s(i32 %a, i32 %b, float %f1, float %f2) #0 {
|
|
; SPE-LABEL: test_f32_one_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: efscmplt cr0, r5, r6
|
|
; SPE-NEXT: efscmpgt cr1, r5, r6
|
|
; SPE-NEXT: cror 4*cr5+lt, 4*cr1+gt, gt
|
|
; SPE-NEXT: bclr 12, 4*cr5+lt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f32(float %f1, float %f2, metadata !"one", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f32_ord_s(i32 %a, i32 %b, float %f1, float %f2) #0 {
|
|
; SPE-LABEL: test_f32_ord_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: efscmpeq cr0, r6, r6
|
|
; SPE-NEXT: efscmpeq cr1, r5, r5
|
|
; SPE-NEXT: crand 4*cr5+lt, 4*cr1+gt, gt
|
|
; SPE-NEXT: bclr 12, 4*cr5+lt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f32(float %f1, float %f2, metadata !"ord", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f32_ueq_s(i32 %a, i32 %b, float %f1, float %f2) #0 {
|
|
; SPE-LABEL: test_f32_ueq_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: efscmplt cr0, r5, r6
|
|
; SPE-NEXT: efscmpgt cr1, r5, r6
|
|
; SPE-NEXT: cror 4*cr5+lt, 4*cr1+gt, gt
|
|
; SPE-NEXT: bc 12, 4*cr5+lt, .LBB7_1
|
|
; SPE-NEXT: blr
|
|
; SPE-NEXT: .LBB7_1:
|
|
; SPE-NEXT: addi r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f32(float %f1, float %f2, metadata !"ueq", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f32_ugt_s(i32 %a, i32 %b, float %f1, float %f2) #0 {
|
|
; SPE-LABEL: test_f32_ugt_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: efscmpeq cr0, r6, r6
|
|
; SPE-NEXT: efscmpeq cr1, r6, r6
|
|
; SPE-NEXT: crnor 4*cr5+lt, gt, 4*cr1+gt
|
|
; SPE-NEXT: efscmpeq cr0, r5, r5
|
|
; SPE-NEXT: efscmpeq cr1, r5, r5
|
|
; SPE-NEXT: crnor 4*cr5+gt, gt, 4*cr1+gt
|
|
; SPE-NEXT: cror 4*cr5+lt, 4*cr5+gt, 4*cr5+lt
|
|
; SPE-NEXT: efscmpgt cr0, r5, r6
|
|
; SPE-NEXT: cror 4*cr5+lt, gt, 4*cr5+lt
|
|
; SPE-NEXT: bclr 12, 4*cr5+lt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f32(float %f1, float %f2, metadata !"ugt", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f32_uge_s(i32 %a, i32 %b, float %f1, float %f2) #0 {
|
|
; SPE-LABEL: test_f32_uge_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: efscmplt cr0, r5, r6
|
|
; SPE-NEXT: efscmplt cr1, r5, r6
|
|
; SPE-NEXT: crnor 4*cr5+lt, gt, 4*cr1+gt
|
|
; SPE-NEXT: bclr 12, 4*cr5+lt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f32(float %f1, float %f2, metadata !"uge", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f32_ult_s(i32 %a, i32 %b, float %f1, float %f2) #0 {
|
|
; SPE-LABEL: test_f32_ult_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: efscmpeq cr0, r6, r6
|
|
; SPE-NEXT: efscmpeq cr1, r6, r6
|
|
; SPE-NEXT: crnor 4*cr5+lt, gt, 4*cr1+gt
|
|
; SPE-NEXT: efscmpeq cr0, r5, r5
|
|
; SPE-NEXT: efscmpeq cr1, r5, r5
|
|
; SPE-NEXT: crnor 4*cr5+gt, gt, 4*cr1+gt
|
|
; SPE-NEXT: cror 4*cr5+lt, 4*cr5+gt, 4*cr5+lt
|
|
; SPE-NEXT: efscmplt cr0, r5, r6
|
|
; SPE-NEXT: cror 4*cr5+lt, gt, 4*cr5+lt
|
|
; SPE-NEXT: bclr 12, 4*cr5+lt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f32(float %f1, float %f2, metadata !"ult", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f32_ule_s(i32 %a, i32 %b, float %f1, float %f2) #0 {
|
|
; SPE-LABEL: test_f32_ule_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: efscmpgt cr0, r5, r6
|
|
; SPE-NEXT: efscmpgt cr1, r5, r6
|
|
; SPE-NEXT: crnor 4*cr5+lt, gt, 4*cr1+gt
|
|
; SPE-NEXT: bclr 12, 4*cr5+lt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f32(float %f1, float %f2, metadata !"ule", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f32_une_s(i32 %a, i32 %b, float %f1, float %f2) #0 {
|
|
; SPE-LABEL: test_f32_une_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: efscmpeq cr0, r5, r6
|
|
; SPE-NEXT: efscmpeq cr1, r5, r6
|
|
; SPE-NEXT: crnor 4*cr5+lt, gt, 4*cr1+gt
|
|
; SPE-NEXT: bclr 12, 4*cr5+lt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f32(float %f1, float %f2, metadata !"une", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f32_uno_s(i32 %a, i32 %b, float %f1, float %f2) #0 {
|
|
; SPE-LABEL: test_f32_uno_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: efscmpeq cr0, r6, r6
|
|
; SPE-NEXT: efscmpeq cr1, r6, r6
|
|
; SPE-NEXT: crnor 4*cr5+lt, gt, 4*cr1+gt
|
|
; SPE-NEXT: efscmpeq cr0, r5, r5
|
|
; SPE-NEXT: efscmpeq cr1, r5, r5
|
|
; SPE-NEXT: crnor 4*cr5+gt, gt, 4*cr1+gt
|
|
; SPE-NEXT: cror 4*cr5+lt, 4*cr5+gt, 4*cr5+lt
|
|
; SPE-NEXT: bclr 12, 4*cr5+lt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f32(float %f1, float %f2, metadata !"uno", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f64_oeq_s(i32 %a, i32 %b, double %f1, double %f2) #0 {
|
|
; SPE-LABEL: test_f64_oeq_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: evmergelo r7, r7, r8
|
|
; SPE-NEXT: evmergelo r5, r5, r6
|
|
; SPE-NEXT: efdcmpeq cr0, r5, r7
|
|
; SPE-NEXT: bclr 12, gt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f64(double %f1, double %f2, metadata !"oeq", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f64_ogt_s(i32 %a, i32 %b, double %f1, double %f2) #0 {
|
|
; SPE-LABEL: test_f64_ogt_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: evmergelo r7, r7, r8
|
|
; SPE-NEXT: evmergelo r5, r5, r6
|
|
; SPE-NEXT: efdcmpgt cr0, r5, r7
|
|
; SPE-NEXT: bclr 12, gt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f64(double %f1, double %f2, metadata !"ogt", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f64_oge_s(i32 %a, i32 %b, double %f1, double %f2) #0 {
|
|
; SPE-LABEL: test_f64_oge_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: evmergelo r7, r7, r8
|
|
; SPE-NEXT: evmergelo r5, r5, r6
|
|
; SPE-NEXT: efdcmplt cr0, r5, r7
|
|
; SPE-NEXT: efdcmplt cr1, r5, r7
|
|
; SPE-NEXT: efdcmpeq cr5, r7, r7
|
|
; SPE-NEXT: efdcmpeq cr6, r5, r5
|
|
; SPE-NEXT: crnor 4*cr7+lt, gt, 4*cr1+gt
|
|
; SPE-NEXT: crand 4*cr5+lt, 4*cr6+gt, 4*cr5+gt
|
|
; SPE-NEXT: crand 4*cr5+lt, 4*cr7+lt, 4*cr5+lt
|
|
; SPE-NEXT: bclr 12, 4*cr5+lt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f64(double %f1, double %f2, metadata !"oge", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f64_olt_s(i32 %a, i32 %b, double %f1, double %f2) #0 {
|
|
; SPE-LABEL: test_f64_olt_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: evmergelo r7, r7, r8
|
|
; SPE-NEXT: evmergelo r5, r5, r6
|
|
; SPE-NEXT: efdcmplt cr0, r5, r7
|
|
; SPE-NEXT: bclr 12, gt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f64(double %f1, double %f2, metadata !"olt", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f64_ole_s(i32 %a, i32 %b, double %f1, double %f2) #0 {
|
|
; SPE-LABEL: test_f64_ole_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: evmergelo r7, r7, r8
|
|
; SPE-NEXT: evmergelo r5, r5, r6
|
|
; SPE-NEXT: efdcmpgt cr0, r5, r7
|
|
; SPE-NEXT: efdcmpgt cr1, r5, r7
|
|
; SPE-NEXT: efdcmpeq cr5, r7, r7
|
|
; SPE-NEXT: efdcmpeq cr6, r5, r5
|
|
; SPE-NEXT: crnor 4*cr7+lt, gt, 4*cr1+gt
|
|
; SPE-NEXT: crand 4*cr5+lt, 4*cr6+gt, 4*cr5+gt
|
|
; SPE-NEXT: crand 4*cr5+lt, 4*cr7+lt, 4*cr5+lt
|
|
; SPE-NEXT: bclr 12, 4*cr5+lt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f64(double %f1, double %f2, metadata !"ole", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f64_one_s(i32 %a, i32 %b, double %f1, double %f2) #0 {
|
|
; SPE-LABEL: test_f64_one_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: evmergelo r7, r7, r8
|
|
; SPE-NEXT: evmergelo r5, r5, r6
|
|
; SPE-NEXT: efdcmplt cr0, r5, r7
|
|
; SPE-NEXT: efdcmpgt cr1, r5, r7
|
|
; SPE-NEXT: cror 4*cr5+lt, 4*cr1+gt, gt
|
|
; SPE-NEXT: bclr 12, 4*cr5+lt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f64(double %f1, double %f2, metadata !"one", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f64_ord_s(i32 %a, i32 %b, double %f1, double %f2) #0 {
|
|
; SPE-LABEL: test_f64_ord_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: evmergelo r5, r5, r6
|
|
; SPE-NEXT: evmergelo r6, r7, r8
|
|
; SPE-NEXT: efdcmpeq cr0, r6, r6
|
|
; SPE-NEXT: efdcmpeq cr1, r5, r5
|
|
; SPE-NEXT: crand 4*cr5+lt, 4*cr1+gt, gt
|
|
; SPE-NEXT: bclr 12, 4*cr5+lt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f64(double %f1, double %f2, metadata !"ord", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f64_ueq_s(i32 %a, i32 %b, double %f1, double %f2) #0 {
|
|
; SPE-LABEL: test_f64_ueq_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: evmergelo r7, r7, r8
|
|
; SPE-NEXT: evmergelo r5, r5, r6
|
|
; SPE-NEXT: efdcmplt cr0, r5, r7
|
|
; SPE-NEXT: efdcmpgt cr1, r5, r7
|
|
; SPE-NEXT: cror 4*cr5+lt, 4*cr1+gt, gt
|
|
; SPE-NEXT: bc 12, 4*cr5+lt, .LBB21_1
|
|
; SPE-NEXT: blr
|
|
; SPE-NEXT: .LBB21_1:
|
|
; SPE-NEXT: addi r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f64(double %f1, double %f2, metadata !"ueq", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f64_ugt_s(i32 %a, i32 %b, double %f1, double %f2) #0 {
|
|
; SPE-LABEL: test_f64_ugt_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: evmergelo r5, r5, r6
|
|
; SPE-NEXT: evmergelo r6, r7, r8
|
|
; SPE-NEXT: efdcmpeq cr0, r6, r6
|
|
; SPE-NEXT: efdcmpeq cr1, r6, r6
|
|
; SPE-NEXT: efdcmpeq cr5, r5, r5
|
|
; SPE-NEXT: efdcmpeq cr6, r5, r5
|
|
; SPE-NEXT: efdcmpgt cr7, r5, r6
|
|
; SPE-NEXT: crnor 4*cr1+lt, gt, 4*cr1+gt
|
|
; SPE-NEXT: crnor 4*cr5+lt, 4*cr5+gt, 4*cr6+gt
|
|
; SPE-NEXT: cror 4*cr5+lt, 4*cr5+lt, 4*cr1+lt
|
|
; SPE-NEXT: cror 4*cr5+lt, 4*cr7+gt, 4*cr5+lt
|
|
; SPE-NEXT: bclr 12, 4*cr5+lt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f64(double %f1, double %f2, metadata !"ugt", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f64_uge_s(i32 %a, i32 %b, double %f1, double %f2) #0 {
|
|
; SPE-LABEL: test_f64_uge_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: evmergelo r7, r7, r8
|
|
; SPE-NEXT: evmergelo r5, r5, r6
|
|
; SPE-NEXT: efdcmplt cr0, r5, r7
|
|
; SPE-NEXT: efdcmplt cr1, r5, r7
|
|
; SPE-NEXT: crnor 4*cr5+lt, gt, 4*cr1+gt
|
|
; SPE-NEXT: bclr 12, 4*cr5+lt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f64(double %f1, double %f2, metadata !"uge", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f64_ult_s(i32 %a, i32 %b, double %f1, double %f2) #0 {
|
|
; SPE-LABEL: test_f64_ult_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: evmergelo r5, r5, r6
|
|
; SPE-NEXT: evmergelo r6, r7, r8
|
|
; SPE-NEXT: efdcmpeq cr0, r6, r6
|
|
; SPE-NEXT: efdcmpeq cr1, r6, r6
|
|
; SPE-NEXT: efdcmpeq cr5, r5, r5
|
|
; SPE-NEXT: efdcmpeq cr6, r5, r5
|
|
; SPE-NEXT: efdcmplt cr7, r5, r6
|
|
; SPE-NEXT: crnor 4*cr1+lt, gt, 4*cr1+gt
|
|
; SPE-NEXT: crnor 4*cr5+lt, 4*cr5+gt, 4*cr6+gt
|
|
; SPE-NEXT: cror 4*cr5+lt, 4*cr5+lt, 4*cr1+lt
|
|
; SPE-NEXT: cror 4*cr5+lt, 4*cr7+gt, 4*cr5+lt
|
|
; SPE-NEXT: bclr 12, 4*cr5+lt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f64(double %f1, double %f2, metadata !"ult", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f64_ule_s(i32 %a, i32 %b, double %f1, double %f2) #0 {
|
|
; SPE-LABEL: test_f64_ule_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: evmergelo r7, r7, r8
|
|
; SPE-NEXT: evmergelo r5, r5, r6
|
|
; SPE-NEXT: efdcmpgt cr0, r5, r7
|
|
; SPE-NEXT: efdcmpgt cr1, r5, r7
|
|
; SPE-NEXT: crnor 4*cr5+lt, gt, 4*cr1+gt
|
|
; SPE-NEXT: bclr 12, 4*cr5+lt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f64(double %f1, double %f2, metadata !"ule", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f64_une_s(i32 %a, i32 %b, double %f1, double %f2) #0 {
|
|
; SPE-LABEL: test_f64_une_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: evmergelo r7, r7, r8
|
|
; SPE-NEXT: evmergelo r5, r5, r6
|
|
; SPE-NEXT: efdcmpeq cr0, r5, r7
|
|
; SPE-NEXT: efdcmpeq cr1, r5, r7
|
|
; SPE-NEXT: crnor 4*cr5+lt, gt, 4*cr1+gt
|
|
; SPE-NEXT: bclr 12, 4*cr5+lt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f64(double %f1, double %f2, metadata !"une", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
define i32 @test_f64_uno_s(i32 %a, i32 %b, double %f1, double %f2) #0 {
|
|
; SPE-LABEL: test_f64_uno_s:
|
|
; SPE: # %bb.0:
|
|
; SPE-NEXT: evmergelo r5, r5, r6
|
|
; SPE-NEXT: evmergelo r6, r7, r8
|
|
; SPE-NEXT: efdcmpeq cr0, r6, r6
|
|
; SPE-NEXT: efdcmpeq cr1, r6, r6
|
|
; SPE-NEXT: efdcmpeq cr5, r5, r5
|
|
; SPE-NEXT: efdcmpeq cr6, r5, r5
|
|
; SPE-NEXT: crnor 4*cr7+lt, gt, 4*cr1+gt
|
|
; SPE-NEXT: crnor 4*cr5+lt, 4*cr5+gt, 4*cr6+gt
|
|
; SPE-NEXT: cror 4*cr5+lt, 4*cr5+lt, 4*cr7+lt
|
|
; SPE-NEXT: bclr 12, 4*cr5+lt, 0
|
|
; SPE-NEXT: # %bb.1:
|
|
; SPE-NEXT: ori r3, r4, 0
|
|
; SPE-NEXT: blr
|
|
%cond = call i1 @llvm.experimental.constrained.fcmps.f64(double %f1, double %f2, metadata !"uno", metadata !"fpexcept.strict") #0
|
|
%res = select i1 %cond, i32 %a, i32 %b
|
|
ret i32 %res
|
|
}
|
|
|
|
attributes #0 = { strictfp nounwind }
|
|
|
|
declare i1 @llvm.experimental.constrained.fcmps.f32(float, float, metadata, metadata)
|
|
declare i1 @llvm.experimental.constrained.fcmps.f64(double, double, metadata, metadata)
|