

# AES VIP VERIFICATION PLAN

#### **P**URPOSE

This document describes the verification of AES VIP. It contains an overview of which AES128 IP features will be verified, verification strategy and objectives. It will also detail the flow, the test bench architecture, and tests used for achieving the complete verification of AES VIP.

# **Revision History**

| Rev | Date       | Author       | Description         |
|-----|------------|--------------|---------------------|
| 0.1 | 31/10/2024 | Vincent Yang | First draft release |
|     |            |              |                     |

## References

| Title                                                    | Reference                                                |
|----------------------------------------------------------|----------------------------------------------------------|
| Specification for the ADVANCED ENCRYPTION STANDARD (AES) | https://nvlpubs.nist.gov/nistpubs/fips/nist.fips.197.pdf |

# Contents

| 1.  | Verification strategy                  | 5  |
|-----|----------------------------------------|----|
|     |                                        |    |
| 2.  | Test bench                             | 6  |
| 2.  | 1. Block diagram                       | 6  |
| 2.: |                                        |    |
| 2.  | 3. Interface                           | 8  |
| 2.  |                                        |    |
| 2.  |                                        |    |
| 2.  | 5.1. Driver                            |    |
|     | 5.2. Monitor                           |    |
|     | 6. Scoreboard                          |    |
|     | 6.1. C Model                           |    |
| 2.  | 7. Coverage                            |    |
| 3.  | DUT                                    | 13 |
| 4.  | Database Structure and Simulation Flow | 14 |
|     |                                        |    |
| 4.  |                                        |    |
|     | 2. Simulation Flow                     |    |
| 5.  | Assertions and checks                  | 15 |
| 6.  | Tests                                  | 16 |
| 6.  | 1. UVM Sequences                       | 17 |
|     | ndix                                   |    |
|     |                                        |    |

# List of figures

| Figure 1: AES VIP top level block diagram              | 6        |
|--------------------------------------------------------|----------|
| Figure 2: Block diagram of compare_to_c_model function | 12       |
| Figure 3: Block diagram of DUT aes128                  | 13       |
| Figure 4: Directory structure of the VIP environment   | 14       |
|                                                        |          |
|                                                        |          |
| List of tables                                         |          |
| Table 1: Configuration class fields                    | <i>7</i> |
| Table 2: Interface class fields                        |          |
| Table 3: Sequence item fields                          | 9        |
| Table 4: Sequence item constraints                     | 9        |
| Table 5: Driver class fields                           | 10       |
| Table 6: Driver functions and tasks                    |          |
| Table 7: Monitor fields                                | 11       |
| Table 8: Monitor functions and tasks                   | 11       |
| Table 9: C model main function                         | 12       |
| Table 10: Coverpoint list                              | 13       |
| Table 11: Assertion list                               | 16       |
| Table 12: Summary of tests used to verify the AES core | 16       |
| Table 13: Sequence list                                | 17       |

## 1. Verification strategy

The AES VIP is an UVM environment for all AES protocol-based IPs. According to the specification, this AES VIP supports AES encryption and decryption protocol features below:

- Supports 128-bit plaintext and ciphertext data.
- Supports 128-bit encryption keys.

Verification of AES VIP will follow the steps below:

- The environment will be written in System Verilog.
- An agent will communicate directly to the AES IP ports.
- An AES C model will be used to check the DUT output in the scoreboard with a DPI-C import.
- SV Assertions will be used to check the protocol in the interface class.

#### 2. Test bench

#### 2.1. Block diagram

Figure 1 gives the AES VIP block diagram that shows the structure and flow. Inside the aes\_env, an aes\_agent is instantiated to drive the aes128 VHDL IP core. The signals generated by the IP core are monitored by the aes\_monitor, which gathers these signals and sends them to the scoreboard.

The scoreboard then forwards these signals to a DPI-C function, which compares them to a reference output generated by a C model. This setup allows for real-time verification by comparing the IP core's output against expected values from the C model.



Figure 1: AES VIP top level block diagram

## 2.2. Configuration

The configuration aes\_config class contains the different settings given to the VIP. Table 1 gives configuration class fields.

