CIRCT 20.0.0git
Loading...
Searching...
No Matches
Namespaces | Classes | Typedefs | Enumerations | Functions | Variables
circt::calyx Namespace Reference

Namespaces

namespace  direction
 

Classes

class  BasicLoopInterface
 
class  BuildBasicBlockRegs
 Builds registers for each block argument in the program. More...
 
class  BuildCallInstance
 Builds instance for the calyx.invoke and calyx.group in order to initialize the instance. More...
 
class  BuildReturnRegs
 Builds registers for the return statement of the program and constant assignments to the component return value. More...
 
class  CalyxLoweringState
 An interface for conversion passes that lower Calyx programs. More...
 
class  Combinational
 Signals that the following operation is combinational. More...
 
class  ComponentLoweringStateInterface
 
class  ControlLike
 Signals that the following operation is "control-like.". More...
 
class  ConvertIndexTypes
 Converts all index-typed operations and values to i32 values. More...
 
struct  DeduplicateParallelOp
 Removes duplicate EnableOps in parallel operations. More...
 
struct  DeduplicateStaticParallelOp
 Removes duplicate EnableOps in static parallel operations. More...
 
struct  EliminateUnusedCombGroups
 Removes calyx::CombGroupOps which are unused. More...
 
class  FuncOpPartialLoweringPattern
 FuncOpPartialLoweringPatterns are patterns which intend to match on FuncOps and then perform their own walking of the IR. More...
 
class  InlineCombGroups
 This pass recursively inlines use-def chains of combinational logic (from non-stateful groups) into groups referenced in the control schedule. More...
 
class  LoopInterface
 
class  LoopLoweringStateInterface
 
struct  MemoryInterface
 
struct  MemoryPortsImpl
 
struct  MultipleGroupDonePattern
 When building groups which contain accesses to multiple sequential components, a group_done op is created for each of these. More...
 
struct  NonTerminatingGroupDonePattern
 GroupDoneOp's are terminator operations and should therefore be the last operator in a group. More...
 
class  PartialLoweringPattern
 Base class for partial lowering passes. More...
 
struct  PortInfo
 This holds information about the port for either a Component or Cell. More...
 
struct  PredicateInfo
 Predicate information for the floating point comparisons. More...
 
class  RepeatOpInterface
 
class  RewriteMemoryAccesses
 This pass rewrites memory accesses that have a width mismatch. More...
 
class  SchedulerInterface
 Holds common utilities used for scheduling when lowering to Calyx. More...
 
class  WhileOpInterface
 

Typedefs

using PatternApplicationState = DenseMap< const mlir::RewritePattern *, SmallPtrSet< Operation *, 16 > >
 Extra state that is passed to all PartialLoweringPatterns so they can record when they have run on an Operation, and only run once.
 

Enumerations

enum class  FloatingPointStandard { IEEE754 }
 
enum  Direction { Input = 0 , Output = 1 }
 The direction of a Component or Cell port. More...
 

Functions

hw::HWModuleExternOp getExternHWModule (OpBuilder &builder, ComponentOp op)
 Returns a hw.module.extern operation describing the Verilog module which a ComponentOp eventually results in.
 
mlir::LogicalResult exportCalyx (mlir::ModuleOp module, llvm::raw_ostream &os)
 
void registerToCalyxTranslation ()
 
calyx::RegisterOp createRegister (Location loc, OpBuilder &builder, ComponentOp component, size_t width, Twine prefix)
 Creates a RegisterOp, with input and output port bit widths defined by width.
 
hw::ConstantOp createConstant (Location loc, OpBuilder &builder, ComponentOp component, size_t width, size_t value)
 A helper function to create constants in the HW dialect.
 
calyx::InstanceOp createInstance (Location loc, OpBuilder &builder, ComponentOp component, SmallVectorImpl< Type > &resultTypes, StringRef instanceName, StringRef componentName)
 A helper function to create calyx.instance operation.
 
std::string getInstanceName (mlir::func::CallOp callOp)
 A helper function to get the instance name.
 
bool isControlLeafNode (Operation *op)
 
DictionaryAttr getMandatoryPortAttr (MLIRContext *ctx, StringRef name)
 
void addMandatoryComponentPorts (PatternRewriter &rewriter, SmallVectorImpl< calyx::PortInfo > &ports)
 
unsigned handleZeroWidth (int64_t dim)
 
template<typename Op >
static void updateGroupAssignmentGuards (OpBuilder &builder, GroupOp &group, Op &op)
 Updates the guard of each assignment within a group with op.
 
void appendPortsForExternalMemref (PatternRewriter &rewriter, StringRef memName, Value memref, unsigned memoryID, SmallVectorImpl< calyx::PortInfo > &inPorts, SmallVectorImpl< calyx::PortInfo > &outPorts)
 
