

## AHB-Lite Multilayer Interconnect

Datasheet (v1.1)

HTTPS://ROALOGIC.GITHUB.IO/AHB3LITE\_INTERCONNECT

 $16 ext{-Sep-}2019$ 

## **Contents**

| 1 | Intr | oducti   | on                                      | 1  |
|---|------|----------|-----------------------------------------|----|
|   | 1.1  | Featur   | es                                      | 1  |
| 2 | Spe  | cificati | ons                                     | 2  |
|   | 2.1  | Functi   | onal Description                        | 2  |
|   | 2.2  | Master   | r Port                                  | 2  |
|   |      | 2.2.1    | Master Priority                         | 3  |
|   |      | 2.2.2    | Bus Locking Support                     | 3  |
|   |      | 2.2.3    | Specifying the number of Master Ports   | 3  |
|   | 2.3  | Slave 1  | Port                                    | 3  |
|   |      | 2.3.1    | Address Space Configuration             | 4  |
|   |      | 2.3.2    | Slave Port HREADYOUT and HREADY Routing | 5  |
|   |      | 2.3.3    | Specifying the number of Slave Ports    | 6  |
| 3 | Cor  | ıfigura  | tions                                   | 7  |
|   | 3.1  | Introd   | uction                                  | 7  |
|   | 3.2  | Core F   | Parameters                              | 7  |
|   |      | 3.2.1    | HADDR_SIZE                              | 7  |
|   |      | 3.2.2    | HDATA_SIZE                              | 7  |
|   |      | 3.2.3    | MASTERS                                 | 7  |
|   |      | 3.2.4    | SLAVES                                  | 7  |
|   |      | 3.2.5    | SLAVE_MASK[]                            | 7  |
|   |      | 3.2.6    | ERROR_ON_SLAVE_MASK[]                   | 8  |
| 4 | Inte | erfaces  |                                         | 9  |
|   | 4.1  | Global   | Signals                                 | 9  |
|   |      | 4.1.1    | HRESETn                                 | 9  |
|   |      | 4.1.2    | HCLK                                    | 9  |
|   | 4.2  | Master   | r Interfaces                            | 9  |
|   |      | 4.2.1    | mst_priority                            | 10 |
|   |      | 4.2.2    | mst_HSEL                                | 10 |
|   |      | 4.2.3    | mst_HTRANS                              | 10 |
|   |      | 4.2.4    | mst_HADDR                               | 10 |
|   |      | 405      | most HWD ATA                            | 11 |

| 6 | Rev | ision H | History       | 18 |
|---|-----|---------|---------------|----|
| 5 | Res | ources  |               | 17 |
|   |     | 4.3.15  | slv_HRESP     | 16 |
|   |     | 4.3.14  | slv_HREADY    | 16 |
|   |     | 4.3.13  | slv_HREADYOUT | 15 |
|   |     | 4.3.12  | slv_HMASTLOCK | 15 |
|   |     | 4.3.11  | slv_HTRANS    | 15 |
|   |     | 4.3.10  | slv_HPROT     | 15 |
|   |     | 4.3.9   | slv_HBURST    | 14 |
|   |     | 4.3.8   | slv_HSIZE     | 14 |
|   |     | 4.3.7   | slv_HWRITE    | 14 |
|   |     | 4.3.6   | slv_HWDATA    | 14 |
|   |     | 4.3.5   | slv_HRDATA    | 14 |
|   |     | 4.3.4   | slv_HADDR     | 14 |
|   |     | 4.3.3   | slv_HSEL      | 13 |
|   |     | 4.3.2   | slv_addr_mask | 13 |
|   |     | 4.3.1   | slv_addr_base | 13 |
|   | 4.3 |         |               |    |
|   |     |         | mst_HRESP     |    |
|   |     |         | mst_HREADY    |    |
|   |     |         | mst_HMASTLOCK |    |
|   |     |         | mst_HREADYOUT |    |
|   |     | _       | mst_HPROT     |    |
|   |     | 4.2.9   | mst_HBURST    |    |
|   |     | 4.2.8   | mst_HSIZE     |    |
|   |     | 4.2.7   | mst_HWRITE    |    |
|   |     | 4.2.6   | mst_HRDATA    | 11 |

## 1. Introduction

