2024-03-01 04:10:52 -06:00
|
|
|
read_verilog ../common/add_sub.v
|
|
|
|
hierarchy -top top
|
|
|
|
proc
|
2024-07-24 06:29:51 -05:00
|
|
|
equiv_opt -run :prove -map +/nanoxplore/cells_sim.v -map +/nanoxplore/cells_sim_u.v synth_nanoxplore -noiopad
|
2024-05-30 10:29:33 -05:00
|
|
|
opt -full
|
|
|
|
|
|
|
|
miter -equiv -flatten -make_assert -make_outputs gold gate miter
|
|
|
|
sat -verify -prove-asserts -seq 3 -set-init-zero -show-inputs -show-outputs miter
|
2024-03-01 04:10:52 -06:00
|
|
|
design -load postopt # load the post-opt design (otherwise equiv_opt loads the pre-opt design)
|
|
|
|
cd top # Constrain all select calls below inside the top module
|
|
|
|
select -assert-count 2 t:NX_CY
|
|
|
|
select -assert-count 4 t:NX_LUT
|
|
|
|
select -assert-none t:NX_CY t:NX_LUT %% t:* %D
|
|
|
|
|
2024-05-30 10:29:33 -05:00
|
|
|
design -reset
|
|
|
|
read_verilog <<EOT
|
|
|
|
module top
|
|
|
|
(
|
|
|
|
input [5:0] x,
|
|
|
|
input [5:0] y,
|
|
|
|
|
|
|
|
output [5:0] A,
|
|
|
|
input CI,
|
|
|
|
output CO
|
|
|
|
);
|
|
|
|
|
|
|
|
assign {CO, A} = x + y + CI;
|
|
|
|
endmodule
|
|
|
|
EOT
|
|
|
|
|
|
|
|
hierarchy -top top
|
|
|
|
proc
|
2024-07-24 06:29:51 -05:00
|
|
|
equiv_opt -run :prove -map +/nanoxplore/cells_sim.v -map +/nanoxplore/cells_sim_u.v synth_nanoxplore -noiopad
|
2024-05-30 10:29:33 -05:00
|
|
|
opt -full
|
|
|
|
|
|
|
|
miter -equiv -flatten -make_assert -make_outputs gold gate miter
|
|
|
|
sat -verify -prove-asserts -seq 3 -set-init-zero -show-inputs -show-outputs miter
|
|
|
|
|
|
|
|
design -load postopt
|
|
|
|
cd top
|
|
|
|
stat
|
|
|
|
select -assert-count 2 t:NX_CY
|
|
|
|
select -assert-none t:NX_CY %% t:* %D
|
|
|
|
|
|
|
|
design -reset
|
|
|
|
read_verilog <<EOT
|
|
|
|
module top
|
|
|
|
(
|
|
|
|
input [189:0] x,
|
|
|
|
input [189:0] y,
|
|
|
|
|
|
|
|
output [189:0] A
|
|
|
|
);
|
|
|
|
|
|
|
|
assign A = x + y;
|
|
|
|
endmodule
|
|
|
|
EOT
|
|
|
|
|
|
|
|
hierarchy -top top
|
|
|
|
proc
|
2024-07-24 06:29:51 -05:00
|
|
|
equiv_opt -run :prove -map +/nanoxplore/cells_sim.v -map +/nanoxplore/cells_sim_u.v synth_nanoxplore -noiopad
|
2024-05-30 10:29:33 -05:00
|
|
|
opt -full
|
|
|
|
|
|
|
|
miter -equiv -flatten -make_assert -make_outputs gold gate miter
|
|
|
|
sat -verify -prove-asserts -seq 3 -set-init-zero -show-inputs -show-outputs miter
|
|
|
|
|
|
|
|
design -load postopt
|
|
|
|
cd top
|
|
|
|
stat
|
|
|
|
select -assert-count 48 t:NX_CY
|
2024-07-24 06:41:12 -05:00
|
|
|
select -assert-none t:NX_CY %% t:* %D
|