| Name                       | Туре                  | Default value | Description                    |  |  |
|----------------------------|-----------------------|---------------|--------------------------------|--|--|
|                            |                       |               |                                |  |  |
| vif                        | virtual aes_if        | None          | Virtual interface              |  |  |
| name                       | string                | None          | Name of the configuration      |  |  |
| General UVM specifications |                       |               |                                |  |  |
| is_active                  | uvm_active_passive_en | UVM_          | Set the agent configuration to |  |  |
|                            | um                    | ACTIVE        | active or passive              |  |  |
| coverage_enable            | bit                   | 0             | Enable coverage                |  |  |
| checks_enable              | bit                   | 0             | Enable checks                  |  |  |

Table 1: Configuration class fields

#### 2.3. Interface

The interface aes\_if class contains the different wires driven by the AES interface and assertions to check the AES protocol. Section 4 describes assertions.

Table 2 gives interface class fields.

| Name   | Туре         | Description                                                                                                                                                        |  |
|--------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| clk    | Wire         | Clock, actions are performed on its rising edge                                                                                                                    |  |
| rst    | Wire         | Synchronous reset, active high. When asserted, set all the signals to its initial state                                                                            |  |
| start  | Wire         | Start signal. When asserted, it indicates that the input data is ready to be processed. This signal triggers the beginning of the encryption or decryption process |  |
| din    | Wire [127:0] | Data input signal. It carries the 128-bit plaintext data that needs to be encrypted                                                                                |  |
| key_in | Wire [127:0] | Key input signal. It carries the 128-bit encryption key used for the AES algorithm                                                                                 |  |
| cipher | Wire         | Indicates which operation is performed. If set to 1, it's an encryption; if set to 0, it's a decryption                                                            |  |
| dout   | Wire [127:0] | Data output signal. It carries the 128-bit ciphertext result after the encryption process is completed.                                                            |  |
| finish | Wire         | The finish signal. When asserted, it indicates that the encryption process is complete and the output data is valid.                                               |  |

Table 2: Interface class fields

#### 2.4. Sequence item

Sequence item aes\_tx class contain the different attributes contained in a transaction, constraints on these attributes, and basic functions to print, copy, compare transactions.

Table 3 gives sequence item fields.

| Name     | Туре             | Description                          |  |  |
|----------|------------------|--------------------------------------|--|--|
| m_din    | rand bit [127:0] | Data input signal                    |  |  |
| m_key_in | rand bit [127:0] | Key input signal                     |  |  |
| m_dout   | rand bit [127:0] | Data output signal                   |  |  |
| m_cipher | rand bit         | Encryption or decryption mod signal. |  |  |
| m_delay  | rand int         | Delay between each operation         |  |  |

Table 3: Sequence item fields

Table 4 gives sequence item constraints.

| Name             | Min value         | Max value | Description              |
|------------------|-------------------|-----------|--------------------------|
| max_delay_rate_c | elay_rate_c 1 100 |           | Constrains m_delay range |

Table 4: Sequence item constraints

## 2.5. Agent

Agent aes\_agent class contains the instantiations of agent blocks: driver, monitor and sequencer.

## 2.5.1. Driver

Driver aes\_driver class drives transactions from sequencer to the interface. They drive interface's control signals regarding from the AES protocol.

Table 5 gives driver fields.

| Name           | Туре           | Description                    |  |  |
|----------------|----------------|--------------------------------|--|--|
| General fields |                |                                |  |  |
| vif            | virtual aes_if | Virtual aes interface          |  |  |
| m_config       | aes_config     | Configuration set by the agent |  |  |

Table 5: Driver class fields

Table 6 gives driver functions and tasks.

| Name         | Туре     | Arguments                               | Return | Description                                                      |
|--------------|----------|-----------------------------------------|--------|------------------------------------------------------------------|
| new          | Function | string name,<br>uvm_component<br>parent | /      | Constructor                                                      |
| build_phase  | Function | uvm_phase phase                         | void   | Build phase                                                      |
| run_phase    | Task     | uvm_phase phase                         | void   | This task gets a new transaction, and call drive item tasks      |
| do_drive     | Task     | /                                       | /      | This task drives sequence items received to virtual interface    |
| handle_reset | Task     | /                                       | /      | This task set reset values to all data driven if rst is asserted |

Table 6: Driver functions and tasks

## 2.5.2. Monitor

Monitor aes\_monitor class detect AES operation at the interface by waiting finish signals. They send sequence item to the scoreboard and to subscribers.

Table 7 gives monitor fields.

