-
Notifications
You must be signed in to change notification settings - Fork 0
/
eth_pck.sv
39 lines (32 loc) · 888 Bytes
/
eth_pck.sv
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
class eth_pkt; // definition
// property declaration
rand bit [55:0] preamble;
bit [7:0] sof; // without the rand keyord randmize function wont take values
rand bit [47:0] mac_d;
rand bit[47:0] mac_s;
rand bit [15:0] length;
rand bit[7:0] payload [$]; // dynmaic in size
rand bit[31:0] crc;
//methods
function print();
$display("Printing Ethernet Pcaket");
$display("premable =%0h",premable);
$display("start of frame =%0h",sof);
$display("mac destination =%0h",mac_d);
$display("mac source =%0h",mac_s);
$display("length =%0h",length);
$display("payload =%p",payload);
$display("crc =%0h",crc);
endfunction
//constraints
constraint payload1{ payload.size() == length;
}
endclass
module top;
eth_pkt m; //creating handle
initial begin
m=new(); // allocating memory
m.randomize();
m.print();
end
endmodule