[llvm] [InstCombine] Resolve TODO: Remove one-time check if other logic operand (Y) is constant (PR #77973)
via llvm-commits
llvm-commits at lists.llvm.org
Fri Jan 19 12:24:31 PST 2024
https://github.com/AtariDreams updated https://github.com/llvm/llvm-project/pull/77973
>From 38c8c190be00b06361505e61b3c8713c784107ce Mon Sep 17 00:00:00 2001
From: Rose <83477269+AtariDreams at users.noreply.github.com>
Date: Sun, 14 Jan 2024 12:53:37 -0500
Subject: [PATCH 1/2] [InstCombine] Add pre-commit tests [NFC]
---
llvm/test/Transforms/InstCombine/shift-logic.ll | 15 +++++++++++++++
1 file changed, 15 insertions(+)
diff --git a/llvm/test/Transforms/InstCombine/shift-logic.ll b/llvm/test/Transforms/InstCombine/shift-logic.ll
index 544694d398431e..fc564ba15daf10 100644
--- a/llvm/test/Transforms/InstCombine/shift-logic.ll
+++ b/llvm/test/Transforms/InstCombine/shift-logic.ll
@@ -240,6 +240,21 @@ define i32 @lshr_or_extra_use(i32 %x, i32 %y, ptr %p) {
ret i32 %sh1
}
+define i32 @lshr_or_extra_use_multiuse(i32 %x, ptr %p) {
+; CHECK-LABEL: @lshr_or_extra_use_multiuse(
+; CHECK-NEXT: [[SH0:%.*]] = lshr i32 [[X:%.*]], 5
+; CHECK-NEXT: [[R:%.*]] = or i32 [[SH0]], 42
+; CHECK-NEXT: store i32 [[R]], ptr [[P:%.*]], align 4
+; CHECK-NEXT: [[SH1:%.*]] = lshr i32 [[X]], 12
+; CHECK-NEXT: ret i32 [[SH1]]
+;
+ %sh0 = lshr i32 %x, 5
+ %r = or i32 %sh0, 42
+ store i32 %r, ptr %p
+ %sh1 = lshr i32 %r, 7
+ ret i32 %sh1
+}
+
; Avoid crashing on constant expressions.
@g = external global i32
>From 43bccf732d1277bba53aad0b6c9b56716e2da016 Mon Sep 17 00:00:00 2001
From: Rose <83477269+AtariDreams at users.noreply.github.com>
Date: Fri, 12 Jan 2024 15:15:27 -0500
Subject: [PATCH 2/2] [Transforms] Remove one-time check if other logic operand
(Y) is constant
By using match(W, m_ImmConstant()), we do not need to worry about one-time use anymore.
---
llvm/lib/Transforms/InstCombine/InstCombineShifts.cpp | 11 +++++------
1 file changed, 5 insertions(+), 6 deletions(-)
diff --git a/llvm/lib/Transforms/InstCombine/InstCombineShifts.cpp b/llvm/lib/Transforms/InstCombine/InstCombineShifts.cpp
index b7958978c450c9..cbad2d6f8be789 100644
--- a/llvm/lib/Transforms/InstCombine/InstCombineShifts.cpp
+++ b/llvm/lib/Transforms/InstCombine/InstCombineShifts.cpp
@@ -368,12 +368,11 @@ static Instruction *foldShiftOfShiftedBinOp(BinaryOperator &I,
// Find a matching one-use shift by constant. The fold is not valid if the sum
// of the shift values equals or exceeds bitwidth.
- // TODO: Remove the one-use check if the other logic operand (Y) is constant.
Value *X, *Y;
- auto matchFirstShift = [&](Value *V) {
+ auto matchFirstShift = [&](Value *V, Value *W) {
APInt Threshold(Ty->getScalarSizeInBits(), Ty->getScalarSizeInBits());
- return match(V,
- m_OneUse(m_BinOp(ShiftOpcode, m_Value(X), m_Constant(C0)))) &&
+ return match(V, m_BinOp(ShiftOpcode, m_Value(X), m_Constant(C0))) &&
+ (V->hasOneUse() || match(W, m_ImmConstant())) &&
match(ConstantExpr::getAdd(C0, C1),
m_SpecificInt_ICMP(ICmpInst::ICMP_ULT, Threshold));
};
@@ -382,9 +381,9 @@ static Instruction *foldShiftOfShiftedBinOp(BinaryOperator &I,
// is not so we cannot reoder if we match operand(1) and need to keep the
// operands in their original positions.
bool FirstShiftIsOp1 = false;
- if (matchFirstShift(BinInst->getOperand(0)))
+ if (matchFirstShift(BinInst->getOperand(0), BinInst->getOperand(1)))
Y = BinInst->getOperand(1);
- else if (matchFirstShift(BinInst->getOperand(1))) {
+ else if (matchFirstShift(BinInst->getOperand(1), BinInst->getOperand(0))) {
Y = BinInst->getOperand(0);
FirstShiftIsOp1 = BinInst->getOpcode() == Instruction::Sub;
} else
More information about the llvm-commits
mailing list