WalkResult getCiderSourceLocationMetadata (calyx::ComponentOp component, SmallVectorImpl< Attribute > &sourceLocations)
 
bool matchConstantOp (Operation *op, APInt &value)
 
bool singleLoadFromMemory (Value memoryReference)
 
bool noStoresToMemory (Value memoryReference)
 
Value getComponentOutput (calyx::ComponentOp compOp, unsigned outPortIdx)
 
Type normalizeType (OpBuilder &builder, Type type)
 
template<typename TGroup >
TGroup createGroup (OpBuilder &builder, calyx::ComponentOp compOp, Location loc, Twine uniqueName)
 
void buildAssignmentsForRegisterWrite (OpBuilder &builder, calyx::GroupOp groupOp, calyx::ComponentOp componentOp, calyx::RegisterOp &reg, Value inputValue)
 Creates register assignment operations within the provided groupOp.
 
LogicalResult applyModuleOpConversion (mlir::ModuleOp, StringRef topLevelFunction)
 Helper to update the top-level ModuleOp to set the entrypoing function.
 
PredicateInfo getPredicateInfo (mlir::arith::CmpFPredicate pred)
 
template<typename T >
Type toBitVector (T type)
 Performs a bit cast from a non-signless integer type value, such as a floating point value, to a signless integer type.
 
LogicalResult verifyControlLikeOp (Operation *op)
 A helper function to verify each control-like operation has a valid parent and, if applicable, body.
 
LogicalResult verifyCombinationalOp (Operation *op)
 A helper function to verify a combinational operation.
 
LogicalResult verifyComponent (Operation *op)
 A helper function to verify each operation with the Ccomponent trait.
 
LogicalResult verifyCell (Operation *op)
 A helper function to verify each operation with the Cell trait.
 
LogicalResult verifyGroupInterface (Operation *op)
 A helper function to verify each operation with the Group Interface trait.
 
LogicalResult verifyIf (Operation *op)
 A helper function to verify each operation with the If trait.
 
PortInfo getPortInfo (BlockArgument arg)
 Returns port information for the block argument provided.
 
std::unique_ptr< mlir::Pass > createCompileControlPass ()
 
std::unique_ptr< mlir::Pass > createGoInsertionPass ()
 
std::unique_ptr< mlir::Pass > createRemoveCombGroupsPass ()
 
std::unique_ptr< mlir::Pass > createRemoveGroupsPass ()
 
std::unique_ptr< mlir::Pass > createClkInsertionPass ()
 
std::unique_ptr< mlir::Pass > createResetInsertionPass ()
 
std::unique_ptr< mlir::Pass > createGroupInvariantCodeMotionPass ()
 
template<typename OpTy >
static LogicalResult deduplicateParallelOperation (OpTy parOp, PatternRewriter &rewriter)
 
PredicateInfo getPredicateInfo (CmpFPredicate pred)
 

Variables

static constexpr std::string_view goPort = "go"
 
static constexpr std::string_view donePort = "done"
 
static constexpr std::string_view resetPort = "reset"
 
static constexpr std::string_view clkPort = "clk"
 

Typedef Documentation

◆ PatternApplicationState

using circt::calyx::PatternApplicationState = typedef DenseMap<const mlir::RewritePattern *, SmallPtrSet<Operation *, 16> >

Extra state that is passed to all PartialLoweringPatterns so they can record when they have run on an Operation, and only run once.

Definition at line 597 of file CalyxLoweringUtils.h.

Enumeration Type Documentation

◆ Direction

The direction of a Component or Cell port.

this is similar to the implementation found in the FIRRTL dialect.

Enumerator
Input 
Output 

Definition at line 76 of file CalyxOps.h.

◆ FloatingPointStandard

Enumerator
IEEE754 

Definition at line 70 of file CalyxOps.h.

Function Documentation

◆ addMandatoryComponentPorts()

void circt::calyx::addMandatoryComponentPorts ( PatternRewriter &  rewriter,
SmallVectorImpl< calyx::PortInfo > &  ports 
)

◆ appendPortsForExternalMemref()

void circt::calyx::appendPortsForExternalMemref ( PatternRewriter &  rewriter,
StringRef  memName,
Value  memref,
unsigned  memoryID,
SmallVectorImpl< calyx::PortInfo > &  inPorts,
SmallVectorImpl< calyx::PortInfo > &  outPorts 
)

◆ applyModuleOpConversion()

LogicalResult circt::calyx::applyModuleOpConversion ( mlir::ModuleOp  moduleOp,
StringRef  topLevelFunction 
)

Helper to update the top-level ModuleOp to set the entrypoing function.

Definition at line 490 of file CalyxLoweringUtils.cpp.

Referenced by circt::pipelinetocalyx::LoopScheduleToCalyxPass::labelEntryPoint().

