mirror of
https://github.com/YosysHQ/sby.git
synced 2025-04-05 22:14:08 +00:00
Merge pull request #259 from jix/prepare-check
Prepare SBY for upcomming `$check` cell support and prevent backend failure for `$print` cells
This commit is contained in:
commit
bd9e218c4a
|
@ -1055,6 +1055,7 @@ class SbyTask(SbyConfig):
|
|||
print(f"# running in {self.workdir}/model/", file=f)
|
||||
print(f"""read_ilang design_prep.il""", file=f)
|
||||
print("hierarchy -smtcheck", file=f)
|
||||
print("delete */t:$print", file=f)
|
||||
print("formalff -assume", file=f)
|
||||
if "_nomem" in model_name:
|
||||
print("memory_map -formal", file=f)
|
||||
|
@ -1088,6 +1089,7 @@ class SbyTask(SbyConfig):
|
|||
print(f"# running in {self.workdir}/model/", file=f)
|
||||
print(f"""read_ilang design_prep.il""", file=f)
|
||||
print("hierarchy -simcheck", file=f)
|
||||
print("delete */t:$print", file=f)
|
||||
print("formalff -assume", file=f)
|
||||
if "_nomem" in model_name:
|
||||
print("memory_map -formal", file=f)
|
||||
|
@ -1122,6 +1124,7 @@ class SbyTask(SbyConfig):
|
|||
with open(f"{self.workdir}/model/design_aiger.ys", "w") as f:
|
||||
print(f"# running in {self.workdir}/model/", file=f)
|
||||
print("read_ilang design_prep.il", file=f)
|
||||
print("delete */t:$print", file=f)
|
||||
print("hierarchy -simcheck", file=f)
|
||||
print("formalff -assume", file=f)
|
||||
print("flatten", file=f)
|
||||
|
|
|
@ -71,6 +71,18 @@ class SbyProperty:
|
|||
return c.LIVE
|
||||
raise ValueError("Unknown property type: " + name)
|
||||
|
||||
@classmethod
|
||||
def from_flavor(c, name):
|
||||
if name == "assume":
|
||||
return c.ASSUME
|
||||
if name == "assert":
|
||||
return c.ASSERT
|
||||
if name == "cover":
|
||||
return c.COVER
|
||||
if name == "live":
|
||||
return c.LIVE
|
||||
raise ValueError("Unknown property type: " + name)
|
||||
|
||||
name: str
|
||||
path: Tuple[str, ...]
|
||||
type: Type
|
||||
|
@ -199,6 +211,20 @@ def design_hierarchy(filename):
|
|||
location=location,
|
||||
hierarchy=sub_hierarchy)
|
||||
mod.properties.append(p)
|
||||
if sort["type"] == "$check":
|
||||
for cell in sort["cells"]:
|
||||
try:
|
||||
location = cell["attributes"]["src"]
|
||||
except KeyError:
|
||||
location = ""
|
||||
p = SbyProperty(
|
||||
name=cell["name"],
|
||||
path=(*path, *cell_path(cell)),
|
||||
type=SbyProperty.Type.from_flavor(cell["parameters"]["FLAVOR"]),
|
||||
location=location,
|
||||
hierarchy=sub_hierarchy)
|
||||
mod.properties.append(p)
|
||||
|
||||
if sort["type"][0] != '$' or sort["type"].startswith("$paramod"):
|
||||
for cell in sort["cells"]:
|
||||
mod.submodules[cell["name"]] = make_mod_hier(
|
||||
|
|
Loading…
Reference in a new issue