[llvm] [X86] Match SETCC_CARRY in addition of SUB when trying to reconstruct LEA (PR #126551)
Phoebe Wang via llvm-commits
llvm-commits at lists.llvm.org
Thu Feb 13 06:53:32 PST 2025
================
@@ -52011,22 +52011,33 @@ static SDValue combineOr(SDNode *N, SelectionDAG &DAG,
if (SDValue R = combineLogicBlendIntoPBLENDV(N, dl, DAG, Subtarget))
return R;
- // (0 - SetCC) | C -> (zext (not SetCC)) * (C + 1) - 1 if we can get a LEA out of it.
- if ((VT == MVT::i32 || VT == MVT::i64) &&
- N0.getOpcode() == ISD::SUB && N0.hasOneUse() &&
- isNullConstant(N0.getOperand(0))) {
- SDValue Cond = N0.getOperand(1);
- if (Cond.getOpcode() == ISD::ZERO_EXTEND && Cond.hasOneUse())
- Cond = Cond.getOperand(0);
-
- if (Cond.getOpcode() == X86ISD::SETCC && Cond.hasOneUse()) {
- if (auto *CN = dyn_cast<ConstantSDNode>(N1)) {
- uint64_t Val = CN->getZExtValue();
- if (Val == 1 || Val == 2 || Val == 3 || Val == 4 || Val == 7 || Val == 8) {
- X86::CondCode CCode = (X86::CondCode)Cond.getConstantOperandVal(0);
- CCode = X86::GetOppositeBranchCondition(CCode);
- SDValue NotCond = getSETCC(CCode, Cond.getOperand(1), SDLoc(Cond), DAG);
+ // Combine `(x86isd::setcc_carry) | C` and `(0 - SetCC) | C`
+ // into `(zext (not SetCC)) * (C + 1) - 1` if we can get a LEA out of it.
+ if (VT == MVT::i32 || VT == MVT::i64) {
+ if (auto *CN = dyn_cast<ConstantSDNode>(N1)) {
+ uint64_t Val = CN->getZExtValue();
+ if ((Val == 1 || Val == 2 || Val == 3 || Val == 4 || Val == 7 ||
+ Val == 8) &&
+ N0.hasOneUse()) {
----------------
phoebewang wrote:
Oh, I meant move `N0.hasOneUse()` to line 52016..
https://github.com/llvm/llvm-project/pull/126551
More information about the llvm-commits
mailing list