2012-06-03 12:20:12 +00:00
|
|
|
// DESCRIPTION: Verilator: Verilog Test module
|
|
|
|
//
|
|
|
|
// This file ONLY is placed into the Public Domain, for any use,
|
|
|
|
// without warranty, 2010 by Wilson Snyder.
|
|
|
|
|
2018-05-08 00:42:28 +00:00
|
|
|
`define STRINGIFY(x) `"x`"
|
|
|
|
|
2012-06-03 12:20:12 +00:00
|
|
|
module t (/*AUTOARG*/
|
|
|
|
// Outputs
|
|
|
|
out,
|
|
|
|
// Inputs
|
|
|
|
in
|
|
|
|
);
|
|
|
|
|
|
|
|
input in; // inputs don't get flagged as undriven
|
|
|
|
output out; // outputs don't get flagged as unused
|
|
|
|
|
|
|
|
sub sub ();
|
|
|
|
|
|
|
|
// Check we don't warn about unused UDP signals
|
|
|
|
udp_mux2 udpsub (out, in, in, in);
|
|
|
|
|
|
|
|
// Check ignoreds mark as used
|
2018-10-27 14:03:28 +00:00
|
|
|
reg sysused;
|
2012-06-03 12:20:12 +00:00
|
|
|
initial $bboxed(sysused);
|
|
|
|
|
|
|
|
// Check file IO. The fopen is the "driver" all else a usage.
|
|
|
|
integer infile;
|
|
|
|
integer outfile;
|
|
|
|
initial begin
|
2018-05-08 00:42:28 +00:00
|
|
|
outfile = $fopen({`STRINGIFY(`TEST_OBJ_DIR),"/open.log"}, "w");
|
2012-06-03 12:20:12 +00:00
|
|
|
$fwrite(outfile, "1\n");
|
|
|
|
$fclose(outfile);
|
2018-05-08 00:42:28 +00:00
|
|
|
infile = $fopen({`STRINGIFY(`TEST_OBJ_DIR),"/open.log"}, "r");
|
2012-06-03 12:20:12 +00:00
|
|
|
if ($fgetc(infile) != "1") begin end
|
|
|
|
end
|
|
|
|
|
|
|
|
wire _unused_ok;
|
|
|
|
|
|
|
|
endmodule
|
|
|
|
|
|
|
|
module sub;
|
|
|
|
|
|
|
|
wire pub /*verilator public*/; // Ignore publics
|
|
|
|
|
|
|
|
localparam THREE = 3;
|
|
|
|
|
|
|
|
endmodule
|
|
|
|
|
|
|
|
primitive udp_mux2 (q, a, b, s);
|
|
|
|
output q;
|
|
|
|
input a, b, s;
|
|
|
|
table
|
|
|
|
//a b s : out
|
|
|
|
1 ? 0 : 1 ;
|
|
|
|
0 ? 0 : 0 ;
|
|
|
|
? 1 1 : 1 ;
|
|
|
|
? 0 1 : 0 ;
|
|
|
|
0 0 x : 0 ;
|
|
|
|
1 1 x : 1 ;
|
|
|
|
endtable
|
|
|
|
endprimitive
|