2009-11-19 22:04:21 +00:00
|
|
|
// DESCRIPTION: Verilator: Verilog Test module
|
|
|
|
//
|
|
|
|
// This file ONLY is placed into the Public Domain, for any use,
|
|
|
|
// without warranty, 2009 by Wilson Snyder.
|
|
|
|
|
|
|
|
module t;
|
|
|
|
|
2019-12-03 23:22:17 +00:00
|
|
|
integer p_i; // signal type IData
|
|
|
|
reg [15:0] p_s; // signal type SData
|
|
|
|
reg [7:0] p_c; // signal type CData
|
|
|
|
real p_r; // signal type double
|
2009-11-19 22:04:21 +00:00
|
|
|
reg [7*8:1] p_str;
|
2016-05-17 01:57:49 +00:00
|
|
|
string sv_str;
|
2017-05-19 02:41:43 +00:00
|
|
|
reg [7*8:1] p_in;
|
|
|
|
string sv_in;
|
2009-11-19 22:04:21 +00:00
|
|
|
|
|
|
|
initial begin
|
|
|
|
if ($test$plusargs("PLUS")!==1) $stop;
|
|
|
|
if ($test$plusargs("PLUSNOT")!==0) $stop;
|
|
|
|
if ($test$plusargs("PL")!==1) $stop;
|
|
|
|
//if ($test$plusargs("")!==1) $stop; // Simulators differ in this answer
|
|
|
|
if ($test$plusargs("NOTTHERE")!==0) $stop;
|
|
|
|
|
|
|
|
p_i = 10;
|
|
|
|
if ($value$plusargs("NOTTHERE%d", p_i)!==0) $stop;
|
|
|
|
if (p_i !== 10) $stop;
|
|
|
|
|
2017-05-19 11:20:41 +00:00
|
|
|
p_i = 0;
|
2009-11-19 22:04:21 +00:00
|
|
|
if ($value$plusargs("INT=%d", p_i)!==1) $stop;
|
|
|
|
if (p_i !== 32'd1234) $stop;
|
|
|
|
|
2017-05-19 11:20:41 +00:00
|
|
|
p_i = 0;
|
2009-11-19 22:04:21 +00:00
|
|
|
if ($value$plusargs("INT=%H", p_i)!==1) $stop; // tests uppercase % also
|
|
|
|
if (p_i !== 32'h1234) $stop;
|
|
|
|
|
2017-05-19 11:20:41 +00:00
|
|
|
p_i = 0;
|
|
|
|
// Check octal and WIDTH
|
|
|
|
if (!$value$plusargs("INT=%o", p_i)) $stop;
|
2009-11-19 22:04:21 +00:00
|
|
|
if (p_i !== 32'o1234) $stop;
|
|
|
|
|
2019-12-03 23:22:17 +00:00
|
|
|
// Check handling of 'SData' type signals (Issue #1592)
|
|
|
|
p_s = 0;
|
|
|
|
if (!$value$plusargs("INT=%d", p_s)) $stop;
|
|
|
|
if (p_s !== 16'd1234) $stop;
|
|
|
|
|
|
|
|
// Check handling of 'CData' type signals (Issue #1592)
|
|
|
|
p_c = 0;
|
|
|
|
if (!$value$plusargs("INT=%d", p_c)) $stop;
|
|
|
|
if (p_c !== 8'd210) $stop;
|
|
|
|
|
|
|
|
// Check handling of 'double' type signals (Issue #1619)
|
|
|
|
p_r = 0;
|
|
|
|
if (!$value$plusargs("REAL=%e", p_r)) $stop;
|
|
|
|
$display("r='%e'", p_r);
|
|
|
|
if (p_r !== 1.2345) $stop;
|
|
|
|
|
|
|
|
p_r = 0;
|
|
|
|
if (!$value$plusargs("REAL=%f", p_r)) $stop;
|
|
|
|
$display("r='%f'", p_r);
|
|
|
|
if (p_r !== 1.2345) $stop;
|
|
|
|
|
|
|
|
p_r = 0;
|
|
|
|
if (!$value$plusargs("REAL=%g", p_r)) $stop;
|
|
|
|
$display("r='%g'", p_r);
|
|
|
|
if (p_r !== 1.2345) $stop;
|
|
|
|
|
2017-05-19 02:41:43 +00:00
|
|
|
p_str = "none";
|
2009-11-19 22:04:21 +00:00
|
|
|
if ($value$plusargs("IN%s", p_str)!==1) $stop;
|
|
|
|
$display("str='%s'",p_str);
|
|
|
|
if (p_str !== "T=1234") $stop;
|
|
|
|
|
2017-05-19 02:41:43 +00:00
|
|
|
sv_str = "none";
|
2016-05-17 01:57:49 +00:00
|
|
|
if ($value$plusargs("IN%s", sv_str)!==1) $stop;
|
|
|
|
$display("str='%s'",sv_str);
|
|
|
|
if (sv_str != "T=1234") $stop;
|
|
|
|
|
2018-03-09 04:40:19 +00:00
|
|
|
sv_str = "none";
|
|
|
|
$value$plusargs("IN%s", sv_str);
|
|
|
|
$display("str='%s'",sv_str);
|
|
|
|
if (sv_str != "T=1234") $stop;
|
|
|
|
|
2017-05-19 02:41:43 +00:00
|
|
|
p_in = "IN%s";
|
|
|
|
`ifdef VERILATOR
|
|
|
|
p_in = $c(p_in); // Prevent constant propagation
|
|
|
|
`endif
|
|
|
|
sv_str = "none";
|
|
|
|
if ($value$plusargs(p_in, sv_str)!==1) $stop;
|
|
|
|
$display("str='%s'",sv_str);
|
|
|
|
if (sv_str != "T=1234") $stop;
|
|
|
|
|
|
|
|
sv_in = "INT=%d";
|
|
|
|
`ifdef VERILATOR
|
|
|
|
if ($c1(0)) sv_in = "NEVER"; // Prevent constant propagation
|
|
|
|
`endif
|
|
|
|
p_i = 0;
|
|
|
|
if ($value$plusargs(sv_in, p_i)!==1) $stop;
|
|
|
|
$display("i='%d'",p_i);
|
|
|
|
if (p_i !== 32'd1234) $stop;
|
|
|
|
|
2009-11-19 22:04:21 +00:00
|
|
|
$write("*-* All Finished *-*\n");
|
|
|
|
$finish;
|
|
|
|
end
|
|
|
|
endmodule
|