CIRCT 20.0.0git
|
This class models the accumulation of physical propagation delays on combinational paths along SSA dependences. More...
#include <Problems.h>
Public Member Functions | |
std::optional< float > | getIncomingDelay (OperatorType opr) |
The incoming delay denotes the propagation time from the operand inputs to either the result outputs (combinational operators) or the first internal register stage. | |
void | setIncomingDelay (OperatorType opr, float delay) |
std::optional< float > | getOutgoingDelay (OperatorType opr) |
The outgoing delay denotes the propagation time from either the operand inputs (combinational operators) or the last internal register stage to the result outputs. | |
void | setOutgoingDelay (OperatorType opr, float delay) |
std::optional< float > | getStartTimeInCycle (Operation *op) |
Computed by the scheduler, this start time is relative to the beginning of the cycle that op starts in. | |
void | setStartTimeInCycle (Operation *op, float time) |
void | clearStartTimeInCycle () |
virtual PropertyStringVector | getProperties (Operation *op) override |
virtual PropertyStringVector | getProperties (OperatorType opr) override |
virtual LogicalResult | check () override |
Return success if the constructed scheduling problem is valid. | |
virtual LogicalResult | verify () override |
Return success if the computed solution is valid. | |
Problem (Operation *containingOp) | |
Construct an empty scheduling problem. | |
Problem ()=default | |
Public Member Functions inherited from circt::scheduling::Problem | |
Problem (Operation *containingOp) | |
Construct an empty scheduling problem. | |
virtual | ~Problem ()=default |
void | insertOperation (Operation *op) |
Include op in this scheduling problem. | |
LogicalResult | insertDependence (Dependence dep) |
Include dep in the scheduling problem. | |
void | insertOperatorType (OperatorType opr) |
Include opr in this scheduling problem. | |
OperatorType | getOrInsertOperatorType (StringRef name) |
Retrieves the operator type identified by the client-specific name . | |
Operation * | getContainingOp () |
Return the operation containing this problem, e.g. to emit diagnostics. | |
void | setContainingOp (Operation *op) |
Set the operation containing this problem, e.g. to emit diagnostics. | |
bool | hasOperation (Operation *op) |
Return true if op is part of this problem. | |
const OperationSet & | getOperations () |
Return the set of operations. | |
DependenceRange | getDependences (Operation *op) |
Return a range object to transparently iterate over op's incoming 1) implicit def-use dependences (backed by the SSA graph), and then 2) explictly added auxiliary dependences. | |
bool | hasOperatorType (OperatorType opr) |
Return true if opr is part of this problem. | |
const OperatorTypeSet & | getOperatorTypes () |
Return the set of operator types. | |
std::optional< OperatorType > | getLinkedOperatorType (Operation *op) |
The linked operator type provides the runtime characteristics for op . | |
void | setLinkedOperatorType (Operation *op, OperatorType opr) |
std::optional< unsigned > | getLatency (OperatorType opr) |
The latency is the number of cycles opr needs to compute its result. | |
void | setLatency (OperatorType opr, unsigned val) |
std::optional< unsigned > | getStartTime (Operation *op) |
Return the start time for op , as computed by the scheduler. | |
void | setStartTime (Operation *op, unsigned val) |
std::optional< unsigned > | getEndTime (Operation *op) |
Returns the end time for op , as computed by the scheduler. | |
StringAttr | getInstanceName () |
void | setInstanceName (StringAttr name) |
StringAttr | getLibraryName () |
void | setLibraryName (StringAttr name) |
StringAttr | getOperationName (Operation *op) |
void | setOperationName (Operation *op, StringAttr name) |
virtual PropertyStringVector | getProperties (Dependence dep) |
virtual PropertyStringVector | getProperties () |
Static Public Attributes | |
static constexpr auto | name = "ChainingProblem" |
Static Public Attributes inherited from circt::scheduling::Problem | |
static constexpr auto | name = "Problem" |
Protected Member Functions | |
ChainingProblem ()=default | |
virtual LogicalResult | checkDelays (OperatorType opr) |
Incoming/outgoing delays are set for opr and non-negative. | |
virtual LogicalResult | verifyStartTimeInCycle (Operation *op) |
op has a non-negative start time in its cycle. | |
virtual LogicalResult | verifyPrecedenceInCycle (Dependence dep) |
If dep is an SSA edge and its source operation finishes in the same time step as the destination operation, the source's result is available before the destination starts in that cycle. | |
Protected Member Functions inherited from circt::scheduling::Problem | |
Problem ()=default | |
virtual LogicalResult | checkLinkedOperatorType (Operation *op) |
op is linked to a registered operator type. | |
virtual LogicalResult | checkLatency (OperatorType opr) |
opr has a latency. | |
virtual LogicalResult | verifyStartTime (Operation *op) |
op has a start time. | |
virtual LogicalResult | verifyPrecedence (Dependence dep) |
dep's source operation is available before dep's destination operation starts. | |
Private Attributes | |
OperatorTypeProperty< float > | incomingDelay |
OperatorTypeProperty< float > | outgoingDelay |
OperationProperty< float > | startTimeInCycle |
Additional Inherited Members | |
Public Types inherited from circt::scheduling::Problem | |
using | Dependence = detail::Dependence |
A thin wrapper to allow a uniform handling of def-use and auxiliary dependences. | |
using | OperatorType = mlir::StringAttr |
Operator types are distinguished by name (chosen by the client). | |
using | OperationSet = llvm::SetVector< Operation * > |
using | DependenceRange = llvm::iterator_range< detail::DependenceIterator > |
using | OperatorTypeSet = llvm::SetVector< OperatorType > |
using | PropertyStringVector = llvm::SmallVector< std::pair< std::string, std::string >, 2 > |
Protected Types inherited from circt::scheduling::Problem | |
using | AuxDependenceMap = llvm::DenseMap< Operation *, llvm::SmallSetVector< Operation *, 4 > > |
template<typename T > | |
using | OperationProperty = llvm::DenseMap< Operation *, std::optional< T > > |
template<typename T > | |
using | DependenceProperty = llvm::DenseMap< Dependence, std::optional< T > > |
template<typename T > | |
using | OperatorTypeProperty = llvm::DenseMap< OperatorType, std::optional< T > > |
template<typename T > | |
using | InstanceProperty = std::optional< T > |
This class models the accumulation of physical propagation delays on combinational paths along SSA dependences.
Each operator type is annotated with estimated values for incoming and outgoing delays. Combinational operators (zero-latency, no internal registers) have only a single delay; this important special case is modeled by setting the incoming and outgoing delays to the same value.
A solution to this problem comprises per-operation start times in a continuous unit, e.g. in nanoseconds, inside the discrete time steps/cycles determined by the underlying scheduling problem.
Definition at line 339 of file Problems.h.
|
protecteddefault |
|
overridevirtual |
Return success if the constructed scheduling problem is valid.
Reimplemented from circt::scheduling::Problem.
Reimplemented in circt::scheduling::ChainingCyclicProblem.
Definition at line 290 of file Problems.cpp.
References circt::scheduling::Problem::check(), checkDelays(), and circt::scheduling::Problem::getOperatorTypes().
Referenced by circt::scheduling::ChainingCyclicProblem::check().
|
protectedvirtual |
Incoming/outgoing delays are set for opr
and non-negative.
The delays are equal if opr
is a zero-latency operator type.
Definition at line 224 of file Problems.cpp.
References circt::scheduling::Problem::getContainingOp(), getIncomingDelay(), circt::scheduling::Problem::getLatency(), getOutgoingDelay(), incomingDelay, and outgoingDelay.
Referenced by check().
|
inline |
Definition at line 380 of file Problems.h.
References startTimeInCycle.
Referenced by circt::scheduling::computeStartTimesInCycle().
|
inline |
The incoming delay denotes the propagation time from the operand inputs to either the result outputs (combinational operators) or the first internal register stage.
Definition at line 355 of file Problems.h.
References incomingDelay.
Referenced by checkDelays(), and getProperties().
|
inline |
The outgoing delay denotes the propagation time from either the operand inputs (combinational operators) or the last internal register stage to the result outputs.
Definition at line 365 of file Problems.h.
References outgoingDelay.
Referenced by checkDelays(), circt::scheduling::computeStartTimesInCycle(), getProperties(), and verifyPrecedenceInCycle().
|
overridevirtual |
Reimplemented from circt::scheduling::Problem.
Definition at line 208 of file Problems.cpp.
References circt::scheduling::Problem::getProperties(), and getStartTimeInCycle().
|
overridevirtual |
Reimplemented from circt::scheduling::Problem.
Definition at line 215 of file Problems.cpp.
References getIncomingDelay(), getOutgoingDelay(), and circt::scheduling::Problem::getProperties().
|
inline |
Computed by the scheduler, this start time is relative to the beginning of the cycle that op
starts in.
Definition at line 374 of file Problems.h.
References startTimeInCycle.
Referenced by circt::scheduling::computeStartTimesInCycle(), getProperties(), verifyPrecedenceInCycle(), and verifyStartTimeInCycle().
|
default |
|
inlineexplicit |
Construct an empty scheduling problem.
containingOp
is used for its MLIRContext and to emit diagnostics.
Definition at line 81 of file Problems.h.
|
inline |
Definition at line 358 of file Problems.h.
References incomingDelay.
|
inline |
Definition at line 368 of file Problems.h.
References outgoingDelay.
|
inline |
Definition at line 377 of file Problems.h.
References startTimeInCycle.
Referenced by circt::scheduling::computeStartTimesInCycle().
|
overridevirtual |
Return success if the computed solution is valid.
Reimplemented from circt::scheduling::Problem.
Reimplemented in circt::scheduling::ChainingCyclicProblem.
Definition at line 301 of file Problems.cpp.
References circt::scheduling::Problem::getDependences(), circt::scheduling::Problem::getOperations(), circt::scheduling::Problem::verify(), verifyPrecedenceInCycle(), and verifyStartTimeInCycle().
Referenced by circt::scheduling::ChainingCyclicProblem::verify().
|
protectedvirtual |
If dep
is an SSA edge and its source operation finishes in the same time step as the destination operation, the source's result is available before the destination starts in that cycle.
Definition at line 255 of file Problems.cpp.
References circt::scheduling::Problem::getContainingOp(), circt::scheduling::detail::Dependence::getDestination(), circt::scheduling::Problem::getLatency(), circt::scheduling::Problem::getLinkedOperatorType(), getOutgoingDelay(), circt::scheduling::detail::Dependence::getSource(), circt::scheduling::Problem::getStartTime(), getStartTimeInCycle(), and circt::scheduling::detail::Dependence::isAuxiliary().
Referenced by verify().
|
protectedvirtual |
op
has a non-negative start time in its cycle.
Definition at line 248 of file Problems.cpp.
References getStartTimeInCycle(), and startTimeInCycle.
Referenced by verify().
|
private |
Definition at line 348 of file Problems.h.
Referenced by checkDelays(), getIncomingDelay(), and setIncomingDelay().
|
staticconstexpr |
Definition at line 341 of file Problems.h.
|
private |
Definition at line 348 of file Problems.h.
Referenced by checkDelays(), getOutgoingDelay(), and setOutgoingDelay().
|
private |
Definition at line 349 of file Problems.h.
Referenced by clearStartTimeInCycle(), getStartTimeInCycle(), setStartTimeInCycle(), and verifyStartTimeInCycle().