# International SpaceWire and SpaceFibre Conference 2022, Pisa, 17-19 October







# **SpaceWire Codec VIP:**

# an innovative architecture of UVM-based Verification Environment

Simone Vagaggini<sup>1,2</sup>, Marco Trafeli<sup>2</sup>, Daniele Davalle<sup>2</sup>, Roberto Ciardi<sup>1,2</sup>, Lucana Santos<sup>3</sup>, Pietro Nannipieri<sup>1</sup>, Luca Fanucci<sup>1</sup>

<sup>1</sup>Dept. Of Information Engineering, University of Pisa, Via Caruso 16, Pisa, Italy

<sup>2</sup>IngeniArs S.r.l., Via Ponte a Piglieri 8, Pisa, Italy

<sup>3</sup>European Space Research and Technology Centre, European Space Agency, Keplerlaan 1, Noordwijk, The Netherlands







# **OUTLINE**

Introduction







# **OUTLINE**

- Introduction
- SpaceWire Systems Functional Verification





- Introduction
- SpaceWire Systems Functional Verification
- UVM-based SpaceWire Codec Twin Model





- Introduction
- SpaceWire Systems Functional Verification
- UVM-based SpaceWire Codec Twin Model
- UVM-based SpaceWire Data-Strobe Error Injection Model





- Introduction
- SpaceWire Systems Functional Verification
- UVM-based SpaceWire Codec Twin Model
- UVM-based SpaceWire Data-Strobe Error Injection Model
- UVM-based Verification Environment Architecture







- Introduction
- SpaceWire Systems Functional Verification
- UVM-based SpaceWire Codec Twin Model
- UVM-based SpaceWire Data-Strobe Error Injection Model
- UVM-based Verification Environment Architecture
- Verification Campaign







- Introduction
- SpaceWire Systems Functional Verification
- UVM-based SpaceWire Codec Twin Model
- UVM-based SpaceWire Data-Strobe Error Injection Model
- UVM-based Verification Environment Architecture
- Verification Campaign
- UVM-based Approach Advantages



- Introduction
- SpaceWire Systems Functional Verification
- UVM-based SpaceWire Codec Twin Model
- UVM-based SpaceWire Data-Strobe Error Injection Model
- UVM-based Verification Environment Architecture
- Verification Campaign
- UVM-based Approach Advantages
- **Results and Conclusions**



- Introduction
- SpaceWire Systems Functional Verification
- UVM-based SpaceWire Codec Twin Model
- UVM-based SpaceWire Data-Strobe Error Injection Model
- UVM-based Verification Environment Architecture
- Verification Campaign
- UVM-based Approach Advantages
- **Results and Conclusions**
- Q&A



**Universal Verification Methodology (UVM) Verification Intellectual Property (VIP)** for Functional Verification of any SpaceWire Codec





# **Universal Verification Methodology (UVM)** Verification Intellectual Property (VIP) for Functional Verification of any SpaceWire Codec

Developed by IngeniArs S.r.l.







# **Universal Verification Methodology (UVM)** Verification Intellectual Property (VIP) for Functional Verification of any SpaceWire Codec

- Developed by IngeniArs S.r.l.
- European Space Agency project











# Universal Verification Methodology (UVM) Verification Intellectual Property (VIP) for Functional Verification of any SpaceWire Codec

- Developed by IngeniArs S.r.l.
- European Space Agency project
- Activity goals:
  - > Check the compliance of IP Cores with the SpW standard
  - > Evaluation of UVM advantages
  - > Applicability of UVM to space systems











# Universal Verification Methodology (UVM) Verification Intellectual Property (VIP) for Functional Verification of any SpaceWire Codec

- Developed by IngeniArs S.r.l.
- European Space Agency project
- Activity goals:
  - > Check the compliance of IP Cores with the SpW standard
  - > Evaluation of UVM advantages
  - > Applicability of UVM to space systems





Promotion of UVM-based Verification Approach













# Functional Verification of a SpaceWire Codec

Critical and complex phase







- Critical and complex phase
  - > Handshake for link initialization







- Critical and complex phase
  - > Handshake for link initialization
  - > TX and RX credit handling





- Critical and complex phase
  - > Handshake for link initialization
  - > TX and RX credit handling
  - > NULL codes transmission







