

# AXI4 to AXI4-Lite Bridge (Beta Release)

Version 0.1



#### Copyright

Copyright © 2021 Rapid Silicon. All rights reserved. This document may not, in whole or part, be reproduced, modified, distributed, or publicly displayed without prior written consent from Rapid Silicon ("Rapid Silicon").

#### **Trademarks**

All Rapid Silicon trademarks are as listed at www.rapidsilicon.com. Synopsys and Synplify Pro are trademarks of Synopsys, Inc. Aldec and Active-HDL are trademarks of Aldec, Inc. Modelsim and Questa are trademarks or registered trademarks of Siemens Industry Software Inc. or its subsidiaries in the United States or other countries. All other trademarks are the property of their respective owners.

#### **Disclaimers**

NO WARRANTIES: THE INFORMATION PROVIDED IN THIS DOCUMENT IS "AS IS" WITHOUT ANY EXPRESS OR IMPLIED WARRANTY OF ANY KIND INCLUDING WARRANTIES OF ACCURACY, COMPLETENESS, MERCHANTABILITY, NONINFRINGEMENT OF INTELLECTUAL PROPERTY, OR FITNESS FOR ANY PARTICULAR PURPOSE. IN NO EVENT WILL RAPID SILICON OR ITS SUPPLIERS BE LIABLE FOR ANY DAMAGES WHATSOEVER (WHETHER DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL, INCLUDING, WITHOUT LIMITATION, DAMAGES FOR LOSS OF PROFITS, BUSINESS INTERRUPTION, OR LOSS OF INFORMATION) ARISING OUT OF THE USE OF OR INABILITY TO USE THE INFORMATION PROVIDED IN THIS DOCUMENT, EVEN IF RAPID SILICON HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. BECAUSE SOME JURISDICTIONS PROHIBIT THE EXCLUSION OR LIMITATION OF CERTAIN LIABILITY, SOME OF THE ABOVE LIMITATIONS MAY NOT APPLY TO YOU.

Rapid Silicon may make changes to these materials, specifications, or information, or to the products described herein, at any time without notice. Rapid Silicon makes no commitment to update this documentation. Rapid Silicon reserves the right to discontinue any product or service without notice and assumes no obligation to correct any errors contained herein or to advise any user of this document of any correction if such be made. Rapid Silicon recommends its customers obtain the latest version of the relevant information to establish that the information being relied upon is current and before ordering any products.



## **Contents**

| IP Summary                      | 3  |
|---------------------------------|----|
| Introduction                    | 3  |
| Overview                        | 4  |
| AXI4 to AXI4-Lite Bridge        | 4  |
| IP Specification                | 5  |
| Standards                       | 6  |
| IP Support Details              | 7  |
| Parameters                      | 7  |
| Resource Utilization            | /  |
| Port List                       | č  |
| Design Flow                     | 10 |
| IP Customization and Generation | 10 |
| Parameters Customization        | 11 |
| Example Design                  | 12 |
| Overview                        |    |
| Simulating the Example Design   |    |
| Synthesis and PR                |    |
| Test Bench                      | 13 |
| Release                         | 15 |
| Release History                 | 15 |



# **IP Summary**

#### Introduction

An AXI to AXI Lite bridge is a type of interface that allows communication between a master that uses the AXI protocol and a slave that uses the AXI Lite protocol. The bridge acts as a translator, converting the signals and commands from one protocol to the other, allowing the two devices to communicate with each other. This is typically used in system designs where different IP blocks may use different protocols for communication. This AXI4 compliant bridge can be used in a number of IPs that support either AXI4 or AXILite interface.

#### **Features**

- · Configurable Data Width for the AXI Master and Slave interfaces.
- · Configurable Address Width for AXI Master and Slave interfaces.
- · Configurable ID Width for AXI Slave interface.
- Conversion from AXI to AXI-lite with no performance loss.
- · Maintains the one-clock per transition speed of AXI.
- Buffer to handle bursts that can maintain full speed of the AXI.



## **Overview**

#### **AXI4 to AXI4-Lite Bridge**

