20#include "mlir/Transforms/Passes.h"
21#include "llvm/Support/FileSystem.h"
22#include "llvm/Support/Path.h"
29 pm.nest<firrtl::CircuitOp>().addPass(
30 firrtl::createCheckRecursiveInstantiation());
31 pm.nest<firrtl::CircuitOp>().addPass(firrtl::createCheckLayers());
33 pm.nest<firrtl::CircuitOp>().addPass(firrtl::createLowerOpenAggs());
35 pm.nest<firrtl::CircuitOp>().addPass(firrtl::createResolvePaths());
37 pm.nest<firrtl::CircuitOp>().addPass(firrtl::createLowerFIRRTLAnnotations(
43 pm.nest<firrtl::CircuitOp>().addNestedPass<firrtl::FModuleOp>(
44 firrtl::createMaterializeDebugInfo());
46 pm.nest<firrtl::CircuitOp>().addPass(firrtl::createLowerIntmodules(
48 pm.nest<firrtl::CircuitOp>().nest<firrtl::FModuleOp>().addPass(
49 firrtl::createLowerIntrinsics());
58 pm.addNestedPass<firrtl::CircuitOp>(firrtl::createSpecializeOption(
61 pm.nest<firrtl::CircuitOp>().addPass(firrtl::createLowerSignatures());
67 pm.nest<firrtl::CircuitOp>().addPass(firrtl::createInjectDUTHierarchy());
71 pm.nest<firrtl::CircuitOp>().nest<firrtl::FModuleOp>().addPass(
72 mlir::createCSEPass());
74 pm.nest<firrtl::CircuitOp>().nestAny().addPass(mlir::createCSEPass());
77 pm.nest<firrtl::CircuitOp>().nest<firrtl::FModuleOp>().addPass(
78 firrtl::createPassiveWires());
80 pm.nest<firrtl::CircuitOp>().nest<firrtl::FModuleOp>().addPass(
83 pm.nest<firrtl::CircuitOp>().nest<firrtl::FModuleOp>().addPass(
84 firrtl::createLowerCHIRRTLPass());
88 pm.nest<firrtl::CircuitOp>().nest<firrtl::FModuleOp>().addPass(
89 firrtl::createLowerMatches());
92 pm.nest<firrtl::CircuitOp>().addPass(firrtl::createInferWidths());
94 pm.nest<firrtl::CircuitOp>().addPass(firrtl::createMemToRegOfVec(
98 pm.nest<firrtl::CircuitOp>().addPass(firrtl::createInferResets());
100 pm.nest<firrtl::CircuitOp>().addPass(firrtl::createDropConst());
103 firrtl::DedupOptions opts;
105 pm.nest<firrtl::CircuitOp>().addPass(firrtl::createDedup(opts));
109 pm.addNestedPass<firrtl::CircuitOp>(firrtl::createLowerFIRRTLTypes(
112 pm.addNestedPass<firrtl::CircuitOp>(firrtl::createVBToBV());
116 pm.nest<firrtl::CircuitOp>().nest<firrtl::FModuleOp>().addPass(
117 firrtl::createFlattenMemory());
122 pm.addNestedPass<firrtl::CircuitOp>(firrtl::createLowerFIRRTLTypes(
127 auto &modulePM = pm.nest<firrtl::CircuitOp>().nest<firrtl::FModuleOp>();
128 modulePM.addPass(firrtl::createExpandWhens());
129 modulePM.addPass(firrtl::createSFCCompat());
132 pm.addNestedPass<firrtl::CircuitOp>(firrtl::createCheckCombLoops());
136 pm.addNestedPass<firrtl::CircuitOp>(firrtl::createSpecializeLayers());
140 pm.nest<firrtl::CircuitOp>().addPass(firrtl::createProbesToSignals());
142 pm.nest<firrtl::CircuitOp>().addPass(firrtl::createInliner());
144 pm.nest<firrtl::CircuitOp>().nest<firrtl::FModuleOp>().addPass(
145 firrtl::createLayerMerge());
152 pm.nest<firrtl::CircuitOp>().nest<firrtl::FModuleOp>().addPass(
153 firrtl::createRandomizeRegisterInit());
157 pm.nest<firrtl::CircuitOp>().nest<firrtl::FModuleOp>().addPass(
163 pm.nest<firrtl::CircuitOp>().nest<firrtl::FModuleOp>().addPass(
164 firrtl::createInferReadWrite());
167 pm.nest<firrtl::CircuitOp>().addPass(firrtl::createLowerMemory());
170 pm.nest<firrtl::CircuitOp>().addPass(firrtl::createIMConstProp());
172 pm.addNestedPass<firrtl::CircuitOp>(firrtl::createAddSeqMemPorts());
174 pm.addPass(firrtl::createCreateSiFiveMetadata(
181 pm.addNestedPass<firrtl::CircuitOp>(firrtl::createExtractInstances());
185 pm.addNestedPass<firrtl::CircuitOp>(mlir::createSymbolDCEPass());
188 pm.addPass(firrtl::createInnerSymbolDCE());
195 pm.nest<firrtl::CircuitOp>().nest<firrtl::FModuleOp>().addPass(
196 circt::firrtl::createEliminateWires());
197 pm.nest<firrtl::CircuitOp>().nest<firrtl::FModuleOp>().addPass(
199 pm.nest<firrtl::CircuitOp>().nest<firrtl::FModuleOp>().addPass(
200 circt::firrtl::createRegisterOptimizer());
203 pm.nest<firrtl::CircuitOp>().addPass(firrtl::createIMConstProp());
204 pm.nest<firrtl::CircuitOp>().nest<firrtl::FModuleOp>().addPass(
206 pm.addPass(firrtl::createIMDeadCodeElim());
208 pm.nest<firrtl::CircuitOp>().addPass(
209 firrtl::createAnnotateInputOnlyModules());
210 pm.nest<firrtl::CircuitOp>().addPass(firrtl::createInliner());
211 pm.nest<firrtl::CircuitOp>().nest<firrtl::FModuleOp>().addPass(
217 pm.nest<firrtl::CircuitOp>().nest<firrtl::FModuleOp>().addPass(
218 firrtl::createMergeConnections(
223 pm.nest<firrtl::CircuitOp>().nest<firrtl::FModuleOp>().addPass(
224 firrtl::createVectorization());
231 StringRef inputFilename) {
236 pm.nest<firrtl::CircuitOp>().addPass(firrtl::createLayerSink());
241 pm.nest<firrtl::CircuitOp>().addPass(firrtl::createLowerXMR());
250 pm.nest<firrtl::CircuitOp>().addPass(
253 pm.nest<firrtl::CircuitOp>().nest<firrtl::FModuleOp>().addPass(
257 if (outputFilename ==
"-")
260 pm.nest<firrtl::CircuitOp>().addPass(firrtl::createAssignOutputDirs(
261 {outputFilename.str()}));
269 pm.addNestedPass<firrtl::CircuitOp>(
275 ? llvm::sys::path::parent_path(inputFilename)
277 pm.nest<firrtl::CircuitOp>().addPass(
278 firrtl::createBlackBoxReader({blackBoxRoot.str()}));
282 pm.nest<firrtl::CircuitOp>().addPass(
285 pm.nest<firrtl::CircuitOp>().addPass(firrtl::createLowerDPI());
286 pm.nest<firrtl::CircuitOp>().addPass(firrtl::createLowerDomains());
287 pm.nest<firrtl::CircuitOp>().addPass(firrtl::createLowerClasses());
288 pm.nest<firrtl::CircuitOp>().addPass(om::createVerifyObjectFieldsPass());
291 pm.nest<firrtl::CircuitOp>().addPass(circt::firrtl::createLint(
300 modulePM.addPass(mlir::createCSEPass());
305 pm.addPass(hw::createVerifyInnerRefNamespace());
308 pm.addPass(om::createVerifyObjectFieldsPass());
311 pm.addNestedPass<
hw::HWModuleOp>(verif::createVerifyClockedAssertLikePass());
318 pm.nestAny().addPass(verif::createStripContractsPass());
319 pm.addPass(verif::createLowerTestsPass());
324 pm.addPass(sv::createSVExtractTestCodePass(
333 FirtoolOptions::RandomKind::Reg),
339 pm.addPass(seq::createHWMemSimImplPass(
341 FirtoolOptions::RandomKind::Mem),
346 ? seq::ReadEnableMode::Ignore
347 : seq::ReadEnableMode::Undefined,
355 modulePM.addPass(mlir::createCSEPass());
357 modulePM.addPass(mlir::createCSEPass());
358 modulePM.addPass(sv::createHWCleanupPass(
363 pm.addPass(hw::createVerifyInnerRefNamespace());
366 pm.addPass(om::createVerifyObjectFieldsPass());
377 pm.addNestedPass<
hw::HWModuleOp>(verif::createVerifyClockedAssertLikePass());
388 if (
auto fileLoc = dyn_cast<FileLineColLoc>(loc))
389 return fileLoc.getFilename().getValue().ends_with(
".fir");
395 [](mlir::Location loc) {
return true; }));
402 pm.addPass(hw::createVerifyInnerRefNamespace());
413 std::unique_ptr<llvm::raw_ostream> os) {
423 llvm::raw_ostream &os) {
433 llvm::StringRef directory) {
443 pm.addPass(firrtl::createFinalizeIR());
444 pm.addPass(om::createFreezePathsPass());
451 llvm::raw_ostream &os) {
453 pm.addNestedPass<
hw::HWModuleOp>(circt::verif::createPrepareForFormalPass());
454 pm.addPass(circt::hw::createFlattenModules());
467struct FirtoolCmdOptions {
470 llvm::cl::desc(
"Output filename, or directory for split output"),
471 llvm::cl::value_desc(
"filename"),
476 "disable-annotation-unknown",
477 llvm::cl::desc(
"Ignore unknown annotations when parsing"),
478 llvm::cl::init(
false)};
481 "disable-annotation-classless",
482 llvm::cl::desc(
"Ignore annotations without a class when parsing"),
483 llvm::cl::init(
false)};
486 "lower-annotations-no-ref-type-ports",
488 "Create real ports instead of ref type ports when resolving "
489 "wiring problems inside the LowerAnnotations pass"),
490 llvm::cl::init(
false), llvm::cl::Hidden};
494 llvm::cl::desc(
"Convert probes to non-probe signals"),
495 llvm::cl::init(
false), llvm::cl::Hidden};
499 "preserve-aggregate",
500 llvm::cl::desc(
"Specify input file format:"),
503 "Preserve no aggregate"),
505 "Preserve only 1d vectors of ground type"),
507 "Preserve only vectors"),
509 "Preserve vectors and bundles")),
515 llvm::cl::desc(
"Specify the values which can be optimized away"),
518 "Strip all names. No name is preserved"),
520 "Names could be preserved by best-effort unlike `strip`"),
522 "Preserve values with meaningful names"),
524 "Preserve all values")),
528 "g", llvm::cl::desc(
"Enable the generation of debug information"),
529 llvm::cl::init(
false)};
533 "O", llvm::cl::desc(
"Controls how much optimization should be performed"),
536 "Compile with only necessary optimizations"),
538 "release",
"Compile with optimizations")),
542 llvm::cl::desc(
"Disable layer sink"),
547 llvm::cl::desc(
"Disable optimizations"),
552 llvm::cl::desc(
"Transform vectors of bundles to bundles of vectors"),
553 llvm::cl::init(
false)};
557 llvm::cl::desc(
"Disable deduplication of structurally identical modules"),
558 llvm::cl::init(
false)};
563 "Deduplicate FIRRTL classes, violating their nominal typing"),
564 llvm::cl::init(
true)};
567 "grand-central-companion-mode",
568 llvm::cl::desc(
"Specifies the handling of Grand Central companions"),
570 clEnumValN(firrtl::CompanionMode::Bind,
"bind",
571 "Lower companion instances to SystemVerilog binds"),
572 clEnumValN(firrtl::CompanionMode::Instantiate,
"instantiate",
573 "Instantiate companions in the design"),
574 clEnumValN(firrtl::CompanionMode::Drop,
"drop",
575 "Remove companions from the design")),
576 llvm::cl::init(firrtl::CompanionMode::Bind),
583 "Disable lowering of FIRRTL view intrinsics (delete them instead)"),
584 llvm::cl::init(
false),
588 "disable-aggressive-merge-connections",
590 "Disable aggressive merge connections (i.e. merge all field-level "
591 "connections into bulk connections)"),
592 llvm::cl::init(
false)};
596 llvm::cl::desc(
"Lower memories to have memories with masks as an "
597 "array with one memory per ground type"),
598 llvm::cl::init(
false)};
603 "Optional path to use as the root of black box annotations"),
604 llvm::cl::value_desc(
"path"),
610 llvm::cl::desc(
"Replace the seq mem for macro replacement and emit "
611 "relevant metadata"),
612 llvm::cl::init(
false)};
615 "repl-seq-mem-file", llvm::cl::desc(
"File name for seq mem metadata"),
619 "extract-test-code", llvm::cl::desc(
"Run the extract test code pass"),
620 llvm::cl::init(
false)};
623 "ignore-read-enable-mem",
624 llvm::cl::desc(
"Ignore the read enable signal, instead of "
625 "assigning X on read disable"),
626 llvm::cl::init(
false)};
630 "Disable random initialization code (may break semantics!)"),
632 clEnumValN(firtool::FirtoolOptions::RandomKind::Mem,
633 "disable-mem-randomization",
634 "Disable emission of memory randomization code"),
635 clEnumValN(firtool::FirtoolOptions::RandomKind::Reg,
636 "disable-reg-randomization",
637 "Disable emission of register randomization code"),
638 clEnumValN(firtool::FirtoolOptions::RandomKind::All,
639 "disable-all-randomization",
640 "Disable emission of all randomization code")),
641 llvm::cl::init(firtool::FirtoolOptions::RandomKind::None)};
644 "output-annotation-file",
645 llvm::cl::desc(
"Optional output annotation file"),
646 llvm::cl::CommaSeparated, llvm::cl::value_desc(
"filename")};
649 "warn-on-unprocessed-annotations",
651 "Warn about annotations that were not removed by lower-to-hw"),
652 llvm::cl::init(
false)};
656 llvm::cl::desc(
"Annotate mux pragmas for memory array access"),
657 llvm::cl::init(
false)};
660 "verification-flavor",
661 llvm::cl::desc(
"Specify a verification flavor used in LowerFIRRTLToHW"),
663 clEnumValN(firrtl::VerificationFlavor::None,
"none",
664 "Use the flavor specified by the op"),
665 clEnumValN(firrtl::VerificationFlavor::IfElseFatal,
"if-else-fatal",
666 "Use Use `if(cond) else $fatal(..)` format"),
667 clEnumValN(firrtl::VerificationFlavor::Immediate,
"immediate",
668 "Use immediate verif statements"),
669 clEnumValN(firrtl::VerificationFlavor::SVA,
"sva",
"Use SVA")),
670 llvm::cl::init(firrtl::VerificationFlavor::None)};
673 "emit-separate-always-blocks",
675 "Prevent always blocks from being merged and emit constructs into "
676 "separate always blocks whenever possible"),
677 llvm::cl::init(
false)};
680 "etc-disable-instance-extraction",
681 llvm::cl::desc(
"Disable extracting instances only that feed test code"),
682 llvm::cl::init(
false)};
685 "etc-disable-register-extraction",
686 llvm::cl::desc(
"Disable extracting registers that only feed test code"),
687 llvm::cl::init(
false)};
690 "etc-disable-module-inlining",
691 llvm::cl::desc(
"Disable inlining modules that only feed test code"),
692 llvm::cl::init(
false)};
695 "add-vivado-ram-address-conflict-synthesis-bug-workaround",
697 "Add a vivado specific SV attribute (* ram_style = "
698 "\"distributed\" *) to unpacked array registers as a workaronud "
699 "for a vivado synthesis bug that incorrectly modifies "
700 "address conflict behavivor of combinational memories"),
701 llvm::cl::init(
false)};
708 "ckg-name", llvm::cl::desc(
"Clock gate module name"),
709 llvm::cl::init(
"EICG_wrapper")};
712 "ckg-input", llvm::cl::desc(
"Clock gate input port name"),
713 llvm::cl::init(
"in")};
716 "ckg-output", llvm::cl::desc(
"Clock gate output port name"),
717 llvm::cl::init(
"out")};
720 "ckg-enable", llvm::cl::desc(
"Clock gate enable port name"),
721 llvm::cl::init(
"en")};
725 llvm::cl::desc(
"Clock gate test enable port name (optional)"),
726 llvm::cl::init(
"test_en")};
729 "export-module-hierarchy",
730 llvm::cl::desc(
"Export module and instance hierarchy as JSON"),
731 llvm::cl::init(
false)};
734 "strip-fir-debug-info",
736 "Disable source fir locator information in output Verilog"),
737 llvm::cl::init(
true)};
741 llvm::cl::desc(
"Disable source locator information in output Verilog"),
742 llvm::cl::init(
false)};
745 "fixup-eicg-wrapper",
746 llvm::cl::desc(
"Lower `EICG_wrapper` modules into clock gate intrinsics"),
747 llvm::cl::init(
false)};
750 "select-default-for-unspecified-instance-choice",
752 "Specialize instance choice to default, if no option selected"),
753 llvm::cl::init(
false)};
757 llvm::cl::desc(
"Control how symbolic values are lowered"),
758 llvm::cl::init(verif::SymbolicValueLowering::ExtModule),
759 verif::symbolicValueLoweringCLValues()};
762 "disable-wire-elimination", llvm::cl::desc(
"Disable wire elimination"),
763 llvm::cl::init(
false)};
766 "emit-all-bind-files",
767 llvm::cl::desc(
"Emit bindfiles for private modules"),
768 llvm::cl::init(
false)};
771 "inline-input-only-modules", llvm::cl::desc(
"Inline input-only modules"),
772 llvm::cl::init(
false)};
779 "lint-static-asserts", llvm::cl::desc(
"Lint static assertions"),
780 llvm::cl::init(
true)};
784 "lint-xmrs-in-design", llvm::cl::desc(
"Lint XMRs in the design"),
785 llvm::cl::init(
false)};
801 : outputFilename(
"-"), disableAnnotationsUnknown(false),
802 disableAnnotationsClassless(false), lowerAnnotationsNoRefTypePorts(false),
803 probesToSignals(false),
804 preserveAggregate(firrtl::PreserveAggregate::None),
805 preserveMode(firrtl::PreserveValues::None), enableDebugInfo(false),
806 buildMode(BuildModeRelease), disableLayerSink(false),
807 disableOptimization(false), vbToBV(false), noDedup(false),
808 dedupClasses(true), companionMode(firrtl::CompanionMode::Bind),
809 noViews(false), disableAggressiveMergeConnections(false),
810 lowerMemories(false), blackBoxRootPath(
""), replSeqMem(false),
811 replSeqMemFile(
""), extractTestCode(false), ignoreReadEnableMem(false),
812 disableRandom(
RandomKind::None), outputAnnotationFilename(
""),
813 enableAnnotationWarning(false), addMuxPragmas(false),
814 verificationFlavor(firrtl::VerificationFlavor::None),
815 emitSeparateAlwaysBlocks(false), etcDisableInstanceExtraction(false),
816 etcDisableRegisterExtraction(false), etcDisableModuleInlining(false),
817 addVivadoRAMAddressConflictSynthesisBugWorkaround(false),
818 ckgModuleName(
"EICG_wrapper"), ckgInputName(
"in"), ckgOutputName(
"out"),
819 ckgEnableName(
"en"), ckgTestEnableName(
"test_en"), ckgInstName(
"ckg"),
820 exportModuleHierarchy(false), stripFirDebugInfo(true),
821 stripDebugInfo(false), fixupEICGWrapper(false),
822 disableCSEinClasses(false), selectDefaultInstanceChoice(false),
823 symbolicValueLowering(
verif::SymbolicValueLowering::ExtModule),
824 disableWireElimination(false), lintStaticAsserts(true),
825 lintXmrsInDesign(true), emitAllBindFiles(false),
826 inlineInputOnlyModules(false) {
846 clOptions->disableAggressiveMergeConnections;
863 clOptions->addVivadoRAMAddressConflictSynthesisBugWorkaround;
@ All
Preserve all aggregate values.
@ OneDimVec
Preserve only 1d vectors of ground type (e.g. UInt<2>[3]).
@ Vec
Preserve only vectors (e.g. UInt<2>[3][3]).
@ None
Don't preserve aggregate at all.
@ None
Don't explicitly preserve any named values.
@ Strip
Strip all names. No name on declaration is preserved.
std::unique_ptr< mlir::Pass > createVerifyObjectFieldsPass()
std::unique_ptr< mlir::Pass > createHWExportModuleHierarchyPass()
std::unique_ptr< mlir::Pass > createHWLegalizeModulesPass()
std::unique_ptr< mlir::Pass > createPrettifyVerilogPass()
The InstanceGraph op interface, see InstanceGraphInterface.td for more details.
std::unique_ptr< mlir::Pass > createExportSplitVerilogPass(llvm::StringRef directory="./")
std::unique_ptr< OperationPass< hw::HWModuleOp > > createLowerVerifToSVPass()
Create the Verif to SV conversion pass.
std::unique_ptr< mlir::Pass > createLowerSeqToSVPass(const LowerSeqToSVOptions &options={})
std::unique_ptr< mlir::Pass > createLowerLTLToCorePass()
std::unique_ptr< mlir::Pass > createLowerFIRRTLToHWPass(bool enableAnnotationWarning=false, firrtl::VerificationFlavor assertionFlavor=firrtl::VerificationFlavor::None)
This is the pass constructor.
std::unique_ptr< mlir::Pass > createLowerSimToSVPass()
std::unique_ptr< Pass > createSimpleCanonicalizerPass()
Create a simple canonicalizer pass.
std::unique_ptr< mlir::Pass > createConvertHWToBTOR2Pass()
std::unique_ptr< mlir::Pass > createExportVerilogPass()
std::unique_ptr< mlir::Pass > createStripDebugInfoWithPredPass(const std::function< bool(mlir::Location)> &pred)
Creates a pass to strip debug information from a function.
LogicalResult populatePrepareForExportVerilog(mlir::PassManager &pm, const firtool::FirtoolOptions &opt)