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 & | getFromInputPortToEndPoint () const |
const auto & | getFromOutputPortToStartPoint () const |
const auto & | getEndPointResults () 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 (mig::MajorityInverterOp 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 | markStartPoint (Value value, size_t bitPos, SmallVectorImpl< OpenPath > &results) |
LogicalResult | markRegEndPoint (Value endPoint, Value start, Value reset={}, Value resetValue={}, Value enable={}) |
Private Attributes | |
llvm::MapVector< std::pair< BlockArgument, size_t >, ObjectToMaxDistance > | fromInputPortToEndPoint |
llvm::MapVector< std::tuple< size_t, size_t >, ObjectToMaxDistance > | fromOutputPortToStartPoint |
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 > > | endPointResults |
std::unique_ptr< OperationAnalyzer > | operationAnalyzer |
std::atomic_bool | done |
std::condition_variable | cv |
std::mutex | mutex |
bool | topLevel = false |
Definition at line 579 of file LongestPathAnalysis.cpp.
using LocalVisitor::ObjectToMaxDistance = llvm::MapVector<Object, std::pair<int64_t, llvm::ImmutableList<DebugPoint> >> |
Definition at line 595 of file LongestPathAnalysis.cpp.
LocalVisitor::LocalVisitor | ( | hw::HWModuleOp | module, |
Context * | ctx | ||
) |
Definition at line 750 of file LongestPathAnalysis.cpp.
References ctx, debugPointFactory, done, instancePathCache, and operationAnalyzer.
|
private |
Definition at line 852 of file LongestPathAnalysis.cpp.
References getOrComputePaths().
Referenced by addLogicOp(), visit(), visit(), visit(), and visitDefault().
|
private |
Definition at line 1045 of file LongestPathAnalysis.cpp.
References addEdge(), ctx, and filterPaths().
|
inlineprivate |
Definition at line 660 of file LongestPathAnalysis.cpp.
ArrayRef< OpenPath > LocalVisitor::getCachedPaths | ( | Value | value, |
size_t | bitPos | ||
) | const |
Definition at line 763 of file LongestPathAnalysis.cpp.
References cachedResults, ec, and getCachedPaths().
Referenced by getCachedPaths().
void LocalVisitor::getClosedPaths | ( | SmallVectorImpl< DataflowPath > & | results | ) | const |
|
inline |
Definition at line 616 of file LongestPathAnalysis.cpp.
|
inline |
Definition at line 610 of file LongestPathAnalysis.cpp.
|
inline |
Definition at line 604 of file LongestPathAnalysis.cpp.
|
inline |
Definition at line 607 of file LongestPathAnalysis.cpp.
|
inline |
Definition at line 602 of file LongestPathAnalysis.cpp.
|
inline |
Definition at line 612 of file LongestPathAnalysis.cpp.
Referenced by synth.LongestPathAnalysis::Impl::collectClosedPaths().
FailureOr< ArrayRef< OpenPath > > LocalVisitor::getOrComputePaths | ( | Value | value, |
size_t | bitPos | ||
) |
Definition at line 1105 of file LongestPathAnalysis.cpp.
References assert(), cachedResults, ctx, ec, filterPaths(), getOrComputePaths(), and visitValue().
Referenced by addEdge(), synth.LongestPathAnalysis::Impl::computeLocalPaths(), getOrComputePaths(), initializeAndRun(), initializeAndRun(), initializeAndRun(), markRegEndPoint(), and visit().
LogicalResult LocalVisitor::initializeAndRun | ( | ) |
Definition at line 1265 of file LongestPathAnalysis.cpp.
References ctx, and getOrComputePaths().
|
private |
Definition at line 1187 of file LongestPathAnalysis.cpp.
References assert(), concatList(), ctx, debugPointFactory, endPointResults, fromInputPortToEndPoint, circt::hw::getBitWidth(), getOrComputePaths(), instancePathCache, mapList(), and putUnclosedResult().
|
private |
Definition at line 1248 of file LongestPathAnalysis.cpp.
References fromOutputPortToStartPoint, circt::hw::getBitWidth(), getOrComputePaths(), and putUnclosedResult().
|
inline |
Definition at line 601 of file LongestPathAnalysis.cpp.
|
private |
Definition at line 841 of file LongestPathAnalysis.cpp.
References assert(), ec, and visitValue().
|
private |
Definition at line 796 of file LongestPathAnalysis.cpp.
References endPointResults, fromInputPortToEndPoint, circt::hw::getBitWidth(), getOrComputePaths(), and putUnclosedResult().
|
private |
Definition at line 932 of file LongestPathAnalysis.cpp.
Referenced by visit().
|
private |
Definition at line 781 of file LongestPathAnalysis.cpp.
Referenced by initializeAndRun(), initializeAndRun(), and markRegEndPoint().
|
inline |
Definition at line 600 of file LongestPathAnalysis.cpp.
|
private |
Definition at line 865 of file LongestPathAnalysis.cpp.
References addLogicOp().
|
private |
Definition at line 883 of file LongestPathAnalysis.cpp.
References addLogicOp().
|
private |
Definition at line 1028 of file LongestPathAnalysis.cpp.
References circt::hw::getBitWidth(), and markEquivalent().
|
private |
Definition at line 918 of file LongestPathAnalysis.cpp.
References assert(), circt::hw::getBitWidth(), and markEquivalent().
|
private |
Definition at line 898 of file LongestPathAnalysis.cpp.
References addEdge(), ctx, and filterPaths().
|
private |
Definition at line 888 of file LongestPathAnalysis.cpp.
References addLogicOp().
|
private |
Definition at line 926 of file LongestPathAnalysis.cpp.
References circt::hw::getBitWidth(), and markEquivalent().
|
private |
Definition at line 909 of file LongestPathAnalysis.cpp.
References addEdge().
|
private |
Definition at line 893 of file LongestPathAnalysis.cpp.
References addLogicOp().
|
inlineprivate |
Definition at line 686 of file LongestPathAnalysis.cpp.
|
private |
Definition at line 943 of file LongestPathAnalysis.cpp.
References assert(), concatList(), ctx, debugPointFactory, synth.DebugPoint::delay, getOrComputePaths(), instancePathCache, mapList(), and markStartPoint().
|
private |
Definition at line 938 of file LongestPathAnalysis.cpp.
References markEquivalent().
|
private |
Definition at line 871 of file LongestPathAnalysis.cpp.
References addEdge().
|
private |
Definition at line 1091 of file LongestPathAnalysis.cpp.
References assert(), ctx, and debugPointFactory.
Referenced by visitValue().
|
inlineprivate |
Definition at line 697 of file LongestPathAnalysis.cpp.
|
inlineprivate |
Definition at line 702 of file LongestPathAnalysis.cpp.
|
inlineprivate |
Definition at line 707 of file LongestPathAnalysis.cpp.
|
inlineprivate |
Definition at line 692 of file LongestPathAnalysis.cpp.
|
private |
Definition at line 1057 of file LongestPathAnalysis.cpp.
References addEdge(), and operationAnalyzer.
Referenced by visitValue().
|
private |
Definition at line 1142 of file LongestPathAnalysis.cpp.
References ctx, debugPointFactory, visit(), and visitDefault().
Referenced by getOrComputePaths(), and markEquivalent().
void LocalVisitor::waitUntilDone | ( | ) | const |
Definition at line 790 of file LongestPathAnalysis.cpp.
References cv, done, and mutex.
Referenced by Context::getLocalVisitorMutable().
|
private |
Definition at line 733 of file LongestPathAnalysis.cpp.
Referenced by getCachedPaths(), and getOrComputePaths().
|
private |
Definition at line 725 of file LongestPathAnalysis.cpp.
Referenced by addLogicOp(), getOrComputePaths(), initializeAndRun(), initializeAndRun(), LocalVisitor(), visit(), visit(), visit(), and visitValue().
|
mutableprivate |
Definition at line 743 of file LongestPathAnalysis.cpp.
Referenced by waitUntilDone().
|
private |
Definition at line 730 of file LongestPathAnalysis.cpp.
Referenced by initializeAndRun(), LocalVisitor(), visit(), visit(), and visitValue().
|
private |
Definition at line 742 of file LongestPathAnalysis.cpp.
Referenced by LocalVisitor(), and waitUntilDone().
|
private |
Definition at line 658 of file LongestPathAnalysis.cpp.
Referenced by getCachedPaths(), getOrComputePaths(), and markEquivalent().
|
private |
Definition at line 659 of file LongestPathAnalysis.cpp.
|
private |
Definition at line 736 of file LongestPathAnalysis.cpp.
Referenced by initializeAndRun(), and markRegEndPoint().
|
private |
Definition at line 627 of file LongestPathAnalysis.cpp.
Referenced by initializeAndRun(), and markRegEndPoint().
|
private |
Definition at line 631 of file LongestPathAnalysis.cpp.
Referenced by initializeAndRun().
|
private |
Definition at line 728 of file LongestPathAnalysis.cpp.
Referenced by initializeAndRun(), LocalVisitor(), and visit().
|
mutableprivate |
Definition at line 744 of file LongestPathAnalysis.cpp.
Referenced by waitUntilDone().
|
private |
Definition at line 739 of file LongestPathAnalysis.cpp.
Referenced by LocalVisitor(), and visitDefault().
|
private |
Definition at line 747 of file LongestPathAnalysis.cpp.