The Roa Logic AHB-Lite Multi-layer Interconnect is a fully parameterized soft IP High Performance, Low Latency Interconnect Fabric for AHB-Lite. It allows a virtually unlimited number of AHB-Lite Bus Masters and Slaves to be connected without the need of bus arbitration to be implemented by the Bus Masters. Instead, Slave Side Arbitration is implemented for each Slave Port within the core.



Figure 1.1: Multi-layer Interconnect Usage Example

The Multi-layer Interconnect supports priority based and Round-Robin based arbitration when multiple Bus Masters request access to the same Slave Port. Typically arbitration completes within 1 clock cycle.

## 1.1 Features

- AMBA AHB-Lite Compatible
- Fully parameterized
- Unlimited number of Bus Masters and Slaves<sup>1</sup>
- Slave side arbitration
- Priority and Round-Robin based arbitration
- Slave Port address decoding

<sup>&</sup>lt;sup>1</sup>The number of Bus Masters and Slaves is physically limited by the timing requirements.

## 2. Specifications

## 2.1 Functional Description

The Roa Logic AHB-Lite Multi-layer Interconnect is a highly configurable Interconnect Fabric for AMBA AHB-Lite based systems, enabling multiple Masters to be connected to multiple Slaves.

Connections are dynamically created based on which Slave a Master is addressing, and once created enable direct communication between Master and Slave without other Masters being aware or interfering.

A new connection is typically created within one clock cycle, providing high bandwidth and low latency communication between Master and Slave.



Figure 2.1: Example Master / Slave Communication Setup

## 2.2 Master Port

An AHB-Lite Bus Master connects to a Master port of the Multi-layer Interconnect. The Master port is implemented as a regular AHB-Lite Slave Interface thereby allowing support for complex bus structures.

The following figure shows an example bus structure where a Bus Master – Master-1 – has two directly connected Slaves; the Interconnect-Master-Port1 and Slave-4

To access a Slave, the Interconnect first checks if the designated Slave Port is available. If it is available the Slave Port immediately switches to the requesting Master. If the Slave Port is occupied due to another Master accessing the Slave, the Master Port generates wait states until the requested Slave becomes available. Note the pipelined nature of the AHB-Lite bus may cause a single wait state to be inserted when the Slave switches to a new Master.

The Slave Port always retains the connection to the Master until another Master requests access to that Slave Port; this enables the original Master to request further access to the Slave without incurring any delay due to arbitration.



Figure 2.2: Connectivity Example for 2 Bus Masters, 4 Slaves

## 2.2.1 Master Priority

Each Master Port has a priority level port (mst\_priority[]).

When multiple Masters with different priority levels request access to the same Slave Port, access is always granted to the Master with the highest priority level. If a new Master requests access while a transaction is already in progress, access will be granted according to its priority, ahead of any waiting lower priority Masters. If Masters have the same priority level, then access is granted based on a Round-Robin scheme.

Master priority may be set dynamically, however assigning a static priority results in a smaller Interconnect and reduces timing paths. The priority value may only be changed while the Master Port is idle; i.e. mst\_HSEL is negated ('0') and/or when mst\_HTRANS is IDLE.

## 2.2.2 Bus Locking Support

The priority levels determine the order in which Masters are granted access to the Slave Port. The Slave Port switches between masters when the current accessing master is idle (mst\_HSEL is negated and/or mst\_HTRANS = IDLE) or when the current burst completes.

However the current Master may lock the bus by asserting HMASTLOCK; this prevents the Slave port switching.

## 2.2.3 Specifying the number of Master Ports

The number of Master Ports is specified by the MASTERS parameter.

## 2.3 Slave Port

An AHB-Lite Bus Slave connects to a Slave Port of the Multi-layer Interconnect. The Slave Port is implemented as a regular AHB3-Lite Master Interface thereby allowing support for complex bus structures such as shown below:



Figure 2.3: Connectivity Example for 2 Bus Masters, 6 Slaves

## 2.3.1 Address Space Configuration

Each Slave Port has an Address Base (slv\_addr\_base) and Address Mask (slv\_addr\_mask) port. Together these set the address range covered by the Slave Port.

