From 945b6990230a2e34164d2bf2f10aa6d4d9d61f34 Mon Sep 17 00:00:00 2001 From: Daniel Kroening Date: Sat, 9 Dec 2023 11:31:20 -0800 Subject: [PATCH] ebmc: test for k-induction with both refuted and proved property --- regression/ebmc/k-induction/k-induction5.desc | 9 ++++++++ regression/ebmc/k-induction/k-induction5.v | 21 +++++++++++++++++++ 2 files changed, 30 insertions(+) create mode 100644 regression/ebmc/k-induction/k-induction5.desc create mode 100644 regression/ebmc/k-induction/k-induction5.v diff --git a/regression/ebmc/k-induction/k-induction5.desc b/regression/ebmc/k-induction/k-induction5.desc new file mode 100644 index 000000000..e29287140 --- /dev/null +++ b/regression/ebmc/k-induction/k-induction5.desc @@ -0,0 +1,9 @@ +CORE +k-induction5.v +--module main --bound 1 --k-induction +^EXIT=10$ +^SIGNAL=0$ +^\[main.property.property1\] .* SUCCESS$ +^\[main.property.property2\] .* FAILURE$ +-- +^warning: ignoring diff --git a/regression/ebmc/k-induction/k-induction5.v b/regression/ebmc/k-induction/k-induction5.v new file mode 100644 index 000000000..8eb68bbbd --- /dev/null +++ b/regression/ebmc/k-induction/k-induction5.v @@ -0,0 +1,21 @@ +module main(); + + reg [31:0] x, y; + wire clk; + + initial x=1; + initial y=1; + + always @(posedge clk) + if(x<1000) begin + x<=x+1; + y<=y+1; + end + + // true, and 1-inductive + always assert property1: x<=1000; + + // false, bound 1 suffices + always assert property2: x!=2; + +endmodule