◆ buildAssignmentsForRegisterWrite()

void circt::calyx::buildAssignmentsForRegisterWrite ( OpBuilder &  builder,
calyx::GroupOp  groupOp,
calyx::ComponentOp  componentOp,
calyx::RegisterOp &  reg,
Value  inputValue 
)

◆ createClkInsertionPass()

std::unique_ptr< mlir::Pass > circt::calyx::createClkInsertionPass ( )

Definition at line 69 of file ClkResetInsertion.cpp.

◆ createCompileControlPass()

std::unique_ptr< mlir::Pass > circt::calyx::createCompileControlPass ( )

Definition at line 206 of file CompileControl.cpp.

◆ createConstant()

hw::ConstantOp circt::calyx::createConstant ( Location  loc,
OpBuilder &  builder,
ComponentOp  component,
size_t  width,
size_t  value 
)

◆ createGoInsertionPass()

std::unique_ptr< mlir::Pass > circt::calyx::createGoInsertionPass ( )

Definition at line 58 of file GoInsertion.cpp.

◆ createGroup()

template<typename TGroup >
TGroup circt::calyx::createGroup ( OpBuilder &  builder,
calyx::ComponentOp  compOp,
Location  loc,
Twine  uniqueName 
)

Definition at line 73 of file CalyxLoweringUtils.h.

◆ createGroupInvariantCodeMotionPass()

std::unique_ptr< mlir::Pass > circt::calyx::createGroupInvariantCodeMotionPass ( )

Definition at line 52 of file GICM.cpp.

◆ createInstance()

calyx::InstanceOp circt::calyx::createInstance ( Location  loc,
OpBuilder &  builder,
ComponentOp  component,
SmallVectorImpl< Type > &  resultTypes,
StringRef  instanceName,
StringRef  componentName 
)

A helper function to create calyx.instance operation.

Definition at line 39 of file CalyxHelpers.cpp.

Referenced by circt::calyx::BuildCallInstance::partiallyLowerFuncToComp().

◆ createRegister()

calyx::RegisterOp circt::calyx::createRegister ( Location  loc,
OpBuilder &  builder,
ComponentOp  component,
size_t  width,
Twine  prefix 
)

Creates a RegisterOp, with input and output port bit widths defined by width.

Definition at line 22 of file CalyxHelpers.cpp.

Referenced by circt::calyx::BuildBasicBlockRegs::partiallyLowerFuncToComp(), circt::calyx::BuildReturnRegs::partiallyLowerFuncToComp(), and CompileControlVisitor::visit().

◆ createRemoveCombGroupsPass()

std::unique_ptr< mlir::Pass > circt::calyx::createRemoveCombGroupsPass ( )

Definition at line 296 of file RemoveCombGroups.cpp.

◆ createRemoveGroupsPass()

std::unique_ptr< mlir::Pass > circt::calyx::createRemoveGroupsPass ( )

Definition at line 128 of file RemoveGroups.cpp.

◆ createResetInsertionPass()

std::unique_ptr< mlir::Pass > circt::calyx::createResetInsertionPass ( )

Definition at line 73 of file ClkResetInsertion.cpp.

◆ deduplicateParallelOperation()

template<typename OpTy >
static LogicalResult circt::calyx::deduplicateParallelOperation ( OpTy  parOp,
PatternRewriter &  rewriter 
)
static

Definition at line 33 of file CalyxLoweringUtils.cpp.

◆ exportCalyx()

mlir::LogicalResult circt::calyx::exportCalyx ( mlir::ModuleOp  module,
llvm::raw_ostream &  os 
)

Definition at line 1115 of file CalyxEmitter.cpp.

Referenced by registerToCalyxTranslation().

◆ getCiderSourceLocationMetadata()

WalkResult circt::calyx::getCiderSourceLocationMetadata ( calyx::ComponentOp  component,
SmallVectorImpl< Attribute > &  sourceLocations 
)

Definition at line 119 of file CalyxLoweringUtils.cpp.

References isControlLeafNode().

◆ getComponentOutput()

Value circt::calyx::getComponentOutput ( calyx::ComponentOp  compOp,
unsigned  outPortIdx 
)

Definition at line 154 of file CalyxLoweringUtils.cpp.

References assert().

Referenced by circt::calyx::BuildReturnRegs::partiallyLowerFuncToComp().

◆ getExternHWModule()

hw::HWModuleExternOp circt::calyx::getExternHWModule ( OpBuilder &  builder,
ComponentOp  op 
)

Returns a hw.module.extern operation describing the Verilog module which a ComponentOp eventually results in.

◆ getInstanceName()

std::string circt::calyx::getInstanceName ( mlir::func::CallOp  callOp)

A helper function to get the instance name.

Definition at line 50 of file CalyxHelpers.cpp.

