Compiler projects using 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)