

**APB SLAVE**  
**VERIFICATION DOCUMENT**

# **CHAPTER 1: INTRODUCTION AND OBJECTIVES**

## **1.1 Introduction:**

APB is low bandwidth and low performance bus. So, the components requiring lower bandwidth like the peripheral devices such as UART, Keypad, Timer and PIO (Peripheral Input Output) devices are connected to the APB. The bridge connects the high performance AHB or ASB bus to the APB bus. So, for APB the bridge acts as the master and all the devices connected on the APB bus acts as the slave.

## **1.2 Specification**

- The DUT is a single APB slave, receiving signals from an APB master.
- **Signal priority:**
  1. PRESETn (active low reset)
  2. PSEL
  3. PENABLE
  4. PREADY
  5. PWRITE
- **Data width:** 32 bits
- **Address width:** 8 bits

**Write:** PWRITE=1, PWpdata sent from master to slave

**Read:** PWRITE=0, PRDATA sent from slave to master

| SIGNAL  | SOURCE       | DESCRIPTION                                                | WIDTH |
|---------|--------------|------------------------------------------------------------|-------|
| PCLK    | Clock Source | All APB functionality occurs at rising edge                | 1     |
| PRESETn | System Bus   | Active low reset                                           | 1     |
| PADDR   | APB Master   | Address bus                                                | 8     |
| PSEL    | APB Master   | Slave select signal, active high                           | 1     |
| PENABLE | APB Master   | Indicates the second cycle of a data transfer, active high | 1     |
| PWRITE  | APB Master   | Direction of transfer (1=write, 0=read)                    | 1     |
| PREADY  | Slave        | Indicates slave is ready for data transfer                 | 1     |
| PSLVERR | Slave        | Indicates a transfer failure                               | 1     |
| PRDATA  | Slave        | Read data output from the slave                            | 32    |
| PWpdata | APB Master   | Write data input to the slave                              | 32    |

## **CHAPTER 2 - VERIFICATION ARCHITECTURE**



The figure shows the verification architecture for an APB slave built using a UVM testbench approach.

## Key Components:

- **Sequence Item** – A user-defined transaction class that holds all the required fields for a single APB operation, such as address, data, and control information.
  - **Sequence** – Produces a stream of sequence items that serve as stimulus for the DUT. The test triggers the sequence to start generating transactions.

- **Sequencer** – Serves as the communication channel between the sequence and the driver. It forwards sequence items to the driver using a TLM interface and ensures proper handshaking.
- **Driver** – Receives transactions from the sequencer and translates them into pin-level APB signal activities. It drives the DUT through the APB interface
- **Monitor** – Observes DUT signal activity using the virtual interface.  
The **active monitor** captures the APB inputs driven to the DUT.  
The **passive monitor** captures the DUT's output responses.  
Both convert observed signal activity back into transaction objects and publish them through TLM analysis ports.
- **Agent** – A modular UVM component that groups related verification elements.  
The **active agent** contains the sequencer, driver, and an input monitor.  
The **passive agent** contains only the monitor that tracks output responses.
- **Scoreboard** – Receives monitored transactions and compares the DUT's output with expected results to detect mismatches.
- **Subscriber** – Collects functional coverage information. It connects to analysis ports from both active and passive monitors to ensure all required scenarios are covered.
- **Environment** – A higher-level container that instantiates and connects all verification components, including agents, the scoreboard, and subscriber.
- **Test** – The top-level UVM class that builds the environment, configures components, and launches sequences that generate stimulus.
- **Top Module** – Instantiates the DUT and interface, connects everything to the UVM testbench, and starts the UVM phase flow.

- **Interface** – Provides the connection between the DUT and the testbench elements, exposing the APB signals to the driver and monitors via the virtual interface.

# CHAPTER 3 - RESULT

## Waveforms:

### Write



### Read



## Write\_ Read



## Slave\_err



## Coverage Report:

### Assertions

