[llvm] e6aa29e - [ConstraintElim] Move FactOrCheck and State definitions to top. (NFC)
Florian Hahn via llvm-commits
llvm-commits at lists.llvm.org
Wed Jun 28 01:41:35 PDT 2023
Author: Florian Hahn
Date: 2023-06-28T09:40:54+01:00
New Revision: e6aa29eddd3fe05e27ac644fceff9ef4027540d8
URL: https://github.com/llvm/llvm-project/commit/e6aa29eddd3fe05e27ac644fceff9ef4027540d8
DIFF: https://github.com/llvm/llvm-project/commit/e6aa29eddd3fe05e27ac644fceff9ef4027540d8.diff
LOG: [ConstraintElim] Move FactOrCheck and State definitions to top. (NFC)
This will enable follow-up refactoring to use the State directly in the
constraint system, reducing the need to pass lots of arguments around.
Added:
Modified:
llvm/lib/Transforms/Scalar/ConstraintElimination.cpp
Removed:
################################################################################
diff --git a/llvm/lib/Transforms/Scalar/ConstraintElimination.cpp b/llvm/lib/Transforms/Scalar/ConstraintElimination.cpp
index 8ccfae4757e8f..a869605054ef1 100644
--- a/llvm/lib/Transforms/Scalar/ConstraintElimination.cpp
+++ b/llvm/lib/Transforms/Scalar/ConstraintElimination.cpp
@@ -75,7 +75,86 @@ static int64_t addWithOverflow(int64_t A, int64_t B) {
return Result;
}
+static Instruction *getContextInstForUse(Use &U) {
+ Instruction *UserI = cast<Instruction>(U.getUser());
+ if (auto *Phi = dyn_cast<PHINode>(UserI))
+ UserI = Phi->getIncomingBlock(U)->getTerminator();
+ return UserI;
+}
+
namespace {
+/// Represents either
+/// * a condition that holds on entry to a block (=conditional fact)
+/// * an assume (=assume fact)
+/// * a use of a compare instruction to simplify.
+/// It also tracks the Dominator DFS in and out numbers for each entry.
+struct FactOrCheck {
+ union {
+ Instruction *Inst;
+ Use *U;
+ };
+ unsigned NumIn;
+ unsigned NumOut;
+ bool HasInst;
+ bool Not;
+
+ FactOrCheck(DomTreeNode *DTN, Instruction *Inst, bool Not)
+ : Inst(Inst), NumIn(DTN->getDFSNumIn()), NumOut(DTN->getDFSNumOut()),
+ HasInst(true), Not(Not) {}
+
+ FactOrCheck(DomTreeNode *DTN, Use *U)
+ : U(U), NumIn(DTN->getDFSNumIn()), NumOut(DTN->getDFSNumOut()),
+ HasInst(false), Not(false) {}
+
+ static FactOrCheck getFact(DomTreeNode *DTN, Instruction *Inst,
+ bool Not = false) {
+ return FactOrCheck(DTN, Inst, Not);
+ }
+
+ static FactOrCheck getCheck(DomTreeNode *DTN, Use *U) {
+ return FactOrCheck(DTN, U);
+ }
+
+ static FactOrCheck getCheck(DomTreeNode *DTN, CallInst *CI) {
+ return FactOrCheck(DTN, CI, false);
+ }
+
+ bool isCheck() const {
+ return !HasInst ||
+ match(Inst, m_Intrinsic<Intrinsic::ssub_with_overflow>());
+ }
+
+ Instruction *getContextInst() const {
+ if (HasInst)
+ return Inst;
+ return getContextInstForUse(*U);
+ }
+ Instruction *getInstructionToSimplify() const {
+ assert(isCheck());
+ if (HasInst)
+ return Inst;
+ // The use may have been simplified to a constant already.
+ return dyn_cast<Instruction>(*U);
+ }
+ bool isConditionFact() const { return !isCheck() && isa<CmpInst>(Inst); }
+};
+
+/// Keep state required to build worklist.
+struct State {
+ DominatorTree &DT;
+ SmallVector<FactOrCheck, 64> WorkList;
+
+ State(DominatorTree &DT) : DT(DT) {}
+
+ /// Process block \p BB and add known facts to work-list.
+ void addInfoFor(BasicBlock &BB);
+
+ /// Returns true if we can add a known condition from BB to its successor
+ /// block Succ.
+ bool canAddSuccessor(BasicBlock &BB, BasicBlock *Succ) const {
+ return DT.dominates(BasicBlockEdge(&BB, Succ), Succ);
+ }
+};
class ConstraintInfo;
@@ -660,89 +739,6 @@ void ConstraintInfo::transferToOtherSystem(
}
}
-static Instruction *getContextInstForUse(Use &U) {
- Instruction *UserI = cast<Instruction>(U.getUser());
- if (auto *Phi = dyn_cast<PHINode>(UserI))
- UserI = Phi->getIncomingBlock(U)->getTerminator();
- return UserI;
-}
-
-namespace {
-/// Represents either
-/// * a condition that holds on entry to a block (=conditional fact)
-/// * an assume (=assume fact)
-/// * a use of a compare instruction to simplify.
-/// It also tracks the Dominator DFS in and out numbers for each entry.
-struct FactOrCheck {
- union {
- Instruction *Inst;
- Use *U;
- };
- unsigned NumIn;
- unsigned NumOut;
- bool HasInst;
- bool Not;
-
- FactOrCheck(DomTreeNode *DTN, Instruction *Inst, bool Not)
- : Inst(Inst), NumIn(DTN->getDFSNumIn()), NumOut(DTN->getDFSNumOut()),
- HasInst(true), Not(Not) {}
-
- FactOrCheck(DomTreeNode *DTN, Use *U)
- : U(U), NumIn(DTN->getDFSNumIn()), NumOut(DTN->getDFSNumOut()),
- HasInst(false), Not(false) {}
-
- static FactOrCheck getFact(DomTreeNode *DTN, Instruction *Inst,
- bool Not = false) {
- return FactOrCheck(DTN, Inst, Not);
- }
-
- static FactOrCheck getCheck(DomTreeNode *DTN, Use *U) {
- return FactOrCheck(DTN, U);
- }
-
- static FactOrCheck getCheck(DomTreeNode *DTN, CallInst *CI) {
- return FactOrCheck(DTN, CI, false);
- }
-
- bool isCheck() const {
- return !HasInst ||
- match(Inst, m_Intrinsic<Intrinsic::ssub_with_overflow>());
- }
-
- Instruction *getContextInst() const {
- if (HasInst)
- return Inst;
- return getContextInstForUse(*U);
- }
- Instruction *getInstructionToSimplify() const {
- assert(isCheck());
- if (HasInst)
- return Inst;
- // The use may have been simplified to a constant already.
- return dyn_cast<Instruction>(*U);
- }
- bool isConditionFact() const { return !isCheck() && isa<CmpInst>(Inst); }
-};
-
-/// Keep state required to build worklist.
-struct State {
- DominatorTree &DT;
- SmallVector<FactOrCheck, 64> WorkList;
-
- State(DominatorTree &DT) : DT(DT) {}
-
- /// Process block \p BB and add known facts to work-list.
- void addInfoFor(BasicBlock &BB);
-
- /// Returns true if we can add a known condition from BB to its successor
- /// block Succ.
- bool canAddSuccessor(BasicBlock &BB, BasicBlock *Succ) const {
- return DT.dominates(BasicBlockEdge(&BB, Succ), Succ);
- }
-};
-
-} // namespace
-
#ifndef NDEBUG
static void dumpConstraint(ArrayRef<int64_t> C,
More information about the llvm-commits
mailing list