verilator/test_regress/t/t_force_assign.v

51 lines
1.1 KiB
Systemverilog

// DESCRIPTION: Verilator: Verilog Test module
//
// This file ONLY is placed under the Creative Commons Public Domain
// SPDX-FileCopyrightText: 2026 Antmicro
// SPDX-License-Identifier: CC0-1.0
// verilog_format: off
`define stop $stop
`define checkb(gotv,expv) do if ((gotv) !== (expv)) begin $write("%%Error: %s:%0d: got='b%x exp='b%x\n", `__FILE__,`__LINE__, (gotv), (expv)); `stop; end while(0);
// verilog_format: on
module t;
reg [1:0] a = 0, b = 1;
reg [1:0] r;
initial begin
r = 2'b00;
assign r = 2'b01;
`checkb(r, 2'b01)
r = 2'b00; // ignored
#1;
`checkb(r, 2'b01)
deassign r;
`checkb(r, 2'b01)
r = 2'b00;
`checkb(r, 2'b00)
assign r = a;
`checkb(r, 2'b00)
a = 2'b01;
`checkb(r, 2'b01)
a = 2'b00;
`checkb(r, 2'b00)
force r = a + b;
a = 2'b00;
b = 2'b00;
#1;
`checkb(r, 2'b00)
a = 2'b01;
b = 2'b01;
#1;
`checkb(r, 2'b10)
assign r = b; // covered
r = 2'b11; // ignored
`checkb(r, 2'b10)
release r;
`checkb(r, 2'b01)
b = 2'b00;
`checkb(r, 2'b00)
$finish;
end
endmodule