The Address Base port specifies the base address for the address range covered by the Slave Port and the Address Mask port defines the address range covered by the Slave Port. The internal port select signal is specified as slv\_addr\_base AND slv\_addr\_mask.

The Address Base and Address Mask values may be changed dynamically, however assigning static values results in a smaller Interconnect and reduces timing paths. Address Base and Address Mask may only be changed when the slave port(s) are idle. Since multiple masters may be active at the same time trying to access the Interconnect, special care must be taken to ensure NO master accesses the Interconnect while updating the Address Base and Address Mask values.

The Slave Port asserts HSEL when accesses are within the port's address range. When the port is not being accessed HSEL is negated ('0'), but HTRANS and other AMBA signals will still provide data. These signals must be ignored while HSEL is negated ('0').

The slave port will output the full address, i.e. all HADDR\_SIZE bits, on its address bus (slv\_HADDR). Connected AMBA slaves should use the relevant least significant bits (LSBs) only.

## Example 1

```
slave_addr_base = 32'h1000_0000
slave_addr_mask = 32'hF000_0000
Address-range = 32'h1000 0000 to 32'h1FFF FFFF
```

## Example 2

```
slave_addr_base = 32'h4000_0000
slave_addr_mask = 32'hE000_0000
Address-range = 32'h4000_0000 to 32'h5FFF_FFFF
```

## 2.3.2 Slave Port HREADYOUT and HREADY Routing

The Slave Port has an HREADYOUT port, which is not part of the AHB-Lite specification. It is required to support slaves on the master's local bus. The HREADY signal, generated by the multiplexor, is driven to the addressed slave's HREADYOUT port.



Figure 2.4: HREADYOUT and HREADY Routing

The simple case of where only one master is connected to a Master Port or where only a single slave is connected to a Slave Port is illustrated below.

There are no multiplexors on either the Master Bus or the Slave Bus. Since there is no other slave on the Master Bus, its HREADY signal is only driven by the Master Port's HREADYOUT signal. Thus the Master Port's HREADYOUT drives both the Master's HREADY input and the Master Port's HREADY input.

Similarly since there is no other slave on the Slave Bus, the Slave Port's HREADYOUT signals drives the slave's HREADY input and the slave's HREADYOUT signal drives the Slave Port's HREADY input.



Figure 2.5: Single Master/Slave Routing

## 2.3.3 Specifying the number of Slave Ports

The number of Slave Ports is specified by the SLAVES parameter.

## 3. Configurations

## 3.1 Introduction

The Roa Logic AHB-Lite Multi-layer Interconnect is a highly configurable Interconnect Fabric for AMBA AHB-Lite based systems. The core parameters and configuration options are described in this section.

## 3.2 Core Parameters

| Type    | Default                                           | Description                                              |
|---------|---------------------------------------------------|----------------------------------------------------------|
| Integer | 32                                                | Address Bus Size                                         |
| Integer | 32                                                | Data Bus Size                                            |
| Integer | 3                                                 | Number of Master Ports                                   |
| Integer | 8                                                 | Number of Slave Ports                                    |
| Array   | All '1's                                          | Mask Slaves accessible by                                |
|         |                                                   | each Master                                              |
| Array   | All '1's                                          | Enable Error Reporting for masked Slaves                 |
|         | Integer<br>Integer<br>Integer<br>Integer<br>Array | Integer 32 Integer 32 Integer 3 Integer 8 Array All '1's |

Table 3.1: Core Parameters

## 3.2.1 HADDR\_SIZE

The HADDR\_SIZE parameter specifies the width of the address bus for all Master and Slave ports.

#### 3.2.2 HDATA\_SIZE

The HDATA\_SIZE parameter specifies the width of the data bus for all Master and Slave ports.

#### 3.2.3 MASTERS

The MASTERS parameter specifies the number of Master Ports on the Interconnect fabric.

#### **3.2.4 SLAVES**

The SLAVES parameter specifies the number of Slave Ports on the Interconnect Fabric.

## 3.2.5 SLAVE\_MASK[]

The SLAVE\_MASK[] parameter determines if a master may access a slave. Defining which master may access individual slaves (rather than allowing all masters to access all slaves) may significantly reduce the logic area of the interconnect and improve overall performance.

There is one  $SLAVE\_MASK$  parameter per master, each SLAVES bits wide. i.e.  $SLAVE\_MASK[]$  is an array of dimensions MASTERS x SLAVES.