An AXI to AXI-Lite bridge serves as a communication link between two different bus protocols in a system-on-chip (SoC) design. The AXI protocol is designed for high-performance and high-bandwidth communication between devices like processors, memory controllers, and high-speed peripherals. In contrast, the AXI-Lite protocol is a simplified version of AXI and is used for connecting low-bandwidth peripherals and control registers. The AXI to AXI-Lite bridge acts as a mediator, enabling communication between the two protocols. It receives AXI transactions from the high-speed bus and converts them into AXI-Lite transactions that can be understood by the low-bandwidth bus. Similarly, it receives AXI-Lite transactions from the low-bandwidth bus and converts them into AXI transactions that can be understood by the high-speed bus. Aside from protocol translation, the AXI to AXI-Lite bridge also performs additional functions like address mapping, data buffering, and protocol optimization to ensure efficient and reliable data transfer between the different bus types. The AXI to AXI-Lite bridge is an essential component in a system-on-chip design or an FPGA that facilitates smooth integration of high-speed and low-speed peripherals. A block diagram for the AXI to AXI-Lite Bridge IP is shown in Figure 1.



Figure 1: AXI4 to AXI4-Lite Bridge Block Diagram



# **IP Specification**

The AXI to AXI-Lite bridge is a hardware component that facilitates communication between devices operating with the AXI protocol and those operating with the AXI-Lite protocol in a system-on-chip (SoC) design. The bridge acts as a mediator and translator, enabling seamless integration of high-speed and low-speed peripherals in an SoC. The working of the bridge is detailed as below:

#### Protocol Translation

The AXI to AXI-Lite bridge supports protocol translation from the AXI protocol to the AXI-Lite protocol and vice versa. It is capable of receiving AXI transactions from the high-speed bus and converting them into AXI-Lite transactions that can be understood by the low-speed bus. Similarly, it is able to receive AXI-Lite transactions from the low-speed bus and convert them into AXI transactions that can be understood by the high-speed bus.

#### Address Mapping

The AXI to AXI-Lite bridge supports address mapping, enabling it to map AXI addresses to AXI-Lite addresses and vice versa. This is necessary because the AXI and AXI-Lite protocols have different address widths, and mapping the addresses enables smooth communication between the devices.

#### · Data Buffering

The AXI to AXI-Lite bridge supports data buffering to avoid data loss due to congestion. When the high-speed bus is sending data to the low-speed bus, the bridge should buffer the data and release it to the low-speed bus at a rate that the bus can handle. Similarly, when the low-speed bus is sending data to the high-speed bus, the bridge buffers the data and release it at a rate that the high-speed bus can handle.

#### Protocol Optimization

The AXI to AXI-Lite bridge supports protocol optimization to ensure efficient and reliable data transfer between the two buses. The bridge optimizes the AXI transactions and AXI-Lite transactions to minimize latency and maximize throughput.

#### Interrupt Handling

The AXI to AXI-Lite bridge supports interrupt handling, enabling it to generate interrupts to the low-speed bus when events occur on the high-speed bus. The bridge is capable of generating interrupts based on pre-defined criteria and provide a mechanism for the low-speed bus to acknowledge and clear the interrupts.

The internal block diagram can be seen in Figure 2.



Figure 2: AXI to AXI-Lite Bridge Internal Diagram

Brief details of the internal modules is given below:

#### skidbuffer

Skid buffers are required for high throughput AXI code, since the AXI specification requires that all outputs be registered. This means that, if there are any stall conditions calculated, it will take a clock cycle before the stall can be propagated up stream. This means that the data will need to be buffered for a cycle until the stall signal can make it to the output. Handling that buffer is the purpose of this core. On one end of this core, you have the i\_valid and i\_data inputs to connect to your bus interface. There's also a registered o\_ready signal to signal stalls for the bus interface. The other end of the core has the same basic interface, but it isn't registered. This allows you to interact with the bus interfaces as though they were combinatorial logic, by interacting with this half of the core. If at any time the incoming !stall signal, i\_ready, signals a stall, the incoming data is placed into a buffer. Internally, that buffer is held in r\_data with the r\_valid flag used to indicate that valid data is within it.

