[llvm] [DAGCombine] Remove oneuse restrictions for RISCV in folding (shl (add_nsw x, c1)), c2) and folding (shl(sext(add x, c1)), c2) in some scenarios (PR #101294)
Simon Pilgrim via llvm-commits
llvm-commits at lists.llvm.org
Sat Nov 9 08:06:03 PST 2024
================
@@ -60468,3 +60468,20 @@ Align X86TargetLowering::getPrefLoopAlignment(MachineLoop *ML) const {
return Align(1ULL << ExperimentalPrefInnermostLoopAlignment);
return TargetLowering::getPrefLoopAlignment();
}
+
+bool X86TargetLowering::isDesirableToCommuteWithShift(
+ const SDNode *N, CombineLevel Level) const {
+ assert((N->getOpcode() == ISD::SHL || N->getOpcode() == ISD::SRA ||
+ N->getOpcode() == ISD::SRL) &&
+ "Expected shift op");
+
+ SDValue ShiftLHS = N->getOperand(0);
+ if (!ShiftLHS->hasOneUse())
+ return false;
+
+ if ((ShiftLHS.getOpcode() == ISD::SIGN_EXTEND &&
----------------
RKSimon wrote:
remove extra ( )
https://github.com/llvm/llvm-project/pull/101294
More information about the llvm-commits
mailing list