From b6467f080102834c82718470d706c4a848a6cb90 Mon Sep 17 00:00:00 2001 From: gatecat Date: Wed, 16 Nov 2022 13:35:37 +0100 Subject: [PATCH] fabulous: Allow adding extra custom prims and map rules Signed-off-by: gatecat --- techlibs/fabulous/synth_fabulous.cc | 32 ++++++++++++++++++++++++++++ tests/arch/fabulous/custom_map.v | 3 +++ tests/arch/fabulous/custom_prims.v | 8 +++++++ tests/arch/fabulous/customisation.ys | 10 +++++++++ 4 files changed, 53 insertions(+) create mode 100644 tests/arch/fabulous/custom_map.v create mode 100644 tests/arch/fabulous/custom_prims.v create mode 100644 tests/arch/fabulous/customisation.ys diff --git a/techlibs/fabulous/synth_fabulous.cc b/techlibs/fabulous/synth_fabulous.cc index 11c415c03..d7c45e094 100644 --- a/techlibs/fabulous/synth_fabulous.cc +++ b/techlibs/fabulous/synth_fabulous.cc @@ -65,6 +65,14 @@ struct SynthPass : public ScriptPass log(" -plib \n"); log(" use the specified Verilog file as a primitive library.\n"); log("\n"); + log(" -extra-plib \n"); + log(" use the specified Verilog file for extra primitives (can be specified multiple\n"); + log(" times).\n"); + log("\n"); + log(" -extra-map \n"); + log(" use the specified Verilog file for extra techmap rules (can be specified multiple\n"); + log(" times).\n"); + log("\n"); log(" -encfile \n"); log(" passed to 'fsm_recode' via 'fsm'\n"); log("\n"); @@ -112,6 +120,8 @@ struct SynthPass : public ScriptPass } string top_module, json_file, blif_file, plib, fsm_opts, memory_opts; + std::vector extra_plib, extra_map; + bool autotop, forvpr, noalumacc, nofsm, noshare, noregfile, iopad, complexdff, flatten; int lut; @@ -179,6 +189,14 @@ struct SynthPass : public ScriptPass plib = args[++argidx]; continue; } + if (args[argidx] == "-extra-plib" && argidx+1 < args.size()) { + extra_plib.push_back(args[++argidx]); + continue; + } + if (args[argidx] == "-extra-map" && argidx+1 < args.size()) { + extra_map.push_back(args[++argidx]); + continue; + } if (args[argidx] == "-nofsm") { nofsm = true; continue; @@ -237,6 +255,12 @@ struct SynthPass : public ScriptPass else run("read_verilog -lib " + plib); + if (help_mode) { + run("read_verilog -lib ", "(for each -extra-plib)"); + } else for (auto lib : extra_plib) { + run("read_verilog -lib " + lib); + } + if (check_label("begin")) { if (top_module.empty()) { if (autotop) @@ -325,6 +349,14 @@ struct SynthPass : public ScriptPass } run("techmap -map +/fabulous/latches_map.v"); run("techmap -map +/fabulous/ff_map.v"); + if (help_mode) { + run("techmap -map ...", "(for each -extra-map)"); + } else if (!extra_map.empty()) { + std::string map_str = "techmap"; + for (auto map : extra_map) + map_str += stringf(" -map %s", map.c_str()); + run(map_str); + } run("clean"); } diff --git a/tests/arch/fabulous/custom_map.v b/tests/arch/fabulous/custom_map.v new file mode 100644 index 000000000..1538e837b --- /dev/null +++ b/tests/arch/fabulous/custom_map.v @@ -0,0 +1,3 @@ +module AND(input [7:0] A, B, output [7:0] Y); + ALU #(.MODE("AND")) _TECHMAP_REPLACE_ (.A(A), .B(B), .Y(Y)); +endmodule diff --git a/tests/arch/fabulous/custom_prims.v b/tests/arch/fabulous/custom_prims.v new file mode 100644 index 000000000..4989188e2 --- /dev/null +++ b/tests/arch/fabulous/custom_prims.v @@ -0,0 +1,8 @@ +(* blackbox *) +module AND(input [7:0] A, B, output [7:0] Y); +endmodule + +(* blackbox *) +module ALU(input [7:0] A, B, output [7:0] Y); +parameter MODE = ""; +endmodule diff --git a/tests/arch/fabulous/customisation.ys b/tests/arch/fabulous/customisation.ys new file mode 100644 index 000000000..0e78d2e56 --- /dev/null +++ b/tests/arch/fabulous/customisation.ys @@ -0,0 +1,10 @@ +read_verilog <