| Assertions                 | Failure Count | Pass Count | Attempt Count | Vacuous Count | Disable Count | Active Count | Peak Active Count | Status                                       |
|----------------------------|---------------|------------|---------------|---------------|---------------|--------------|-------------------|----------------------------------------------|
| assert_pclk_valid          | 0             | 3080       | 3080          | 0             | 0             | 0            | 0                 | 1 <span style="color: green;">Covered</span> |
| assert_presetn_valid       | 0             | 3080       | 3080          | 0             | 0             | 0            | 0                 | 1 <span style="color: green;">Covered</span> |
| assert_psel_valid          | 0             | 3079       | 3080          | 0             | 1             | 0            | 0                 | 1 <span style="color: green;">Covered</span> |
| assert_penable_valid       | 0             | 3079       | 3080          | 0             | 1             | 0            | 0                 | 1 <span style="color: green;">Covered</span> |
| assert_pwrite_valid        | 0             | 3079       | 3080          | 0             | 1             | 0            | 0                 | 1 <span style="color: green;">Covered</span> |
| assert_paddr_valid         | 0             | 3079       | 3080          | 0             | 1             | 0            | 0                 | 1 <span style="color: green;">Covered</span> |
| assert_pwdata_valid        | 0             | 3079       | 3080          | 0             | 1             | 0            | 0                 | 1 <span style="color: green;">Covered</span> |
| assert_pstrb_valid         | 0             | 3079       | 3080          | 0             | 1             | 0            | 0                 | 1 <span style="color: green;">Covered</span> |
| setup_access_phase         | 0             | 1024       | 3080          | 2055          | 1             | 0            | 0                 | 1 <span style="color: green;">Covered</span> |
| no_wait_states             | 0             | 1024       | 3080          | 2055          | 1             | 0            | 0                 | 1 <span style="color: green;">Covered</span> |
| psel_stable                | 0             | 1024       | 3080          | 2055          | 1             | 0            | 0                 | 1 <span style="color: green;">Covered</span> |
| prdata_valid               | 0             | 512        | 3080          | 2567          | 1             | 0            | 0                 | 1 <span style="color: green;">Covered</span> |
| pslverr_valid              | 0             | 1024       | 3080          | 2055          | 1             | 0            | 0                 | 1 <span style="color: green;">Covered</span> |
| no_new_input_during_access | 0             | 1024       | 3080          | 2055          | 1             | 0            | 0                 | 1 <span style="color: green;">Covered</span> |

## Questa Coverage Report

|                      |   |
|----------------------|---|
| Number of tests run: | 1 |
| Passed:              | 1 |
| Warning:             | 0 |
| Error:               | 0 |
| Fatal:               | 0 |

