28#include "mlir/Transforms/Passes.h"
36 pm.addPass(arc::createResolveXMRRef());
37 pm.addPass(om::createStripOMPass());
38 pm.addPass(emit::createStripEmitPass());
40 pm.addPass(createLowerVerifSimulationsPass());
42 arc::AddTapsOptions opts;
46 pm.addPass(arc::createAddTaps(opts));
50 arc::InferMemoriesOptions opts;
53 pm.addPass(arc::createInferMemories(opts));
55 pm.addPass(sim::createLowerDPIFunc());
56 pm.addPass(createCSEPass());
57 pm.addPass(arc::createArcCanonicalizer());
63 ConvertToArcsPassOptions opts;
65 pm.addPass(createConvertToArcsPass(opts));
68 pm.addPass(arc::createDedup());
69 pm.addPass(hw::createFlattenModules());
70 pm.addPass(createCSEPass());
71 pm.addPass(arc::createArcCanonicalizer());
78 pm.addPass(arc::createSplitLoops());
80 pm.addPass(arc::createDedup());
82 arc::InferStatePropertiesOptions opts;
85 pm.addPass(arc::createInferStateProperties(opts));
87 pm.addPass(createCSEPass());
88 pm.addPass(arc::createArcCanonicalizer());
91 pm.addPass(arc::createMakeTables());
92 pm.addPass(createCSEPass());
93 pm.addPass(arc::createArcCanonicalizer());
110 pm.addPass(arc::createLowerStatePass());
119 pm.addPass(arc::createInlineArcs());
121 pm.addPass(arc::createMergeIfsPass());
122 pm.addPass(createCSEPass());
123 pm.addPass(arc::createArcCanonicalizer());
128 pm.addPass(arc::createLowerArcsToFuncs());
130 AllocateStateOptions allocStateOpts;
132 pm.nest<arc::ModelOp>().addPass(arc::createAllocateState(allocStateOpts));
134 pm.nest<arc::ModelOp>().addPass(arc::createAllocateState());
135 pm.addPass(arc::createLowerClocksToFuncs());
140 pm.addPass(createCSEPass());
141 pm.addPass(arc::createArcCanonicalizer());
147 hw::HWConvertBitcastsOptions options;
148 options.allowPartialConversion =
false;
149 pm.addPass(hw::createHWConvertBitcasts(options));
151 if (!options.noRuntime) {
152 InsertRuntimeOptions opts;
154 opts.traceFileName = options.traceFileName;
155 pm.addPass(createInsertRuntime(opts));
158 pm.addPass(createCSEPass());
159 pm.addPass(arc::createArcCanonicalizer());
The InstanceGraph op interface, see InstanceGraphInterface.td for more details.
void populateArcStateLoweringPipeline(mlir::OpPassManager &pm, const ArcStateLoweringOptions &options={})
void populateArcToLLVMPipeline(mlir::OpPassManager &pm, const ArcToLLVMOptions &options={})
void populateArcOptimizationPipeline(mlir::OpPassManager &pm, const ArcOptimizationOptions &options={})
void populateArcConversionPipeline(mlir::OpPassManager &pm, const ArcConversionOptions &options={})
std::unique_ptr< mlir::Pass > createLowerFirMemPass()
std::unique_ptr< OperationPass< ModuleOp > > createLowerArcToLLVMPass()
void populateArcPreprocessingPipeline(mlir::OpPassManager &pm, const ArcPreprocessingOptions &options={})
void populateArcStateAllocationPipeline(mlir::OpPassManager &pm, const ArcStateAllocationOptions &options={})
Option< bool > observeRegisters
Option< bool > shouldDedup
Option< bool > shouldMakeLUTs
Option< bool > shouldDetectResets
Option< bool > shouldDetectEnables
Option< bool > shouldDedup
Option< bool > observeNamedValues
Option< bool > observeMemories
Option< bool > asyncResetsAsSync
Option< bool > observeWires
Option< bool > observePorts
Option< bool > insertTraceTaps
Option< unsigned > splitFuncsThreshold
Option< bool > shouldInline
Option< std::string > extraRuntimeArgs