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 sim::SquashSimTriggeredOptions opts;
64 opts.convertToHW =
true;
65 pm.addNestedPass<
hw::HWModuleOp>(sim::createSquashSimTriggered(opts));
68 ConvertToArcsPassOptions opts;
70 pm.addPass(createConvertToArcsPass(opts));
73 pm.addPass(arc::createDedup());
74 pm.addPass(hw::createFlattenModules());
75 pm.addPass(createCSEPass());
76 pm.addPass(arc::createArcCanonicalizer());
83 pm.addPass(arc::createSplitLoops());
85 pm.addPass(arc::createDedup());
87 arc::InferStatePropertiesOptions opts;
90 pm.addPass(arc::createInferStateProperties(opts));
92 pm.addPass(createCSEPass());
93 pm.addPass(arc::createArcCanonicalizer());
96 pm.addPass(arc::createMakeTables());
97 pm.addPass(createCSEPass());
98 pm.addPass(arc::createArcCanonicalizer());
115 pm.addPass(arc::createLowerStatePass());
124 pm.addPass(arc::createInlineArcs());
126 pm.addPass(arc::createMergeIfsPass());
127 pm.addPass(createCSEPass());
128 pm.addPass(arc::createArcCanonicalizer());
133 pm.addPass(arc::createLowerArcsToFuncs());
134 pm.addPass(arc::createRemoveI0Types());
136 AllocateStateOptions allocStateOpts;
138 pm.nest<arc::ModelOp>().addPass(arc::createAllocateState(allocStateOpts));
140 pm.nest<arc::ModelOp>().addPass(arc::createAllocateState());
141 pm.addPass(arc::createLowerClocksToFuncs());
146 pm.addPass(createCSEPass());
147 pm.addPass(arc::createArcCanonicalizer());
153 hw::HWConvertBitcastsOptions options;
154 options.allowPartialConversion =
false;
155 pm.addPass(hw::createHWConvertBitcasts(options));
157 if (!options.noRuntime) {
158 InsertRuntimeOptions opts;
160 opts.traceFileName = options.traceFileName;
161 pm.addPass(createInsertRuntime(opts));
163 if (options.bufferizeArrays) {
164 pm.addPass(createLowerArrays());
167 pm.addPass(createCSEPass());
168 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