2019-09-05 10:43:22 -05:00
|
|
|
read_verilog <<EOT
|
|
|
|
module peepopt_shiftmul_0 #(parameter N=3, parameter W=3) (input [N*W-1:0] i, input [$clog2(N)-1:0] s, output [W-1:0] o);
|
|
|
|
assign o = i[s*W+:W];
|
|
|
|
endmodule
|
|
|
|
EOT
|
|
|
|
|
|
|
|
prep -nokeepdc
|
2019-09-07 00:48:04 -05:00
|
|
|
equiv_opt -assert peepopt
|
2019-09-05 10:43:22 -05:00
|
|
|
design -load postopt
|
|
|
|
clean
|
|
|
|
select -assert-count 1 t:$shiftx
|
|
|
|
select -assert-count 0 t:$shiftx t:* %D
|
|
|
|
|
|
|
|
####################
|
|
|
|
|
|
|
|
design -reset
|
|
|
|
read_verilog <<EOT
|
|
|
|
module peepopt_shiftmul_1 (output [7:0] y, input [2:0] w);
|
2019-09-13 18:33:18 -05:00
|
|
|
assign y = 1'b1 >> (w * (3'b110));
|
2019-09-05 10:43:22 -05:00
|
|
|
endmodule
|
|
|
|
EOT
|
|
|
|
|
|
|
|
prep -nokeepdc
|
2019-09-07 00:48:04 -05:00
|
|
|
equiv_opt -assert peepopt
|
2019-09-05 10:43:22 -05:00
|
|
|
design -load postopt
|
|
|
|
clean
|
|
|
|
select -assert-count 1 t:$shr
|
2019-09-13 18:33:18 -05:00
|
|
|
select -assert-count 1 t:$mul
|
2019-09-05 10:43:22 -05:00
|
|
|
select -assert-count 0 t:$shr t:$mul %% t:* %D
|
|
|
|
|
|
|
|
####################
|
|
|
|
|
2019-09-13 18:41:10 -05:00
|
|
|
design -reset
|
|
|
|
read_verilog <<EOT
|
|
|
|
module peepopt_shiftmul_2 (input [11:0] D, input [1:0] S, output [11:0] Y);
|
|
|
|
assign Y = D >> (S*3);
|
|
|
|
endmodule
|
|
|
|
EOT
|
|
|
|
|
|
|
|
prep
|
|
|
|
design -save gold
|
|
|
|
peepopt
|
|
|
|
design -stash gate
|
|
|
|
|
|
|
|
design -import gold -as gold peepopt_shiftmul_2
|
|
|
|
design -import gate -as gate peepopt_shiftmul_2
|
|
|
|
|
|
|
|
miter -equiv -make_assert -make_outputs -ignore_gold_x -flatten gold gate miter
|
|
|
|
sat -show-public -enable_undef -prove-asserts miter
|
2019-09-13 20:19:07 -05:00
|
|
|
cd gate
|
2019-09-13 18:41:10 -05:00
|
|
|
select -assert-count 1 t:$shr
|
|
|
|
select -assert-count 1 t:$mul
|
|
|
|
select -assert-count 0 t:$shr t:$mul %% t:* %D
|
|
|
|
|
|
|
|
####################
|
|
|
|
|
2019-09-05 10:43:22 -05:00
|
|
|
design -reset
|
|
|
|
read_verilog <<EOT
|
|
|
|
module peepopt_muldiv_0(input [1:0] i, output [1:0] o);
|
|
|
|
wire [3:0] t;
|
|
|
|
assign t = i * 3;
|
|
|
|
assign o = t / 3;
|
|
|
|
endmodule
|
|
|
|
EOT
|
|
|
|
|
|
|
|
prep -nokeepdc
|
2019-09-07 00:48:04 -05:00
|
|
|
equiv_opt -assert peepopt
|
2019-09-05 10:43:22 -05:00
|
|
|
design -load postopt
|
|
|
|
clean
|
|
|
|
select -assert-count 0 t:*
|
|
|
|
|
|
|
|
####################
|
|
|
|
|
2019-09-11 02:07:17 -05:00
|
|
|
design -reset
|
|
|
|
read_verilog <<EOT
|
|
|
|
module peepopt_dffmuxext_unsigned(input clk, ce, input [1:0] i, output reg [3:0] o);
|
|
|
|
always @(posedge clk) if (ce) o <= i;
|
|
|
|
endmodule
|
|
|
|
EOT
|
|
|
|
|
2019-09-11 02:14:06 -05:00
|
|
|
proc
|
2019-09-11 02:07:17 -05:00
|
|
|
equiv_opt -assert peepopt
|
|
|
|
design -load postopt
|
|
|
|
clean
|
|
|
|
select -assert-count 1 t:$dff r:WIDTH=2 %i
|
|
|
|
select -assert-count 1 t:$mux r:WIDTH=2 %i
|
|
|
|
select -assert-count 0 t:$dff t:$mux %% t:* %D
|
|
|
|
|
|
|
|
####################
|
|
|
|
|
2019-09-05 10:43:22 -05:00
|
|
|
design -reset
|
|
|
|
read_verilog <<EOT
|
|
|
|
module peepopt_dffmuxext_signed(input clk, ce, input signed [1:0] i, output reg signed [3:0] o);
|
|
|
|
always @(posedge clk) if (ce) o <= i;
|
|
|
|
endmodule
|
|
|
|
EOT
|
|
|
|
|
2019-09-11 02:14:06 -05:00
|
|
|
proc
|
2019-09-07 00:50:03 -05:00
|
|
|
equiv_opt -assert peepopt
|
2019-09-05 10:43:22 -05:00
|
|
|
design -load postopt
|
|
|
|
clean
|
|
|
|
select -assert-count 1 t:$dff r:WIDTH=2 %i
|
|
|
|
select -assert-count 1 t:$mux r:WIDTH=2 %i
|
|
|
|
select -assert-count 0 t:$dff t:$mux %% t:* %D
|
2019-09-11 15:22:41 -05:00
|
|
|
|
|
|
|
###################
|
|
|
|
|
|
|
|
design -reset
|
|
|
|
read_verilog <<EOT
|
|
|
|
module peepopt_dffmuxext_const(input clk, ce, input [1:0] i, output reg [5:0] o);
|
|
|
|
always @(posedge clk) if (ce) o <= {1'b0, i[1], 2'b1x, i[0], 1'bz};
|
|
|
|
endmodule
|
|
|
|
EOT
|
|
|
|
|
|
|
|
proc
|
|
|
|
equiv_opt -assert peepopt
|
|
|
|
design -load postopt
|
|
|
|
select -assert-count 1 t:$dff r:WIDTH=2 %i
|
|
|
|
select -assert-count 1 t:$mux r:WIDTH=2 %i
|
|
|
|
select -assert-count 0 t:$dff t:$mux %% t:* %D
|
|
|
|
|
|
|
|
###################
|
|
|
|
|
|
|
|
design -reset
|
|
|
|
read_verilog <<EOT
|
|
|
|
module peepopt_dffmuxext_const_init(input clk, ce, input [1:0] i, (* init=6'b0x00x1 *) output reg [5:0] o);
|
|
|
|
always @(posedge clk) if (ce) o <= {1'b0, i[1], 2'b1x, i[0], 1'bz};
|
|
|
|
endmodule
|
|
|
|
EOT
|
|
|
|
|
|
|
|
proc
|
|
|
|
equiv_opt -assert peepopt
|
|
|
|
design -load postopt
|
2019-10-02 23:26:26 -05:00
|
|
|
select -assert-count 1 t:$dff r:WIDTH=4 %i
|
|
|
|
select -assert-count 1 t:$mux r:WIDTH=4 %i
|
2019-09-11 15:22:41 -05:00
|
|
|
select -assert-count 0 t:$dff t:$mux %% t:* %D
|
2019-09-11 15:36:37 -05:00
|
|
|
|
|
|
|
####################
|
|
|
|
|
|
|
|
design -reset
|
|
|
|
read_verilog <<EOT
|
|
|
|
module peepopt_dffmuxext_unsigned_rst(input clk, ce, rst, input [1:0] i, output reg [3:0] o);
|
|
|
|
always @(posedge clk) if (rst) o <= 0; else if (ce) o <= i;
|
|
|
|
endmodule
|
|
|
|
EOT
|
|
|
|
|
|
|
|
proc
|
|
|
|
equiv_opt -assert peepopt
|
|
|
|
design -load postopt
|
|
|
|
wreduce
|
|
|
|
select -assert-count 1 t:$dff r:WIDTH=2 %i
|
|
|
|
select -assert-count 2 t:$mux
|
|
|
|
select -assert-count 2 t:$mux r:WIDTH=2 %i
|
|
|
|
select -assert-count 0 t:$dff t:$mux %% t:* %D
|
|
|
|
|
|
|
|
####################
|
|
|
|
|
|
|
|
design -reset
|
|
|
|
read_verilog <<EOT
|
|
|
|
module peepopt_dffmuxext_signed_rst(input clk, ce, rstn, input signed [1:0] i, output reg signed [3:0] o);
|
|
|
|
always @(posedge clk) begin
|
|
|
|
if (ce) o <= i;
|
|
|
|
if (!rstn) o <= 4'b1111;
|
|
|
|
end
|
|
|
|
endmodule
|
|
|
|
EOT
|
|
|
|
|
|
|
|
proc
|
|
|
|
equiv_opt -assert peepopt
|
|
|
|
design -load postopt
|
|
|
|
wreduce
|
|
|
|
select -assert-count 1 t:$dff r:WIDTH=2 %i
|
|
|
|
select -assert-count 2 t:$mux
|
|
|
|
select -assert-count 2 t:$mux r:WIDTH=2 %i
|
|
|
|
select -assert-count 0 t:$logic_not t:$dff t:$mux %% t:* %D
|
2019-10-02 19:48:55 -05:00
|
|
|
|
|
|
|
####################
|
|
|
|
|
|
|
|
design -reset
|
|
|
|
read_verilog <<EOT
|
|
|
|
module peepopt_dffmuxext_signed_rst_init(input clk, ce, rstn, input signed [1:0] i, output reg signed [3:0] o);
|
|
|
|
initial o <= 4'b0010;
|
|
|
|
always @(posedge clk) begin
|
|
|
|
if (ce) o <= i;
|
|
|
|
if (!rstn) o <= 4'b1111;
|
|
|
|
end
|
|
|
|
endmodule
|
|
|
|
EOT
|
|
|
|
|
|
|
|
proc
|
2019-10-03 13:11:50 -05:00
|
|
|
# NB: equiv_opt uses equiv_induct which covers
|
|
|
|
# only the induction half of temporal induction
|
|
|
|
# --- missing the base-case half
|
|
|
|
# This makes it akin to `sat -tempinduct-inductonly`
|
|
|
|
# instead of `sat -tempinduct-baseonly` or
|
|
|
|
# `sat -tempinduct` which is necessary for this
|
|
|
|
# testcase
|
2019-10-02 20:12:25 -05:00
|
|
|
#equiv_opt -assert peepopt
|
|
|
|
|
|
|
|
design -save gold
|
|
|
|
peepopt
|
|
|
|
wreduce
|
|
|
|
design -stash gate
|
|
|
|
design -import gold -as gold
|
|
|
|
design -import gate -as gate
|
|
|
|
miter -equiv -flatten -make_assert -make_outputs gold gate miter
|
2019-10-03 13:11:50 -05:00
|
|
|
sat -tempinduct -verify -prove-asserts -show-ports miter
|
2019-10-02 20:12:25 -05:00
|
|
|
|
|
|
|
design -load gate
|
2019-10-02 20:03:45 -05:00
|
|
|
select -assert-count 1 t:$dff r:WIDTH=4 %i
|
2019-10-02 19:48:55 -05:00
|
|
|
select -assert-count 2 t:$mux
|
2019-10-02 20:03:45 -05:00
|
|
|
select -assert-count 2 t:$mux r:WIDTH=4 %i
|
2019-10-02 19:48:55 -05:00
|
|
|
select -assert-count 0 t:$logic_not t:$dff t:$mux %% t:* %D
|