From db1de5fe5d3ff8d4847dcc510c3909674bd07636 Mon Sep 17 00:00:00 2001 From: Miodrag Milanovic Date: Tue, 30 Jan 2024 16:33:44 +0100 Subject: [PATCH] verific: add option to skip simplifying complex ports --- frontends/verific/verific.cc | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/frontends/verific/verific.cc b/frontends/verific/verific.cc index adabd2700..4123c3741 100644 --- a/frontends/verific/verific.cc +++ b/frontends/verific/verific.cc @@ -2815,6 +2815,9 @@ struct VerificPass : public Pass { log(" -extnets\n"); log(" Resolve references to external nets by adding module ports as needed.\n"); log("\n"); + log(" -no-split-complex-ports\n"); + log(" Complex ports (structs or arrays) are not split and remain packed as a single port.\n"); + log("\n"); log(" -autocover\n"); log(" Generate automatic cover statements for all asserts\n"); log("\n"); @@ -3548,6 +3551,7 @@ struct VerificPass : public Pass { bool mode_nosva = false, mode_names = false, mode_verific = false; bool mode_autocover = false, mode_fullinit = false; bool flatten = false, extnets = false, mode_cells = false; + bool split_complex_ports = true; string dumpfile; string ppfile; Map parameters(STRING_HASH); @@ -3565,6 +3569,10 @@ struct VerificPass : public Pass { flatten = true; continue; } + if (args[argidx] == "-no-split-complex-ports") { + split_complex_ports = false; + continue; + } if (args[argidx] == "-extnets") { extnets = true; continue; @@ -3804,8 +3812,10 @@ struct VerificPass : public Pass { worker.run(nl.second); } - for (auto nl : nl_todo) - nl.second->ChangePortBusStructures(1 /* hierarchical */); + if (split_complex_ports) { + for (auto nl : nl_todo) + nl.second->ChangePortBusStructures(1 /* hierarchical */); + } if (!dumpfile.empty()) { VeriWrite veri_writer;