2020-08-23 12:42:50 +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
|
|
|
|
|
|
|
|
// Methods defined by IEEE:
|
|
|
|
// function int unsigned $urandom [ (int seed ) ] ;
|
|
|
|
// function int unsigned $urandom_range( int unsigned maxval,
|
|
|
|
// int unsigned minval = 0 );
|
|
|
|
|
|
|
|
module t(/*AUTOARG*/);
|
|
|
|
`ifndef VERILATOR
|
|
|
|
`define PROC
|
|
|
|
`endif
|
|
|
|
`ifdef PROC
|
|
|
|
process p;
|
|
|
|
`endif
|
|
|
|
|
|
|
|
int unsigned v1;
|
|
|
|
int unsigned v2;
|
|
|
|
int unsigned v3;
|
|
|
|
string s;
|
|
|
|
|
|
|
|
initial begin
|
|
|
|
`ifdef PROC
|
|
|
|
if (p != null) $stop;
|
|
|
|
p = process::self();
|
|
|
|
`endif
|
|
|
|
|
|
|
|
v1 = $urandom;
|
|
|
|
v2 = $urandom;
|
|
|
|
v3 = $urandom();
|
|
|
|
if (v1 == v2 && v1 == v3) $stop; // Possible, but 2^-64
|
|
|
|
|
|
|
|
// Range
|
2020-12-22 12:52:38 +00:00
|
|
|
v2 = $urandom_range(v1, v1);
|
|
|
|
if (v1 != v2) $stop;
|
|
|
|
|
2021-10-11 12:45:19 +00:00
|
|
|
v2 = $urandom_range(0, 32'hffffffff);
|
|
|
|
if (v2 == v1) $stop;
|
|
|
|
|
2020-08-23 12:42:50 +00:00
|
|
|
for (int test = 0; test < 20; ++test) begin
|
2020-09-22 12:44:51 +00:00
|
|
|
v1 = 2;
|
|
|
|
v1 = $urandom_range(0, v1);
|
2020-12-22 12:52:38 +00:00
|
|
|
if (v1 != 0 && v1 != 1 && v1 != 2) $stop;
|
2020-08-23 12:42:50 +00:00
|
|
|
v1 = $urandom_range(2, 0);
|
2020-12-22 12:52:38 +00:00
|
|
|
if (v1 != 0 && v1 != 1 && v1 !=2) $stop;
|
2020-12-16 23:33:08 +00:00
|
|
|
v1 = $urandom_range(3);
|
2020-12-22 12:52:38 +00:00
|
|
|
if (v1 != 0 && v1 != 1 && v1 != 2 && v1 != 3) $stop;
|
2020-08-23 12:42:50 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
// Seed stability
|
|
|
|
// Note UVM doesn't use $urandom seeding
|
|
|
|
v1 = $urandom(1);
|
|
|
|
v2 = $urandom(1);
|
|
|
|
if (v1 != v2) $stop;
|
|
|
|
v2 = $urandom(1);
|
|
|
|
if (v1 != v2) $stop;
|
|
|
|
|
|
|
|
`ifdef PROC
|
|
|
|
// Seed stability via process.srandom
|
|
|
|
p.srandom(1);
|
|
|
|
v1 = $urandom();
|
|
|
|
p.srandom(1);
|
|
|
|
v2 = $urandom();
|
|
|
|
if (v1 != v2) $stop;
|
|
|
|
p.srandom(1);
|
|
|
|
v2 = $urandom();
|
|
|
|
if (v1 != v2) $stop;
|
|
|
|
|
|
|
|
// Seed stability via process.get_randstate
|
|
|
|
s = p.get_randstate();
|
|
|
|
v1 = $urandom();
|
|
|
|
p.set_randstate(s);
|
|
|
|
v2 = $urandom();
|
|
|
|
if (v1 != v2) $stop;
|
|
|
|
p.set_randstate(s);
|
|
|
|
v2 = $urandom();
|
|
|
|
if (v1 != v2) $stop;
|
|
|
|
`endif
|
|
|
|
|
|
|
|
$write("*-* All Finished *-*\n");
|
|
|
|
$finish;
|
|
|
|
end
|
|
|
|
endmodule
|