mirror of
https://github.com/YosysHQ/sby.git
synced 2025-04-06 14:24:08 +00:00
Merge pull request #240 from YosysHQ/claire/aigfolds
Add "pdr -d" engine support (and aigfolds config option)
This commit is contained in:
commit
fbbbab235f
|
@ -1154,7 +1154,7 @@ class SbyTask(SbyConfig):
|
||||||
self,
|
self,
|
||||||
model_name,
|
model_name,
|
||||||
self.model("aig"),
|
self.model("aig"),
|
||||||
f"""cd {self.workdir}/model; {self.exe_paths["abc"]} -c 'read_aiger design_aiger.aig; fold; strash; write_aiger design_aiger_fold.aig'""",
|
f"""cd {self.workdir}/model; {self.exe_paths["abc"]} -c 'read_aiger design_aiger.aig; fold{" -s" if self.opt_aigfolds else ""}; strash; write_aiger design_aiger_fold.aig'""",
|
||||||
logfile=open(f"{self.workdir}/model/design_aiger_fold.log", "w")
|
logfile=open(f"{self.workdir}/model/design_aiger_fold.log", "w")
|
||||||
)
|
)
|
||||||
proc.checkretcode = True
|
proc.checkretcode = True
|
||||||
|
@ -1236,6 +1236,7 @@ class SbyTask(SbyConfig):
|
||||||
self.handle_bool_option("fst", False)
|
self.handle_bool_option("fst", False)
|
||||||
|
|
||||||
self.handle_bool_option("witrename", True)
|
self.handle_bool_option("witrename", True)
|
||||||
|
self.handle_bool_option("aigfolds", False)
|
||||||
self.handle_bool_option("aigvmap", False)
|
self.handle_bool_option("aigvmap", False)
|
||||||
self.handle_bool_option("aigsyms", False)
|
self.handle_bool_option("aigsyms", False)
|
||||||
|
|
||||||
|
|
|
@ -42,7 +42,7 @@ def run(mode, task, engine_idx, engine):
|
||||||
elif abc_command[0] == "pdr":
|
elif abc_command[0] == "pdr":
|
||||||
if mode != "prove":
|
if mode != "prove":
|
||||||
task.error("ABC command 'pdr' is only valid in prove mode.")
|
task.error("ABC command 'pdr' is only valid in prove mode.")
|
||||||
abc_command[0] += f" -v"
|
abc_command[0] += f" -v -I engine_{engine_idx}/invariants.pla"
|
||||||
|
|
||||||
else:
|
else:
|
||||||
task.error(f"Invalid ABC command {abc_command[0]}.")
|
task.error(f"Invalid ABC command {abc_command[0]}.")
|
||||||
|
@ -66,7 +66,9 @@ def run(mode, task, engine_idx, engine):
|
||||||
task,
|
task,
|
||||||
f"engine_{engine_idx}",
|
f"engine_{engine_idx}",
|
||||||
task.model("aig"),
|
task.model("aig"),
|
||||||
f"""cd {task.workdir}; {task.exe_paths["abc"]} -c 'read_aiger model/design_aiger.aig; fold; strash; {" ".join(abc_command)}; write_cex -a engine_{engine_idx}/trace.aiw'""",
|
f"""cd {task.workdir}; {task.exe_paths["abc"]} -c 'read_aiger model/design_aiger.aig; fold{
|
||||||
|
" -s" if task.opt_aigfolds or (abc_command[0].startswith("pdr ") and "-d" in abc_command[1:]) else ""
|
||||||
|
}; strash; {" ".join(abc_command)}; write_cex -a engine_{engine_idx}/trace.aiw'""",
|
||||||
logfile=open(f"{task.workdir}/engine_{engine_idx}/logfile.txt", "w")
|
logfile=open(f"{task.workdir}/engine_{engine_idx}/logfile.txt", "w")
|
||||||
)
|
)
|
||||||
proc.checkretcode = True
|
proc.checkretcode = True
|
||||||
|
|
Loading…
Reference in a new issue