CIRCT 22.0.0git
|
Public Types | |
using | ObjectToMaxDistance = llvm::MapVector< Object, std::pair< int64_t, llvm::ImmutableList< DebugPoint > > > |
Public Member Functions | |
LocalVisitor (hw::HWModuleOp module, Context *ctx) | |
LogicalResult | initializeAndRun () |
void | waitUntilDone () const |
FailureOr< ArrayRef< OpenPath > > | getOrComputePaths (Value value, size_t bitPos) |
ArrayRef< OpenPath > | getCachedPaths (Value value, size_t bitPos) const |
void | getClosedPaths (SmallVectorImpl< DataflowPath > &results) const |
void | setTopLevel () |
bool | isTopLevel () const |
hw::HWModuleOp | getHWModuleOp () const |
const auto & | getFromInputPortToFanOut () const |
const auto & | getFromOutputPortToFanIn () const |
const auto & | getFanOutResults () const |
circt::igraph::InstancePathCache * | getInstancePathCache () const |
llvm::ImmutableListFactory< DebugPoint > * | getDebugPointFactory () const |
Private Member Functions | |
void | putUnclosedResult (const Object &object, int64_t delay, llvm::ImmutableList< DebugPoint > history, ObjectToMaxDistance &objectToMaxDistance) |
LogicalResult | initializeAndRun (hw::InstanceOp instance) |
LogicalResult | initializeAndRun (hw::OutputOp output) |
LogicalResult | visitValue (Value value, size_t bitPos, SmallVectorImpl< OpenPath > &results) |
LogicalResult | visit (mlir::BlockArgument argument, size_t bitPos, SmallVectorImpl< OpenPath > &results) |
LogicalResult | visit (hw::InstanceOp op, size_t bitPos, size_t resultNum, SmallVectorImpl< OpenPath > &results) |
LogicalResult | visit (hw::WireOp op, size_t bitPos, SmallVectorImpl< OpenPath > &results) |
LogicalResult | visit (comb::ConcatOp op, size_t bitPos, SmallVectorImpl< OpenPath > &results) |
LogicalResult | visit (comb::ExtractOp op, size_t bitPos, SmallVectorImpl< OpenPath > &results) |
LogicalResult | visit (comb::ReplicateOp op, size_t bitPos, SmallVectorImpl< OpenPath > &results) |
std::pair< Value, size_t > | findLeader (Value value, size_t bitpos) const |
LogicalResult | markEquivalent (Value from, size_t fromBitPos, Value to, size_t toBitPos, SmallVectorImpl< OpenPath > &results) |
LogicalResult | visit (aig::AndInverterOp op, size_t bitPos, SmallVectorImpl< OpenPath > &results) |
LogicalResult | visit (comb::AndOp op, size_t bitPos, SmallVectorImpl< OpenPath > &results) |
LogicalResult | visit (comb::XorOp op, size_t bitPos, SmallVectorImpl< OpenPath > &results) |
LogicalResult | visit (comb::OrOp op, size_t bitPos, SmallVectorImpl< OpenPath > &results) |
LogicalResult | visit (comb::MuxOp op, size_t bitPos, SmallVectorImpl< OpenPath > &results) |
LogicalResult | addLogicOp (Operation *op, size_t bitPos, SmallVectorImpl< OpenPath > &results) |
LogicalResult | visit (comb::TruthTableOp op, size_t bitPos, SmallVectorImpl< OpenPath > &results) |
LogicalResult | visit (hw::ConstantOp op, size_t bitPos, SmallVectorImpl< OpenPath > &results) |
LogicalResult | visit (seq::FirRegOp op, size_t bitPos, SmallVectorImpl< OpenPath > &results) |
LogicalResult | visit (seq::CompRegOp op, size_t bitPos, SmallVectorImpl< OpenPath > &results) |
LogicalResult | visit (seq::FirMemReadOp op, size_t bitPos, SmallVectorImpl< OpenPath > &results) |
LogicalResult | visit (seq::FirMemReadWriteOp op, size_t bitPos, SmallVectorImpl< OpenPath > &results) |
LogicalResult | visitDefault (OpResult result, size_t bitPos, SmallVectorImpl< OpenPath > &results) |
LogicalResult | addEdge (Value to, size_t toBitPos, int64_t delay, SmallVectorImpl< OpenPath > &results) |
LogicalResult | markFanIn (Value value, size_t bitPos, SmallVectorImpl< OpenPath > &results) |
LogicalResult | markRegFanOut (Value fanOut, Value start, Value reset={}, Value resetValue={}, Value enable={}) |
Private Attributes | |
llvm::MapVector< std::pair< BlockArgument, size_t >, ObjectToMaxDistance > | fromInputPortToFanOut |
llvm::MapVector< std::tuple< size_t, size_t >, ObjectToMaxDistance > | fromOutputPortToFanIn |
llvm::EquivalenceClasses< std::pair< Value, size_t > > | ec |
DenseMap< std::pair< Value, size_t >, std::pair< Value, size_t > > | ecMap |
hw::HWModuleOp Context * | ctx |
std::unique_ptr< circt::igraph::InstancePathCache > | instancePathCache |
std::unique_ptr< llvm::ImmutableListFactory< DebugPoint > > | debugPointFactory |
DenseMap< std::pair< Value, size_t >, SmallVector< OpenPath > > | cachedResults |
DenseMap< Object, SmallVector< OpenPath > > | fanOutResults |
std::unique_ptr< OperationAnalyzer > | operationAnalyzer |
std::atomic_bool | done |
std::condition_variable | cv |
std::mutex | mutex |
bool | topLevel = false |
Definition at line 578 of file LongestPathAnalysis.cpp.
using LocalVisitor::ObjectToMaxDistance = llvm::MapVector<Object, std::pair<int64_t, llvm::ImmutableList<DebugPoint> >> |
Definition at line 594 of file LongestPathAnalysis.cpp.
LocalVisitor::LocalVisitor | ( | hw::HWModuleOp | module, |
Context * | ctx | ||
) |
Definition at line 743 of file LongestPathAnalysis.cpp.
References ctx, debugPointFactory, done, instancePathCache, and operationAnalyzer.
|
private |
Definition at line 844 of file LongestPathAnalysis.cpp.
References getOrComputePaths().
Referenced by addLogicOp(), visit(), visit(), and visitDefault().
|
private |
Definition at line 1025 of file LongestPathAnalysis.cpp.
References addEdge(), ctx, and filterPaths().
|
inlineprivate |
Definition at line 655 of file LongestPathAnalysis.cpp.
ArrayRef< OpenPath > LocalVisitor::getCachedPaths | ( | Value | value, |
size_t | bitPos | ||
) | const |
Definition at line 756 of file LongestPathAnalysis.cpp.
References cachedResults, ec, and getCachedPaths().
Referenced by getCachedPaths().
void LocalVisitor::getClosedPaths | ( | SmallVectorImpl< DataflowPath > & | results | ) | const |
|
inline |
Definition at line 611 of file LongestPathAnalysis.cpp.
|
inline |
Definition at line 605 of file LongestPathAnalysis.cpp.
|
inline |
Definition at line 603 of file LongestPathAnalysis.cpp.
|
inline |
Definition at line 604 of file LongestPathAnalysis.cpp.
|
inline |
Definition at line 601 of file LongestPathAnalysis.cpp.
|
inline |
Definition at line 607 of file LongestPathAnalysis.cpp.
Referenced by aig.LongestPathAnalysis::Impl::collectClosedPaths().
FailureOr< ArrayRef< OpenPath > > LocalVisitor::getOrComputePaths | ( | Value | value, |
size_t | bitPos | ||
) |
Definition at line 1085 of file LongestPathAnalysis.cpp.
References assert(), cachedResults, ctx, ec, filterPaths(), getOrComputePaths(), and visitValue().
Referenced by addEdge(), aig.LongestPathAnalysis::Impl::computeLocalPaths(), getOrComputePaths(), initializeAndRun(), initializeAndRun(), initializeAndRun(), markRegFanOut(), and visit().
LogicalResult LocalVisitor::initializeAndRun | ( | ) |
Definition at line 1243 of file LongestPathAnalysis.cpp.
References ctx, and getOrComputePaths().
|
private |
Definition at line 1166 of file LongestPathAnalysis.cpp.
References assert(), concatList(), ctx, debugPointFactory, fanOutResults, fromInputPortToFanOut, circt::hw::getBitWidth(), getOrComputePaths(), instancePathCache, mapList(), and putUnclosedResult().
|
private |
Definition at line 1226 of file LongestPathAnalysis.cpp.
References fromOutputPortToFanIn, circt::hw::getBitWidth(), getOrComputePaths(), and putUnclosedResult().
|
inline |
Definition at line 600 of file LongestPathAnalysis.cpp.
|
private |
Definition at line 833 of file LongestPathAnalysis.cpp.
References assert(), ec, and visitValue().
|
private |
Definition at line 912 of file LongestPathAnalysis.cpp.
Referenced by visit().
|
private |
Definition at line 789 of file LongestPathAnalysis.cpp.
References fanOutResults, fromInputPortToFanOut, circt::hw::getBitWidth(), getOrComputePaths(), and putUnclosedResult().
|
private |
Definition at line 774 of file LongestPathAnalysis.cpp.
Referenced by initializeAndRun(), initializeAndRun(), and markRegFanOut().
|
inline |
Definition at line 599 of file LongestPathAnalysis.cpp.
|
private |
Definition at line 857 of file LongestPathAnalysis.cpp.
References addLogicOp().
|
private |
Definition at line 863 of file LongestPathAnalysis.cpp.
References addLogicOp().
|
private |
Definition at line 1008 of file LongestPathAnalysis.cpp.
References circt::hw::getBitWidth(), and markEquivalent().
|
private |
Definition at line 898 of file LongestPathAnalysis.cpp.
References assert(), circt::hw::getBitWidth(), and markEquivalent().
|
private |
Definition at line 878 of file LongestPathAnalysis.cpp.
References addEdge(), ctx, and filterPaths().
|
private |
Definition at line 868 of file LongestPathAnalysis.cpp.
References addLogicOp().
|
private |
Definition at line 906 of file LongestPathAnalysis.cpp.
References circt::hw::getBitWidth(), and markEquivalent().
|
private |
Definition at line 889 of file LongestPathAnalysis.cpp.
References addEdge().
|
private |
Definition at line 873 of file LongestPathAnalysis.cpp.
References addLogicOp().
|
inlineprivate |
Definition at line 679 of file LongestPathAnalysis.cpp.
|
private |
Definition at line 923 of file LongestPathAnalysis.cpp.
References assert(), concatList(), ctx, debugPointFactory, aig.DebugPoint::delay, getOrComputePaths(), instancePathCache, mapList(), and markFanIn().
|
private |
Definition at line 918 of file LongestPathAnalysis.cpp.
References markEquivalent().
|
private |
Definition at line 1071 of file LongestPathAnalysis.cpp.
References assert(), ctx, and debugPointFactory.
Referenced by visitValue().
|
inlineprivate |
Definition at line 690 of file LongestPathAnalysis.cpp.
|
inlineprivate |
Definition at line 695 of file LongestPathAnalysis.cpp.
|
inlineprivate |
Definition at line 700 of file LongestPathAnalysis.cpp.
|
inlineprivate |
Definition at line 685 of file LongestPathAnalysis.cpp.
|
private |
Definition at line 1037 of file LongestPathAnalysis.cpp.
References addEdge(), and operationAnalyzer.
Referenced by visitValue().
|
private |
Definition at line 1122 of file LongestPathAnalysis.cpp.
References ctx, debugPointFactory, visit(), and visitDefault().
Referenced by getOrComputePaths(), and markEquivalent().
void LocalVisitor::waitUntilDone | ( | ) | const |
Definition at line 783 of file LongestPathAnalysis.cpp.
References cv, done, and mutex.
Referenced by Context::getLocalVisitorMutable().
|
private |
Definition at line 726 of file LongestPathAnalysis.cpp.
Referenced by getCachedPaths(), and getOrComputePaths().
|
private |
Definition at line 718 of file LongestPathAnalysis.cpp.
Referenced by addLogicOp(), getOrComputePaths(), initializeAndRun(), initializeAndRun(), LocalVisitor(), visit(), visit(), visit(), and visitValue().
|
mutableprivate |
Definition at line 736 of file LongestPathAnalysis.cpp.
Referenced by waitUntilDone().
|
private |
Definition at line 723 of file LongestPathAnalysis.cpp.
Referenced by initializeAndRun(), LocalVisitor(), visit(), visit(), and visitValue().
|
private |
Definition at line 735 of file LongestPathAnalysis.cpp.
Referenced by LocalVisitor(), and waitUntilDone().
|
private |
Definition at line 653 of file LongestPathAnalysis.cpp.
Referenced by getCachedPaths(), getOrComputePaths(), and markEquivalent().
|
private |
Definition at line 654 of file LongestPathAnalysis.cpp.
|
private |
Definition at line 729 of file LongestPathAnalysis.cpp.
Referenced by initializeAndRun(), and markRegFanOut().
|
private |
Definition at line 622 of file LongestPathAnalysis.cpp.
Referenced by initializeAndRun(), and markRegFanOut().
|
private |
Definition at line 626 of file LongestPathAnalysis.cpp.
Referenced by initializeAndRun().
|
private |
Definition at line 721 of file LongestPathAnalysis.cpp.
Referenced by initializeAndRun(), LocalVisitor(), and visit().
|
mutableprivate |
Definition at line 737 of file LongestPathAnalysis.cpp.
Referenced by waitUntilDone().
|
private |
Definition at line 732 of file LongestPathAnalysis.cpp.
Referenced by LocalVisitor(), and visitDefault().
|
private |
Definition at line 740 of file LongestPathAnalysis.cpp.