

▷ Home(/) / SystemVerilog / 5. Classes & OOP

/ SystemVerilog Abstract Class

# SystemVerilog Abstract Class

- Syntax ([/systemverilog/systemverilog-abstract-class#syntax](#))
- Normal Class ([/systemverilog/systemverilog-abstract-class#normal-class-example](#))
- Abstract Class ([/systemverilog/systemverilog-abstract-class#abstract-class-example](#))
- Extending Abstract Classes ([/systemverilog/systemverilog-abstract-class#extending-abstract-classes](#))
- Pure Virtual Methods ([/systemverilog/systemverilog-abstract-class#pure-virtual-methods](#))
- Pure Method Example ([/systemverilog/systemverilog-abstract-class#pure-method-example](#))

SystemVerilog prohibits a class declared as `virtual` to be directly instantiated and is called an *abstract* class.

# Syntax

---

```
1 | virtual class <class_name>
2 |     // class definition
3 | endclass
```

However, this class can be extended to form other subclasses which can then be instantiated. This is useful to enforce testcase developers to always extend a base class to form another class for their needs. So *base* classes are usually declared as `virtual` although it is not mandatory.

## Normal Class Example

---

```
1 | class BaseClass;
2 |     int data;
3 |
4 |     function new();
5 |         data = 32'hc0de_c0de;
6 |     endfunction
7 | endclass
8
9 module tb;
10    BaseClass base;
11    initial begin
12        base = new();
13        $display ("data=%0h", base.data);
14    end
15 endmodule
```

- OUTPUT

```
ncsim> run
data=0xc0dec0de
ncsim: *W,RNQUIE: Simulation is complete.
```

# Abstract Class Example

Let us declare the class **BaseClass** as **virtual** to make it an *abstract* class and see what happens.

```
1 virtual class BaseClass;
2     int data;
3
4     function new();
5         data = 32'hc0de_c0de;
6     endfunction
7 endclass
8
9 module tb;
10    BaseClass base;
11    initial begin
12        base = new();
13        $display ("data=0x%0h", base.data);
14    end
15 endmodule
```

A compilation error is reported by the simulator as shown below since abstract classes are not allowed to be instantiated.

-  **OUTPUT**

```
base = new();
|
ncvlog: *E,CNIABC (testbench.sv,12|5): An
abstract (virtual) class cannot be instantiated.
```

➤ Click to try  
this example in a  
simulator!

([https://www.edaplayground.com/x/5\\_mR](https://www.edaplayground.com/x/5_mR))

# Extending Abstract Classes

Abstract classes can be extended just like any other SystemVerilog class using the `extends` keyword like shown below.

```
1 virtual class BaseClass;
2     int data;
3
4     function new();
5         data = 32'hc0de_c0de;
6     endfunction
7 endclass
8
9 class ChildClass extends BaseClass;
10    function new();
11        data = 32'hfade_fade;
12    endfunction
13 endclass
14
15 module tb;
16     ChildClass child;
17     initial begin
18         child = new();
19         $display ("data=%0h", child.data);
20     end
21 endmodule
```

It can be seen from the simulation output below that it is perfectly valid to extend abstract classes to form other classes that can be instantiated using `new()` method.

-  OUTPUT

```
ncsim> run
data=0xfadefade
ncsim: *W,RNQUIE: Simulation is complete.
```

➤ Click to try this example in a simulator! (<https://www.edaplayground.com/x/3B9K>)

## Pure Virtual Methods

A `virtual` method inside an abstract class can be declared with the keyword `pure` and is called a *pure virtual* method. Such methods only require a prototype to be specified within the abstract class and the implementation is left to be defined within the sub-classes.

## Pure Method Example

```
1  virtual class BaseClass;
2      int data;
3
4      pure virtual function int getData();
5  endclass
6
7  class ChildClass extends BaseClass;
8      virtual function int getData();
9          data = 32'hcafe_cafe;
10         return data;
11     endfunction
12 endclass
13
14 module tb;
15     ChildClass child;
16     initial begin
17         child = new();
18         $display ("data = 0x%0h", child.getData());
19     end
20 endmodule
```

The pure virtual method prototype and its implementation should have the same arguments and return type.

-  OUTPUT

```
ncsim> run  
data = 0xcafecafe  
ncsim: *W,RNQUIE: Simulation is complete.
```

➤ Click to try  
this example in a  
simulator!

(<https://www.edaplayground.com/x/3SWh>)

## INTERVIEW QUESTIONS

- > SystemVerilog (/systemverilog/systemverilog-interview-questions-set-1)
  - > Interview Set 1 (/systemverilog/systemverilog-interview-questions-set-2)
  - > Interview Set 2 (/systemverilog/systemverilog-interview-questions-set-3)
  - > Interview Set 3 (/systemverilog/systemverilog-interview-questions-set-4)
  - > Interview Set 4 (/systemverilog/systemverilog-interview-questions-set-5)

## Verification Guide

# Abstract Class in SystemVerilog

## Abstract Class

### Table of Contents



#### 1. Abstract Class

##### 1.1. Abstract class Syntax

##### 1.2. Abstract Class Examples

###### 1.2.1. Instantiating virtual class

###### 1.2.2. Deriving virtual class

SystemVerilog class declared with the keyword `virtual` is referred to as an *abstract class*.

- An abstract class sets out the prototype for the sub-classes.
- An abstract class cannot be instantiated, it can only be derived.
- An abstract class can contain methods for which there are only a prototype and no implementation, just a method declaration.



# Abstract class Syntax

```
virtual class abc;  
    //Class definatoin  
endclass
```

## Abstract Class Examples

### Instantiating virtual class

In the below example, Creating an object of a virtual class. An abstract class can only be derived, creating an object of a virtual class leads to a compilation error.

```
//abstract class  
virtual class packet;  
    bit [31:0] addr;  
endclass  
module virtual_class;  
    initial begin  
        packet p;  
        p = new();  
    end  
endmodule
```

### Simulator Output

```
virtual_class, "p = new();"  
Instantiation of the object 'p' can not be done because its type  
'packet' is  
an abstract base class.  
Perhaps there is a derived class that should be used.
```

Click to execute on  EDA playground

## Deriving virtual class

In the below example, An abstract class is derived and written extend the class and creating it.

```
//abstract class
virtual class packet;
    bit [31:0] addr;
endclass

class extended_packet extends packet;
    function void display;
        $display("Value of addr is %0d", addr);
    endfunction
endclass

module virtual_class;
    initial begin
        extended_packet p;
        p = new();
        p.addr = 10;
        p.display();
    end
endmodule
```

### Simulator Output

```
Value of addr is 10
```

Click to execute on



◀ Previous

Next ▶

## Verification Guide

# SystemVerilog Virtual Method

## Virtual Methods in SystemVerilog

### Table of Contents



|                                                                  |
|------------------------------------------------------------------|
| <a href="#"><u>1. Virtual Methods in SystemVerilog</u></a>       |
| <a href="#"><u>1.1. Virtual Methods,</u></a>                     |
| <a href="#"><u>    1.1.1. Virtual Functions</u></a>              |
| <a href="#"><u>    1.1.2. Virtual Task</u></a>                   |
| <a href="#"><u>1.2. About Virtual Method</u></a>                 |
| <a href="#"><u>    1.2.1. Virtual function syntax</u></a>        |
| <a href="#"><u>    1.2.2. Virtual task syntax</u></a>            |
| <a href="#"><u>1.3. Virtual Method Examples</u></a>              |
| <a href="#"><u>    1.3.1. Method without virtual keyword</u></a> |
| <a href="#"><u>    1.3.2. A method with virtual keyword</u></a>  |

SystemVerilog Methods declared with the keyword *virtual* are referred to as virtual methods.

## Virtual Methods,

- Virtual Functions
- Virtual Tasks

## Virtual Functions

A function declared with a virtual keyword before the function keyword is referred to as virtual Function

## Virtual Task

Task declared with a virtual keyword before the task keyword is referred to as virtual task

## About Virtual Method

In a virtual method,

If the base\_class handle is referring to the extended class, then the extended class method handle will get assigned to the base class handle.

In the below explanation, extended\_class is an extended class of base\_class.

```
base_class      b_c;
```

```
extended_class e_c;
```

Considering both the class's has the method display().

assigning e\_c to b\_c,

```
b_c = e_c;
```

On calling b\_c.display()

- if display() method in base\_class is virtual, then extended class display method will get called
- if display() method in base\_class is non-virtual, then base class display method will get called

## Virtual function syntax

```
virtual function function_name;  
    //Function definition  
endfunction
```

## Virtual task syntax

```
virtual task task_name;  
    //task definition  
endtask
```

## Virtual Method Examples

### Method without virtual keyword

In the below example,

the method inside the base class is declared without a virtual keyword, on calling method of the base class which is pointing to the extended class will call the base class method.

```
class base_class;  
  
    function void display;  
        $display("Inside base_class");  
    endfunction  
  
endclass  
  
class extended_class extends base_class;  
  
    function void display;  
        $display("Inside extended class");  
    endfunction
```

```
endclass

module virtual_class;
initial begin
    base_class      b_c;
    extended_class e_c;

    e_c = new();
    b_c = e_c;

    b_c.display();
end
endmodule
```

## Simulator Output

```
Inside base_class
```

Click to execute on  EDA playground

## A method with virtual keyword

In the below example, the method inside the base class is declared with a virtual keyword, on calling method of the base class which is pointing to an extended class will call the extended class method.

```
class base_class;

    virtual function void display;
        $display("Inside base_class");
    endfunction

endclass

class extended_class extends base_class;
```

```
function void display;
    $display("Inside extended_class");
endfunction

endclass

module virtual_class;
initial begin
    base_class      b_c;
    extended_class e_c;

    e_c = new();
    b_c = e_c;

    b_c.display();
end
endmodule
```

## Simulator Output

```
Inside extended_class
```

Click to execute on  EDA playground

◀ Previous

Next ▶