Andrei Safronov a2c9f7dbcc
[Xtensa] Implement lowering SELECT_CC/BRCC for Xtensa FP Option. (#145544)
Also minor format changes in disassembler test for Xtensa FP Option.
2025-07-02 13:48:49 +03:00

458 lines
11 KiB
LLVM

; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
; RUN: llc -mtriple=xtensa -mattr=+fp -disable-block-placement -verify-machineinstrs < %s \
; RUN: | FileCheck %s
define float @brcc_oeq(float %a, float %b) nounwind {
; CHECK-LABEL: brcc_oeq:
; CHECK: # %bb.0:
; CHECK-NEXT: wfr f8, a3
; CHECK-NEXT: wfr f9, a2
; CHECK-NEXT: oeq.s b0, f9, f8
; CHECK-NEXT: bf b0, .LBB0_2
; CHECK-NEXT: # %bb.1: # %t1
; CHECK-NEXT: l32r a8, .LCPI0_1
; CHECK-NEXT: wfr f8, a8
; CHECK-NEXT: add.s f8, f9, f8
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
; CHECK-NEXT: .LBB0_2: # %t2
; CHECK-NEXT: l32r a8, .LCPI0_0
; CHECK-NEXT: wfr f9, a8
; CHECK-NEXT: add.s f8, f8, f9
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
%wb = fcmp oeq float %a, %b
br i1 %wb, label %t1, label %t2
t1:
%t1v = fadd float %a, 4.0
br label %exit
t2:
%t2v = fadd float %b, 8.0
br label %exit
exit:
%v = phi float [ %t1v, %t1 ], [ %t2v, %t2 ]
ret float %v
}
define float @brcc_ogt(float %a, float %b) nounwind {
; CHECK-LABEL: brcc_ogt:
; CHECK: # %bb.0:
; CHECK-NEXT: wfr f8, a3
; CHECK-NEXT: wfr f9, a2
; CHECK-NEXT: ule.s b0, f9, f8
; CHECK-NEXT: bt b0, .LBB1_2
; CHECK-NEXT: # %bb.1: # %t1
; CHECK-NEXT: l32r a8, .LCPI1_1
; CHECK-NEXT: wfr f8, a8
; CHECK-NEXT: add.s f8, f9, f8
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
; CHECK-NEXT: .LBB1_2: # %t2
; CHECK-NEXT: l32r a8, .LCPI1_0
; CHECK-NEXT: wfr f9, a8
; CHECK-NEXT: add.s f8, f8, f9
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
%wb = fcmp ogt float %a, %b
br i1 %wb, label %t1, label %t2
t1:
%t1v = fadd float %a, 4.0
br label %exit
t2:
%t2v = fadd float %b, 8.0
br label %exit
exit:
%v = phi float [ %t1v, %t1 ], [ %t2v, %t2 ]
ret float %v
}
define float @brcc_oge(float %a, float %b) nounwind {
; CHECK-LABEL: brcc_oge:
; CHECK: # %bb.0:
; CHECK-NEXT: wfr f8, a3
; CHECK-NEXT: wfr f9, a2
; CHECK-NEXT: ult.s b0, f9, f8
; CHECK-NEXT: bt b0, .LBB2_2
; CHECK-NEXT: # %bb.1: # %t1
; CHECK-NEXT: l32r a8, .LCPI2_1
; CHECK-NEXT: wfr f8, a8
; CHECK-NEXT: add.s f8, f9, f8
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
; CHECK-NEXT: .LBB2_2: # %t2
; CHECK-NEXT: l32r a8, .LCPI2_0
; CHECK-NEXT: wfr f9, a8
; CHECK-NEXT: add.s f8, f8, f9
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
%wb = fcmp oge float %a, %b
br i1 %wb, label %t1, label %t2
t1:
%t1v = fadd float %a, 4.0
br label %exit
t2:
%t2v = fadd float %b, 8.0
br label %exit
exit:
%v = phi float [ %t1v, %t1 ], [ %t2v, %t2 ]
ret float %v
}
define float @brcc_olt(float %a, float %b) nounwind {
; CHECK-LABEL: brcc_olt:
; CHECK: # %bb.0:
; CHECK-NEXT: wfr f8, a3
; CHECK-NEXT: wfr f9, a2
; CHECK-NEXT: ule.s b0, f8, f9
; CHECK-NEXT: bt b0, .LBB3_2
; CHECK-NEXT: # %bb.1: # %t1
; CHECK-NEXT: l32r a8, .LCPI3_1
; CHECK-NEXT: wfr f8, a8
; CHECK-NEXT: add.s f8, f9, f8
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
; CHECK-NEXT: .LBB3_2: # %t2
; CHECK-NEXT: l32r a8, .LCPI3_0
; CHECK-NEXT: wfr f9, a8
; CHECK-NEXT: add.s f8, f8, f9
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
%wb = fcmp olt float %a, %b
br i1 %wb, label %t1, label %t2
t1:
%t1v = fadd float %a, 4.0
br label %exit
t2:
%t2v = fadd float %b, 8.0
br label %exit
exit:
%v = phi float [ %t1v, %t1 ], [ %t2v, %t2 ]
ret float %v
}
define float @brcc_ole(float %a, float %b) nounwind {
; CHECK-LABEL: brcc_ole:
; CHECK: # %bb.0:
; CHECK-NEXT: wfr f8, a3
; CHECK-NEXT: wfr f9, a2
; CHECK-NEXT: ult.s b0, f8, f9
; CHECK-NEXT: bt b0, .LBB4_2
; CHECK-NEXT: # %bb.1: # %t1
; CHECK-NEXT: l32r a8, .LCPI4_1
; CHECK-NEXT: wfr f8, a8
; CHECK-NEXT: add.s f8, f9, f8
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
; CHECK-NEXT: .LBB4_2: # %t2
; CHECK-NEXT: l32r a8, .LCPI4_0
; CHECK-NEXT: wfr f9, a8
; CHECK-NEXT: add.s f8, f8, f9
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
%wb = fcmp ole float %a, %b
br i1 %wb, label %t1, label %t2
t1:
%t1v = fadd float %a, 4.0
br label %exit
t2:
%t2v = fadd float %b, 8.0
br label %exit
exit:
%v = phi float [ %t1v, %t1 ], [ %t2v, %t2 ]
ret float %v
}
define float @brcc_one(float %a, float %b) nounwind {
; CHECK-LABEL: brcc_one:
; CHECK: # %bb.0:
; CHECK-NEXT: wfr f8, a3
; CHECK-NEXT: wfr f9, a2
; CHECK-NEXT: ueq.s b0, f9, f8
; CHECK-NEXT: bt b0, .LBB5_2
; CHECK-NEXT: # %bb.1: # %t1
; CHECK-NEXT: l32r a8, .LCPI5_1
; CHECK-NEXT: wfr f8, a8
; CHECK-NEXT: add.s f8, f9, f8
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
; CHECK-NEXT: .LBB5_2: # %t2
; CHECK-NEXT: l32r a8, .LCPI5_0
; CHECK-NEXT: wfr f9, a8
; CHECK-NEXT: add.s f8, f8, f9
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
%wb = fcmp one float %a, %b
br i1 %wb, label %t1, label %t2
t1:
%t1v = fadd float %a, 4.0
br label %exit
t2:
%t2v = fadd float %b, 8.0
br label %exit
exit:
%v = phi float [ %t1v, %t1 ], [ %t2v, %t2 ]
ret float %v
}
define float @brcc_ord(float %a, float %b) nounwind {
; CHECK-LABEL: brcc_ord:
; CHECK: # %bb.0:
; CHECK-NEXT: wfr f8, a3
; CHECK-NEXT: wfr f9, a2
; CHECK-NEXT: un.s b0, f9, f8
; CHECK-NEXT: bt b0, .LBB6_2
; CHECK-NEXT: # %bb.1: # %t1
; CHECK-NEXT: l32r a8, .LCPI6_1
; CHECK-NEXT: wfr f8, a8
; CHECK-NEXT: add.s f8, f9, f8
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
; CHECK-NEXT: .LBB6_2: # %t2
; CHECK-NEXT: l32r a8, .LCPI6_0
; CHECK-NEXT: wfr f9, a8
; CHECK-NEXT: add.s f8, f8, f9
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
%wb = fcmp ord float %a, %b
br i1 %wb, label %t1, label %t2
t1:
%t1v = fadd float %a, 4.0
br label %exit
t2:
%t2v = fadd float %b, 8.0
br label %exit
exit:
%v = phi float [ %t1v, %t1 ], [ %t2v, %t2 ]
ret float %v
}
define float @brcc_ueq(float %a, float %b) nounwind {
; CHECK-LABEL: brcc_ueq:
; CHECK: # %bb.0:
; CHECK-NEXT: wfr f8, a3
; CHECK-NEXT: wfr f9, a2
; CHECK-NEXT: ueq.s b0, f9, f8
; CHECK-NEXT: bt b0, .LBB7_2
; CHECK-NEXT: # %bb.1: # %t1
; CHECK-NEXT: l32r a8, .LCPI7_1
; CHECK-NEXT: wfr f8, a8
; CHECK-NEXT: add.s f8, f9, f8
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
; CHECK-NEXT: .LBB7_2: # %t2
; CHECK-NEXT: l32r a8, .LCPI7_0
; CHECK-NEXT: wfr f9, a8
; CHECK-NEXT: add.s f8, f8, f9
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
%wb = fcmp ueq float %a, %b
br i1 %wb, label %t1, label %t2
t1:
%t1v = fadd float %a, 4.0
br label %exit
t2:
%t2v = fadd float %b, 8.0
br label %exit
exit:
%v = phi float [ %t1v, %t1 ], [ %t2v, %t2 ]
ret float %v
}
define float @brcc_ugt(float %a, float %b) nounwind {
; CHECK-LABEL: brcc_ugt:
; CHECK: # %bb.0:
; CHECK-NEXT: wfr f8, a3
; CHECK-NEXT: wfr f9, a2
; CHECK-NEXT: ole.s b0, f9, f8
; CHECK-NEXT: bt b0, .LBB8_2
; CHECK-NEXT: # %bb.1: # %t1
; CHECK-NEXT: l32r a8, .LCPI8_1
; CHECK-NEXT: wfr f8, a8
; CHECK-NEXT: add.s f8, f9, f8
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
; CHECK-NEXT: .LBB8_2: # %t2
; CHECK-NEXT: l32r a8, .LCPI8_0
; CHECK-NEXT: wfr f9, a8
; CHECK-NEXT: add.s f8, f8, f9
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
%wb = fcmp ugt float %a, %b
br i1 %wb, label %t1, label %t2
t1:
%t1v = fadd float %a, 4.0
br label %exit
t2:
%t2v = fadd float %b, 8.0
br label %exit
exit:
%v = phi float [ %t1v, %t1 ], [ %t2v, %t2 ]
ret float %v
}
define float @brcc_uge(float %a, float %b) nounwind {
; CHECK-LABEL: brcc_uge:
; CHECK: # %bb.0:
; CHECK-NEXT: wfr f8, a3
; CHECK-NEXT: wfr f9, a2
; CHECK-NEXT: olt.s b0, f9, f8
; CHECK-NEXT: bt b0, .LBB9_2
; CHECK-NEXT: # %bb.1: # %t1
; CHECK-NEXT: l32r a8, .LCPI9_1
; CHECK-NEXT: wfr f8, a8
; CHECK-NEXT: add.s f8, f9, f8
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
; CHECK-NEXT: .LBB9_2: # %t2
; CHECK-NEXT: l32r a8, .LCPI9_0
; CHECK-NEXT: wfr f9, a8
; CHECK-NEXT: add.s f8, f8, f9
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
%wb = fcmp uge float %a, %b
br i1 %wb, label %t1, label %t2
t1:
%t1v = fadd float %a, 4.0
br label %exit
t2:
%t2v = fadd float %b, 8.0
br label %exit
exit:
%v = phi float [ %t1v, %t1 ], [ %t2v, %t2 ]
ret float %v
}
define float @brcc_ult(float %a, float %b) nounwind {
; CHECK-LABEL: brcc_ult:
; CHECK: # %bb.0:
; CHECK-NEXT: wfr f8, a3
; CHECK-NEXT: wfr f9, a2
; CHECK-NEXT: ole.s b0, f8, f9
; CHECK-NEXT: bt b0, .LBB10_2
; CHECK-NEXT: # %bb.1: # %t1
; CHECK-NEXT: l32r a8, .LCPI10_1
; CHECK-NEXT: wfr f8, a8
; CHECK-NEXT: add.s f8, f9, f8
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
; CHECK-NEXT: .LBB10_2: # %t2
; CHECK-NEXT: l32r a8, .LCPI10_0
; CHECK-NEXT: wfr f9, a8
; CHECK-NEXT: add.s f8, f8, f9
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
%wb = fcmp ult float %a, %b
br i1 %wb, label %t1, label %t2
t1:
%t1v = fadd float %a, 4.0
br label %exit
t2:
%t2v = fadd float %b, 8.0
br label %exit
exit:
%v = phi float [ %t1v, %t1 ], [ %t2v, %t2 ]
ret float %v
}
define float @brcc_ule(float %a, float %b) nounwind {
; CHECK-LABEL: brcc_ule:
; CHECK: # %bb.0:
; CHECK-NEXT: wfr f8, a3
; CHECK-NEXT: wfr f9, a2
; CHECK-NEXT: olt.s b0, f8, f9
; CHECK-NEXT: bt b0, .LBB11_2
; CHECK-NEXT: # %bb.1: # %t1
; CHECK-NEXT: l32r a8, .LCPI11_1
; CHECK-NEXT: wfr f8, a8
; CHECK-NEXT: add.s f8, f9, f8
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
; CHECK-NEXT: .LBB11_2: # %t2
; CHECK-NEXT: l32r a8, .LCPI11_0
; CHECK-NEXT: wfr f9, a8
; CHECK-NEXT: add.s f8, f8, f9
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
%wb = fcmp ule float %a, %b
br i1 %wb, label %t1, label %t2
t1:
%t1v = fadd float %a, 4.0
br label %exit
t2:
%t2v = fadd float %b, 8.0
br label %exit
exit:
%v = phi float [ %t1v, %t1 ], [ %t2v, %t2 ]
ret float %v
}
define float @brcc_une(float %a, float %b) nounwind {
; CHECK-LABEL: brcc_une:
; CHECK: # %bb.0:
; CHECK-NEXT: wfr f8, a3
; CHECK-NEXT: wfr f9, a2
; CHECK-NEXT: oeq.s b0, f9, f8
; CHECK-NEXT: bt b0, .LBB12_2
; CHECK-NEXT: # %bb.1: # %t1
; CHECK-NEXT: l32r a8, .LCPI12_1
; CHECK-NEXT: wfr f8, a8
; CHECK-NEXT: add.s f8, f9, f8
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
; CHECK-NEXT: .LBB12_2: # %t2
; CHECK-NEXT: l32r a8, .LCPI12_0
; CHECK-NEXT: wfr f9, a8
; CHECK-NEXT: add.s f8, f8, f9
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
%wb = fcmp une float %a, %b
br i1 %wb, label %t1, label %t2
t1:
%t1v = fadd float %a, 4.0
br label %exit
t2:
%t2v = fadd float %b, 8.0
br label %exit
exit:
%v = phi float [ %t1v, %t1 ], [ %t2v, %t2 ]
ret float %v
}
define float @brcc_uno(float %a, float %b) nounwind {
; CHECK-LABEL: brcc_uno:
; CHECK: # %bb.0:
; CHECK-NEXT: wfr f8, a3
; CHECK-NEXT: wfr f9, a2
; CHECK-NEXT: un.s b0, f9, f8
; CHECK-NEXT: bf b0, .LBB13_2
; CHECK-NEXT: # %bb.1: # %t1
; CHECK-NEXT: l32r a8, .LCPI13_1
; CHECK-NEXT: wfr f8, a8
; CHECK-NEXT: add.s f8, f9, f8
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
; CHECK-NEXT: .LBB13_2: # %t2
; CHECK-NEXT: l32r a8, .LCPI13_0
; CHECK-NEXT: wfr f9, a8
; CHECK-NEXT: add.s f8, f8, f9
; CHECK-NEXT: rfr a2, f8
; CHECK-NEXT: ret
%wb = fcmp uno float %a, %b
br i1 %wb, label %t1, label %t2
t1:
%t1v = fadd float %a, 4.0
br label %exit
t2:
%t2v = fadd float %b, 8.0
br label %exit
exit:
%v = phi float [ %t1v, %t1 ], [ %t2v, %t2 ]
ret float %v
}
define float @copysign_f32(float %a, float %b) {
entry:
%c = call float @llvm.copysign.f32(float %a, float %b)
ret float %c
}