2006-08-26 11:35:28 +00:00
|
|
|
// DESCRIPTION: Verilator: Verilog Test module
|
|
|
|
//
|
|
|
|
// This file ONLY is placed into the Public Domain, for any use,
|
|
|
|
// without warranty, 2003 by Wilson Snyder.
|
|
|
|
|
|
|
|
module t;
|
|
|
|
reg [40:0] quad; initial quad = 41'ha_bbbb_cccc;
|
|
|
|
reg [80:0] wide; initial wide = 81'habc_1234_5678_1234_5678;
|
|
|
|
reg [31:0] str; initial str = "\000\277\021\n";
|
|
|
|
reg [47:0] str2; initial str2 = "\000what!";
|
|
|
|
reg [79:0] str3; initial str3 = "\000hmmm!1234";
|
2006-08-30 01:14:29 +00:00
|
|
|
|
|
|
|
sub sub ();
|
|
|
|
sub2 sub2 ();
|
|
|
|
|
2006-08-26 11:35:28 +00:00
|
|
|
initial begin
|
2006-08-30 01:14:29 +00:00
|
|
|
$write("[%0t] In %m: Hi\n", $time);
|
|
|
|
sub.write_m;
|
|
|
|
sub2.write_m;
|
2006-08-26 11:35:28 +00:00
|
|
|
|
2008-03-26 14:58:30 +00:00
|
|
|
// Escapes
|
|
|
|
$display("[%0t] Back \\ Quote \"", $time); // Old bug when \" last on the line.
|
|
|
|
|
2006-08-26 11:35:28 +00:00
|
|
|
// Display formatting
|
|
|
|
$display("[%0t] %%X=%X %%D=%D %%0X=%0X %%0O=%0O %%B=%B", $time,
|
|
|
|
quad[5:0], quad[5:0], quad[5:0], quad[5:0], quad[5:0]);
|
|
|
|
$display("[%0t] %%x=%x %%d=%d %%0x=%0x %%0o=%0o %%b=%b", $time,
|
|
|
|
quad[5:0], quad[5:0], quad[5:0], quad[5:0], quad[5:0]);
|
|
|
|
$display("[%0t] %%x=%x %%0x=%0x %%o=%o %%b=%b", $time,
|
|
|
|
quad, quad, quad, quad);
|
|
|
|
$display("[%0t] %%x=%x %%0x=%0x %%o=%o %%b=%b", $time,
|
|
|
|
wide, wide, wide, wide);
|
|
|
|
$display;
|
|
|
|
// Not testing %0s, it does different things in different simulators
|
|
|
|
$display("[%0t] %%s=%s %%s=%s %%s=%s", $time,
|
|
|
|
str2[7:0], str2, str3);
|
|
|
|
|
2007-06-14 14:24:21 +00:00
|
|
|
$display("[%0t] %s%s%s", $time,
|
2007-06-14 18:34:08 +00:00
|
|
|
"hel", "lo, fr", "om a very long string. Percent %s are literally substituted in.");
|
2007-06-14 14:24:21 +00:00
|
|
|
|
2006-08-26 11:35:28 +00:00
|
|
|
// Str check
|
|
|
|
`ifndef nc // NC-Verilog 5.3 chokes on this test
|
|
|
|
if (str !== 32'h00_bf_11_0a) $stop;
|
|
|
|
`endif
|
|
|
|
$write("*-* All Finished *-*\n");
|
|
|
|
$finish;
|
|
|
|
end
|
|
|
|
endmodule
|
2006-08-30 01:14:29 +00:00
|
|
|
|
|
|
|
module sub;
|
|
|
|
task write_m;
|
2007-03-06 18:53:24 +00:00
|
|
|
begin
|
|
|
|
$write("[%0t] In %m\n", $time);
|
|
|
|
begin : subblock
|
2009-09-11 23:25:42 +00:00
|
|
|
$write("[%0t] In %M\n", $time); // Uppercase %M test
|
2007-03-06 18:53:24 +00:00
|
|
|
end
|
|
|
|
end
|
2006-08-30 01:14:29 +00:00
|
|
|
endtask
|
|
|
|
endmodule
|
|
|
|
|
|
|
|
module sub2;
|
|
|
|
// verilator no_inline_module
|
|
|
|
task write_m;
|
2007-03-06 18:53:24 +00:00
|
|
|
begin
|
|
|
|
$write("[%0t] In %m\n", $time);
|
|
|
|
begin : subblock2
|
|
|
|
$write("[%0t] In %m\n", $time);
|
|
|
|
end
|
|
|
|
end
|
2006-08-30 01:14:29 +00:00
|
|
|
endtask
|
|
|
|
endmodule
|