#### · axi\_addr

The AXI (full) standard has some rather complicated addressing modes, where the address can either be FIXED, INCRementing, or even where it can WRAP around some boundary. When in either INCR or WRAP modes, the next address must always be aligned. In WRAP mode, the next address calculation needs to wrap around a given value, and that value is dependent upon the burst size (i.e. bytes per beat) and length (total numbers of beats). Since this calculation can be non-trivial, and since it needs to be done multiple times, the logic below captures it for every time it might be needed.

#### · sfifo

It is just a synchronous data FIFO to synchronize the transactions on both sides of the protocols with the clock.

#### **Standards**

The AXI4 and AXI4-Lite interfaces are compliant with the AMBA® AXI Protocol Specifications.



### **IP Support Details**

The Table 1 gives the support details for AXI4 to AXI4-Lite Bridge.

| Co     | mpliance    | IP Resources |                  |           | Tool Flow        |                         |                 |           |
|--------|-------------|--------------|------------------|-----------|------------------|-------------------------|-----------------|-----------|
| Device | Interface   | Source Files | Constraint Files | Testbench | Simulation Model | Analyze and Elaboration | Simualtion      | Synthesis |
| Gemini | AXI4-Stream | Verilog      | -                | Python    | Cocotb           | Surelog (Raptor)        | Icarus (Raptor) | Raptor    |

Table 1: IP Details

#### **Parameters**

Table 2 lists the parameters of the AXI4 to AXI4-Lite Bridge.

| Parameter  | Values                     | Default<br>Value | Description          |
|------------|----------------------------|------------------|----------------------|
| DATA WIDTH | 8, 16, 32, 64,<br>128, 256 | 32               | Bridge Data Width    |
| ADDR WIDTH | 6 - 32                     | 16               | Bridge Address Width |
| ID WIDTH   | 1 - 32                     | 2                | Bridge ID Width      |

Table 2: Parameters

#### **Resource Utilization**

The parameters for computing the maximum and minimum resource utilization are given in Table 3, remaining parameters have been kept at their default values.

| Tool                 | Raptor Design Suite<br>GEMINI |                         |                   |          |  |
|----------------------|-------------------------------|-------------------------|-------------------|----------|--|
| FPGA Device          |                               |                         |                   |          |  |
| Co                   | onfiguration                  |                         | Resource Utilized |          |  |
|                      | Options                       | Configuration Resources |                   | Utilized |  |
| Minimum Resource     | DATA WIDTH                    | 8                       | LUTs              | 417      |  |
| Willing Resource     | ADDR WIDTH                    | 6                       | Registers         | 417      |  |
|                      | ID WIDTH                      | 1                       | Registers         | 407      |  |
|                      | Options                       | Configuration           | Resources         | Utilized |  |
| Maximum Resource     | DATA WIDTH                    | 256                     | LUTs              | 2022     |  |
| waxiiilaiii Resource | ADDR WIDTH                    | 32                      | Registers         | 3110     |  |
|                      | ID WIDTH                      | 32                      | Adder Carry       | 26       |  |

Table 3: Resource Utilization



## **Port List**

Table 4 lists the top interface ports of the AXI4 to AXI4-Lite Bridge.

