CIRCT 20.0.0git
Loading...
Searching...
No Matches
Public Member Functions | Private Member Functions | Private Attributes | List of all members
circt::scftocalyx::BuildOpGroups Class Reference

Iterate through the operations of a source function and instantiate components or primitives based on the type of the operations. More...

Inheritance diagram for circt::scftocalyx::BuildOpGroups:
Inheritance graph
[legend]
Collaboration diagram for circt::scftocalyx::BuildOpGroups:
Collaboration graph
[legend]

Public Member Functions

 BuildOpGroups (MLIRContext *context, LogicalResult &resRef, calyx::PatternApplicationState &patternState, DenseMap< mlir::func::FuncOp, calyx::ComponentOp > &map, calyx::CalyxLoweringState &state, mlir::Pass::Option< std::string > &writeJsonOpt)
 
LogicalResult partiallyLowerFuncToComp (FuncOp funcOp, PatternRewriter &rewriter) const override
 
- Public Member Functions inherited from circt::calyx::FuncOpPartialLoweringPattern
 FuncOpPartialLoweringPattern (MLIRContext *context, LogicalResult &resRef, PatternApplicationState &patternState, DenseMap< mlir::func::FuncOp, calyx::ComponentOp > &map, calyx::CalyxLoweringState &state)
 
LogicalResult partiallyLower (mlir::func::FuncOp funcOp, PatternRewriter &rewriter) const override final
 Entry point to initialize the state of this class and conduct the partial lowering.
 
calyx::ComponentOp getComponent () const
 Returns the component operation associated with the currently executing partial lowering.
 
template<typename T = ComponentLoweringStateInterface>
T & getState () const
 
CalyxLoweringStateloweringState () const
 Return the calyx lowering state for this pattern.
 
virtual LogicalResult partiallyLowerFuncToComp (mlir::func::FuncOp funcOp, PatternRewriter &rewriter) const =0
 
- Public Member Functions inherited from circt::calyx::PartialLoweringPattern< mlir::func::FuncOp >
 PartialLoweringPattern (MLIRContext *ctx, LogicalResult &resRef, PatternApplicationState &patternState)
 
LogicalResult matchAndRewrite (mlir::func::FuncOp op, PatternRewriter &rewriter) const override
 

Private Member Functions

LogicalResult buildOp (PatternRewriter &rewriter, scf::YieldOp yieldOp) const
 Op builder specializations.
 
LogicalResult buildOp (PatternRewriter &rewriter, BranchOpInterface brOp) const
 
LogicalResult buildOp (PatternRewriter &rewriter, arith::ConstantOp constOp) const
 
LogicalResult buildOp (PatternRewriter &rewriter, SelectOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, AddIOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, SubIOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, MulIOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, DivUIOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, DivSIOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, RemUIOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, RemSIOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, AddFOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, MulFOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, CmpFOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, ShRUIOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, ShRSIOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, ShLIOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, AndIOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, OrIOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, XOrIOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, CmpIOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, TruncIOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, ExtUIOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, ExtSIOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, ReturnOp op) const
 For each return statement, we create a new group for assigning to the previously created return value registers.
 
LogicalResult buildOp (PatternRewriter &rewriter, IndexCastOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, memref::AllocOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, memref::AllocaOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, memref::GetGlobalOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, memref::LoadOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, memref::StoreOp op) const
 
LogicalResult buildOp (PatternRewriter &rewriter, scf::WhileOp whileOp) const
 
LogicalResult buildOp (PatternRewriter &rewriter, scf::ForOp forOp) const
 
LogicalResult buildOp (PatternRewriter &rewriter, scf::IfOp ifOp) const
 
LogicalResult buildOp (PatternRewriter &rewriter, scf::ReduceOp reduceOp) const
 
LogicalResult buildOp (PatternRewriter &rewriter, scf::ParallelOp parallelOp) const
 
LogicalResult buildOp (PatternRewriter &rewriter, scf::ExecuteRegionOp executeRegionOp) const
 
LogicalResult buildOp (PatternRewriter &rewriter, CallOp callOp) const
 
template<typename TGroupOp , typename TCalyxLibOp , typename TSrcOp >
LogicalResult buildLibraryOp (PatternRewriter &rewriter, TSrcOp op, TypeRange srcTypes, TypeRange dstTypes) const
 buildLibraryOp will build a TCalyxLibOp inside a TGroupOp based on the source operation TSrcOp.
 