Setting a SLAVE\_MASK[] bit to '0' indicates that master cannot access the slave. Conversely, setting a SLAVE\_MASK[] bit to '1' indicates that master may access the slave.

## 3.2.6 ERROR\_ON\_SLAVE\_MASK[]

The ERROR\_ON\_SLAVE\_MASK[] parameter enables generating an AHB error response when the master attempts to access a masked Slave Port.

There is one ERROR\_ON\_SLAVE\_MASK parameter per master, each SLAVES bits wide. i.e. ERROR\_ON\_SLAVE\_MASK[] is an array of dimensions MASTERS x SLAVES.

Setting an ERROR\_ON\_SLAVE\_MASK[] bit to '0' indicates that an AHB error response will not be generated if the master is masked from accessing the corresponding slave. Conversely, setting a ERROR\_ON\_SLAVE\_MASK[] bit to '1' indicates that an AHB error response will be generated if the master is masked from accessing the corresponding slave - this is the default setting.

## 4. Interfaces

## 4.1 Global Signals

The common signals are shared between all devices on the AHB bus. The AHB-Lite Interconnect has Master and Slave AHB-Lite buses and they all use the global signals.

| Port    | Size | Direction | Description                   |
|---------|------|-----------|-------------------------------|
| HRESETn | 1    | Input     | Asynchronous active low reset |
| HCLK    | 1    | Input     | System clock input            |

Table 4.1: AMBA3 Global Signals

#### 4.1.1 HRESETn

When the active low asynchronous HRESETn input is asserted ('0'), the core is put into its initial reset state.

#### 4.1.2 HCLK

HCLK is the system clock. All internal logic operates at the rising edge of the system clock. All AHB bus timings are related to the rising edge of HCLK. All Master and Slave ports must operate at the same HCLK clock.

## 4.2 Master Interfaces

The Master Ports are regular AHB3-Lite slave interfaces. All signals are supported. See the AHB-Lite specifications for a complete description of the signals.

The AHB-Lite Multi-layer Interconnect implements 1 or more interfaces to AHB-Lite masters as defined by the MASTERS parameter. Therefore the following signals are all arrays reflecting the number of masters supported.

| Port         | Size                                      | Direction | Description            |
|--------------|-------------------------------------------|-----------|------------------------|
| mst_priority | $\operatorname{clog}_2(\mathtt{MASTERS})$ | Input     | Master Priority Levels |

Table 4.2: Master Interface Customisation Port

**Note:** clog<sub>2</sub>() refers to the System Verilog function by the same name, defined below, and is used to determine the required bitwidth of a bus required to represent the defined range of values:

The system function \$clog2 shall return the ceiling of the log base 2 of the argument (the log rounded up to an integer value). The argument can be an integer or an arbitrary sized vector value. The argument shall be treated as an unsigned value, and an argument value of 0 shall produce a result of 0.

| Port                   | Size                | Direction | Description               |
|------------------------|---------------------|-----------|---------------------------|
| mst_HSEL               | 1                   | Input     | Bus Select                |
| ${\tt mst\_HTRANS}$    | 2                   | Input     | Transfer Type             |
| ${\tt mst\_HADDR}$     | ${\tt HADDR\_SIZE}$ | Input     | Address Bus               |
| ${\tt mst\_HWDATA}$    | ${\tt HDATA\_SIZE}$ | Input     | Write Data Bus            |
| ${\tt mst\_HRDATA}$    | HDATA_SIZE          | Output    | Read Data Bus             |
| mst_HWRITE             | 1                   | Input     | Write Select              |
| mst_HSIZE              | 3                   | Input     | Transfer Size             |
| $mst\_HBURST$          | 3                   | Input     | Transfer Burst Size       |
| $mst\_HPROT$           | 4                   | Input     | Transfer Protection Level |
| ${\tt mst\_HMASTLOCK}$ | 1                   | Input     | Transfer Master Lock      |
| ${\tt mst\_HREADYOUT}$ | 1                   | Output    | Transfer Ready Output     |
| mst_HREADY             | 1                   | Input     | Transfer Ready Input      |
| mst_HRESP              | 1                   | Input     | Transfer Response         |

