mirror of
https://github.com/YosysHQ/sby.git
synced 2025-04-06 14:24:08 +00:00
Add smtbmc stbv support
This commit is contained in:
parent
b5be4a5759
commit
1c8e006e46
53
sbysrc/demo3.sby
Normal file
53
sbysrc/demo3.sby
Normal file
|
@ -0,0 +1,53 @@
|
||||||
|
[options]
|
||||||
|
depth 10
|
||||||
|
mode bmc
|
||||||
|
|
||||||
|
[engines]
|
||||||
|
smtbmc yices
|
||||||
|
|
||||||
|
[script]
|
||||||
|
read_verilog -formal demo.v
|
||||||
|
prep -top top
|
||||||
|
|
||||||
|
[file demo.v]
|
||||||
|
module top (
|
||||||
|
input clk,
|
||||||
|
input [7:0] addr,
|
||||||
|
input [7:0] wdata,
|
||||||
|
output [7:0] rdata,
|
||||||
|
);
|
||||||
|
const rand reg [7:0] test_addr;
|
||||||
|
reg [7:0] test_data;
|
||||||
|
reg test_valid = 0;
|
||||||
|
|
||||||
|
always @(posedge clk) begin
|
||||||
|
if (addr == test_addr) begin
|
||||||
|
if (test_valid)
|
||||||
|
assert(test_data == rdata);
|
||||||
|
test_data <= wdata;
|
||||||
|
test_valid <= 1;
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
memory uut (
|
||||||
|
.clk (clk ),
|
||||||
|
.addr (addr ),
|
||||||
|
.wdata(wdata),
|
||||||
|
.rdata(rdata)
|
||||||
|
);
|
||||||
|
endmodule
|
||||||
|
|
||||||
|
|
||||||
|
module memory (
|
||||||
|
input clk,
|
||||||
|
input [7:0] addr,
|
||||||
|
input [7:0] wdata,
|
||||||
|
output [7:0] rdata,
|
||||||
|
);
|
||||||
|
reg [7:0] mem [0:255];
|
||||||
|
|
||||||
|
always @(posedge clk)
|
||||||
|
mem[addr] <= wdata;
|
||||||
|
|
||||||
|
assign rdata = mem[addr];
|
||||||
|
endmodule
|
|
@ -314,20 +314,23 @@ class SbyJob:
|
||||||
|
|
||||||
return [task]
|
return [task]
|
||||||
|
|
||||||
if model_name in ["smt2", "smt2_syn", "smt2_nomem", "smt2_syn_nomem"]:
|
if re.match(r"^smt2(_syn)?(_nomem)?(_stbv)?$", model_name):
|
||||||
with open("%s/model/design_%s.ys" % (self.workdir, model_name), "w") as f:
|
with open("%s/model/design_%s.ys" % (self.workdir, model_name), "w") as f:
|
||||||
print("# running in %s/model/" % (self.workdir), file=f)
|
print("# running in %s/model/" % (self.workdir), file=f)
|
||||||
print("read_ilang design.il", file=f)
|
print("read_ilang design.il", file=f)
|
||||||
if model_name in ["smt2_nomem", "smt2_syn_nomem"]:
|
if "_nomem" in model_name:
|
||||||
print("memory_map", file=f)
|
print("memory_map", file=f)
|
||||||
print("opt -keepdc -fast", file=f)
|
print("opt -keepdc -fast", file=f)
|
||||||
if model_name in ["smt2_syn", "smt2_syn_nomem"]:
|
if "_syn" in model_name:
|
||||||
print("techmap", file=f)
|
print("techmap", file=f)
|
||||||
print("opt -fast", file=f)
|
print("opt -fast", file=f)
|
||||||
print("abc", file=f)
|
print("abc", file=f)
|
||||||
print("opt_clean", file=f)
|
print("opt_clean", file=f)
|
||||||
print("stat", file=f)
|
print("stat", file=f)
|
||||||
print("write_smt2 -wires design_%s.smt2" % model_name, file=f)
|
if "_stbv" in model_name:
|
||||||
|
print("write_smt2 -stbv -wires design_%s.smt2" % model_name, file=f)
|
||||||
|
else:
|
||||||
|
print("write_smt2 -wires design_%s.smt2" % model_name, file=f)
|
||||||
|
|
||||||
task = SbyTask(self, model_name, self.model("ilang"),
|
task = SbyTask(self, model_name, self.model("ilang"),
|
||||||
"cd %s/model; %s -ql design_%s.log design_%s.ys" % (self.workdir, self.exe_paths["yosys"], model_name, model_name))
|
"cd %s/model; %s -ql design_%s.log design_%s.ys" % (self.workdir, self.exe_paths["yosys"], model_name, model_name))
|
||||||
|
|
|
@ -23,14 +23,17 @@ def run(mode, job, engine_idx, engine):
|
||||||
smtbmc_opts = []
|
smtbmc_opts = []
|
||||||
nomem_opt = False
|
nomem_opt = False
|
||||||
syn_opt = False
|
syn_opt = False
|
||||||
|
stbv_opt = False
|
||||||
|
|
||||||
opts, args = getopt.getopt(engine[1:], "s:", ["nomem", "syn"])
|
opts, args = getopt.getopt(engine[1:], "s:", ["nomem", "syn", "stbv"])
|
||||||
|
|
||||||
for o, a in opts:
|
for o, a in opts:
|
||||||
if o == "--nomem":
|
if o == "--nomem":
|
||||||
nomem_opt = True
|
nomem_opt = True
|
||||||
elif o == "--syn":
|
elif o == "--syn":
|
||||||
syn_opt = True
|
syn_opt = True
|
||||||
|
elif o == "--stbv":
|
||||||
|
stbv_opt = True
|
||||||
else:
|
else:
|
||||||
assert False
|
assert False
|
||||||
|
|
||||||
|
@ -40,6 +43,7 @@ def run(mode, job, engine_idx, engine):
|
||||||
model_name = "smt2"
|
model_name = "smt2"
|
||||||
if syn_opt: model_name += "_syn"
|
if syn_opt: model_name += "_syn"
|
||||||
if nomem_opt: model_name += "_nomem"
|
if nomem_opt: model_name += "_nomem"
|
||||||
|
if stbv_opt: model_name += "_stbv"
|
||||||
|
|
||||||
if mode == "prove":
|
if mode == "prove":
|
||||||
run("prove_basecase", job, engine_idx, engine)
|
run("prove_basecase", job, engine_idx, engine)
|
||||||
|
|
Loading…
Reference in a new issue