[List of tests included in report...](#)

[List of global attributes included in report...](#)

[List of Design Units included in report...](#)

| Coverage Summary by Structure: |        | Coverage Summary by Type: |                 |        |        |          |          |         |            |
|--------------------------------|--------|---------------------------|-----------------|--------|--------|----------|----------|---------|------------|
| Design Scope ▾                 | Hits % | Coverage %                | Total Coverage: |        |        |          | 90.43%   | 96.63%  |            |
| top                            | 89.61% | 97.46%                    | Coverage Type ▾ | Bins ▾ | Hits ▾ | Misses ▾ | Weight ▾ | % Hit ▾ | Coverage ▾ |
| intf                           | 98.93% | 99.60%                    | Covergroups     | 68     | 67     | 1        | 1        | 98.52%  | 91.66%     |
| DUV                            | 77.22% | 94.66%                    | Statements      | 57     | 55     | 2        | 1        | 96.49%  | 96.49%     |
| apb_pkg                        | 98.52% | 91.66%                    | Branches        | 10     | 10     | 0        | 1        | 100.00% | 100.00%    |
| apb_subscriber                 | 98.52% | 91.66%                    | FEC Expressions | 9      | 9      | 0        | 1        | 100.00% | 100.00%    |
|                                |        |                           | FEC Conditions  | 4      | 4      | 0        | 1        | 100.00% | 100.00%    |
|                                |        |                           | Toggles         | 580    | 512    | 68       | 1        | 88.27%  | 88.27%     |
|                                |        |                           | Assertions      | 14     | 14     | 0        | 1        | 100.00% | 100.00%    |

## DUT Coverage:

### Local Instance Coverage Details:

| Total Coverage:                 |      |      |        |        |         | 77.22%         | <b>94.66%</b> |
|---------------------------------|------|------|--------|--------|---------|----------------|---------------|
| Coverage Type                   | Bins | Hits | Misses | Weight | % Hit   | Coverage       |               |
| <a href="#">Statements</a>      | 18   | 18   | 0      | 1      | 100.00% | <b>100.00%</b> |               |
| <a href="#">Branches</a>        | 10   | 10   | 0      | 1      | 100.00% | <b>100.00%</b> |               |
| <a href="#">FEC Expressions</a> | 9    | 9    | 0      | 1      | 100.00% | <b>100.00%</b> |               |
| <a href="#">FEC Conditions</a>  | 4    | 4    | 0      | 1      | 100.00% | <b>100.00%</b> |               |
| <a href="#">Toggles</a>         | 240  | 176  | 64     | 1      | 73.33%  | <b>73.33%</b>  |               |

## Input coverage:

### Covergroup type:

#### input\_cov

| Summary     | Total Bins | Hits | Hit %          |
|-------------|------------|------|----------------|
| Coverpoints | 20         | 20   | <b>100.00%</b> |
| Crosses     | 39         | 39   | <b>100.00%</b> |

| Search: <input type="text"/>     |            |      |        |         |                |                |
|----------------------------------|------------|------|--------|---------|----------------|----------------|
| CoverPoints                      | Total Bins | Hits | Misses | Hit %   | Goal %         | Coverage %     |
| <a href="#">① APB_ADDR</a>       | 5          | 5    | 0      | 100.00% | <b>100.00%</b> | <b>100.00%</b> |
| <a href="#">① APB_WRITE_DATA</a> | 5          | 5    | 0      | 100.00% | <b>100.00%</b> | <b>100.00%</b> |
| <a href="#">① ENABLE</a>         | 1          | 1    | 0      | 100.00% | <b>100.00%</b> | <b>100.00%</b> |
| <a href="#">① SLAVE</a>          | 1          | 1    | 0      | 100.00% | <b>100.00%</b> | <b>100.00%</b> |
| <a href="#">① STRB</a>           | 6          | 6    | 0      | 100.00% | <b>100.00%</b> | <b>100.00%</b> |
| <a href="#">① WRITE_READ</a>     | 2          | 2    | 0      | 100.00% | <b>100.00%</b> | <b>100.00%</b> |

| Search: <input type="text"/>            |            |      |        |         |                |                |
|-----------------------------------------|------------|------|--------|---------|----------------|----------------|
| Crosses                                 | Total Bins | Hits | Misses | Hit %   | Goal %         | Coverage %     |
| <a href="#">① ADDR_X_APB_WRITE_DATA</a> | 25         | 25   | 0      | 100.00% | <b>100.00%</b> | <b>100.00%</b> |
| <a href="#">① WRITE_READ_X_ADDR</a>     | 10         | 10   | 0      | 100.00% | <b>100.00%</b> | <b>100.00%</b> |
| <a href="#">① WRITE_READ_X_ENABLE</a>   | 2          | 2    | 0      | 100.00% | <b>100.00%</b> | <b>100.00%</b> |
| <a href="#">① WRITE_READ_X_SLAVE</a>    | 2          | 2    | 0      | 100.00% | <b>100.00%</b> | <b>100.00%</b> |

## Covergroup type:

**output\_cov**

| Summary     | Total Bins | Hits | Hit %  |
|-------------|------------|------|--------|
| Coverpoints | 9          | 8    | 88.88% |
| Crosses     | 0          | 0    | 0.00%  |

Search:

| CoverPoints                       | Total Bins | Hits | Misses | Hit %   | Goal %  | Coverage % |
|-----------------------------------|------------|------|--------|---------|---------|------------|
| <a href="#">APB_READ_DATA_OUT</a> | 5          | 5    | 0      | 100.00% | 100.00% | 100.00%    |
| <a href="#">APB_SLVERR</a>        | 2          | 2    | 0      | 100.00% | 100.00% | 100.00%    |
| <a href="#">READY</a>             | 2          | 1    | 1      | 50.00%  | 50.00%  | 50.00%     |