3
0
Fork 0
mirror of https://github.com/YosysHQ/sby.git synced 2025-04-05 22:14:08 +00:00
sby/tests/unsorted/floor_divmod.sby
2022-05-25 03:35:21 -07:00

46 lines
566 B
Plaintext

[options]
mode bmc
depth 1
[engines]
smtbmc
[script]
read_verilog -icells -formal test.v
prep -top top
[file test.v]
module top;
wire [7:0] a = $anyconst, b = $anyconst, fdiv, fmod, a2;
assign a2 = b * fdiv + fmod;
\$divfloor #(
.A_WIDTH(8),
.B_WIDTH(8),
.A_SIGNED(1),
.B_SIGNED(1),
.Y_WIDTH(8),
) fdiv_m (
.A(a),
.B(b),
.Y(fdiv)
);
\$modfloor #(
.A_WIDTH(8),
.B_WIDTH(8),
.A_SIGNED(1),
.B_SIGNED(1),
.Y_WIDTH(8),
) fmod_m (
.A(a),
.B(b),
.Y(fmod)
);
always @* begin
assume(b != 0);
assert(a == a2);
end
endmodule