template<typename TGroupOp , typename TCalyxLibOp , typename TSrcOp >
LogicalResult buildLibraryOp (PatternRewriter &rewriter, TSrcOp op) const
 buildLibraryOp which provides in- and output types based on the operands and results of the op argument.
 
template<typename TGroupOp >
TGroupOp createGroupForOp (PatternRewriter &rewriter, Operation *op) const
 Creates a group named by the basic block which the input op resides in.
 
template<typename TOpType , typename TSrcOp >
LogicalResult buildLibraryBinaryPipeOp (PatternRewriter &rewriter, TSrcOp op, TOpType opPipe, Value out) const
 buildLibraryBinaryPipeOp will build a TCalyxLibBinaryPipeOp, to deal with MulIOp, DivUIOp and RemUIOp.
 
void assignAddressPorts (PatternRewriter &rewriter, Location loc, calyx::GroupInterface group, calyx::MemoryInterface memoryInterface, Operation::operand_range addressValues) const
 Creates assignments within the provided group to the address ports of the memoryOp based on the provided addressValues.
 
calyx::RegisterOp createSignalRegister (PatternRewriter &rewriter, Value signal, bool invert, StringRef nameSuffix, calyx::CompareFOpIEEE754 calyxCmpFOp, calyx::GroupOp group) const
 

Private Attributes

mlir::Pass::Option< std::string > & writeJson
 

Additional Inherited Members

- Protected Attributes inherited from circt::calyx::FuncOpPartialLoweringPattern
DenseMap< mlir::func::FuncOp, calyx::ComponentOp > & functionMapping
 

Detailed Description

Iterate through the operations of a source function and instantiate components or primitives based on the type of the operations.

Definition at line 275 of file SCFToCalyx.cpp.

Constructor & Destructor Documentation

◆ BuildOpGroups()

circt::scftocalyx::BuildOpGroups::BuildOpGroups ( MLIRContext *  context,
LogicalResult &  resRef,
calyx::PatternApplicationState patternState,
DenseMap< mlir::func::FuncOp, calyx::ComponentOp > &  map,
calyx::CalyxLoweringState state,
mlir::Pass::Option< std::string > &  writeJsonOpt 
)
inline

Definition at line 277 of file SCFToCalyx.cpp.

Member Function Documentation

◆ assignAddressPorts()

void circt::scftocalyx::BuildOpGroups::assignAddressPorts ( PatternRewriter &  rewriter,
Location  loc,
calyx::GroupInterface  group,
calyx::MemoryInterface  memoryInterface,
Operation::operand_range  addressValues 
) const
inlineprivate

Creates assignments within the provided group to the address ports of the memoryOp based on the provided addressValues.

Definition at line 525 of file SCFToCalyx.cpp.

References circt::calyx::MemoryInterface::addrPorts(), assert(), and circt::calyx::FuncOpPartialLoweringPattern::getComponent().

Referenced by buildOp(), and buildOp().

◆ buildLibraryBinaryPipeOp()

template<typename TOpType , typename TSrcOp >
LogicalResult circt::scftocalyx::BuildOpGroups::buildLibraryBinaryPipeOp ( PatternRewriter &  rewriter,
TSrcOp  op,
TOpType  opPipe,
Value  out 
) const
inlineprivate

buildLibraryBinaryPipeOp will build a TCalyxLibBinaryPipeOp, to deal with MulIOp, DivUIOp and RemUIOp.

Definition at line 465 of file SCFToCalyx.cpp.

References circt::comb::createOrFoldNot(), and circt::calyx::FuncOpPartialLoweringPattern::getComponent().

◆ buildLibraryOp() [1/2]

template<typename TGroupOp , typename TCalyxLibOp , typename TSrcOp >
LogicalResult circt::scftocalyx::BuildOpGroups::buildLibraryOp ( PatternRewriter &  rewriter,
TSrcOp  op 
) const
inlineprivate

buildLibraryOp which provides in- and output types based on the operands and results of the op argument.

Definition at line 446 of file SCFToCalyx.cpp.

◆ buildLibraryOp() [2/2]

template<typename TGroupOp , typename TCalyxLibOp , typename TSrcOp >
LogicalResult circt::scftocalyx::BuildOpGroups::buildLibraryOp ( PatternRewriter &  rewriter,
TSrcOp  op,
TypeRange  srcTypes,
TypeRange  dstTypes 
) const
inlineprivate

