|
|
|
|
|
|
|
|
|
|
|
|
Virtual Class
|
|
|
Like in C++, in Systemverilog we can create virtual class for abstract class, this abstract class can contain abstract methods(virtual methods). Virtual methods provide prototypes for subroutines, all of the information generally found on the first line of a method declaration: the encapsulation criteria, the type and number of arguments, and the return type if it is needed. Later, when subclasses override virtual methods, they must follow the prototype exactly. Thus, all versions of the virtual method will look identical in all subclasses. |
|
|
|
|
|
Methods of normal classes can also be declared virtual. In this case, the method must have a body. If the method does have a body, then the class can be instantiated, as can its subclasses. However, if the subclass overrides the virtual method, then the new method must exactly match the superclass¿s prototype. |
|
|
|
|
|
We offen call this abstract virtual class as base objects. |
|
|
|
|
|
|
|
|
|
|
|
Code : virtual class
|
|
|
|
|
|
1 program class_virtual;
2 // Virtual class for body of any driver
3 virtual class verif;
4 // This starts all the threads
5 virtual task startSim();
6 endtask
7 // This stops all the threads
8 virtual task stopSim();
9 endtask
10 // This prints all the stats
11 virtual task printStats();
12 endtask
13 // This check if driver is done or not
14 virtual function bit isDone ();
15 begin
16 isDone = 0;
17 end
18 endfunction
19 // set the driver config
20 virtual task setConfig(integer item, integer value);
21 endtask
22 virtual function integer getConfig(integer item);
23 begin
24 getConfig = 32'hDEAD_BEAF;
25 end
26 endfunction
27 endclass
28 // ethernet inherits verif
29 class ethernet extends verif;
30 integer min_frame_size;
31 integer max_frame_size;
32 function new();
33 begin
34 min_frame_size = 32'h40;
35 max_frame_size = 32'h200;
36 end
37 endfunction
38 task startSim();
39 begin
40 $write("Starting Simulation\n");
41 end
42 endtask
43 task stopSim();
44 begin
45 $write("Stopping Simulation\n");
46 end
47 endtask
48 task printStats();
49 begin
50 $write("Sent normal frames %d\n",100);
51 $write("Sent runt frames %d\n",1);
52 $write("Sent oversize frames %d\n",1);
53 end
54 endtask
55 function bit isDone();
56 begin
57 isDone = 1;
58 end
59 endfunction
60 task setConfig(integer item, integer value);
61 begin
62 case(item)
63 0 : min_frame_size = value;
64 1 : max_frame_size = value;
65 endcase
66 end
67 endtask
68 function integer getConfig(integer item);
69 begin
70 case(item)
71 0 : getConfig = min_frame_size;
72 1 : getConfig = max_frame_size;
73 default : begin
74 $write("Calling super.setConfig\n");
75 getConfig = super.getConfig(item);
76 end
77 endcase
78 end
79 endfunction
80 endclass
81
82 class ethernet2 extends ethernet;
83 integer min_ipg;
84 function new();
85 begin
86 min_ipg = 32'hc;
87 end
88 endfunction
89 task setConfig(integer item, integer value);
90 begin
91 case(item)
92 2 : min_ipg = value;
93 default : begin
94 $write("Calling super.setConfig\n");
95 super.setConfig(item,value);
96 end
97 endcase
98 end
99 endtask
100 function integer getConfig(integer item);
101 begin
102 case(item)
103 2 : getConfig = min_ipg;
104 default : begin
105 $write("Calling super.setConfig\n");
106 getConfig = super.getConfig(item);
107 end
108 endcase
109 end
110 endfunction
111 endclass
112
113
114 initial begin
115 ethernet2 eth = new();
116 eth.setConfig(0,32'h100);
117 eth.setConfig(2,32'h24);
118 $write ("Value of min_frame is %0x\n", eth.getConfig(0));
119 $write ("Value of max_frame is %0x\n", eth.getConfig(1));
120 $write ("Value of min_ipg is %0x\n", eth.getConfig(2));
121 $write ("Value of unknown is %0x\n", eth.getConfig(3));
122
123 eth.startSim();
124 while (eth.isDone() == 0) begin
125 #1 ;
126 end
127 eth.stopSim();
128 eth.printStats();
129 end
130
131 endprogram
You could download file class_virtual.sv here
|
|
|
|
|
|
Simulation : virtual class
|
|
|
|
|
|
Calling super.setConfig
Calling super.setConfig
Value of min_frame is 100
Calling super.setConfig
Value of max_frame is 200
Value of min_ipg is 24
Calling super.setConfig
Calling super.setConfig
Value of unknown is deadbeaf
Starting Simulation
Stopping Simulation
Sent normal frames 100
Sent runt frames 1
Sent oversize frames 1
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Copyright © 1998-2025 |
Deepak Kumar Tala - All rights reserved |
Do you have any Comment? mail me at:deepak@asic-world.com
|
|