3
0
Fork 0
mirror of https://github.com/YosysHQ/sby.git synced 2025-10-24 18:04:36 +00:00

Add support for "abc sim3" engine

This commit is contained in:
Clifford Wolf 2017-02-02 16:59:09 +01:00
parent 0a1f207ab5
commit 1f6037c158
2 changed files with 23 additions and 6 deletions

View file

@ -33,6 +33,7 @@ class SbyTask:
self.deps = deps self.deps = deps
self.cmdline = cmdline self.cmdline = cmdline
self.logfile = logfile self.logfile = logfile
self.noprintregex = None
self.notify = [] self.notify = []
for dep in self.deps: for dep in self.deps:
@ -92,8 +93,11 @@ class SbyTask:
while True: while True:
outs = self.p.stdout.readline().decode("utf-8") outs = self.p.stdout.readline().decode("utf-8")
if len(outs) == 0: break if len(outs) == 0: break
self.job.log("%s: %s" % (self.info, outs.strip())) outs = outs.strip()
self.handle_output(outs.strip()) if len(outs) == 0: continue
if self.noprintregex is None or not self.noprintregex.match(outs):
self.job.log("%s: %s" % (self.info, outs))
self.handle_output(outs)
if self.p.poll() is not None: if self.p.poll() is not None:
self.job.log("%s: finished (returncode=%d)" % (self.info, self.p.returncode)) self.job.log("%s: finished (returncode=%d)" % (self.info, self.p.returncode))

View file

@ -20,12 +20,24 @@ import re, os, getopt
from sby_core import SbyTask from sby_core import SbyTask
def run(mode, job, engine_idx, engine): def run(mode, job, engine_idx, engine):
if mode == "bmc": abc_opts, abc_command = getopt.getopt(engine[1:], "", [])
assert engine == ["abc", "bmc3"]
for o, a in abc_opts:
assert False
if abc_command[0] == "bmc3":
assert mode == "bmc"
assert len(abc_command) == 1
abc_command = "bmc3 -F %d -v" % job.opt_depth abc_command = "bmc3 -F %d -v" % job.opt_depth
elif mode == "prove": elif abc_command[0] == "sim3":
assert engine == ["abc", "pdr"] assert mode == "bmc"
assert len(abc_command) == 1
abc_command = "sim3 -F %d -v" % job.opt_depth
elif abc_command[0] == "pdr":
assert mode == "prove"
assert len(abc_command) == 1
abc_command = "pdr" abc_command = "pdr"
else: else:
@ -36,6 +48,7 @@ def run(mode, job, engine_idx, engine):
"write_cex -a engine_%d/trace.aiw'") % (job.workdir, abc_command, engine_idx), "write_cex -a engine_%d/trace.aiw'") % (job.workdir, abc_command, engine_idx),
logfile=open("%s/engine_%d/logfile.txt" % (job.workdir, engine_idx), "w")) logfile=open("%s/engine_%d/logfile.txt" % (job.workdir, engine_idx), "w"))
task.noprintregex = re.compile(r"^\.+$")
task_status = None task_status = None
def output_callback(line): def output_callback(line):