Table 4.3: Master Interface AHB-Lite Port

## 4.2.1 mst\_priority

mst\_priority defines the priority of each master. The width of the bus is calculated as clog<sub>2</sub>(MASTERS). For example, for a system with 4 masters the width of mst\_priority will be 2 bits.

Lowest priority is 0, highest priority is MASTERS - 1.

## 4.2.2 mst\_HSEL

The Master Port only responds to other signals on its bus when mst\_HSEL is asserted ('1'). When mst\_HSEL is negated ('0') the Master Port considers the bus IDLE and negates HREADYOUT ('0').

## 4.2.3 mst\_HTRANS

mst\_HTRANS indicates the type of the current transfer. It is driven to the connected slave.

| HTRANS | Type   | Description                                       |
|--------|--------|---------------------------------------------------|
| 00     | IDLE   | No transfer required                              |
| 01     | BUSY   | Connected master is not ready to accept data, but |
|        |        | intents to continue the current burst.            |
| 10     | NONSEQ | First transfer of a burst or a single transfer    |
| 11     | SEQ    | Remaining transfers of a burst                    |

Table 4.4: Transfer Type (HTRANS)

### 4.2.4 mst\_HADDR

mst\_HADDR is the address bus. Its size is determined by the HADDR\_SIZE parameter. It is driven to the connected slave.

## 4.2.5 mst\_HWDATA

mst\_HWDATA is the write data bus. Its size is determined by the HDATA\_SIZE parameter. It is driven to the connected slave.

## 4.2.6 mst\_HRDATA

mst\_HRDATA is the read data bus. Its size is determined by HDATA\_SIZE parameter. The connected slave drives it.

## 4.2.7 mst\_HWRITE

mst\_HWRITE is the read/write signal. mst\_HWRITE asserted ('1') indicates a write transfer. It is driven to the connected slave.

### 4.2.8 mst\_HSIZE

mst\_HSIZE indicates the size of the current transfer. It is driven to the connected slave.

| HSIZE | Size     | Description |
|-------|----------|-------------|
| 000   | 8bit     | Byte        |
| 001   | 16 bit   | Half Word   |
| 010   | 32bit    | Word        |
| 011   | 64bits   | Double Word |
| 100   | 128bit   |             |
| 101   | 256bit   |             |
| 110   | 512 bit  |             |
| 111   | 1024 bit |             |

Table 4.5: Transfer Size Values (HSIZE)

## 4.2.9 mst\_HBURST

The burst type indicates if the transfer is a single transfer or part of a burst. It is driven to the connected slave.

| HBURST | Type   | Description                  |
|--------|--------|------------------------------|
| 000    | SINGLE | Single access                |
| 001    | INCR   | Continuous incremental burst |
| 010    | WRAP4  | 4-beat wrapping burst        |
| 011    | INCR4  | 4-beat incrementing burst    |
| 100    | WRAP8  | 8-beat wrapping burst        |
| 101    | INCR8  | 8-beat incrementing burst    |
| 110    | WRAP16 | 16-beat wrapping burst       |
| 111    | INCR16 | 16-beat incrementing burst   |

Table 4.6: Burst Types (HBURST)

### 4.2.10 mst\_HPROT

The protection signals provide information about the bus transfer. They are intended to implement some level of protection. It is driven to the connected slave.

| Bit # | Value | Description                    |
|-------|-------|--------------------------------|
| 3     | 1     | Cacheable region addressed     |
|       | 0     | Non-cacheable region addressed |
| 2     | 1     | Bufferable                     |
|       | 0     | Non-bufferable                 |
| 1     | 1     | Privileged Access              |
|       | 0     | User Access                    |
| 0     | 1     | Data Access                    |
|       | 0     | Opcode fetch                   |

Table 4.7: Protection Signals (HPROT)

## 4.2.11 mst\_HREADYOUT

When a slave is addressed, the mst\_HREADYOUT indicates that the addressed slave finished the current transfer. The Interconnect IP routes the addressed slave's HREADY signal to the master.

When no slave is addressed, the  ${\tt mst\_HREADYOUT}$  signal is generated locally, inside the Interconnect.

#### 4.2.12 mst\_HMASTLOCK

