mirror of
https://github.com/YosysHQ/yosys
synced 2025-08-05 19:00:26 +00:00
chformal: Add -assert2cover option
Also add to chformal tests.
This commit is contained in:
parent
67f8de54dc
commit
45131f4425
2 changed files with 24 additions and 0 deletions
|
@ -115,6 +115,7 @@ struct ChformalPass : public Pass {
|
|||
log("\n");
|
||||
#endif
|
||||
log(" -assert2assume\n");
|
||||
log(" -assert2cover\n");
|
||||
log(" -assume2assert\n");
|
||||
log(" -live2fair\n");
|
||||
log(" -fair2live\n");
|
||||
|
@ -129,6 +130,7 @@ struct ChformalPass : public Pass {
|
|||
void execute(std::vector<std::string> args, RTLIL::Design *design) override
|
||||
{
|
||||
bool assert2assume = false;
|
||||
bool assert2cover = false;
|
||||
bool assume2assert = false;
|
||||
bool live2fair = false;
|
||||
bool fair2live = false;
|
||||
|
@ -187,6 +189,11 @@ struct ChformalPass : public Pass {
|
|||
mode = 'c';
|
||||
continue;
|
||||
}
|
||||
if ((mode == 0 || mode == 'c') && args[argidx] == "-assert2cover") {
|
||||
assert2cover = true;
|
||||
mode = 'c';
|
||||
continue;
|
||||
}
|
||||
if ((mode == 0 || mode == 'c') && args[argidx] == "-assume2assert") {
|
||||
assume2assert = true;
|
||||
mode = 'c';
|
||||
|
@ -218,6 +225,10 @@ struct ChformalPass : public Pass {
|
|||
constr_types.insert(ID($cover));
|
||||
}
|
||||
|
||||
if (assert2assume && assert2cover) {
|
||||
log_cmd_error("Cannot use both -assert2assume and -assert2cover.\n");
|
||||
}
|
||||
|
||||
if (mode == 0)
|
||||
log_cmd_error("Mode option is missing.\n");
|
||||
|
||||
|
@ -381,6 +392,8 @@ struct ChformalPass : public Pass {
|
|||
IdString flavor = formal_flavor(cell);
|
||||
if (assert2assume && flavor == ID($assert))
|
||||
set_formal_flavor(cell, ID($assume));
|
||||
if (assert2cover && flavor == ID($assert))
|
||||
set_formal_flavor(cell, ID($cover));
|
||||
else if (assume2assert && flavor == ID($assume))
|
||||
set_formal_flavor(cell, ID($assert));
|
||||
else if (live2fair && flavor == ID($live))
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue