CIRCT
20.0.0git
|
A sample reduction pattern that replaces the right-hand-side of firrtl.connect
and firrtl.matchingconnect
operations with a firrtl.invalidvalue
.
More...
Public Member Functions | |
uint64_t | match (Operation *op) override |
Check if the reduction can apply to a specific operation. More... | |
LogicalResult | rewrite (Operation *op) override |
Apply the reduction to a specific operation. More... | |
std::string | getName () const override |
Return a human-readable name for this reduction pattern. More... | |
bool | acceptSizeIncrease () const override |
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... | |
Public Member Functions inherited from circt::Reduction | |
virtual | ~Reduction () |
virtual void | beforeReduction (mlir::ModuleOp) |
Called before the reduction is applied to a new subset of operations. More... | |
virtual void | afterReduction (mlir::ModuleOp) |
Called after the reduction has been applied to a subset of operations. 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) |
Additional Inherited Members | |
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 replaces the right-hand-side of firrtl.connect
and firrtl.matchingconnect
operations with a firrtl.invalidvalue
.
This removes uses from the fanin cone to these connects and creates opportunities for reduction in DCE/CSE.
Definition at line 570 of file FIRRTLReductions.cpp.
|
inlineoverridevirtual |
Return true if the tool should accept the transformation this reduction performs on the module even if the overall size of the output increases.
This can be handy for patterns that reduce the complexity of the IR at the cost of some verbosity.
Reimplemented from circt::Reduction.
Definition at line 591 of file FIRRTLReductions.cpp.
|
inlineoverridevirtual |
Return a human-readable name for this reduction pattern.
Implements circt::Reduction.
Definition at line 590 of file FIRRTLReductions.cpp.
|
inlineoverridevirtual |
Check if the reduction can apply to a specific operation.
Returns a benefit measure where a higher number means that applying the pattern leads to a bigger reduction and zero means that the patten does not match and thus cannot be applied at all.
Implements circt::Reduction.
Definition at line 571 of file FIRRTLReductions.cpp.
|
inlineoverridevirtual |
Apply the reduction to a specific operation.
If the returned result indicates that the application failed, the resulting module is treated the same as if the tester marked it as uninteresting.
Implements circt::Reduction.
Definition at line 578 of file FIRRTLReductions.cpp.
References assert(), and circt::reduce::pruneUnusedOps().