[PATCH] D137949: [RISCV] Branchless lowering for select (x < 0), TrueConstant, FalseConstant)
Liao Chunyu via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Mon Nov 14 20:08:55 PST 2022
liaolucy updated this revision to Diff 475334.
liaolucy marked 3 inline comments as done.
liaolucy added a comment.
Address Philip Reames's comments
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D137949/new/
https://reviews.llvm.org/D137949
Files:
llvm/lib/Target/RISCV/RISCVISelLowering.cpp
llvm/test/CodeGen/RISCV/select-const.ll
Index: llvm/test/CodeGen/RISCV/select-const.ll
===================================================================
--- llvm/test/CodeGen/RISCV/select-const.ll
+++ llvm/test/CodeGen/RISCV/select-const.ll
@@ -391,3 +391,22 @@
%2 = select i1 %1, i32 10001, i32 10002
ret i32 %2
}
+
+define i32 @select_slt_zero_constant1_constant2(i32 signext %x) {
+; RV32-LABEL: select_slt_zero_constant1_constant2:
+; RV32: # %bb.0:
+; RV32-NEXT: srai a0, a0, 31
+; RV32-NEXT: andi a0, a0, 10
+; RV32-NEXT: addi a0, a0, -3
+; RV32-NEXT: ret
+;
+; RV64-LABEL: select_slt_zero_constant1_constant2:
+; RV64: # %bb.0:
+; RV64-NEXT: srai a0, a0, 63
+; RV64-NEXT: andi a0, a0, 10
+; RV64-NEXT: addi a0, a0, -3
+; RV64-NEXT: ret
+ %cmp = icmp slt i32 %x, 0
+ %cond = select i1 %cmp, i32 7, i32 -3
+ ret i32 %cond
+}
Index: llvm/lib/Target/RISCV/RISCVISelLowering.cpp
===================================================================
--- llvm/lib/Target/RISCV/RISCVISelLowering.cpp
+++ llvm/lib/Target/RISCV/RISCVISelLowering.cpp
@@ -9627,6 +9627,29 @@
}
}
+ // select (x < 0), y, z -> x >> (XLEN - 1) & (y - z) + z
+ auto *C = dyn_cast<ConstantSDNode>(RHS);
+ if (!Subtarget.hasShortForwardBranchOpt() && C && C->isZero() &&
+ CCVal == ISD::CondCode::SETLT && isa<ConstantSDNode>(TrueV) &&
+ isa<ConstantSDNode>(FalseV)) {
+ int64_t TrueSImm = cast<ConstantSDNode>(TrueV)->getSExtValue();
+ int64_t FalseSImm = cast<ConstantSDNode>(FalseV)->getSExtValue();
+ // Only handle simm12, if it is not in this range, it can be considered as
+ // register.
+ if (isInt<12>(TrueSImm) && isInt<12>(FalseSImm) &&
+ isInt<12>(TrueSImm - FalseSImm)) {
+ SDValue SRA;
+ if (Subtarget.is64Bit())
+ SRA = DAG.getNode(ISD::SRA, DL, VT, LHS, DAG.getConstant(63, DL, VT));
+ else
+ SRA = DAG.getNode(ISD::SRA, DL, VT, LHS, DAG.getConstant(31, DL, VT));
+ SDValue AND =
+ DAG.getNode(ISD::AND, DL, VT, SRA,
+ DAG.getConstant(TrueSImm - FalseSImm, DL, VT));
+ return DAG.getNode(ISD::ADD, DL, VT, AND, FalseV);
+ }
+ }
+
if (combine_CC(LHS, RHS, CC, DL, DAG, Subtarget))
return DAG.getNode(RISCVISD::SELECT_CC, DL, N->getValueType(0),
{LHS, RHS, CC, TrueV, FalseV});
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D137949.475334.patch
Type: text/x-patch
Size: 2374 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20221115/dc3c3e24/attachment.bin>
More information about the llvm-commits
mailing list