Referenced by circt::scftocalyx::BuildOpGroups::buildOp(), and circt::calyx::BuildCallInstance::partiallyLowerFuncToComp().

◆ getMandatoryPortAttr()

DictionaryAttr circt::calyx::getMandatoryPortAttr ( MLIRContext *  ctx,
StringRef  name 
)

Definition at line 57 of file CalyxHelpers.cpp.

Referenced by addMandatoryComponentPorts().

◆ getPortInfo()

PortInfo circt::calyx::getPortInfo ( BlockArgument  arg)

Returns port information for the block argument provided.

Gets the port for a given BlockArgument.

Definition at line 142 of file CalyxOps.cpp.

References assert().

Referenced by verifyPortDirection().

◆ getPredicateInfo() [1/2]

PredicateInfo circt::calyx::getPredicateInfo ( CmpFPredicate  pred)

◆ getPredicateInfo() [2/2]

PredicateInfo circt::calyx::getPredicateInfo ( mlir::arith::CmpFPredicate  pred)

◆ handleZeroWidth()

unsigned circt::calyx::handleZeroWidth ( int64_t  dim)

◆ isControlLeafNode()

bool circt::calyx::isControlLeafNode ( Operation *  op)

Definition at line 55 of file CalyxHelpers.cpp.

Referenced by getCiderSourceLocationMetadata().

◆ matchConstantOp()

bool circt::calyx::matchConstantOp ( Operation *  op,
APInt &  value 
)

◆ normalizeType()

Type circt::calyx::normalizeType ( OpBuilder &  builder,
Type  type 
)

◆ noStoresToMemory()

bool circt::calyx::noStoresToMemory ( Value  memoryReference)

◆ registerToCalyxTranslation()

void circt::calyx::registerToCalyxTranslation ( )

Definition at line 1125 of file CalyxEmitter.cpp.

References exportCalyx().

Referenced by circt::registerAllTranslations().

◆ singleLoadFromMemory()

bool circt::calyx::singleLoadFromMemory ( Value  memoryReference)

◆ toBitVector()

template<typename T >
Type circt::calyx::toBitVector ( type)

Performs a bit cast from a non-signless integer type value, such as a floating point value, to a signless integer type.

Calyx treats everything as bit vectors, and leaves their interpretation to the respective operation using it. In CIRCT Calyx, we use signless IntegerType to represent a bit vector.

Definition at line 876 of file CalyxLoweringUtils.h.

Referenced by circt::scftocalyx::BuildOpGroups::buildLibraryOp(), and normalizeType().

◆ updateGroupAssignmentGuards()

template<typename Op >
static void circt::calyx::updateGroupAssignmentGuards ( OpBuilder &  builder,
GroupOp &  group,
Op &  op 
)
static

Updates the guard of each assignment within a group with op.

Definition at line 67 of file CalyxHelpers.h.

Referenced by modifyGroupOperations().

◆ verifyCell()

LogicalResult circt::calyx::verifyCell ( Operation *  op)

A helper function to verify each operation with the Cell trait.

Definition at line 211 of file CalyxOps.cpp.

◆ verifyCombinationalOp()

LogicalResult circt::calyx::verifyCombinationalOp ( Operation *  op)

A helper function to verify a combinational operation.

◆ verifyComponent()

LogicalResult circt::calyx::verifyComponent ( Operation *  op)

A helper function to verify each operation with the Ccomponent trait.

Definition at line 203 of file CalyxOps.cpp.

◆ verifyControlLikeOp()

LogicalResult circt::calyx::verifyControlLikeOp ( Operation *  op)

A helper function to verify each control-like operation has a valid parent and, if applicable, body.

Definition at line 219 of file CalyxOps.cpp.

References hasControlRegion(), and verifyControlBody().

Referenced by circt::calyx::ControlLike< ConcreteType >::verifyTrait().

◆ verifyGroupInterface()

LogicalResult circt::calyx::verifyGroupInterface ( Operation *  op)

A helper function to verify each operation with the Group Interface trait.

Definition at line 1419 of file CalyxOps.cpp.

References verifyPrimitivePortDriving().

◆ verifyIf()

LogicalResult circt::calyx::verifyIf ( Operation *  op)

A helper function to verify each operation with the If trait.

Definition at line 256 of file CalyxOps.cpp.

Variable Documentation

◆ clkPort

constexpr std::string_view circt::calyx::clkPort = "clk"
staticconstexpr

Definition at line 34 of file CalyxOps.h.

Referenced by addMandatoryComponentPorts(), and hasRequiredPorts().

◆ donePort

constexpr std::string_view circt::calyx::donePort = "done"
staticconstexpr

◆ goPort

constexpr std::string_view circt::calyx::goPort = "go"
staticconstexpr

◆ resetPort

constexpr std::string_view circt::calyx::resetPort = "reset"
staticconstexpr