CIRCT
20.0.0git
|
A sample reduction pattern that maps hw.module
to hw.module.extern
.
More...
Public Member Functions | |
void | beforeReduction (mlir::ModuleOp op) override |
Called before the reduction is applied to a new subset of operations. More... | |
uint64_t | match (HWModuleOp op) override |
LogicalResult | rewrite (HWModuleOp op) override |
std::string | getName () const override |
Return a human-readable name for this reduction pattern. More... | |
Public Member Functions inherited from circt::OpReduction< HWModuleOp > | |
uint64_t | match (Operation *op) override |
Check if the reduction can apply to a specific operation. More... | |
virtual uint64_t | match (HWModuleOp op) |
LogicalResult | rewrite (Operation *op) override |
Apply the reduction to a specific operation. More... | |
virtual LogicalResult | rewrite (HWModuleOp op)=0 |
Public Member Functions inherited from circt::Reduction | |
virtual | ~Reduction () |
virtual void | afterReduction (mlir::ModuleOp) |
Called after the reduction has been applied to a subset of operations. More... | |
virtual bool | acceptSizeIncrease () const |
Return true if the tool should accept the transformation this reduction performs on the module even if the overall size of the output increases. More... | |
virtual bool | isOneShot () const |
Return true if the tool should not try to reapply this reduction after it has been successful. More... | |
void | notifyOpErased (Operation *op) |
Public Attributes | |
std::unique_ptr< InstanceGraph > | instanceGraph |
ModuleSizeCache | moduleSizes |
Public Attributes inherited from circt::Reduction | |
std::function< void(Operation *)> | notifyOpErasedCallback = nullptr |
An optional callback for reductions to communicate removal of operations. More... | |
A sample reduction pattern that maps hw.module
to hw.module.extern
.
Definition at line 59 of file HWReductions.cpp.
|
inlineoverridevirtual |
Called before the reduction is applied to a new subset of operations.
Reductions may use this callback to collect information such as symbol tables about the module upfront.
Reimplemented from circt::Reduction.
Definition at line 60 of file HWReductions.cpp.
|
inlineoverridevirtual |
Return a human-readable name for this reduction pattern.
Implements circt::Reduction.
Definition at line 78 of file HWReductions.cpp.
|
inlineoverride |
Definition at line 65 of file HWReductions.cpp.
|
inlineoverride |
Definition at line 69 of file HWReductions.cpp.
std::unique_ptr<InstanceGraph> ModuleExternalizer::instanceGraph |
Definition at line 80 of file HWReductions.cpp.
ModuleSizeCache ModuleExternalizer::moduleSizes |
Definition at line 81 of file HWReductions.cpp.