| Name           | Туре                            | Description                                                  |
|----------------|---------------------------------|--------------------------------------------------------------|
| vif            | virtual aes_if                  | Virtual AES interface                                        |
| m_config       | aes_config                      | Configuration set by the agent                               |
| analysis_port  | uvm_analysis_port<br>#( aes_tx) | Analysis port where monitor writes detected item.            |
| m_trans        | aes_tx                          | Item to receive data from monitor                            |
| m_trans_cloned | aes_tx                          | Item to clone data from monitor to send it to the subscriber |

Table 7: Monitor fields

Table 8 gives monitor functions and tasks.

| Name        | Туре     | Arguments                            | Return | Description                                                                      |
|-------------|----------|--------------------------------------|--------|----------------------------------------------------------------------------------|
| new         | Function | string name,<br>uvm_component parent | /      | Constructor. Build and connect phase                                             |
| run_phase   | Task     | uvm_phase phase                      | /      | Run phase                                                                        |
| do_mon Task |          | /                                    | /      | Fill a sequence item and send it to subscribers while monitor detects a transfer |

Table 8: Monitor functions and tasks

#### 2.6. Scoreboard

The aes\_scoreboard class compares AES operations performed by the DUT as observed by the monitor. It verifies that the encryption or decryption done by the DUT is correct by comparing it to a reference AES C model, if not correct, it sends uvm\_fatal error. To do so, it imports a DPI-C function compare\_to\_c\_model from the aes\_model.c file. Scoboard also keeps a count of all the transactions processed and all transactions that matched with the C model reference.

At the end of the test, it summarizes all the transactions observed.

#### 2.6.1. C Model

An AES C model aes model.c has functions to compute AES encryption or decryption.

Table 9 gives aes\_model.c main function that compare data computed from the DUT and data computed from the reference.

| Name                   | Туре     | Arguments                                                        | Return             | Description                                                                                                   |
|------------------------|----------|------------------------------------------------------------------|--------------------|---------------------------------------------------------------------------------------------------------------|
| Compare_to_c<br>_model | Function | int data_in[3], int key_in[3], int data_out[3], int cipher_phase | int matrix_compare | Computes AES encryption or decryption depending of argument cipher_phase. Then compare computed golden matrix |
|                        |          |                                                                  |                    | to data_out from the VHDL DUT.  Returns 1 if it matches, else return 0.                                       |

Table 9: C model main function

Figure 2 resumes compare to c model operations.



Figure 2: Block diagram of compare\_to\_c\_model function

## 2.7. Coverage

Table 10 gives coverpoints checked during coverage in aes\_coverage class.

| Bins                    | Data covered      | Value covered       | Description                                                 |  |  |  |  |
|-------------------------|-------------------|---------------------|-------------------------------------------------------------|--|--|--|--|
| coverpoint: cp_m_din    |                   |                     |                                                             |  |  |  |  |
| Din_range               | bit [127:0] m_din | Auto_bin_max = 1024 | Checks that the signal takes values between $[0:2^{127}-1]$ |  |  |  |  |
| coverpoint: cp_m_key_in |                   |                     |                                                             |  |  |  |  |
| Key_range               | bit [127:0] m_key | Auto_bin_max = 1024 | Checks that the signal takes values between $[0:2^{127}-1]$ |  |  |  |  |
| coverpoint: cp_m_cipher |                   |                     |                                                             |  |  |  |  |
| Cipher_range            | bit m_cipher      | Auto_bin_max = 2    | Checks that the signal take values between 0 and 1          |  |  |  |  |

Table 10: Coverpoint list

## 3. DUT

DUT is a VHDL 128 bit AES core IP.



Figure 3: Block diagram of DUT aes128

DUT design is detailed in AES\_specification file.

#### 4. Database Structure and Simulation Flow

This section describes simulation directories and simulation commands.

#### 4.1. Database structure

Figure 4 gives the VIP environment structure. Directories, and files inside are detailed below.



Figure 4: Directory structure of the VIP environment

Directory verif uvc aes/contains:

