CIRCT 20.0.0git
|
Handles the current state of lowering of a Calyx component. More...
Public Member Functions | |
ComponentLoweringState (calyx::ComponentOp component) | |
Public Member Functions inherited from circt::calyx::ComponentLoweringStateInterface | |
ComponentLoweringStateInterface (calyx::ComponentOp component) | |
~ComponentLoweringStateInterface () | |
calyx::ComponentOp | getComponentOp () |
Returns the calyx::ComponentOp associated with this lowering state. | |
void | addBlockArgReg (Block *block, calyx::RegisterOp reg, unsigned idx) |
Register reg as being the idx'th argument register for block. | |
const DenseMap< unsigned, calyx::RegisterOp > & | getBlockArgRegs (Block *block) |
Return a mapping of block argument indices to block argument registers. | |
void | addBlockArgGroup (Block *from, Block *to, calyx::GroupOp grp) |
Register 'grp' as a group which performs block argument register transfer when transitioning from basic block 'from' to 'to'. | |
ArrayRef< calyx::GroupOp > | getBlockArgGroups (Block *from, Block *to) |
Returns a list of groups to be evaluated to perform the block argument register assignments when transitioning from basic block 'from' to 'to'. | |
std::string | getUniqueName (StringRef prefix) |
Returns a unique name within compOp with the provided prefix. | |
StringRef | getUniqueName (Operation *op) |
Returns a unique name associated with a specific operation. | |
void | setUniqueName (Operation *op, StringRef prefix) |
Registers a unique name for a given operation using a provided prefix. | |
void | registerEvaluatingGroup (Value v, calyx::GroupInterface group) |
Register value v as being evaluated when scheduling group. | |
void | addReturnReg (calyx::RegisterOp reg, unsigned idx) |
Register reg as being the idx'th return value register. | |
calyx::RegisterOp | getReturnReg (unsigned idx) |
Returns the idx'th return value register. | |
void | registerMemoryInterface (Value memref, const calyx::MemoryInterface &memoryInterface) |
Registers a memory interface as being associated with a memory identified by 'memref'. | |
calyx::MemoryInterface | getMemoryInterface (Value memref) |
Returns the memory interface registered for the given memref. | |
std::optional< calyx::MemoryInterface > | isInputPortOfMemory (Value v) |
If v is an input to any memory registered within this component, returns the memory. | |
void | setFuncOpResultMapping (const DenseMap< unsigned, unsigned > &mapping) |
Assign a mapping between the source funcOp result indices and the corresponding output port indices of this componentOp. | |
unsigned | getFuncOpResultMapping (unsigned funcReturnIdx) |
Get the output port index of this component for which the funcReturnIdx of the original function maps to. | |
InstanceOp | getInstance (StringRef calleeName) |
The instance is obtained from the name of the callee. | |
void | addInstance (StringRef calleeName, InstanceOp instanceOp) |
Put the name of the callee and the instance of the call into map. | |
template<typename TGroupOp = calyx::GroupInterface> | |
std::optional< TGroupOp > | findEvaluatingGroup (Value v) |
Returns the evaluating group or None if not found. | |
template<typename TGroupOp = calyx::GroupInterface> | |
TGroupOp | getEvaluatingGroup (Value v) |
Return the group which evaluates the value v. | |
template<typename TLibraryOp > | |
TLibraryOp | getNewLibraryOpInstance (OpBuilder &builder, Location loc, TypeRange resTypes) |
llvm::json::Value & | getExtMemData () |
const llvm::json::Value & | getExtMemData () const |
void | setDataField (StringRef name, llvm::json::Array data) |
void | setFormat (StringRef name, std::string numType, bool isSigned, unsigned width) |
Public Member Functions inherited from circt::calyx::LoopLoweringStateInterface< PipelineWhileOp > | |
~LoopLoweringStateInterface ()=default | |
void | addLoopIterReg (PipelineWhileOp op, calyx::RegisterOp reg, unsigned idx) |
Register reg as being the idx'th iter_args register for 'op'. | |
calyx::RegisterOp | getLoopIterReg (PipelineWhileOp op, unsigned idx) |
Return a mapping of block argument indices to block argument. | |
const DenseMap< unsigned, calyx::RegisterOp > & | getLoopIterRegs (PipelineWhileOp op) |
Return a mapping of block argument indices to block argument. | |
void | setLoopLatchGroup (PipelineWhileOp op, calyx::GroupOp group) |
Registers grp to be the loop latch group of op . | |
calyx::GroupOp | getLoopLatchGroup (PipelineWhileOp op) |
Retrieve the loop latch group registered for op . | |
void | setLoopInitGroups (PipelineWhileOp op, SmallVector< calyx::GroupOp > groups) |
Registers groups to be the loop init groups of op . | |
SmallVector< calyx::GroupOp > | getLoopInitGroups (PipelineWhileOp op) |
Retrieve the loop init groups registered for op . | |
calyx::GroupOp | buildLoopIterArgAssignments (OpBuilder &builder, PipelineWhileOp op, calyx::ComponentOp componentOp, Twine uniqueSuffix, MutableArrayRef< OpOperand > ops) |
Creates a new group that assigns the 'ops' values to the iter arg registers of the loop operation. | |
Public Member Functions inherited from circt::pipelinetocalyx::PipelineScheduler | |
void | registerNonPipelineOperations (Operation *op, calyx::GroupInterface group) |
Registers operations that may be used in a pipeline, but does not produce a value to be used in a further stage. | |
template<typename TGroupOp = calyx::GroupInterface> | |
std::optional< TGroupOp > | getNonPipelinedGroupFrom (Operation *op) |
Returns the group registered for this non-pipelined value, and None otherwise. | |
void | addPipelineReg (Operation *stage, calyx::RegisterOp reg, unsigned idx) |
Register reg as being the idx'th pipeline register for the stage. | |
const DenseMap< unsigned, calyx::RegisterOp > & | getPipelineRegs (Operation *stage) |
Return a mapping of stage result indices to pipeline registers. | |
std::optional< calyx::RegisterOp > | getPipelineRegister (Value value) |
Returns the pipeline register for this value if its defining operation is a stage, and std::nullopt otherwise. | |
void | addPipelinePrologue (Operation *op, SmallVector< StringAttr > groupNames) |
Add a stage's groups to the pipeline prologue. | |
void | addPipelineEpilogue (Operation *op, SmallVector< StringAttr > groupNames) |
Add a stage's groups to the pipeline epilogue. | |
SmallVector< SmallVector< StringAttr > > | getPipelinePrologue (Operation *op) |
Get the pipeline prologue. | |
void | createPipelinePrologue (Operation *op, PatternRewriter &rewriter) |
Create the pipeline prologue. | |
void | createPipelineEpilogue (Operation *op, PatternRewriter &rewriter) |
Create the pipeline epilogue. | |
Public Member Functions inherited from circt::calyx::SchedulerInterface< Scheduleable > | |
void | addBlockScheduleable (mlir::Block *block, const Scheduleable &scheduleable) |
Register 'scheduleable' as being generated through lowering 'block'. | |
SmallVector< Scheduleable > | getBlockScheduleables (mlir::Block *block) |
Returns an ordered list of schedulables which registered themselves to be a result of lowering the block in the source program. | |
Handles the current state of lowering of a Calyx component.
It is mainly used as a key/value store for recording information during partial lowering, which is required at later lowering passes.
Definition at line 207 of file LoopScheduleToCalyx.cpp.
|
inline |
Definition at line 212 of file LoopScheduleToCalyx.cpp.