- Critical and complex phase
  - ➤ Handshake for link initialization
  - > TX and RX credit handling
  - > NULL codes transmission
  - > Errors recognition







# Functional Verification of a SpaceWire Codec

- Critical and complex phase
  - > Handshake for link initialization
  - > TX and RX credit handling
  - > NULL codes transmission
  - > Errors recognition

Common approach: direct test-bench







- Critical and complex phase
  - > Handshake for link initialization
  - >TX and RX credit handling
  - > NULL codes transmission
  - > Errors recognition

- Common approach: direct test-bench
  - > Manual calibration of inputs required





- Critical and complex phase
  - > Handshake for link initialization
  - > TX and RX credit handling
  - > NULL codes transmission
  - > Errors recognition

- Common approach: direct test-bench
  - > Manual calibration of inputs required
  - > Manual check of outputs required







- Critical and complex phase
  - > Handshake for link initialization
  - > TX and RX credit handling
  - > NULL codes transmission
  - > Errors recognition

- Common approach: direct test-bench
  - > Manual calibration of inputs required
  - > Manual check of outputs required
  - > Inefficient and time-consuming







# **Functional Verification of a SpaceWire Codec**

- Critical and complex phase
  - > Handshake for link initialization
  - >TX and RX credit handling
  - > NULL codes transmission
  - > Errors recognition

- Common approach: direct test-bench
  - > Manual calibration of inputs required
  - > Manual check of outputs required
  - > Inefficient and time-consuming

Proposed approach: advanced and automated Verification Environment







- Critical and complex phase
  - > Handshake for link initialization
  - >TX and RX credit handling
  - > NULL codes transmission
  - > Errors recognition

- Common approach: direct test-bench
  - > Manual calibration of inputs required
  - > Manual check of outputs required
  - > Inefficient and time-consuming

- Proposed approach: advanced and automated Verification Environment
  - ➤ Based on SpW Codec Twin Model







- Critical and complex phase
  - > Handshake for link initialization
  - > TX and RX credit handling
  - > NULL codes transmission
  - > Errors recognition

- Common approach: direct test-bench
  - > Manual calibration of inputs required
  - > Manual check of outputs required
  - > Inefficient and time-consuming

- Proposed approach: advanced and automated Verification Environment
  - ➤ Based on SpW Codec Twin Model
  - > Fully compliant with Universal Verification Methodology (UVM)









- Critical and complex phase
  - > Handshake for link initialization
  - >TX and RX credit handling
  - > NULL codes transmission
  - > Errors recognition

- Common approach: direct test-bench
  - > Manual calibration of inputs required
  - > Manual check of outputs required
  - > Inefficient and time-consuming

- Proposed approach: advanced and automated Verification Environment
  - ➤ Based on SpW Codec Twin Model
  - > Fully compliant with Universal Verification Methodology (UVM)
  - > Capable of verifying any SpW Codec















Emulates the ideal behavior of a SPW Codec







- Emulates the ideal behavior of a SPW Codec
- Fully compliant with Rev.1 of SpW Standard







- Emulates the ideal behavior of a SPW Codec
- Fully compliant with Rev.1 of SpW Standard
- Host interface
  - Packets and BC transmission and reception
  - Configuration changes and readings









- Emulates the ideal behavior of a SPW Codec
- Fully compliant with Rev.1 of SpW Standard
- Host interface
  - Packets and BC transmission and reception
  - Configuration changes and readings
- Data-Strobe interface
  - o Communication with DUT or any system with SpW interface







- Emulates the ideal behavior of a SPW Codec
- Fully compliant with Rev.1 of SpW Standard
- Host interface
  - Packets and BC transmission and reception
  - Configuration changes and readings
- Data-Strobe interface
  - o Communication with DUT or any system with SpW interface
- Developed in SystemVerilog HVL







- Emulates the ideal behavior of a SPW Codec
- Fully compliant with Rev.1 of SpW Standard
- Host interface
  - o Packets and BC transmission and reception
  - Configuration changes and readings
- Data-Strobe interface
  - o Communication with DUT or any system with SpW interface
- Developed in SystemVerilog HVL
- Fully compliant with UVM
  - o Easily reusable and maintainable









Direct Communication with DUT







