## 2018-MS-EE-37

Verification Report

**AHB Slave** 

## Introduction to the Device-Under-Test (DUT)

Design-Under-Test is the Advanced Microcontroller Bus Architecture (AMBA) Advance High performance Bus (AHB) interface between masters and slaves. Its features like wide data bus and burst transfers allow high performance systems with high clock frequency. AHB Slave (Core-1) receives 32-bit Write Data bus and Read Data bus with 32 bit Address Bus. It supports 4 transfer types decided by HTRANS. This protocol can support single transfer, incremental burst transfer and wrapped burst transfer depending on the control signal HBURST and HSIZE. This DUT can handle multiple slaves, their selection depending on higher order bits of Address using decoder. Output back to Master is controlled via multiplexor. Slave gives output of HREADY and HRESP to show the transfer status.

## Verification Plan

| No. | Feature                                                    | Test Description                                                                                                                                                                                         | Ref.                                                   | Туре | Result | Comments                                                                 | Stimulus |
|-----|------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|------|--------|--------------------------------------------------------------------------|----------|
| 1   | Reset                                                      | Assert reset. During reset all masters must ensure the address and control signals are at valid levels and that HTRANS [1:0] indicates IDLE.  During reset all slaves must ensure that HREADYOUT is HIGH | ARM® AMBA® 5 AHB Protocol Specification/ Sec. 7.1.2    | Т    |        | All signals values are according to the test description                 | Direct   |
| 2   | One Write, and<br>then IDLE/ One<br>Read, and then<br>IDLE | Perform one write operation, and then IDLE/<br>read operation and then IDLE                                                                                                                              | ARM® AMBA® 5 AHB Protocol Specification/ Sec.3.1       | Т    |        | Transitions are working fine according to test case                      | Direct   |
| 3   | Write and read to<br>a particular<br>memory location       | Perform write to any memory location, read from the same memory location, read data should be the same as written data                                                                                   | ARM® AMBA® 5 AHB Protocol Specification/ Sec.3.1       | Т    |        | Read data is the same as written data on corresponding address locations | Direct   |
| 4   | Write and read to all memory locations                     | Perform write and read to all the memory locations. Write to all and then Read from all locations                                                                                                        | ARM® AMBA® 5 AHB<br>Protocol<br>Specification/ Sec.3.5 | Т    |        | Read data is the same as written data on all address locations           | Direct   |

| 1 | i                           |                                                                                                                             | 1                                                             | 1 | 1 | i i                                                                                                                     | ı      |
|---|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|---|---|-------------------------------------------------------------------------------------------------------------------------|--------|
| 5 | Address and Data randomized | Random data would be written on random memory address and randomly write or read back from the same address for comparison. | ARM® AMBA® 5 AHB Protocol Specification/ Sec.3.1/3.5          | Т |   | The written data and the read data where same                                                                           | Random |
| 6 | Randomize data only         | Random data would be written on particular memory address and read back from the same address for comparison.               | ARM® AMBA® 5 AHB Protocol Specification/ Sec.3.1/3.5          | Т |   | Random data was<br>written on<br>particular memory<br>location. The same<br>data is read, and<br>the result was<br>same | Random |
| 7 | Randomize<br>address only   | Data would be written on random memory address and read back from the same address for comparison                           | ARM® AMBA® 5 AHB<br>Protocol<br>Specification/<br>Sec.3.1/3.5 | Т |   | Data was written on random addresses and then read. The written and read was same.                                      | Random |
| 8 | Address out of range        | Data would be written on memory location which is out of range of the given design. It should create an Error.              | ARM® AMBA® 5 AHB<br>Specification/<br>Sec.1.3/2.2             | Т |   | Address is out of range and an Error end of the execution                                                               | Direct |

| 9  | Different Size of Data Transfer Depending on HSIZE [2:0] (With in word limit i.e., 32 bits)         | Data (Word/Half word/Byte) would be written and read based on HSIZE on different memory locations. The written data and read data should be same                                                     | ARM® AMBA® 5 AHB Protocol Specification/ Sec.2.2/3.4 | Т | Word/Halfword/<br>Bytes were written<br>and then read. The<br>read data was<br>same as written            | Direct |
|----|-----------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|---|-----------------------------------------------------------------------------------------------------------|--------|
| 10 | Writing Byte and reading Halfword and Word                                                          | Writing the Byte on a memory location and then reading Halfword format and Word format.                                                                                                              | ARM® AMBA® 5 AHB Protocol Specification/ Sec.2.2/3.4 | Т | Read data is not of byte format                                                                           | Direct |
| 11 | Different Size of Data Transfer Depending on HSIZE [2:0] (Greater than the word limit i.e. 32 bits) | Data (Double Word/ 4-word line/ 8- word line) would be written and read based on HSIZE on different memory locations. An error should be generated since data is out of range from the given design. | ARM® AMBA® 5 AHB Protocol Specification/ Sec.2.2/3.4 | Т | Test is failed for the given design because data width is greater than the data width of the given design | Direct |

