CIRCT 20.0.0git
|
#include <Reduction.h>
Public Member Functions | |
uint64_t | match (Operation *op) override |
Check if the reduction can apply to a specific operation. | |
LogicalResult | rewrite (Operation *op) override |
Apply the reduction to a specific operation. | |
virtual uint64_t | match (OpTy op) |
virtual LogicalResult | rewrite (OpTy op)=0 |
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. | |
virtual void | afterReduction (mlir::ModuleOp) |
Called after the reduction has been applied to a subset of operations. | |
virtual std::string | getName () const =0 |
Return a human-readable name for this reduction pattern. | |
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. | |
virtual bool | isOneShot () const |
Return true if the tool should not try to reapply this reduction after it has been successful. | |
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. | |
Definition at line 84 of file Reduction.h.
|
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 85 of file Reduction.h.
References circt::OpReduction< OpTy >::match().
Referenced by circt::OpReduction< OpTy >::match().
|
inlinevirtual |
Reimplemented in FIRRTLModuleExternalizer, RootPortPruner, InstanceStubber, ExtmoduleInstanceRemover, EagerInliner, and NodeSymbolRemover.
Definition at line 94 of file Reduction.h.
|
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 90 of file Reduction.h.
References circt::OpReduction< OpTy >::rewrite().
Referenced by circt::OpReduction< OpTy >::rewrite().
|
pure virtual |