- Direct Communication with DUT
  - > Automatic link initialization









- Direct Communication with DUT
  - > Automatic link initialization
  - > Automatic TX and RX credit handling









- Direct Communication with DUT
  - > Automatic link initialization
  - > Automatic TX and RX credit handling
  - > Automatic TX of NULLs when needed









- Direct Communication with DUT
  - > Automatic link initialization
  - > Automatic TX and RX credit handling
  - > Automatic TX of NULLs when needed
  - > Automatic recognition of all types of errors









- Direct Communication with DUT
  - > Automatic link initialization
  - ➤ Automatic TX and RX credit handling
  - > Automatic TX of NULLs when needed
  - > Automatic recognition of all types of errors
- Higher level of abstraction
  - > Only packets and BCs to be defined







- Direct Communication with DUT
  - > Automatic link initialization
  - > Automatic TX and RX credit handling
  - > Automatic TX of NULLs when needed
  - > Automatic recognition of all types of errors
- Higher level of abstraction
  - > Only packets and BCs to be defined



Significant Simplification of the Verification Process Significant Reduction in Verification Time and Cost







- SpW Standard defines:
  - > Parity Error
  - ➤ Disconnect Error
  - > ESC Error

- > Credit Error
- ➤ GotFCT/GotNChar/GotBC Errors





- SpW Standard defines:
  - ➤ Parity Error
  - > Disconnect Error
  - > ESC Error
- Data-Strobe Error Injection Model
  - > Two Data-Strobe Interface
  - > Host Interface

- > Credit Error
- ➤ GotFCT/GotNChar/GotBC Errors







- SpW Standard defines:
  - ➤ Parity Error
  - > Disconnect Error
  - > ESC Error
- Data-Strobe Error Injection Model
  - > Two Data-Strobe Interface
  - > Host Interface
- Bi-directional Error Injection

- > Credit Error
- > GotFCT/GotNChar/GotBC Errors







- SpW Standard defines:
  - ➤ Parity Error
  - > Disconnect Error
  - > ESC Error
- Data-Strobe Error Injection Model
  - > Two Data-Strobe Interface
  - > Host Interface
- Bi-directional Error Injection
- All types of Errors Supported

- > Credit Error
- > GotFCT/GotNChar/GotBC Errors







- SpW Standard defines:
  - ➤ Parity Error
  - > Disconnect Error
  - > ESC Error
- Data-Strobe Error Injection Model
  - > Two Data-Strobe Interface
  - > Host Interface
- Bi-directional Error Injection
- All types of Errors Supported
- Compliant with UVM
  - > Reusable in any project with SpW Interfaces

- > Credit Error
- > GotFCT/GotNChar/GotBC Errors







Integration within SpW Codec Twin Model







- Integration within SpW Codec Twin Model
- Leveraging UVM power
  - > Extension operation
  - > Inter-block communication







- Integration within SpW Codec Twin Model
- Leveraging UVM power
  - > Extension operation
  - > Inter-block communication

#### **Extended Twin Model:**

- Features of Twin Model
- Possibility to Inject Errors
- Direct communication with DUT













- **Innovative architecture**
- Main Link
  - Communication between DUT and Twin Model







- Main Link
  - Communication between DUT and Twin Model
- Twin Link
  - > Communication between two Twin Models







- Main Link
  - Communication between DUT and Twin Model
- Twin Link
  - > Communication between two Twin Models
  - > Same stimuli of the Main Link







- Main Link
  - Communication between DUT and Twin Model
- Twin Link
  - > Communication between two Twin Models
  - > Same stimuli of the Main Link
  - > Emulates the ideal behavior of the SpW Link







- Main Link
  - Communication between DUT and Twin Model
- Twin Link
  - > Communication between two Twin Models
  - > Same stimuli of the Main Link
  - > Emulates the ideal behavior of the SpW Link
  - > Possibility to be disabled







**Environment Configuration** 







- **Environment Configuration**
- **DUT** Agents
- Twin Model Agents









- **Environment Configuration**
- **DUT** Agents
- Twin Model Agents
- Error Injection Agent









- **Environment Configuration**
- **DUT** Agents
- Twin Model Agents
- Error Injection Agent
- Twin Link Data Collectors