- UVM file: aes\_agent.sv that contains an AES VIP agent class.
- UVM file: aes\_config.sv that contains an AES VIP config class.
- UVM file: aes coverage.sv that contains an AES VIP coverage class.
- UVM file: aes driver.sv that contains an AES VIP driver class.
- UVM file: aes\_if.sv that contains an AES VIP interface.
- UVM file: aes monitor.sv that contains an AES VIP monitor class.
- UVM file: aes\_pkg.sv that contains a package for the VIP.
- UVM file: aes\_sequencer.sv that contains an AES VIP sequencer class.
- UVM file: aes\_tx.sv that contains an AES VIP item class.

#### Directory sequences/ contains:

- UVM file: aes\_seq\_lib.sv that contains different sequence classes used by AES VIP agents.
- UVM file: aes\_top\_seq\_lib.sv that contains different sequences composed of sequences from aes\_seq\_lib.sv to run tests.

#### Directory tb/ contains:

- Directory tb\_sv/ that contains:
  - Directory test/ that contains:
    - UVM file: test aes\_test\_coverage.sv
    - UVM file: test aes\_test\_flush.sv
    - UVM file: test aes\_test\_syncreq.sv
    - UVM file: test aes\_test\_transmit\_coresight\_id.sv
    - UVM file: test aes test transmit locally.sv
    - UVM file: test aes\_test\_wakeup.sv

- UVM file: test aes\_test\_transmit.sv
- UVM file: test aes\_test\_transmit\_then\_flush.sv
- UVM file: test aes\_test\_transmit\_trace\_trigger.sv
- UVM file: aes\_env.sv that contains top level environment of the VIP.
- o UVM file: aes scoreboard.sv that contains the scoreboard.
- O UVM file: aes tb.sv that contains the test bench.
- UVM file: aes test base.sv that contains the base test.
- UVM file: aes\_test\_pkg.sv that a package for the top-level environment of the VIP.
- UVM file: aes th.sv that contains test harness.
- Directory xcelium/ that contains:
  - o Directory output/ that contains output simulation logs.
  - o Bash file: run that will lauch xrun with given arguments.

#### 4.2. Simulation Flow

**TOOL REQUIRED: Cadence Incisive** 

With the run script "run" you can run a test by giving arguments in the command line.

#### To run a test:

- Go to verif\_uvc\_aes/tb/xcelium/ directory.
- Use run bash script with the test wanted in argument.

#### Execution example:

- Run a test aes\_test\_cipher:

```
./run +UVM TESTNAME=aes test cipher
```

The purpose of the regression script "run\_regression" is to run all tests, check if they have passed or failed and then report results to the user in the console and in a log file.

#### To run a regression:

- Go to verif\_uvc\_aes/tb/xcelium/ directory.
- Use run\_regression bash script.

#### Execution example:

- Run a regression with a regression configuration file:

```
./run regression
```

Logs are stored in verif\_uvc\_aes/tb/xcelium/output/regression\_log/ directory.

#### 5. Assertions and checks

This section describes the assertions used by the test bench.

Table 11 gives for each assertion its name and its description.

| ID | Name                                                    | Description |  |
|----|---------------------------------------------------------|-------------|--|
|    | Assertions located in interface (using interface wires) |             |  |
|    | TBD                                                     |             |  |
|    |                                                         |             |  |

Table 11: Assertion list

#### 6. Tests

| Feature covered   | Cipher | Decipher |
|-------------------|--------|----------|
| Test name         |        |          |
| aes_test_base     | X      | X        |
| atb_test_cipher   | X      |          |
| atb_test_decipher |        | X        |

Table 12: Summary of tests used to verify the AES core

These tests will report test passed if they have run all their sequences without any assertion error.

#### 1. aes\_test\_base

This test does:

- Sends a random number of sequence from its virtual sequencer: **aes\_base\_seq** which send random sequences.

#### 2. aes\_test\_cipher

This test does:

- Execute the inherited run\_phase but override aes\_base\_seq by atb\_cipher\_seq.

#### 3. aes\_test\_decipher

This test does:

- Execute the inherited run\_phase but override aes\_base\_seq by atb\_decipher\_seq.

# 6.1. UVM Sequences

| Name             | Description                                                        |
|------------------|--------------------------------------------------------------------|
| aes_base_seq     | Basic sequence that randomizes a sequence item.                    |
| aes_cipher_seq   | Cipher sequence that randomizes a sequence item with cipher = 1.   |
| aes_decipher_seq | Decipher sequence that randomizes a sequence item with cipher = 0. |

Table 13: Sequence list

# **Appendix**

N/A