The master lock signal indicates if the current transfer is part of a locked sequence, commonly used for Read-Modify-Write cycles. While the mst\_HMASTLOCK is asserted, the Interconnect IP cannot switch the addressed slave to another master, even if that master has a higher priority. Instead the current master retains access to slave until it releases mst\_HMASTLOCK.

#### 4.2.13 mst\_HREADY

mst\_HREADY indicates the status of the local HREADY on the master's local bus. It is routed to the HREADYOUT port of the connected slave.

#### 4.2.14 mst\_HRESP

mst\_HRESP is the transfer response from the connected slave, it can either be OKAY ('0') or ERROR ('1'). The Interconnect IP routes the connected slave's HRESP port to mst\_HRESP.

## 4.3 Slave Interface

The Slave Ports are regular AHB-Lite master interfaces.. All signals are supported. In addition each Slave Port has a non-standard slv\_HREADYOUT. See the AHB-Lite specifications for a complete description of the signals.

The AHB-Lite Multi-layer Interconnect implements 1 or more interfaces to AHB-Lite slaves as defined by the SLAVES parameter. Therefore the following signals are all arrays reflecting the number of slaves supported.

| Port                    | Size       | Direction | Description              |
|-------------------------|------------|-----------|--------------------------|
| slv_addr_base           | HADDR_SIZE | Input     | Slave Base Address       |
| ${\tt slv\_addr\_mask}$ | HADDR_SIZE | Input     | Slave Address Space Mask |

Table 4.8: Slave Interface Customisation Port

| Port          | Size                | Direction | Description               |
|---------------|---------------------|-----------|---------------------------|
| slv_HSEL      | 1                   | Output    | Bus Select                |
| $slv\_HADDR$  | ${\tt HADDR\_SIZE}$ | Output    | Address                   |
| slv_HWDATA    | HDATA_SIZE          | Output    | Write Data Bus            |
| slv_HRDATA    | $HDATA\_SIZE$       | Input     | Read Data Bus             |
| slv_HWRITE    | 1                   | Output    | Write Select              |
| slv_HSIZE     | 3                   | Output    | Transfer size             |
| slv_HBURST    | 3                   | Output    | Transfer Burst Size       |
| slv_HPROT     | 4                   | Output    | Transfer Protection Level |
| slv_HTRANS    | 2                   | Input     | Transfer Type             |
| slv_HMASTLOCK | 1                   | Output    | Transfer Master Lock      |
| slv_HREADY    | 1                   | Input     | Transfer Ready Input      |
| slv_HRESP     | 1                   | Input     | Transfer Response         |

Table 4.9: Slave Interface AHB-Lite Port

## 4.3.1 slv\_addr\_base

slv\_addr\_base is a SLAVES sized array of addresses, each HADDR\_SIZE bits wide, defining the base address of each attached slave device.

### 4.3.2 slv\_addr\_mask

slv\_addr\_mask is a SLAVES sized array of HADDR\_SIZE bit wide signals. Each slv\_addr\_base address is masked with the corresponding slv\_addr\_mask value to define the addressable memory space of the attached slave. Setting a bit of slv\_addr\_mask to '0' enables the corresponding address bit.

See section 2.3.1 for specific examples.

#### 4.3.3 slv\_HSEL

Slaves connected to the Slave Port must only respond to other signals on the bus when slv\_HSEL is asserted ('1'). When slv\_HSEL is negated ('0') the interface is idle and the connected Slaves must assert their HREADYOUT ('1').

## 4.3.4 slv\_HADDR

slv\_HADDR is the data address bus. Its size is determined by the HADDR\_SIZE parameter. The connected master drives slv\_HADDR.

## 4.3.5 slv\_HRDATA

slv\_HRDATA is the read data bus. Its size is determined by the HDATA\_SIZE parameter. It is driven to the connected master.

## 4.3.6 slv\_HWDATA

slv\_HWDATA is the write data bus. Its size is determined by the HDATA\_SIZE parameter. The connected master drives slv\_HADDR.

## 4.3.7 slv\_HWRITE

slv\_HWRITE is the read/write signal. slv\_HWRITE asserted ('1') indicates a write transfer. The connected master drives slv\_HWRITE.

#### 4.3.8 slv\_HSIZE

slv\_HSIZE indicates the size of the current transfer. The connected master drives slv\_HSIZE.

| HSIZE | Size     | Description |
|-------|----------|-------------|
| 000   | 8bit     | Byte        |
| 001   | 16 bit   | Half Word   |
| 010   | 32 bit   | Word        |
| 011   | 64bits   | Double Word |
| 100   | 128bit   |             |
| 101   | 256bit   |             |
| 110   | 512 bit  |             |
| 111   | 1024 bit |             |

Table 4.10: Data Transfer Sizes

## 4.3.9 slv\_HBURST

The burst type indicates if the transfer is a single transfer or part of a burst. The connected master drives it.

| HBURST | Type   | Description                  |
|--------|--------|------------------------------|
| 000    | Single | Single access                |
| 001    | INCR   | Continuous incremental burst |
| 010    | WRAP4  | 4-beat wrapping burst        |
| 011    | INCR4  | 4-beat incrementing burst    |
| 100    | WRAP8  | 8-beat wrapping burst        |
| 101    | INCR8  | 8-beat incrementing burst    |
| 110    | WRAP16 | 16-beat wrapping burst       |
|        |        |                              |

| HBURST | Type   | Description                |
|--------|--------|----------------------------|
| 111    | INCR16 | 16-beat incrementing burst |

Table 4.11: Burst Types (HBURST)

#### 4.3.10 slv\_HPROT

The data protection signals provide information about the bus transfer. They are intended to implement some level of protection. The connected master drives slv\_HPROT.

| Bit# | Value | Description                                |
|------|-------|--------------------------------------------|
| 3    | 1     | Cacheable region addressed                 |
|      | 0     | Non-cacheable region addressed             |
| 2    | 1     | Bufferable                                 |
|      | 0     | Non-bufferable                             |
| 1    | 1     | Privileged access. CPU is not in User Mode |
|      | 0     | User access. CPU is in User Mode           |
| 0    | 1     | Data transfer, always '1'                  |

Table 4.12: Data Protection Signals

### 4.3.11 slv\_HTRANS

slv\_HTRANS indicates the type of the current data transfer.

| slv_HTRANS | Type   | Description                          |
|------------|--------|--------------------------------------|
| 00         | IDLE   | No transfer required                 |
| 01         | BUSY   | Not used                             |
| 10         | NONSEQ | First transfer of an data burst      |
| 11         | SEQ    | Remaining transfers of an data burst |

Table 4.13: Data Transfer Type

### 4.3.12 slv\_HMASTLOCK

The master lock signal indicates if the current transfer is part of a locked sequence, commonly used for Read-Modify-Write cycles. The connected master drives slv\_MASTLOCK.

## 4.3.13 slv\_HREADYOUT

The slv\_HREADYOUT signal reflects the state of the connected Master Port's HREADY port. It is provided to support local slaves connected directly to the Master's AHB-Lite bus. It is driven by the connected master's HREADY port.

Note: slv\_HREADYOUT is not an AHB-Lite Signal.

## 4.3.14 slv\_HREADY

slv\_HREADY indicates whether the addressed slave is ready to transfer data or not. When slv\_HREADY is negated ('0') the slave is not ready, forcing wait states. When slv\_HREADY is asserted ('0') the slave is ready and the transfer completed. It is driven to the connected master's HREADYOUT port.

## 4.3.15 slv\_HRESP

slv\_HRESP is the data transfer response, it can either be OKAY ('0') or ERROR ('1'). It is driven to the connected master.

## 5. Resources

Below are some example implementations for various platforms.

All implementations are push button, no effort has been undertaken to reduce area or improve performance.

| Platform | DFF | Logic Cells | Memory | Performance (MHz) |
|----------|-----|-------------|--------|-------------------|
| lfxp3c-5 | 34  | 103         | 0      | $226\mathrm{MHz}$ |

Table 5.1: Resource Utilisation Examples

# 6. Revision History

| Date                      | Rev. | Comments                              |
|---------------------------|------|---------------------------------------|
| 13-Oct-2017               | 1.0  | Initial Release                       |
| $16	ext{-}Sep	ext{-}2019$ | 1.1  | Updated to add SLAVE_MASK[] Parameter |
| 16-Sep-2019               | 1.1  | Updated to add SLAVE_MASK[] Parameter |

Table 6.1: Revision History