verilator/test_regress/t/t_castdyn.v

69 lines
1.2 KiB
Systemverilog
Raw Normal View History

2020-06-06 13:30:11 +00:00
// DESCRIPTION: Verilator: Verilog Test module
//
// This file ONLY is placed under the Creative Commons Public Domain, for
// any use, without warranty, 2020 by Wilson Snyder.
// SPDX-License-Identifier: CC0-1.0
2020-10-24 21:46:09 +00:00
class Base;
endclass
class BasedA extends Base;
endclass
class BasedB extends Base;
endclass
2020-06-06 13:30:11 +00:00
module t (/*AUTOARG*/);
int i;
int a;
2020-10-24 21:46:09 +00:00
int ao;
Base b;
Base bo;
BasedA ba;
BasedA bao;
BasedB bb;
BasedB bbo;
// verilator lint_off CASTCONST
2020-06-06 13:30:11 +00:00
initial begin
2020-10-24 21:46:09 +00:00
a = 1234;
i = $cast(ao, a);
if (i != 1) $stop;
if (ao != 1234) $stop;
2020-11-29 21:58:34 +00:00
2020-10-24 21:46:09 +00:00
a = 12345;
$cast(ao, a);
if (ao != 12345) $stop;
i = $cast(ao, 2.1 * 3.7);
if (i != 1) $stop;
if (ao != 8) $stop;
i = $cast(bo, null);
2020-06-06 13:30:11 +00:00
if (i != 1) $stop;
2020-10-24 21:46:09 +00:00
if (bo != null) $stop;
ba = new;
b = ba;
i = $cast(bao, b);
if (i != 1) $stop;
if (b != ba) $stop;
bb = new;
b = bb;
i = $cast(bbo, b);
if (i != 1) $stop;
if (b != bb) $stop;
bb = new;
2020-10-25 00:30:52 +00:00
b = bb;
bao = ba;
2020-10-24 21:46:09 +00:00
i = $cast(bao, b);
if (i != 0) $stop;
2020-10-25 00:30:52 +00:00
if (bao != ba) $stop; // Unchanged
2020-10-24 21:46:09 +00:00
2020-06-06 13:30:11 +00:00
$write("*-* All Finished *-*\n");
$finish;
end
endmodule