| Signal Name                  | I/O    | Description                                     |  |
|------------------------------|--------|-------------------------------------------------|--|
| Clock and Reset              |        | •                                               |  |
| s_axi_aclk                   | I      | System Clock                                    |  |
| s_axi_aresetn                | I      | Active Low Reset                                |  |
| Slave AXI Write Addre        | ss Cha | nnel                                            |  |
| s_axi_awaddr                 | I      | AXI4 write address                              |  |
| s_axi_awprot                 | I      | AXI4 write address protection data qualifier    |  |
| s_axi_awvalid                | I      | AXI4 valid write address                        |  |
| s_axi_awready                | 0      | AXI4 write address ready                        |  |
| s_axi_awburst                | I      | AXI4 write address burst mode                   |  |
| s_axi_awlen                  | I      | AXI4 write address burst length                 |  |
| s_axi_awsize                 | I      | AXI4 write address burst size                   |  |
| s_axi_awlock                 | I      | AXI4 write address lock qualifier               |  |
| s_axi_awcache                | I      | AXI4 write address cache qualifier              |  |
| s_axi_awregion               | I      | AXI4 write address region                       |  |
| s_axi_awid                   | I      | AXI4 write address ID                           |  |
| s_axi_awuser                 | I      | AXI4 write address user qualifier               |  |
| s_axi_awqos                  | I      | AXI4 write address quality of service qualifier |  |
| Slave AXI Write Data         | Channe |                                                 |  |
| s_axi_wdata                  | I      | AXI4 write data                                 |  |
| s_axi_wstrb                  | I      | AXI4 write strobe                               |  |
| s_axi_wvalid                 | I      | AXI4 data valid                                 |  |
| s_axi_wready                 | 0      | AXI4 data ready                                 |  |
| s_axi_wlast                  | I      | AXI4 write last qualifier                       |  |
| s_axi_wuser                  | I      | AXI4 write user qualifier                       |  |
| Slave AXI Write Response Cha |        | annel                                           |  |
| s_axi_bresp                  | 0      | AXI4 write response                             |  |
| s_axi_bvalid                 | 0      | AXI4 write valid response                       |  |
| s_axi_bready                 | I      | AXI4 write ready response                       |  |
| s_axi_bid                    | 0      | AXI4 write response ID                          |  |
| s_axi_buser                  | 0      | AXI4 write response user qualifier              |  |
| Slave AXI Read Address Chan  |        | nnel                                            |  |
| s_axi_araddr                 | I      | AXI4 read address                               |  |
| s_axi_arprot                 | I      | AXI4 read address protection data qualifier     |  |
| s_axi_arvalid                | I      | AXI4 read address valid                         |  |
| s_axi_arready                | 0      | AXI4 read address ready                         |  |
| s_axi_arburst                | I      | AXI4 read address burst mode                    |  |
| s_axi_arlen                  | I      | AXI4 read address burst length                  |  |
| s_axi_arsize                 | I      | AXI4 read address burst size                    |  |
| s_axi_arlock                 | I      | AXI4 read address lock qualifier                |  |



| s_axi_arcache                          |        | AXI4 read address cache qualifier                 |  |  |
|----------------------------------------|--------|---------------------------------------------------|--|--|
| s_axi_arqos                            | I      | AXI4 read address quality of service qualifier    |  |  |
| s_axi_arregion                         | I      | AXI4 read address region                          |  |  |
| s_axi_arid                             | I      | AXI4 read address ID qualifier                    |  |  |
| s_axi_aruser                           | I      | AXI4 read address user qualifier                  |  |  |
| Slave AXI Read Data Channel            |        |                                                   |  |  |
| s_axi_rdata                            | 0      | AXI4 read data                                    |  |  |
| s_axi_rresp                            | 0      | AXI4 read response                                |  |  |
| s_axi_rvalid                           | 0      | AXI4 read data valid                              |  |  |
| s_axi_rready                           | I      | AXI4 read data ready                              |  |  |
| s_axi_rlast                            | 0      | AXI4 read last qualifier                          |  |  |
| s_axi_rid                              | 0      | AXI4 read ID qualifier                            |  |  |
| s_axi_ruser                            | 0      | AXI4 read user qualifier                          |  |  |
| Master AXI-Lite Write                  | Addres | s Channel                                         |  |  |
| m_axi_awaddr                           | 0      | AXI4-Lite write address                           |  |  |
| m_axi_awprot                           | 0      | AXI4-Lite write address protection data qualifier |  |  |
| m_axi_awvalid                          | 0      | AXI4-Lite valid write address                     |  |  |
| m_axi_awready                          | I      | AXI4-Lite write address ready                     |  |  |
| Master AXI-Lite Write                  | Data C | hannel                                            |  |  |
| m_axi_wdata                            | 0      | AXI4-Lite write data                              |  |  |
| m_axi_wstrb                            | 0      | AXI4-Lite write strobe                            |  |  |
| m_axi_wvalid                           | 0      | AXI4-Lite data valid                              |  |  |
| m_axi_wready                           | I      | AXI4-Lite data ready                              |  |  |
| Master AXI-Lite Write Response Channel |        |                                                   |  |  |
| m_axi_bresp                            | I      | AXI4-Lite write response                          |  |  |
| m_axi_bvalid                           | I      | AXI4-Lite write valid response                    |  |  |
| m_axi_bready                           | 0      | AXI4-Lite write ready response                    |  |  |
| Master AXI-Lite Read Address Channel   |        | s Channel                                         |  |  |
| m_axi_ardata                           | 0      | AXI4-Lite read address                            |  |  |
| m_axi_arprot                           | 0      | AXI4-Lite read address protection qualifier       |  |  |
| m_axi_arvalid                          | 0      | AXI4-Lite read address valid                      |  |  |
| m_axi_arready                          | l      | AXI4-Lite read address ready                      |  |  |
| Master AXI-Lite Read Data Channel      |        |                                                   |  |  |
| m_axi_rdata                            | I      | AXI4-Lite read data                               |  |  |
| m_axi_rresp                            |        | AXI4-Lite read response                           |  |  |
| m_axi_rvalid                           |        | AXI4-Lite read data valid                         |  |  |
| m_axi_rready                           | 0      | AXI4-Lite read data ready                         |  |  |
|                                        |        | · · · · · · · · · · · · · · · · · · ·             |  |  |