buildLibraryOp will build a TCalyxLibOp inside a TGroupOp based on the source operation TSrcOp.

Create assignments to the inputs of the library op.

Replace the result values of the source operator with the new operator.

Definition at line 400 of file SCFToCalyx.cpp.

References assert(), circt::calyx::Input, and circt::calyx::toBitVector().

◆ buildOp() [1/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
AddFOp  op 
) const
private

Definition at line 772 of file SCFToCalyx.cpp.

◆ buildOp() [2/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
AddIOp  op 
) const
private

Definition at line 1317 of file SCFToCalyx.cpp.

◆ buildOp() [3/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
AndIOp  op 
) const
private

Definition at line 1337 of file SCFToCalyx.cpp.

◆ buildOp() [4/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
arith::ConstantOp  constOp 
) const
private

Move constant operations to the compOp body as hw::ConstantOp's.

Definition at line 1292 of file SCFToCalyx.cpp.

References circt::calyx::FuncOpPartialLoweringPattern::getComponent(), and circt::calyx::matchConstantOp().

◆ buildOp() [5/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
BranchOpInterface  brOp 
) const
private

Branch argument passing group creation Branch operands are passed through registers. In BuildBasicBlockRegs we created registers for all branch arguments of each block. We now create groups for assigning values to these registers.

Register the group as a block argument group, to be executed when entering the successor block from this block (srcBlock).

Definition at line 1234 of file SCFToCalyx.cpp.

References circt::calyx::CalyxLoweringState::blockName(), circt::calyx::buildAssignmentsForRegisterWrite(), circt::calyx::FuncOpPartialLoweringPattern::getComponent(), and circt::calyx::FuncOpPartialLoweringPattern::loweringState().

◆ buildOp() [6/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
CallOp  callOp 
) const
private

Definition at line 1485 of file SCFToCalyx.cpp.

References circt::calyx::getInstanceName(), and circt::calyx::Output.

◆ buildOp() [7/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
CmpFOp  op 
) const
private

◆ buildOp() [8/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
CmpIOp  op 
) const
private

Definition at line 1354 of file SCFToCalyx.cpp.

◆ buildOp() [9/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
DivSIOp  op 
) const
private

Definition at line 733 of file SCFToCalyx.cpp.

◆ buildOp() [10/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
DivUIOp  op 
) const
private

Definition at line 720 of file SCFToCalyx.cpp.

◆ buildOp() [11/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
ExtSIOp  op 
) const
private

Definition at line 1391 of file SCFToCalyx.cpp.

◆ buildOp() [12/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
ExtUIOp  op 
) const
private

Definition at line 1385 of file SCFToCalyx.cpp.

◆ buildOp() [13/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
IndexCastOp  op 
) const
private

Drop the index cast and replace uses of the target value with the source value.

pad/slice the source operand.

Definition at line 1397 of file SCFToCalyx.cpp.

References circt::calyx::normalizeType().

◆ buildOp() [14/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
memref::AllocaOp  op 
) const
private

Definition at line 1094 of file SCFToCalyx.cpp.

References circt::scftocalyx::buildAllocOp().

◆ buildOp() [15/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
memref::AllocOp  op 
) const
private

Definition at line 1089 of file SCFToCalyx.cpp.

References circt::scftocalyx::buildAllocOp().

◆ buildOp() [16/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
memref::GetGlobalOp  op 
) const
private

Definition at line 1099 of file SCFToCalyx.cpp.

References circt::scftocalyx::buildAllocOp().

◆ buildOp() [17/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
memref::LoadOp  op 
) const
private

◆ buildOp() [18/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
memref::StoreOp  op 
) const
private

◆ buildOp() [19/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
MulFOp  op 
) const
private

Definition at line 788 of file SCFToCalyx.cpp.

◆ buildOp() [20/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
MulIOp  op 
) const
private

Definition at line 707 of file SCFToCalyx.cpp.

◆ buildOp() [21/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
OrIOp  op 
) const
private

Definition at line 1341 of file SCFToCalyx.cpp.

◆ buildOp() [22/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
RemSIOp  op 
) const
private

Definition at line 759 of file SCFToCalyx.cpp.

◆ buildOp() [23/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
RemUIOp  op 
) const
private

Definition at line 746 of file SCFToCalyx.cpp.

