aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorClifford Wolf <clifford@clifford.at>2018-03-07 19:40:34 +0100
committerClifford Wolf <clifford@clifford.at>2018-03-07 19:40:34 +0100
commit92d5f4db6f1718ad13c45c5efb7f2a617bd10a47 (patch)
treef76838fe67ceb33302ca66e42dc61ea4390b90ab
parent252627fc548526d1d65c1909f31cd5e3fcf9898b (diff)
downloadyosys-92d5f4db6f1718ad13c45c5efb7f2a617bd10a47.tar.gz
yosys-92d5f4db6f1718ad13c45c5efb7f2a617bd10a47.tar.bz2
yosys-92d5f4db6f1718ad13c45c5efb7f2a617bd10a47.zip
Add "verific -import -V"
Signed-off-by: Clifford Wolf <clifford@clifford.at>
-rw-r--r--frontends/verific/verific.cc20
-rw-r--r--frontends/verific/verific.h4
2 files changed, 18 insertions, 6 deletions
diff --git a/frontends/verific/verific.cc b/frontends/verific/verific.cc
index 180e60b6f..4aeedf767 100644
--- a/frontends/verific/verific.cc
+++ b/frontends/verific/verific.cc
@@ -98,9 +98,9 @@ string get_full_netlist_name(Netlist *nl)
// ==================================================================
-VerificImporter::VerificImporter(bool mode_gates, bool mode_keep, bool mode_nosva, bool mode_names) :
+VerificImporter::VerificImporter(bool mode_gates, bool mode_keep, bool mode_nosva, bool mode_names, bool mode_verific) :
mode_gates(mode_gates), mode_keep(mode_keep), mode_nosva(mode_nosva),
- mode_names(mode_names)
+ mode_names(mode_names), mode_verific(mode_verific)
{
}
@@ -1012,6 +1012,9 @@ void VerificImporter::import_netlist(RTLIL::Design *design, Netlist *nl, std::se
if (verific_verbose)
log(" importing cell %s (%s) as %s.\n", inst->Name(), inst->View()->Owner()->Name(), log_id(inst_name));
+ if (mode_verific)
+ goto import_verific_cells;
+
if (inst->Type() == PRIM_PWR) {
module->connect(net_map_at(inst->GetOutput()), RTLIL::State::S1);
continue;
@@ -1214,6 +1217,7 @@ void VerificImporter::import_netlist(RTLIL::Design *design, Netlist *nl, std::se
log_warning("Unsupported Verific primitive %s of type %s\n", inst->Name(), inst->View()->Owner()->Name());
}
+ import_verific_cells:
nl_todo.insert(inst->View());
RTLIL::Cell *cell = module->addCell(inst_name, inst->IsOperator() ?
@@ -1556,6 +1560,9 @@ struct VerificPass : public Pass {
log(" This will also add all SVA related cells to the design parallel to\n");
log(" the checker logic inferred by it.\n");
log("\n");
+ log(" -V\n");
+ log(" Import Verific netlist as-is without translating to Yosys cell types. \n");
+ log("\n");
log(" -nosva\n");
log(" Ignore SVA properties, do not infer checker logic.\n");
log("\n");
@@ -1696,7 +1703,7 @@ struct VerificPass : public Pass {
{
std::set<Netlist*> nl_todo, nl_done;
bool mode_all = false, mode_gates = false, mode_keep = false;
- bool mode_nosva = false, mode_names = false;
+ bool mode_nosva = false, mode_names = false, mode_verific = false;
bool flatten = false, extnets = false;
string dumpfile;
@@ -1729,6 +1736,10 @@ struct VerificPass : public Pass {
mode_names = true;
continue;
}
+ if (args[argidx] == "-V") {
+ mode_verific = true;
+ continue;
+ }
if (args[argidx] == "-v") {
verific_verbose = 1;
continue;
@@ -1823,7 +1834,8 @@ struct VerificPass : public Pass {
while (!nl_todo.empty()) {
Netlist *nl = *nl_todo.begin();
if (nl_done.count(nl) == 0) {
- VerificImporter importer(mode_gates, mode_keep, mode_nosva, mode_names);
+ VerificImporter importer(mode_gates, mode_keep, mode_nosva,
+ mode_names, mode_verific);
importer.import_netlist(design, nl, nl_todo);
}
nl_todo.erase(nl);
diff --git a/frontends/verific/verific.h b/frontends/verific/verific.h
index 5f927d5cf..1f33d4ccb 100644
--- a/frontends/verific/verific.h
+++ b/frontends/verific/verific.h
@@ -65,9 +65,9 @@ struct VerificImporter
std::map<Verific::Net*, RTLIL::SigBit> net_map;
std::map<Verific::Net*, Verific::Net*> sva_posedge_map;
- bool mode_gates, mode_keep, mode_nosva, mode_names;
+ bool mode_gates, mode_keep, mode_nosva, mode_names, mode_verific;
- VerificImporter(bool mode_gates, bool mode_keep, bool mode_nosva, bool mode_names);
+ VerificImporter(bool mode_gates, bool mode_keep, bool mode_nosva, bool mode_names, bool mode_verific);
RTLIL::SigBit net_map_at(Verific::Net *net);