mirror of
https://github.com/YosysHQ/sby.git
synced 2025-04-05 22:14:08 +00:00
handle unreached cover properties
This commit is contained in:
parent
5abaccab69
commit
53eb25fcae
|
@ -455,7 +455,7 @@ def run_task(taskname):
|
|||
|
||||
if not my_opt_tmpdir and not setupmode:
|
||||
with open("{}/{}.xml".format(task.workdir, junit_filename), "w") as f:
|
||||
task.print_junit_result(f, junit_ts_name, junit_tc_name)
|
||||
task.print_junit_result(f, junit_ts_name, junit_tc_name, junit_format_strict=False)
|
||||
|
||||
with open(f"{task.workdir}/status", "w") as f:
|
||||
print(f"{task.status} {task.retcode} {task.total_time}", file=f)
|
||||
|
|
|
@ -756,6 +756,7 @@ class SbyTask:
|
|||
junit_failures = 0
|
||||
else:
|
||||
if self.precise_prop_status:
|
||||
junit_failures = 0
|
||||
for check in checks:
|
||||
if check.status not in self.expect:
|
||||
junit_failures += 1
|
||||
|
@ -777,7 +778,8 @@ class SbyTask:
|
|||
elif check.status == "UNKNOWN":
|
||||
print(f'<skipped />', file=f)
|
||||
elif check.status == "FAIL":
|
||||
print(f'<failure type="{check.type}" message="Property in {check.hierarchy} at {check.location} failed. Trace file: {check.tracefile}" />', file=f)
|
||||
traceinfo = f' Trace file: {check.tracefile}' if check.type == check.Type.ASSERT else ''
|
||||
print(f'<failure type="{check.type}" message="Property {check.type} in {check.hierarchy} at {check.location} failed.{traceinfo}" />', file=f)
|
||||
elif check.status == "ERROR":
|
||||
print(f'<error type="ERROR"/>', file=f) # type mandatory, message optional
|
||||
print(f'</testcase>', file=f)
|
||||
|
|
|
@ -201,6 +201,12 @@ def run(mode, task, engine_idx, engine):
|
|||
last_prop.tracefile = match[1]
|
||||
last_prop = None
|
||||
|
||||
match = re.match(r"^## [0-9: ]+ Unreached cover statement at (\S+) \((\S+)\).", line)
|
||||
if match:
|
||||
cell_name = match[2]
|
||||
prop = task.design_hierarchy.find_property_by_cellname(cell_name)
|
||||
prop.status = "FAIL"
|
||||
|
||||
return line
|
||||
|
||||
def exit_callback(retcode):
|
||||
|
|
31
tests/cover_fail.sby
Normal file
31
tests/cover_fail.sby
Normal file
|
@ -0,0 +1,31 @@
|
|||
[options]
|
||||
mode cover
|
||||
depth 5
|
||||
expect fail
|
||||
|
||||
[engines]
|
||||
smtbmc boolector
|
||||
|
||||
[script]
|
||||
read_verilog -sv test.v
|
||||
prep -top test
|
||||
|
||||
[file test.v]
|
||||
module test(
|
||||
input clk,
|
||||
input rst,
|
||||
output reg [3:0] count
|
||||
);
|
||||
|
||||
initial assume (rst == 1'b1);
|
||||
|
||||
always @(posedge clk) begin
|
||||
if (rst)
|
||||
count <= 4'b0;
|
||||
else
|
||||
count <= count + 1'b1;
|
||||
|
||||
cover (count == 0);
|
||||
cover (count == 4'd11);
|
||||
end
|
||||
endmodule
|
Loading…
Reference in a new issue