[llvm] 08ae945 - GlobalISel: Copy correct flags to select
Matt Arsenault via llvm-commits
llvm-commits at lists.llvm.org
Tue May 19 15:31:32 PDT 2020
Author: Matt Arsenault
Date: 2020-05-19T18:31:24-04:00
New Revision: 08ae945318f351af73b96838c869da4a81434713
URL: https://github.com/llvm/llvm-project/commit/08ae945318f351af73b96838c869da4a81434713
DIFF: https://github.com/llvm/llvm-project/commit/08ae945318f351af73b96838c869da4a81434713.diff
LOG: GlobalISel: Copy correct flags to select
This was looking for a compare condition, and copying the compare
flags. I don't think this was ever correct outside of certain min/max
patterns which aren't checked, but this probably predates select
instructions having fast math flags.
Added:
Modified:
llvm/lib/CodeGen/GlobalISel/IRTranslator.cpp
llvm/test/CodeGen/AArch64/GlobalISel/arm64-irtranslator.ll
Removed:
################################################################################
diff --git a/llvm/lib/CodeGen/GlobalISel/IRTranslator.cpp b/llvm/lib/CodeGen/GlobalISel/IRTranslator.cpp
index d749c0d4518c..eba352aedb07 100644
--- a/llvm/lib/CodeGen/GlobalISel/IRTranslator.cpp
+++ b/llvm/lib/CodeGen/GlobalISel/IRTranslator.cpp
@@ -1008,10 +1008,8 @@ bool IRTranslator::translateSelect(const User &U,
ArrayRef<Register> Op1Regs = getOrCreateVRegs(*U.getOperand(2));
uint16_t Flags = 0;
- if (const SelectInst *SI = dyn_cast<SelectInst>(&U)) {
- if (const CmpInst *Cmp = dyn_cast<CmpInst>(SI->getCondition()))
- Flags = MachineInstr::copyFlagsFromInstruction(*Cmp);
- }
+ if (const SelectInst *SI = dyn_cast<SelectInst>(&U))
+ Flags = MachineInstr::copyFlagsFromInstruction(*SI);
for (unsigned i = 0; i < ResRegs.size(); ++i) {
MIRBuilder.buildSelect(ResRegs[i], Tst, Op0Regs[i], Op1Regs[i], Flags);
diff --git a/llvm/test/CodeGen/AArch64/GlobalISel/arm64-irtranslator.ll b/llvm/test/CodeGen/AArch64/GlobalISel/arm64-irtranslator.ll
index e1444c8ae608..8e312d864798 100644
--- a/llvm/test/CodeGen/AArch64/GlobalISel/arm64-irtranslator.ll
+++ b/llvm/test/CodeGen/AArch64/GlobalISel/arm64-irtranslator.ll
@@ -962,6 +962,31 @@ define i32 @test_select(i1 %tst, i32 %lhs, i32 %rhs) {
ret i32 %res
}
+; CHECK-LABEL: name: test_select_flags
+; CHECK: [[COPY:%[0-9]+]]:_(s32) = COPY $w0
+; CHECK: [[TRUNC:%[0-9]+]]:_(s1) = G_TRUNC [[COPY]](s32)
+; CHECK: [[COPY1:%[0-9]+]]:_(s32) = COPY $s0
+; CHECK: [[COPY2:%[0-9]+]]:_(s32) = COPY $s1
+; CHECK: [[SELECT:%[0-9]+]]:_(s32) = nnan G_SELECT [[TRUNC]](s1), [[COPY1]], [[COPY2]]
+define float @test_select_flags(i1 %tst, float %lhs, float %rhs) {
+ %res = select nnan i1 %tst, float %lhs, float %rhs
+ ret float %res
+}
+
+; Don't take the flags from the compare condition
+; CHECK-LABEL: name: test_select_cmp_flags
+; CHECK: [[COPY0:%[0-9]+]]:_(s32) = COPY $s0
+; CHECK: [[COPY1:%[0-9]+]]:_(s32) = COPY $s1
+; CHECK: [[COPY2:%[0-9]+]]:_(s32) = COPY $s2
+; CHECK: [[COPY3:%[0-9]+]]:_(s32) = COPY $s3
+; CHECK: [[CMP:%[0-9]+]]:_(s1) = nsz G_FCMP floatpred(oeq), [[COPY0]](s32), [[COPY1]]
+; CHECK: [[SELECT:%[0-9]+]]:_(s32) = G_SELECT [[CMP]](s1), [[COPY2]], [[COPY3]]
+define float @test_select_cmp_flags(float %cmp0, float %cmp1, float %lhs, float %rhs) {
+ %tst = fcmp nsz oeq float %cmp0, %cmp1
+ %res = select i1 %tst, float %lhs, float %rhs
+ ret float %res
+}
+
; CHECK-LABEL: name: test_select_ptr
; CHECK: [[TST_C:%[0-9]+]]:_(s32) = COPY $w0
; CHECK: [[TST:%[0-9]+]]:_(s1) = G_TRUNC [[TST_C]]
More information about the llvm-commits
mailing list