

# **MOSCHIP INSTITUTE OF SILICON SYSTEMS (M-ISS)**

## **VERIFICATION PLAN TRANSMITTER (ETHERNET\_IP\_CORE)**

**BY  
BATCH\_02.**

**M.DEVENDRA GOWD(M-ISSDV06 15)  
L.NAGA LAKSHMI(M-ISSDV06 30)  
O.AISHWARYA(M-ISSDV06 35)  
B.SRIDHAR(M-ISSDV06 01)**

|                                        |           |
|----------------------------------------|-----------|
| 1. INTRODUCTION :                      | 3         |
| 2.FEATURES OF ETHERNET :               | 5         |
| 2.1 FEATURES                           | 5         |
| 2.2 RX PATH                            | 5         |
| <b>3.MERITS &amp; DEMERITS :</b>       | <b>6</b>  |
| 3.1 MERITS :                           | 6         |
| 3.2 DEMERITS :                         | 6         |
| 4. PIN DIAGRAM :                       | 7         |
| 4.1 SIGNAL DESCRIPTION:                | 7         |
| 4.2.ARCHITECTURE OF RX:                | 10        |
| <b>5. UVM VERIFICATION ENVIRONMENT</b> | <b>11</b> |
| <b>5.1 TOP MODULE</b>                  | <b>12</b> |
| <b>5.2 TEST CLASS</b>                  | <b>14</b> |
| <b>5.3 TOP ENVIRONMENT</b>             | <b>17</b> |
| 5.3.1 HOST ENVIRONMENT                 | 18        |
| 5.3.1.1 HOST ACTIVE AGENT CLASS        | 19        |
| 5.3.1.1.1 HOST SEQUENCER CLASS         | 20        |
| 5.3.1.1.2 HOST DRIVER CLASS            | 21        |
| 5.3.1.2 MEMORY ACTIVE AGENT CLASS      | 22        |
| 5.3.1.2.1 MEMORY SEQUENCER CLASS       | 23        |
| 5.3.1.2.2 MEMORY DRIVER CLASS          | 24        |
| 5.3.1.3 PASSIVE AGENT CLASS            | 25        |
| 5.3.1.3.1 RX OUTPUT MONITOR CLASS      | 26        |
| 5.3.1.3.2 SEQUENCE CLASS               | 28        |
| 5.3.2 MAC ENVIRONMENT                  | 29        |
| 5.3.2.1 ACTIVE AGENT CLASS             | 30        |
| 5.3.2.1.1 SEQUENCER CLASS              | 31        |
| 5.3.2.1.2 DRIVER CLASS                 | 32        |
| 5.3.2.1.3 INPUT MONITOR CLASS          | 33        |
| 5.3.2.1.4 COVERAGE CLASS               | 35        |
| 5.3.2.1.5 SEQUENCE_ITEM CLASS          | 36        |
| 5.3.2.1.6 SEQUENCE CLASS               | 36        |
| 5.4 INTERFACE                          | 37        |
| 6. RX FLOW OF OPERATION                | 40        |

## 1. INTRODUCTION :

We know that the OSI MODEL of a networking system includes seven layers like physical, data link, network, transport, session, presentation, and applications where each layer has some protocols. So, the first two layers in the OSI model like the physical layer and data link layer have a very popular set of Ethernet protocols. **Ethernet protocol** is available around us in various forms but the present Ethernet can be defined through the IEEE 802.3 standard. So, in this discussion we are verifying an Ethernet protocol working.

LAN networks are built on Ethernet. It is limited to the OSI model's layers 1 and 2 specifications. It is a subnet that allows other protocols, like the TCP/IP suite, to function; it is not a full network protocol.

### **The data link layer:**

First Off To send messages, packet switching is employed. The primary use of packet switching is in computer-to-computer communication. A random amount of data is not transferred continuously over computer networks.

Rather, the data is transferred in discrete packets and small blocks by the network system. For this reason, packet switching networks are another name for computer networks.

### **MAC address:**

Each station on a LAN's common transmission medium needs to have a distinct address. Each participant is assigned an Ethernet address, which is a MAC address (Medium Access Control Address), a physical address specific to the network device. Every network card manufacturer assigns a unique address number to each card, which is kept in the ROM of the device.

The 48 bits (6 bytes) that make up the MAC address are split into two groups of three bytes each. The first 24 bits make up an XEROX-issued manufacturing number. 6196302 manufacturing numbers are possible. For instance, Phoenix Contact's manufacturing number is 00A065h.

A serial number is formed by the lowest 24 bits. Each MAC address needs to be distinct.

### **The Ethernet dataframe:**

The packet fields depicted in the figure are: Preamble, Start Frame Delimiter (SFD), destination and source addresses of the MAC frame, length or type field indicating the protocol type or length of the next field containing the MAC client data, field containing any necessary padding, and Frame Check Sequence (FCS) field containing a cyclic redundancy check value to detect errors in a received MAC frame.

If necessary, an Extension field is added (only for 1000 Mb/s half duplex operation). With the exception of the MAC Client Data, Pad, and Extension fields, which may include an integer number of octets between the minimum and maximum values that are established, all of these fields have a fixed size.

## 2.FEATURES OF ETHERNET :

### 2.1 FEATURES

- The very important function of ethernet is filling the physical layer by sending and receiving the serial bit streams over the medium.
- In this project we are framing a packet in TX path and deframing a packet in the RX path.
- In this we are using a packet switching method to send and receive data between two computer communications.
- This ethernet is mainly controlled by the signals like APB slave/master (Host),MAC interface signal,Reset signal.
- In this spec we configure different registers through which we can make data very stable and concurrent data transmission between layers.
- This protocol works on Half duplex mode for current specification
- This ethernet IP core consists of five modules like host interface,TX/RX module,MII management module.
- This majorly works on packet transmission and error detection from data link to physical layer and Frame reception from physical to data link layer.

## 2.2 RX PATH

- We can generate packets on the physical layer and pass through MRxD of the ethernet ip core using MRxCLK.
- This packet passes through the MAC.
- At the end, the frame will be stored in the memory using m\_pwdata.

## 3.MERITS & DEMERITS :

### 3.1 MERITS :

- The cost is relatively low.
- The system is compatible with older versions.
- It is generally resistant to noise.
- The quality of data transfer is good. It has a high speed.
- The system is reliable.
- Data security is ensured as it is compatible with common firewalls.

### 3.2 DEMERITS :

- Intended for more compact networks over shorter distances.
- Restricted capacity to move.
- The utilisation of lengthier cables may give rise to interference between signals.
- Performance is suboptimal when handling real-time or interactive applications.
- Transmission rates diminish as network traffic intensifies.
- Receivers do not confirm the successful receipt of data packets.
- Diagnosing issues becomes arduous when attempting to identify the precise cable or node responsible for the problem.

## 4. PIN DIAGRAM :

### 4.1 SIGNAL DESCRIPTION:



|             |    |        |                                                                                                                                                                               |
|-------------|----|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| prstn_i     | 1  | INPUT  | This signal is used to set default values.                                                                                                                                    |
| paddr_i     | 32 | INPUT  | Address Input                                                                                                                                                                 |
| pwdata_i    | 32 | INPUT  | Data Input                                                                                                                                                                    |
| prdata_o    | 32 | OUTPUT | Data Output                                                                                                                                                                   |
| psel_i      | 1  | INPUT  | Slave Select Input                                                                                                                                                            |
| pwrite_i    | 1  | INPUT  | shows a read cycle when asserted low and a write cycle when asserted high.                                                                                                    |
| penable_i   | 1  | INPUT  | A legitimate transfer cycle is indicated by the indicator "Enable Input.                                                                                                      |
| pready_o    | 1  | OUTPUT | Peripheral ready Output.                                                                                                                                                      |
| int_o       | 1  | OUTPUT | Interrupt Output: This signal contains a 1 after each BD transmission or receipt. The user should clear this interrupt and keep separate counters for good and faulty frames. |
| m_paddr_o   | 32 | OUTPUT | Address Output                                                                                                                                                                |
| m_prdata_i  | 32 | INPUT  | Data Input                                                                                                                                                                    |
| m_pwdata_o  | 32 | OUTPUT | Data Output                                                                                                                                                                   |
| m_psel_o    | 1  | OUTPUT | Slave Select Output                                                                                                                                                           |
| m_pwrite_o  | 1  | OUTPUT | When asserted high, the Write Output indicates a Write Cycle; when asserted low, it indicates a Read Cycle.                                                                   |
| m_penable_o | 1  | OUTPUT | Enable Output marks the start of a legitimate transfer cycle.                                                                                                                 |
| m_pready_i  | 1  | INPUT  | Acknowledgment Input                                                                                                                                                          |

| PORT      | WIDTH | DIRECTION | DESCRIPTION                                                                                                                                                                                                                                       |
|-----------|-------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MTxClk    | 1     | INPUT     | This Sends a Nibble or Symbol Clock through. The MTxClk signal is supplied by the PHY. It runs at either 2.5 MHz (10 Mbps) or 25 MHz (100 Mbps) in frequency. The timing reference for the transfer of MTxD[3:0], MtxEn, and MTxErr is the clock. |
| MTxD[3:0] | 6     | OUTPUT    | This pin Sends Data Nibble through. Bits of data are transmitted as signals.<br>They are in sync with MTxClk's rising edge. PHY acknowledges the MTxD when MtxEn is asserted.                                                                     |

|           |   |        |                                                                                                                                                                                                                                                                                                                                                                                |
|-----------|---|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MTxEn     | 1 | OUTPUT | Send enabling. This signal, when asserted, tells the PHY that the data MTxD[3:0] is legitimate and that the transmission may begin. The first tidbit of the preamble begins the transmission. Until the PHY receives all of the nibbles that need to be transmitted, the signal is still asserted. It deasserts after the last nibble of a frame, before the first MTxClock.   |
| MTxErr    | 1 | OUTPUT | Send Error Coding. This signal indicates that there has been a transmit coding error by causing the PHY to transmit one or more symbols that are not part of the valid data or delimiter set somewhere in the frame being transmitted when asserted for one MTxClock clock period while MTxEn is also asserted. It is a pulse, MTxErr.                                         |
| MRxClk    | 1 | INPUT  | Acquire the Symbol Clock or Nibble. The MRxClk signal is supplied by the PHY. It runs at either 2.5 MHz (10 Mbps) or 25 MHz (100 Mbps) in frequency. The clock is used as a timing reference for the reception of MRxD[3:0], MRxDV, and MRxErr.                                                                                                                                |
| MRxDV     | 1 | INPUT  | Obtain Valid Data. In order to let the Rx MAC know that it is presenting the legitimate nibbles on the MRxD[3:0] signals, the PHY asserts this signal. Synchronously, the signal is asserted to the MRxClk. From the first recovered nibble of the frame to the last recovered nibble, MRxDV is claimed. After the last nibble, it is then deasserted before the first MRxClk. |
| MRxD[3:0] | 6 | INPUT  | Get Data Nibble here. These signals are the nibbles of received data. They are in sync with MRxClk's rising edge.<br>The PHY transmits a data nibble to the Rx MAC upon assertion of MRxDV. Seven bytes of a preamble and a fully formed SFD need to be passed across the interface in order for the frame to be correctly interpreted.                                        |
| MRxErr    | 1 | INPUT  | Error Received. In order to notify the Rx MAC that a media error was discovered during the transmission of the current frame, the PHY asserts this signal. MRxErr is asserted for one or more MRxClk clock periods before being deasserted. It operates synchronously with the MRxClk. It is a pulse, MRxErr.                                                                  |

|      |   |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|---|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MCrS | 1 | INPUT | <p>Sense of Carrier. When the medium is detected to be in a non-idle state (non idle state- HalfDuplex Tx/Rx), the PHY asynchronously asserts the carrier sense MCrS signal. This signal deasserts to indicate that the media is in an idle state, at which point the transmission can begin.</p> <p>Note: The MAC must ensure that MCrS = 0 (zero denotes an idle state of the medium) in order to initiate the Half Duplex Tx/Rx mode.</p> <p>After the data is available on the channel, PHY must ensure that MCrS = 1 remains at 1, as MAC bears no responsibility for this and may exhibit unexpected behaviour.</p> |
|------|---|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 4.2.ARCHITECTURE OF RX:



## 5. UVM VERIFICATION ENVIRONMENT

### RX\_ENVIRONMENT





## 5.1 TOP MODULE



**Fig:5.1 TOP MODULE**

### DESCRIPTION:

- In the top module we are going to import the uvm inbuilt macros and package.
- Clock generation will take place in top module

- Creating the handles for rx\_test class and interface
- Instantiating the DUT in the top module by order or by the name.
- Setting the config\_db and config\_class inside the initial begin, and then using the run.test() command to execute the test.

## 5.2 TEST CLASS



**Fig:5.2 TEST CLASS****DESCRIPTION:**

- Creating the test class and Extending the class from the uvm\_test class which is the base class.
- Factory registration using uvm macros (`uvm\_component\_utils(test)).
- Declaring the handles for Rx\_environment class and all the sequence classes which are used to generate the stimulus.
- Constructing the memory for class components using a function new method.
- In the build phase creating the memory for above declaring class handles by using create method.
- In the run phase, after raise\_objection, we start the sequence using the start keyword, and after that, drop\_objection is given.

### 5.3 TOP ENVIRONMENT



**Fig:5.3 TOP ENVIRONMENT**

#### DESCRIPTION:

- Extend the class from the `uvm_component` class which is the base class.
- Factory registration by using ``uvm_component_utils``
- Create the handles for `Host_environment`, `MAC_environment`, `Rx_Scoreboard`, `Rx_coverage`.
- Create a memory for the `TOP_environment` by using `new()` constructor.
- In the build phase create a memory for the above handles.

- In the connect phase, connections between output\_monitor which is under the Host environment to Rx\_Scoreboard, and also connection between input\_monitor which is under the MAC environment to Rx\_Scoreboard.

### 5.3.1 HOST ENVIRONMENT



**Fig:5.3.1 HOST ENVIRONMENT**

#### DESCRIPTION:

- Extend the class from the uvm\_component class which is the base class.
- Factory registration by using `uvm\_component\_utils
- Create the handle for Host\_active\_agent, Memory\_active\_agent, passive agent.
- Create a memory for the Host\_environment by using new() constructor.
- In the build phase create a memory for the above handles.

### 5.3.1.1 HOST ACTIVE AGENT CLASS



**Fig:5.3.1.1 ACTIVE AGENT CLASS**

**DESCRIPTION:**

- Extend the class from the uvm\_component class which is the base class.

- Factory registration by using `uvm\_component\_utils
- Create handles for Host\_sequencer class and Host\_driver class.
- Create a memory for the Host\_active\_agent by using new() constructor.
- In the build phase create a memory for the above handles.
- In the connect phase, connection between Host\_sequencer class to Host driver class through seq\_item\_port and seq\_item\_export respectively.

### 5.3.1.1.1 HOST SEQUENCER CLASS



**Fig:5.3.1.1.1 HOST SEQUENCER CLASS**

#### DESCRIPTION:

- Extend the class from the uvm\_component class which is the base class.
- Factory registration by using `uvm\_component\_utils macros
- Create a memory for the Host\_active\_agent by using new() constructor.

### 5.3.1.1.2 HOST DRIVER CLASS



**Fig:5.3.1.1.2 HOST DRIVER CLASS**

#### DESCRIPTION:

- Extend the class from the `uvm_component` class which is the base class.
- Factory registration by using `'uvm_component_utils` macros
- Create the handles for virtual interface and `sequence_item`.
- Create a memory for the `Host_driver` by using `new()` constructor.

- In the build phase create a memory for the above handles. And by using get method access the virtual interface ports
- In the Run phase, assigning sequence\_item ports to the virtual interface handle through the driver clocking blocks.

### 5.3.1.2 MEMORY ACTIVE AGENT CLASS



**Fig:5.3.1.2 MEMORY ACTIVE AGENT CLASS**

## DESCRIPTION:

- Extend the class from the uvm\_component class which is the base class.
- Factory registration by using `uvm\_component\_utils macros
- Create handles for memory\_sequencer class and memory\_driver class.
- Create a memory for the memory\_active\_agent by using new() constructor.
- In the build phase create a memory for the above handles.
- In the connect phase, connection between memory\_sequencer class to memory driver class through seq\_item\_port and seq\_item\_export respectively.

### 5.3.1.2.1 MEMORY SEQUENCER CLASS



**Fig:5.3.1.2.1 MEMORY SEQUENCER CLASS**

## DESCRIPTION:

- Extend the class from the uvm\_component class which is the base class.
- Factory registration by using `uvm\_component\_utils macros
- Create a memory for the memory\_sequencer class by using new() constructor.

### 5.3.1.2.2 MEMORY DRIVER CLASS



**Fig:5.3.1.2.2 MEMORY DRIVER CLASS**

#### DESCRIPTION:

- Extend the class from the uvm\_component class which is the base class.
- Factory registration by using `uvm\_component\_utils macros
- Create the handles for virtual interface and sequence\_item.
- Create a memory for the memory\_driver by using new() constructor.

- In the build phase create a memory for the above handles. And by using get method access the virtual interface ports
- In the Run phase, assigning sequence\_item ports to the virtual interface handle through the driver clocking blocks.

### 5.3.1.3 PASSIVE AGENT CLASS



**Fig:5.3.1.3 PASSIVE AGENT CLASS**

#### DESCRIPTION:

- Extend the class from the uvm\_agent class which is the base class.
- Factory registration by using `uvm\_component\_utils macros
- Create handles for Output\_monitor class.

- Create a memory for the passive\_agent component by using the function new() constructor.
- In the build phase creating a memory for the above handles.
- In the connect phase, using the output monitor handle and the output\_monitor\_port which is declared in the output monitor class, connect the passive agent export.

### 5.3.1.3.1 RX OUTPUT MONITOR CLASS



**Fig:5.3.1.3.1 RX OUTPUT MONITOR CLASS**

### **DESCRIPTION:**

- Creating a class for the output monitor class and extending the class from uvm\_monitor which is the base class in uvm.
- Factory registration using uvm\_macros for the class name using (`uvm\_component\_utils(output\_monitor)).
- Declaring the analysis port by using the uvm\_analysis\_port method.
- Creating the memory for class components by using the function new constructor method.
- In the build phase, create the memory for the analysis port using the new() constructor method and get the interface handle by using the get method.
- Establish the run phase using the interface handle, clocking block, and port name to assign interface data to the Sequence\_item\_portUsing the write method assigning the received data to the scoreboard.

### **5.3.1.3.2 SEQUENCE CLASS**



### **DESCRIPTION:**

- Declare the class Rx\_Host\_Sequence and extend it to base class uvm\_sequence and pass Rx\_Sequence\_item as a parameter.
- Do the Factory Registration for the sequence class by using uvm\_object\_utils macro.

- Create memory for the sequence class by using new() constructor.
- In the task body pass the randomized stimulus of the Rx\_Sequence\_item handle using start\_item() and finish\_item() methods.

### 5.3.2 MAC ENVIRONMENT



**Fig:5.3.1 MAC ENVIRONMENT**

#### DESCRIPTION:

- Extend the class from the uvm\_component class which is the base class.
- Factory registration by using `uvm\_component\_utils macros
- Create the handle for MAC\_active\_agent.
- Create a memory for the MAC\_environment by using new() constructor.

- In the build phase create a memory for the above handle.

### 5.3.2.1 ACTIVE AGENT CLASS



**Fig:5.3.1.1 ACTIVE AGENT CLASS**

#### DESCRIPTION:

- Extend the class from the `uvm_component` class which is the base class.
- Factory registration by using ``uvm_component_utils`` macros
- Create handles for `MAC_sequencer` class and `MAC_driver` class.
- Create a memory for the `MAC_active_agent` by using `new()` constructor.
- In the build phase create a memory for the above handles.

- In the connect phase, connection between MAC\_sequencer class to MAC driver class through seq\_item\_port and seq\_item\_export respectively.

### 5.3.2.1.1 SEQUENCER CLASS



**Fig:5.3.1.1.1 SEQUENCER CLASS**

#### DESCRIPTION:

- Extend the class from the uvm\_component class which is the base class.
- Factory registration by using `uvm\_component\_utils macros.
- Create a memory for the memory\_sequencer class by using new() constructor.

### 5.3.2.1.2 DRIVER CLASS



**Fig:5.3.1.1.2 MAC\_DRIVER CLASS**

#### DESCRIPTION:

- Extend the class from the uvm\_component class which is the base class.
- Factory registration by using `uvm\_component\_utils macros
- Create the handles for virtual interface and sequence\_item.
- Create a memory for the MAC\_driver by using new() constructor.
- In the build phase create a memory for the above handles. And by using get method access the virtual interface ports
- In the Run phase, assigning sequence\_item ports to the virtual interface handle through the driver clocking blocks.

### 5.3.2.1.3 INPUT MONITOR CLASS



**Fig:5.3.1.1.3 INPUT MONITOR CLASS**

**DESCRIPTION:**

- Extend the class from the uvm\_component class which is the base class.
- Factory registration by using `uvm\_component\_utils macros
- Declare an analysis port by using uvm\_analysis\_port method.
- Create the handles for virtual interface and sequence\_item.
- Create a memory for the MAC\_input\_monitor by using new() constructor.
- In the build phase, create a memory for analysis port and sequence\_item class. And by using get method access the virtual interface ports.
- In the run phase, on the virtual interface updating ports to sequence\_item ports through the monitor clocking blocks.

### 5.3.2.1.4 COVERAGE CLASS



**Fig:5.3.1.1.4 COVERAGE CLASS**

#### DESCRIPTION:

- Extend the class from the uvm\_component class which is the base class.
- Factory registration by using `uvm\_component\_utils macros
- Create the handles for the virtual interface.
- Creating the covergroup to write the coverpoints for the input pins.
- Constructing the class component by using the function new() method.
- In the build phase create a memory for the above handles. And by using the get method access the virtual interface ports.
- Create a covergroup and write coverpoints for input ports.
- Create a memory for the covergroup handle by using a new constructor.

### 5.3.2.1.5 SEQUENCE\_ITEM CLASS



#### DESCRIPTION:

- Create the class for Rx\_Sequence\_item and extend it to the base class uvm\_sequence\_item.
- Factory Registration is done for sequence\_item class by using uvm\_object\_utils macro.
- Create memory for the Rx\_Sequence\_item class by using new() constructor.
- Declare the input and output ports of the ethernet ip core with bit type with their dimensions. And put rand and randc for the required inputs for randomisation.
- Declare constraints for the randomized input signals.

### 5.3.2.1.6 SEQUENCE CLASS



#### DESCRIPTION:

- Declare the class Rx\_MAC\_Sequence and extend it to base class uvm\_sequence and pass Rx\_Sequence\_item as a parameter.
- Do the Factory Registration for the sequence class by using uvm\_object\_utils macro.
- Create memory for the sequence class by using new() constructor.
- In the task body pass the randomized stimulus by using Rx\_Sequence\_item handle within the start\_item() and finish\_item() methods.

## 5.4 INTERFACE



**Fig: 5.4 INTERFACE**

### DESCRIPTION:

- Declare Rx\_interface by using interface keyword and clock as input port in the port list.
- Declare all input and output ports of the ethernet ip core as logic type with its dimensions.
- Declare clocking blocks for the Driver and Monitor with separate clock declarations for the Rx\_Host\_Environment and Rx\_MAC\_Environment.



## 6. RX FLOW OF OPERATION

