diff options
author | George Rennie <georgerennie@gmail.com> | 2021-09-04 22:40:51 +0100 |
---|---|---|
committer | George Rennie <georgerennie@gmail.com> | 2022-06-18 18:19:26 +0100 |
commit | c659bd18786633c52d42b5966627d39d99ae89e3 (patch) | |
tree | ad4ac42c0966e6ae028f72d3868dfabc27a80c24 /passes/cmds/chformal.cc | |
parent | 90147f5fbf38aef79067dfb92a9e5eceff791ba7 (diff) | |
download | yosys-c659bd18786633c52d42b5966627d39d99ae89e3.tar.gz yosys-c659bd18786633c52d42b5966627d39d99ae89e3.tar.bz2 yosys-c659bd18786633c52d42b5966627d39d99ae89e3.zip |
chformal: Add -coverprecond option
This inserts $cover cells to cover the enable signal (precondition)
for the selected formal cells.
Diffstat (limited to 'passes/cmds/chformal.cc')
-rw-r--r-- | passes/cmds/chformal.cc | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/passes/cmds/chformal.cc b/passes/cmds/chformal.cc index d813a449c..0131063b3 100644 --- a/passes/cmds/chformal.cc +++ b/passes/cmds/chformal.cc @@ -55,6 +55,9 @@ struct ChformalPass : public Pass { log(" -skip <N>\n"); log(" ignore activation of the constraint in the first <N> clock cycles\n"); log("\n"); + log(" -coverprecond\n"); + log(" add a cover statement for the precondition (enable signal) of the cells\n"); + log("\n"); log(" -assert2assume\n"); log(" -assume2assert\n"); log(" -live2fair\n"); @@ -114,6 +117,10 @@ struct ChformalPass : public Pass { mode_arg = atoi(args[++argidx].c_str()); continue; } + if (mode == 0 && args[argidx] == "-coverprecond") { + mode = 'p'; + continue; + } if ((mode == 0 || mode == 'c') && args[argidx] == "-assert2assume") { assert2assume = true; mode = 'c'; @@ -263,6 +270,13 @@ struct ChformalPass : public Pass { cell->setPort(ID::EN, module->LogicAnd(NEW_ID, en, cell->getPort(ID::EN))); } else + if (mode =='p') + { + for (auto cell : constr_cells) + module->addCover(NEW_ID, cell->getPort(ID::EN), State::S1, + "$auto$coverprecond$" + cell->get_src_attribute()); + } + else if (mode == 'c') { for (auto cell : constr_cells) |