- **Environment Configuration**
- **DUT** Agents
- Twin Model Agents
- Error Injection Agent
- Twin Link Data Collectors
- Scoreboard









Simulation scenario configuration







- Simulation scenario configuration
  - > UVM Virtual sequences method







- Simulation scenario configuration
  - > UVM Virtual sequences method
  - ➤ By setting variables







- Simulation scenario configuration
  - > UVM Virtual sequences method
  - ➤ By setting variables
  - > Not knowing the internal VE architecture









- Simulation scenario configuration
  - > UVM Virtual sequences method
  - ➤ By setting variables
  - > Not knowing the internal VE architecture





# **Verification Intellectual Property (VIP)**

Complete Functional Verification of any SpW Codec (a basic adapter could be required)





Developed all test-cases to achieve 100% functional coverage





- Developed all test-cases to achieve 100% functional coverage
- Performed complete Verification Campaign on:
  - ➤ IngeniArs S.r.l. SpW Codec IP Core
  - ➤ European Space Agency SpW Codec IP Core













- Developed all test-cases to achieve 100% functional coverage
- Performed complete Verification Campaign on:
  - ➤ IngeniArs S.r.l. SpW Codec IP Core
  - ➤ European Space Agency SpW Codec IP Core

| DUT                                        | Compliance with SpW Standard | Compliance with SpW Standard Rev.1 |
|--------------------------------------------|------------------------------|------------------------------------|
| IngeniArs S.r.l. SpW Codec IP Core         | ✓                            | ✓                                  |
| European Space Agency<br>SpW Codec IP Core | <b>√</b>                     |                                    |













# **UVM-BASED APPROACH ADVANTAGES**

Maintainability







# **UVM-BASED APPROACH ADVANTAGES**

- Maintainability
  - >Add functionalities







- Maintainability
  - >Add functionalities



### ➤ Update functionalities







Reusability







14

- Reusability
  - From a single functional block











- Reusability
  - From a single functional block







- Reusability
  - From a single functional block

#### ➤ To all the VIP









14

- Reusability
  - From a single functional block

➤ To all the VIP







14

## Verification IP supporting a full test Campaing of any SpW Codec

Based on a SpW Codec Twin Model





- Based on a SpW Codec Twin Model
- Double Link Architecture





- Based on a SpW Codec Twin Model
- Double Link Architecture
- Complete support of all simulation scenarios involving errors





- Based on a SpW Codec Twin Model
- Double Link Architecture
- Complete support of all simulation scenarios involving errors
- Support all testcases for 100% functional coverage of SpW Standard, Rev.1.





- Based on a SpW Codec Twin Model
- Double Link Architecture
- Complete support of all simulation scenarios involving errors
- Support all testcases for 100% functional coverage of SpW Standard, Rev.1.
- Used for functional verification of:
  - IngeniArs S.r.l. SpW Codec IP Core
  - European Space Agency SpW Codec IP Core





- Based on a SpW Codec Twin Model
- Double Link Architecture
- Complete support of all simulation scenarios involving errors
- Support all testcases for 100% functional coverage of SpW Standard, Rev.1.
- Used for functional verification of:
  - IngeniArs S.r.l. SpW Codec IP Core
  - European Space Agency SpW Codec IP Core
- Fully compliant with UVM with advantages in terms of:
  - Maintainability
  - Reusability in other projects







## Verification IP supporting a full test Campaing of any SpW Codec

- Based on a SpW Codec Twin Model
- Double Link Architecture
- Complete support of all simulation scenarios involving errors
- Support all testcases for 100% functional coverage of SpW Standard, Rev.1.
- Used for functional verification of:
  - IngeniArs S.r.l. SpW Codec IP Core
  - European Space Agency SpW Codec IP Core
- Fully compliant with UVM with advantages in terms of:
  - Maintainability
  - Reusability in other projects

Significant reduction of verification time and costs Significant increase of SpW Codec reliability







## **QUESTIONS & ANSWERS**

# Thanks for your attention!

## For more information about SpW Codec Verification IP:

#### **Email:**

simone.vagaggini@ingeniars.com marco.trafeli@ingeniars.com daniele.davalle@ingeniars.com roberto.ciardi@ingeniars.com

### **Company Website:**

www.ingeniars.com