Table 4: AXI4 to AXI4-Lite Bridge Interface



# **Design Flow**

#### **IP Customization and Generation**

AXI4 to AXI4-Lite Bridge IP core is a part of the Raptor Design Suite Software. A customized AXI4 to AXI4-Lite Bridge can be generated from the Raptor's IP configurator window as shown in Figure 3.



Figure 3: IP list



#### **Parameters Customization**

From the IP configuration window, the parameters of the AXI4 to AXI4-Lite Bridge can be configured and AXI4 to AXI4-Lite Bridge features can be enabled for generating a customized AXI4 to AXI4-Lite Bridge IP core that suits the user application requirement as shown in Figure 4. After IP Customization, all the source files are made available to the user with a top wrapper that instantiates a parameterized instance of the AXI4 to AXI4-Lite Bridge.



Figure 4: IP Configuration



# **Example Design**

#### Overview

This AXI to AXI-Lite Bridge IP can be utilized in a system that requires the translation between AXI and AXI-Lite protocols to integrate both high-speed and low-speed IPs together. AXI to AXI-Lite is a crucial component in many electronic systems, enabling communication between different types of peripherals, essentially making an AXI slave connect with a AXI-Lite Master. One such example design of this AXI to AXI-Lite Bridge, where an AXI capable processor is connected with AXI-Lite peripherals via the AXI to AXI-Lite bridge, can be visualized in Figure 5.



Figure 5: AXI to AXI-Lite Bridge embedded within an FPGA

## **Simulating the Example Design**

The IP being Verilog HDL, can be simulated via a bunch of industry standard stimulus. For instance, it could be simulated via writing a Verilog Test-bench, or incorporating a soft processor that can stimulate this AXI4 to AXI4-Lite Bridge. The bundled example design is stimulated via a Cocotb based environment on Icarus, that iteratively stimulates the soft IP by performing a number of writing and reading operations on this IP on various different addresses to ensure the complete working of the bridge. A stress test is also performed at the end to ensure that the bridge can handle the high speed traffic of the AXI protocol.

## Synthesis and PR

Raptor Design Suite is armed with tools for Synthesis along with Post and Route capabilities and the generated post-synthesis and post-route and place net-lists can be viewed and analyzed from within the Raptor. The generated bit-stream can then be uploaded on an FPGA device to be utilized in hardware applications.



## **Test Bench**

