From c9ed6d8dcf2ae1612422bd34c37441c926d5bddc Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Martin=20Povi=C5=A1er?= Date: Wed, 16 Oct 2024 11:43:54 +0200 Subject: [PATCH] cellmatch: Rename `-lut_attrs` to `-derive_luts`; document option --- passes/techmap/cellmatch.cc | 18 +++++++++++------- tests/techmap/cellmatch.ys | 8 ++++++++ 2 files changed, 19 insertions(+), 7 deletions(-) diff --git a/passes/techmap/cellmatch.cc b/passes/techmap/cellmatch.cc index 235599972..48b1eebf7 100644 --- a/passes/techmap/cellmatch.cc +++ b/passes/techmap/cellmatch.cc @@ -155,18 +155,22 @@ struct CellmatchPass : Pass { log("equivalent as long as their truth tables are identical upto a permutation of\n"); log("inputs and outputs. The supported number of inputs is limited to 6.\n"); log("\n"); + log(" cellmatch -derive_luts [module selection]\n"); + log("\n"); + log("For every port in each selected module, characterize its combinational\n"); + log("function with a 'lut' attribute if possible.\n"); + log("\n"); } void execute(std::vector args, RTLIL::Design *d) override { log_header(d, "Executing CELLMATCH pass. (match cells)\n"); size_t argidx; - bool lut_attrs = false; + bool derive_luts = false; Design *lib = NULL; for (argidx = 1; argidx < args.size(); argidx++) { - if (args[argidx] == "-lut_attrs") { - // an undocumented debugging option - lut_attrs = true; + if (args[argidx] == "-derive_luts") { + derive_luts = true; } else if (args[argidx] == "-lib" && argidx + 1 < args.size()) { if (!saved_designs.count(args[++argidx])) log_cmd_error("No design '%s' found!\n", args[argidx].c_str()); @@ -177,8 +181,8 @@ struct CellmatchPass : Pass { } extra_args(args, argidx, d); - if (!lib && !lut_attrs) - log_cmd_error("Missing required -lib option.\n"); + if (!lib && !derive_luts) + log_cmd_error("Missing required -lib or -derive_luts option.\n"); struct Target { Module *module; @@ -218,7 +222,7 @@ struct CellmatchPass : Pass { SigSpec inputs = module_inputs(m); SigSpec outputs = module_outputs(m); - if (lut_attrs) { + if (derive_luts) { int no = 0; for (auto bit : outputs) { log_assert(bit.is_wire()); diff --git a/tests/techmap/cellmatch.ys b/tests/techmap/cellmatch.ys index bea2f598d..05368fb3b 100644 --- a/tests/techmap/cellmatch.ys +++ b/tests/techmap/cellmatch.ys @@ -77,3 +77,11 @@ opt_clean equiv_induct equiv equiv_status -assert +design -reset +design -load gatelib +cellmatch -derive_luts +select -assert-any bufgate/w:Y a:lut=2'b10 %i +select -assert-any reducegate/w:X a:lut=8'b10000000 %i +select -assert-any reducegate/w:Y a:lut=8'b11111110 %i +select -assert-any fagate/w:X a:lut=8'b10010110 %i +select -assert-any fagate/w:Y a:lut=8'b11101000 %i