From: Clifford Wolf Date: Thu, 15 Oct 2015 13:54:59 +0000 (+0200) Subject: Progress in yosys-smtbmc X-Git-Tag: yosys-0.6~104 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=255bb914bada727806df4bdc22ab8472f03a6317;p=yosys.git Progress in yosys-smtbmc --- diff --git a/backends/smt2/smtbmc.py b/backends/smt2/smtbmc.py index 60cd9775e..db0bce4bb 100644 --- a/backends/smt2/smtbmc.py +++ b/backends/smt2/smtbmc.py @@ -121,6 +121,7 @@ def write_vcd_model(steps): if tempind: + retstatus = False for step in range(num_steps, -1, -1): smt.write("(declare-fun s%d () %s_s)" % (step, topmod)) smt.write("(assert (%s_u s%d))" % (topmod, step)) @@ -140,16 +141,18 @@ if tempind: if smt.check_sat() == "sat": if step == 0: - print("%s temporal induction failed!" % smt.timestamp()) + print("%s Temporal induction failed!" % smt.timestamp()) if vcdfile is not None: write_vcd_model(num_steps+1) else: - print("%s PASSED." % smt.timestamp()) + print("%s Temporal induction successful." % smt.timestamp()) + retstatus = True break else: # not tempind + retstatus = True for step in range(num_steps+1): smt.write("(declare-fun s%d () %s_s)" % (step, topmod)) smt.write("(assert (%s_u s%d))" % (topmod, step)) @@ -176,7 +179,8 @@ else: # not tempind if smt.check_sat() == "sat": print("%s BMC failed!" % smt.timestamp()) if vcdfile is not None: - write_vcd_model(steps+1) + write_vcd_model(step+1) + retstatus = False break else: # unsat @@ -184,7 +188,9 @@ else: # not tempind smt.write("(assert (%s_a s%d))" % (topmod, step)) -print("%s Done." % smt.timestamp()) smt.write("(exit)") smt.wait() +print("%s Status: %s" % (smt.timestamp(), "PASSED" if retstatus else "FAILED (!)")) +sys.exit(0 if retstatus else 1) +