The included testbench for the AXI to AXI-Lite Bridge IP is a Cocotb based Python testbench that performs various read and write operations on the IP core to stimulate all the modules of the IP. Python is used to simulate the IP inside the Cocotb library for this purpose and a total of 25 tests are performed, 12 tests perform read operations and the other 12 perform write operations on the IP at various different addresses to make sure that the protocol translation is working as expected. A stress test is also performed at the end of the simulation to make sure that the IP doesn't break under high speed burst conditions of the AXI protocol. The internal modules such as skidbuffer and FIFOs make sure that the AXI-Lite transactions are always in line with the higher spec AXI transactions and vice versa. The waveforms are also dumped in the format of .vcd for in-depth analysis of the whole operation and can be viewed on the integrated waveviewer by clicking the "View waveform" button as shown in figure 6b. Being written in simple Python, the testbenches are easily modifiable to provide maximum coverage of the AXI to AXI-Lite Bridge IP. The simulation can be easily run by clicking the "Simulate IP" button as shown in figure 6a.



Figure 6: IP Source Window



The simulation results are also displayed in the console window a glimpse of which can be seen in figure 7.

```
*******************
** TEST
                                             STATUS
                                                    SIM TIME (ns)
*******************
** test axi2axilite wrapper.run test write 001
                                                        25430.00
                                              PASS
** test_axi2axilite_wrapper.run_test_write_002
                                                        88080.00
                                              PASS
** test_axi2axilite_wrapper.run_test_write_003
                                              PASS
                                                        46320.00
** test_axi2axilite_wrapper.run_test_write_004
                                              PASS
                                                        88730.00
** test_axi2axilite_wrapper.run_test_write_005
                                              PASS
                                                       339290.00
** test_axi2axilite_wrapper.run_test_write_006
                                              PASS
                                                       172250.00
** test_axi2axilite_wrapper.run_test_write_007
                                                        88740.00
                                              PASS
                                                       339300.00
** test_axi2axilite_wrapper.run_test_write_008
                                              PASS
                                                       172260.00
** test_axi2axilite_wrapper.run_test_write_009
                                              PASS
** test_axi2axilite_wrapper.run_test_write_010
                                              PASS
                                                        93850.00
** test_axi2axilite_wrapper.run_test_write_011
                                                       344410.00
                                              PASS
** test_axi2axilite_wrapper.run_test_write_012
                                              PASS
                                                       177370.00
** test_axi2axilite_wrapper.run_test_read_001
                                                        24800.00
                                              PASS
** test_axi2axilite_wrapper.run_test_read_002
                                              PASS
                                                        87440.00
** test_axi2axilite_wrapper.run_test_read_003
                                              PASS
                                                        45680.00
** test_axi2axilite_wrapper.run_test_read_004
                                                        88730.00
                                              PASS
** test_axi2axilite_wrapper.run_test_read_005
                                                       339290.00
                                              PASS
** test_axi2axilite_wrapper.run_test_read_006
                                                       172250.00
                                              PASS
** test_axi2axilite_wrapper.run_test_read_007
                                                        88740.00
                                              PASS
** test_axi2axilite_wrapper.run_test_read_008
                                                       339300.00
                                              PASS
** test_axi2axilite_wrapper.run_test_read_009
                                                       172260.00
                                              PASS
** test_axi2axilite_wrapper.run_test_read_010
                                                        93850.00
                                              PASS
** test_axi2axilite_wrapper.run_test_read_011
                                              PASS
                                                       344410.00
** test_axi2axilite_wrapper.run_test_read_012
                                                       177370.00
                                              PASS
** test_axi2axilite_wrapper.run_stress_test_001
                                              PASS
                                                       170310.00
**************
                                                      4120460.02
** TESTS=25 PASS=25 FAIL=0 SKIP=0
*******************
```

Figure 7: Simulation Results



# Release

## **Release History**

| Date                 | Version | Revisions                                                    |
|----------------------|---------|--------------------------------------------------------------|
| November 23,<br>2023 | 0.1     | Initial version AXI4 to AXI4-Lite Bridge User Guide Document |