mirror of https://github.com/YosysHQ/yosys.git
Add Verific support for SVA nexttime properties
Signed-off-by: Clifford Wolf <clifford@clifford.at>
This commit is contained in:
parent
e93e4a7a2c
commit
db323685a4
|
@ -36,6 +36,8 @@
|
||||||
// basic_property:
|
// basic_property:
|
||||||
// sequence
|
// sequence
|
||||||
// not basic_property
|
// not basic_property
|
||||||
|
// nexttime basic_property
|
||||||
|
// nexttime[N] basic_property
|
||||||
// sequence #-# basic_property
|
// sequence #-# basic_property
|
||||||
// sequence #=# basic_property
|
// sequence #=# basic_property
|
||||||
// basic_property or basic_property (cover only)
|
// basic_property or basic_property (cover only)
|
||||||
|
@ -1264,6 +1266,26 @@ struct VerificSvaImporter
|
||||||
return node;
|
return node;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (inst->Type() == PRIM_SVA_NEXTTIME || inst->Type() == PRIM_SVA_S_NEXTTIME)
|
||||||
|
{
|
||||||
|
const char *sva_low_s = inst->GetAttValue("sva:low");
|
||||||
|
const char *sva_high_s = inst->GetAttValue("sva:high");
|
||||||
|
|
||||||
|
int sva_low = atoi(sva_low_s);
|
||||||
|
int sva_high = atoi(sva_high_s);
|
||||||
|
log_assert(sva_low == sva_high);
|
||||||
|
|
||||||
|
int node = start_node;
|
||||||
|
|
||||||
|
for (int i = 0; i < sva_low; i++) {
|
||||||
|
int next_node = fsm.createNode();
|
||||||
|
fsm.createEdge(node, next_node);
|
||||||
|
node = next_node;
|
||||||
|
}
|
||||||
|
|
||||||
|
return parse_sequence(fsm, node, inst->GetInput());
|
||||||
|
}
|
||||||
|
|
||||||
if (inst->Type() == PRIM_SVA_SEQ_CONCAT)
|
if (inst->Type() == PRIM_SVA_SEQ_CONCAT)
|
||||||
{
|
{
|
||||||
const char *sva_low_s = inst->GetAttValue("sva:low");
|
const char *sva_low_s = inst->GetAttValue("sva:low");
|
||||||
|
|
Loading…
Reference in New Issue