mirror of https://github.com/YosysHQ/yosys.git
write_btor: Include `$assert` and `$assume` cells in -ywmap output
This commit is contained in:
parent
c71262f66b
commit
884f40df11
|
@ -97,6 +97,8 @@ struct BtorWorker
|
||||||
vector<ywmap_btor_sig> ywmap_states;
|
vector<ywmap_btor_sig> ywmap_states;
|
||||||
dict<SigBit, int> ywmap_clock_bits;
|
dict<SigBit, int> ywmap_clock_bits;
|
||||||
dict<SigBit, int> ywmap_clock_inputs;
|
dict<SigBit, int> ywmap_clock_inputs;
|
||||||
|
vector<Cell *> ywmap_asserts;
|
||||||
|
vector<Cell *> ywmap_assumes;
|
||||||
|
|
||||||
|
|
||||||
PrettyJson ywmap_json;
|
PrettyJson ywmap_json;
|
||||||
|
@ -1277,6 +1279,8 @@ struct BtorWorker
|
||||||
btorf("%d or %d %d %d\n", nid_a_or_not_en, sid, nid_a, nid_not_en);
|
btorf("%d or %d %d %d\n", nid_a_or_not_en, sid, nid_a, nid_not_en);
|
||||||
btorf("%d constraint %d\n", nid, nid_a_or_not_en);
|
btorf("%d constraint %d\n", nid, nid_a_or_not_en);
|
||||||
|
|
||||||
|
if (ywmap_json.active()) ywmap_assumes.emplace_back(cell);
|
||||||
|
|
||||||
btorf_pop(log_id(cell));
|
btorf_pop(log_id(cell));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1301,6 +1305,8 @@ struct BtorWorker
|
||||||
} else {
|
} else {
|
||||||
int nid = next_nid++;
|
int nid = next_nid++;
|
||||||
btorf("%d bad %d%s\n", nid, nid_en_and_not_a, getinfo(cell, true).c_str());
|
btorf("%d bad %d%s\n", nid, nid_en_and_not_a, getinfo(cell, true).c_str());
|
||||||
|
|
||||||
|
if (ywmap_json.active()) ywmap_asserts.emplace_back(cell);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1458,6 +1464,7 @@ struct BtorWorker
|
||||||
log_assert(cursor == 0);
|
log_assert(cursor == 0);
|
||||||
log_assert(GetSize(todo) == 1);
|
log_assert(GetSize(todo) == 1);
|
||||||
btorf("%d bad %d\n", nid, todo[cursor]);
|
btorf("%d bad %d\n", nid, todo[cursor]);
|
||||||
|
// What do we do with ywmap_asserts when using single_bad?
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1523,6 +1530,18 @@ struct BtorWorker
|
||||||
emit_ywmap_btor_sig(entry);
|
emit_ywmap_btor_sig(entry);
|
||||||
ywmap_json.end_array();
|
ywmap_json.end_array();
|
||||||
|
|
||||||
|
ywmap_json.name("asserts");
|
||||||
|
ywmap_json.begin_array();
|
||||||
|
for (Cell *cell : ywmap_asserts)
|
||||||
|
ywmap_json.value(witness_path(cell));
|
||||||
|
ywmap_json.end_array();
|
||||||
|
|
||||||
|
ywmap_json.name("assumes");
|
||||||
|
ywmap_json.begin_array();
|
||||||
|
for (Cell *cell : ywmap_assumes)
|
||||||
|
ywmap_json.value(witness_path(cell));
|
||||||
|
ywmap_json.end_array();
|
||||||
|
|
||||||
ywmap_json.end_object();
|
ywmap_json.end_object();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue