

# Verification of AXI DMA with UVM

Presenter: Noman Rafiq

Tech Lead: Hassan Ashraf

Date: 04 Feb, 2025



## **TCP Overview**



### **TCP Description**

Verification of AXI DMA IP in **Direct Register Mode** with the Scatter/Gather Engine disabled.

#### **Features to Verify**:

- AXI-Lite Interface Read/Write Operations
- Interrupt Generation & Handling
- Error Scenarios
- Reset Feature
- MM2S/S2MM Independent Operation
- Automatic Data Re-Alignment
- Run/Stop Control



### continued...

#### **Deliverables:**

- UVM-based testbench for IP verification.
- Register Abstraction Layer (RAL) model.
- Comprehensive Test Plan
- Verification Architecture Document
- Coverage analysis.



# **TCP Steps**

- Project Initialization
- IP Generation
- Verification Planning
- Testbench Development
- RAL Model
- Scoreboard
- Test Case Development
- Coverage Analysis
- Documentation



Total Duration of the Project (1 Month)

> Start Date: Dec 12, 2024

> End Date: Jan 31, 2024

#### Week 1:

• Familiarization with Vivado IP and AXI/AXI-Stream protocols.

#### Week 2:

• Development of Verification Plan & Testbench components (drivers, monitors).

#### Week 3:

- Development of RAL Model.
- Debugging and fine-tuning testbench.



#### Week 4:

Scoreboard and Test Case Development

#### Week 5:

• Test Case Development & Coverage Analysis

#### Week 6:

Documentation & Delivery

#### Week 7:

Revising and Further Optimizations



### Actual vs Expected Timeline

| Project Phases             | Expected Completion Date | Actual Completion Date | Slack |
|----------------------------|--------------------------|------------------------|-------|
| TCP                        | January 12, 2025         | January 31, 2025       | -19   |
| Project Initialization     | December 16, 2024        | December 16, 2024      | 0     |
| IP Generation              | December 17, 2024        | December 17, 2024      | 0     |
| Veirification Plan         | December 31, 2024        | December 30, 2024      | 1     |
| Testbench Development      | December 21, 2024        | December 28, 2024      | -7    |
| RAL Model                  | December 31, 2024        | December 31, 2024      | 0     |
| Scoreboard                 | January 2, 2025          | January 3, 2025        | -1    |
| Testcase Development       | January 20, 2025         | January 18, 2025       | 2     |
| Coverage and Results       | January 20, 2025         | January 24, 2025       | -4    |
| Documentation & Delivery   | January 20, 2025         | January 24, 2025       | -4    |
| Revisions - Code Review II | January 29, 2025         | January 31, 2025       | -2    |



### **Gantt Chart**





# **Technical Overview**



# **Design Under Test (DUT)**





# **Design Under Test (DUT)**





### **Testbench Structure**







### **Test Workflow**

#### **MM2S Read Operation:**

- Configure the MM2S Control Registers.
- Start the AXI Read Sequence on the Left Side and hand over data to DMA.
- Start the AXI Stream Read Sequence on the Right Side and get the data from DMA.
- Compare the Received Data with the Expected Data in Scoreboard.
- Check if the Interrupt was Generated after transfer completes.

#### **Test Termination:**

Simulation completes when all transactions are processed.



## Verification approach

#### 1. Architecture:

- UVM-based modular environment.
- Parameterized Components

#### 2. Methodology:

- Constrained Random Testing for robustness.
- Directed Testing to target specific features like interrupts and error conditions.
- Random Stimulus Generation for Coverage

#### 3. Validation:

- Scoreboard-Based Comparison to Validate data integrity for MM2S and S2MM transfers.
- Assertion-based Verification and Protocol Compliance
- Coverage Metrics



### **Test Plan**

### **Key Features to Verify:**

- AXI-Lite Interface Read/Write Operations
- AXI-Stream Interface Data Transfer
- Handling Packet Boundaries
- Interrupt Generation & Handling
- Error Scenarios
- Reset Feature
- MM2S/S2MM Independent Operation
- 4 KB Boundary Protection
- Automatic Data Re-Alignment
- Halted and Idle State Management
- Run/Stop Control



### **Test Plan**





### **Statistics**

- Total 22 Test Cases
- 100% Functional Coverage for Direct Register Mode



#### **Groups Coverage Summary**

| Score | Inst Score |  |  |  |  |
|-------|------------|--|--|--|--|
| 100   | 100        |  |  |  |  |

#### Total groups in report: 6

| Name (t)                                                                       | Score 11 | Num Instances | Avg Instances Score 11 | Weight | Goal | Merge Instances | Get Inst Coverage | Per Instance | Auto Bin Max | Comment |
|--------------------------------------------------------------------------------|----------|---------------|------------------------|--------|------|-----------------|-------------------|--------------|--------------|---------|
| <u>Sunit params pkg sv 891442008::axi lite coverage::cg read channel</u>       | 100      | 1             | 100                    | 1      | 100  | 0               | 0                 | 0            | 64           |         |
| Sunit params pkg sv 891442008::axi lite coverage::cg write channel             | 100      | 1             | 100                    | 1      | 100  | 0               | 0                 | 0            | 64           |         |
| <u>Sunit_params_pkg_sv_891442008::axis_read_coverage::cg_axis_read_</u>        | 100      | 1             | 100                    | 1      | 100  | 0               | 0                 | 0            | 64           |         |
| <u>Sunit_params_pkg_sv_891442008::axis_read_coverage::cg_mm2s_introut_</u>     | 100      | 1             | 100                    | 1      | 100  | 0               | 0                 | 0            | 64           |         |
| <u>\$unit_params_pkg_sv_891442008</u> ::axis_write_coverage::cg_axis_write     | 100      | 1             | 100                    | 1      | 100  | 0               | 0                 | 0            | 64           |         |
| <u>\$unit_params_pkg_sv_891442008::s2mm_introut_coverage::cg_s2mm_introut_</u> | 100      | 1             | 100                    | 1      | 100  | 0               | 0                 | 0            | 64           |         |



### Demo

### It's simulation o'clock — let's see the testbench in action!





### **Read After Write Test (RAW)**





### **Boundary Test**





### **Data Re-Alignment Test**





### **Soft Reset Test**





# Challenges

- Memory Mapped Read/Write Operation
- AXI Slave Memory Integration
- Read after Write Test (RAW Test)
- Scoreboard Interrupt Checkers
- Random Failures



### **Achievements**

- Fully Developed UVM Testbench
- Functional RAL Model
- Comprehensive Verification Architecture Document
- Github Repository (<u>AXI DMA Verification</u>)
- Test Plan (<u>Verification Testplan</u>)
- Coverage Analysis (<u>Merged Report</u>)



# Thankyou. Questions?