| 12 | Write and read    | When HSELx is low, no write and read          | ARM® AMBA® 5 AHB        |   |            | When HSELx is 0 or  |        |
|----|-------------------|-----------------------------------------------|-------------------------|---|------------|---------------------|--------|
|    | when HSELx is low | operation in the slave core 1.                | Protocol                | Т |            | 1 slave responds    | Direct |
|    |                   |                                               | Specification/          |   |            | back.               | Direct |
|    |                   |                                               | Sec.2.4/4.2             |   |            |                     |        |
| 13 | Random data       | Random data having specific range will be     | ARM® AMBA® 5 AHB        |   |            | Random data was     |        |
|    | generation in a   | written on all memory locations and then      | Protocol                |   |            | written and then    |        |
|    | specific range    | will be read.                                 | Specification/ Sec.2.2- | Т |            | read. The written   | Random |
|    |                   |                                               | 2.4/6.1                 |   |            | data and read data  |        |
|    |                   |                                               |                         |   |            | were the same       |        |
| 14 | Random Address    | Data would be written on random address       | ARM® AMBA® 5 AHB        |   |            | Address is out of   |        |
|    | generation in     | having value in a specific range              | Protocol                |   |            | range and an Error  |        |
|    | specific range    |                                               | Specification/ Sec.2.2- | Т |            | is generated at the | Random |
|    |                   |                                               | 2.4/6.1                 |   |            | end of the          |        |
|    |                   |                                               |                         |   |            | execution           |        |
| 15 | BURST operation   | Data in BURST format i.e., INCR4, HSIZE byte, | ARM® AMBA® 5 AHB        |   |            | BURST operation is  |        |
|    | with HBURST and   | INCR4, HSIZE halfword, to HUBRST INCR16,      | Protocol                | - |            | not supported by    | Divoct |
|    | HSIZE selection   | HSIZE doubleword will be written and then     | Specification/ Sec.3.5  | Т | the design | Direct              |        |
|    |                   | read                                          |                         |   |            |                     |        |
| 16 | Randomize all     | All fields with rand data type in transaction | ARM® AMBA® 5 AHB        |   |            | The given fields    |        |
|    |                   | will be randomized and response of the        | Protocol                |   |            | with rand data      |        |
|    |                   | design will be checked.                       | Specification/ sec      |   |            | type was            |        |
|    |                   |                                               | 3.1/sec 3.5             | Т |            | randomized. Data    | Random |
|    |                   |                                               |                         |   |            | read was found to   |        |
|    |                   |                                               |                         |   |            | be same as written  |        |
|    |                   |                                               |                         |   |            | data.               |        |

| 17 | Error sequence     | Error sequence should comprise of two          | ARM® AMBA® 5 AHB       |   | Error sequence    |  |
|----|--------------------|------------------------------------------------|------------------------|---|-------------------|--|
|    |                    | cycles, HREADY will be low for first cycle and | Protocol               |   | remained for two  |  |
|    |                    | then will be high in second cycle              | Specification/ sec     | Α | cycles as per     |  |
|    |                    |                                                | 3.6.2                  |   | design            |  |
|    |                    |                                                |                        |   | specifications    |  |
| 18 | Transfer Data size | The values for HSIZE should be between         | ARM® AMBA® 5 AHB       |   | HSIZE exceeded    |  |
|    |                    | 3'b000 and 3'b010.                             | Protocol               | Α | the given range   |  |
|    |                    |                                                | Specification/ sec 3.4 |   |                   |  |
| 19 | BURST operation    | During the BURST transfer either, INCR or      | ARM® AMBA® 5 AHB       |   | During BURST      |  |
|    |                    | WRAP, HISZE and HBURST should remain           | Protocol               | Α | transfer, HSIZE   |  |
|    |                    | same.                                          | Specification/ sec 3.5 |   | remained same     |  |
| 20 | Transfer Type      | When HREADY signal is low, HTRANS should       | ARM® AMBA® 5 AHB       |   | When HREADY was   |  |
|    | excep              | be kept constant by the master. There is an    | Protocol               | ^ | low, HTRANS       |  |
|    |                    | exception for this one in BUSY or IDLE         |                        | А |                   |  |
|    |                    | Transfer                                       | Specification/ sec     |   | remained constant |  |
|    |                    |                                                | 3.6.1                  |   |                   |  |
| 21 | Address Constant   | During the phase when HTRANS transfer          | ARM® AMBA® 5 AHB       |   | When HREADY was   |  |
|    | when slave is not  | type is changed to NONSEQ i.e. 2'b10, the      | Protocol               | Α | low, Address      |  |
|    | ready              | address should remain constant when            | Specification/ sec     | A | remained constant |  |
|    |                    | HREADY is low                                  | 3.6.1                  |   |                   |  |

## Explanation of Different Fields

No.

**Feature** 

**Test Description** 

Ref.

Type

Result

**Comments** 

Coverage

**Stimulus** 

The serial number of the test.

The feature which the current test is verifying in full or partially.

The feature is usually on the abstraction level of a user.

A detailed description of the test case being performed.

You can be as verbose as you want.

Reference to the section in the related standard document.

The section number as well as page numbers should be described here.

Type of the test. Whether the test is an assertion (A) or a transaction (T) type.

Pass (P) or Fail (F).

Any other comments about the test or its results that you want to mention.

Code or Functional

Mention the kind of stimulus give. i.e directed system verilog