◆ buildOp() [24/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
ReturnOp  op 
) const
private

For each return statement, we create a new group for assigning to the previously created return value registers.

Schedule group for execution for when executing the return op block.

Definition at line 1271 of file SCFToCalyx.cpp.

References circt::calyx::buildAssignmentsForRegisterWrite(), and circt::calyx::FuncOpPartialLoweringPattern::getComponent().

◆ buildOp() [25/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
scf::ExecuteRegionOp  executeRegionOp 
) const
private

Definition at line 1477 of file SCFToCalyx.cpp.

◆ buildOp() [26/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
scf::ForOp  forOp 
) const
private

◆ buildOp() [27/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
scf::IfOp  ifOp 
) const
private

Definition at line 1454 of file SCFToCalyx.cpp.

◆ buildOp() [28/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
scf::ParallelOp  parallelOp 
) const
private

Definition at line 1469 of file SCFToCalyx.cpp.

◆ buildOp() [29/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
scf::ReduceOp  reduceOp 
) const
private

Definition at line 1461 of file SCFToCalyx.cpp.

◆ buildOp() [30/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
scf::WhileOp  whileOp 
) const
private

Definition at line 1422 of file SCFToCalyx.cpp.

◆ buildOp() [31/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
scf::YieldOp  yieldOp 
) const
private

Op builder specializations.

Definition at line 1105 of file SCFToCalyx.cpp.

References circt::calyx::FuncOpPartialLoweringPattern::componentOp, circt::calyx::Input, and circt::calyx::Output.

Referenced by partiallyLowerFuncToComp().

◆ buildOp() [32/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
SelectOp  op 
) const
private

Definition at line 1349 of file SCFToCalyx.cpp.

◆ buildOp() [33/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
ShLIOp  op 
) const
private

Definition at line 1333 of file SCFToCalyx.cpp.

◆ buildOp() [34/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
ShRSIOp  op 
) const
private

Definition at line 1329 of file SCFToCalyx.cpp.

◆ buildOp() [35/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
ShRUIOp  op 
) const
private

Definition at line 1325 of file SCFToCalyx.cpp.

◆ buildOp() [36/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
SubIOp  op 
) const
private

Definition at line 1321 of file SCFToCalyx.cpp.

◆ buildOp() [37/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
TruncIOp  op 
) const
private

Definition at line 1380 of file SCFToCalyx.cpp.

◆ buildOp() [38/38]

LogicalResult circt::scftocalyx::BuildOpGroups::buildOp ( PatternRewriter &  rewriter,
XOrIOp  op 
) const
private

Definition at line 1345 of file SCFToCalyx.cpp.

◆ createGroupForOp()

template<typename TGroupOp >
TGroupOp circt::scftocalyx::BuildOpGroups::createGroupForOp ( PatternRewriter &  rewriter,
Operation *  op 
) const
inlineprivate

Creates a group named by the basic block which the input op resides in.

Definition at line 453 of file SCFToCalyx.cpp.

References circt::calyx::FuncOpPartialLoweringPattern::loweringState().

◆ createSignalRegister()

calyx::RegisterOp circt::scftocalyx::BuildOpGroups::createSignalRegister ( PatternRewriter &  rewriter,
Value  signal,
bool  invert,
StringRef  nameSuffix,
calyx::CompareFOpIEEE754  calyxCmpFOp,
calyx::GroupOp  group 
) const
inlineprivate

Definition at line 551 of file SCFToCalyx.cpp.

References circt::calyx::FuncOpPartialLoweringPattern::getComponent().

Referenced by buildOp().

◆ partiallyLowerFuncToComp()

LogicalResult circt::scftocalyx::BuildOpGroups::partiallyLowerFuncToComp ( FuncOp  funcOp,
PatternRewriter &  rewriter 
) const
inlineoverride

We walk the operations of the funcOp to ensure that all def's have been visited before their uses.

SCF

memref

standard arithmetic

floating point

others

Skip: these special cases will be handled separately.

Definition at line 287 of file SCFToCalyx.cpp.

References buildOp(), and writeJson.

Member Data Documentation

◆ writeJson

mlir::Pass::Option<std::string>& circt::scftocalyx::BuildOpGroups::writeJson
private

Definition at line 350 of file SCFToCalyx.cpp.

Referenced by partiallyLowerFuncToComp().


The documentation for this class was generated from the following file: