From: Clifford Wolf Date: Mon, 3 Oct 2016 22:54:44 +0000 (+0200) Subject: Bugfix in yosys-smtbmc --noincr X-Git-Tag: yosys-0.7~40 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=5f7c5e685bb2ea23ced2676e3bbb644769f2d955;p=yosys.git Bugfix in yosys-smtbmc --noincr --- diff --git a/backends/smt2/smtio.py b/backends/smt2/smtio.py index eccb65014..a0c981d3c 100644 --- a/backends/smt2/smtio.py +++ b/backends/smt2/smtio.py @@ -270,11 +270,17 @@ class SmtIo: if self.solver != "dummy": if self.noincr: + if self.p is not None and not stmt.startswith("(get-"): + self.p.stdin.close() + self.p = None if stmt == "(push 1)": self.smt2cache.append(list()) elif stmt == "(pop 1)": self.smt2cache.pop() else: + if self.p is not None: + self.p.stdin.write(bytes(stmt + "\n", "ascii")) + self.p.stdin.flush() self.smt2cache[-1].append(stmt) else: self.p.stdin.write(bytes(stmt + "\n", "ascii")) @@ -394,6 +400,7 @@ class SmtIo: if self.noincr: if self.p is not None: self.p.stdin.close() + self.p = None self.p = subprocess.Popen(self.popen_vargs, stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.STDOUT) for cache_ctx in self.smt2cache: for cache_stmt in cache_ctx: @@ -596,7 +603,7 @@ class SmtIo: return [self.bv2bin(v) for v in self.get_net_list(mod_name, net_path_list, state_name)] def wait(self): - if self.solver != "dummy": + if self.p is not None: self.p.wait()