# # SymbiYosys (sby) -- Front-end for Yosys-based formal verification flows # # Copyright (C) 2016 Claire Xenia Wolf # # Permission to use, copy, modify, and/or distribute this software for any # purpose with or without fee is hereby granted, provided that the above # copyright notice and this permission notice appear in all copies. # # THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES # WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF # MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR # ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES # WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN # ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF # OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. # import re, os, getopt from sby_core import SbyTask def run(job): job.handle_int_option("depth", 20) job.handle_int_option("append", 0) for engine_idx in range(len(job.engines)): engine = job.engines[engine_idx] assert len(engine) > 0 job.log(f"""engine_{engine_idx}: {" ".join(engine)}""") job.makedirs(f"{job.workdir}/engine_{engine_idx}") if engine[0] == "smtbmc": import sby_engine_smtbmc sby_engine_smtbmc.run("cover", job, engine_idx, engine) elif engine[0] == "btor": import sby_engine_btor sby_engine_btor.run("cover", job, engine_idx, engine) else: job.error(f"Invalid engine '{engine[0]}' for cover mode.")