2023-11-12 01:20:37 +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
|
|
|
|
|
|
|
|
class Packet;
|
|
|
|
rand int header; // 0..7
|
|
|
|
rand int length; // 0..15
|
|
|
|
rand int sublength; // 0..15
|
|
|
|
rand bit if_4;
|
|
|
|
rand bit iff_5_6;
|
2024-05-10 10:37:19 +00:00
|
|
|
rand bit if_state_ok;
|
2023-11-12 01:20:37 +00:00
|
|
|
|
|
|
|
rand int array[2]; // 2,4,6
|
|
|
|
|
2024-05-10 10:37:19 +00:00
|
|
|
string state;
|
|
|
|
|
2023-11-12 01:20:37 +00:00
|
|
|
constraint empty {}
|
|
|
|
|
|
|
|
constraint size {
|
|
|
|
header > 0 && header <= 7;
|
|
|
|
length <= 15;
|
|
|
|
length >= header;
|
|
|
|
length dist { [0:1], [2:5] :/ 2, 6 := 6, 7 := 10, 1};
|
|
|
|
}
|
|
|
|
|
|
|
|
constraint ifs {
|
|
|
|
if (header > 4) {
|
|
|
|
if_4 == '1;
|
|
|
|
}
|
|
|
|
if (header == 5 || header == 6) {
|
|
|
|
iff_5_6 == '1;
|
|
|
|
} else {
|
|
|
|
iff_5_6 == '0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
constraint arr_uniq {
|
|
|
|
foreach (array[i]) {
|
|
|
|
array[i] inside {2, 4, 6};
|
|
|
|
}
|
2024-03-19 12:22:39 +00:00
|
|
|
unique { array[0], array[1] };
|
2023-11-12 01:20:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
constraint order { solve length before header; }
|
|
|
|
|
|
|
|
constraint dis {
|
|
|
|
soft sublength;
|
|
|
|
disable soft sublength;
|
|
|
|
sublength <= length;
|
|
|
|
}
|
|
|
|
|
2024-05-10 10:37:19 +00:00
|
|
|
constraint meth {
|
|
|
|
if (strings_equal(state, "ok"))
|
|
|
|
if_state_ok == '1;
|
|
|
|
}
|
|
|
|
|
|
|
|
function bit strings_equal(string a, string b);
|
|
|
|
return a == b;
|
|
|
|
endfunction
|
|
|
|
|
2023-11-12 01:20:37 +00:00
|
|
|
endclass
|
|
|
|
|
|
|
|
module t (/*AUTOARG*/);
|
|
|
|
|
|
|
|
Packet p;
|
|
|
|
|
|
|
|
initial begin
|
|
|
|
// Not testing use of constraints
|
|
|
|
$write("*-* All Finished *-*\n");
|
|
|
|
$finish;
|
|
|
|
end
|
|
|
|
endmodule
|