

# AXI Register (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 Introduction         | 3<br>3<br>3   |
|---------------------------------|---------------|
| Overview AXI Register           | <b>4</b><br>4 |
| IP Specification                | 5             |
| Type of Registers               | 6             |
| Standards                       | 7             |
| Resource Utilization            | 7             |
| Port List                       | 8             |
| Design Flow                     | 11            |
| IP Customization and Generation |               |
| Test Bench                      | 13            |
| Revision History                | 15            |



# **IP Summary**

#### Introduction

An AXI Register is an IP core that provides a simple interface to read and write registers in a system-on-chip (SoC) design. The AXI protocol is a widely-used, industry-standard bus interface that enables high-speed communication between different modules in a SoC. This IP Core acts as a bridge between the AXI bus and the registers in the design. It can be customized to include any number of registers, each with a specific address and width. The IP core supports both read and write operations, allowing software running on a processor or other modules in the SoC to access the registers. The benefits of it include reduced design time, increased reliability, and improved system performance.

#### **Features**

- AXI4 (memory mapped) one master and one slave interface
- · Configurable data width 8, 16, 32, 64, 128, 256, 512 and 1024 bits
- · Configurable address width up to 64 bits
- · Support ID width up to 32 bits
- Register options i.e. bypass, simple buffer or skid buffer for each channel
- Compatible with AXI4 Interconnect



## **Overview**

#### **AXI Register**

The AXI Register IP Core is a part of Raptor Design Suite that can be integrated into a larger SoC design to provide AXI register functionality. It typically includes a set of memory-mapped control registers that are accessed by the processor using memory access instructions. The IP core also includes the necessary logic to interface with the AXI bus and respond to register accesses. The IP core can also be customized and optimized for specific design requirements, such as reducing power consumption or improving performance. It offers flexibility in customization and optimization to meet specific design requirements, which can help reduce the time and cost of development. Additionally, as a pre-designed and pre-verified block of logic, it can speed up the design process and ensure reliability.



Figure 1: AXI Register Block Diagram



# **IP Specification**

The AXI Register is a IP core based on AMBA AXI Protocol which is a widely used, industry-standard bus interface that enables high-speed communication between different modules in an SoC. It has configurable register width and the width of the registers may range from 8 bits to 1024 bits, depending on the specific requirements of the SoC design. It support both read and write operations, allowing software running on a processor or other modules in the SoC to access the registers. It also supports up to 1024 bits for user signals. The IP core is comply with the AXI protocol and be compatible with other AXI-compliant modules in the SoC.



Figure 2: Top Module



#### Type of Registers

The "<channel>\_REG\_TYPE" parameter in an AXI Register IP Core specifies how the register behaves when data is written to it. There are three types of registers that can be selected: Bypass, Simple Buffer, and Skid Buffer.

#### · Bypass Register:

A Bypass register is the simplest type of register. When data is written to it, the register immediately transfers the data to the output without storing it. This type of register is useful when there is no need to store the data and it can be directly passed on to the next module. The bypass register provides the fastest and most efficient data transfer but does not store the data.

#### · Simple Buffer:

A Simple Buffer register stores the data temporarily and releases it when requested. When data is written to a simple buffer register, it is stored in the register and is available for reading until it is overwritten. This type of register is useful when the data needs to be processed before being passed on to the next module. For example, a simple buffer register could be used to store data that needs to be processed by a CPU or a DSP core.

#### · Skid Buffer:

A Skid Buffer register is similar to a Simple Buffer register, but it has an additional feature called "skidding." Skidding means that if new data is written to the register before the old data is read, the new data overwrites the old data. This behavior can be useful when only the most recent data needs to be kept. Skid buffer registers are often used in real-time applications, such as video or audio processing, where it is important to have the most recent data.



#### **Standards**

The AXI4 Master and Slave interfaces are compliant with the AMBA® AXI Protocol Specification.

### **IP Support Details**

The Table 1 gives the support details for AXI Register.

| Comp   | Compliance IP Resources |              |                 | IP Resources Tool Flow |                  |                         |            |           |
|--------|-------------------------|--------------|-----------------|------------------------|------------------|-------------------------|------------|-----------|
| Device | Interface               | Source Files | Constraint File | Testbench              | Simulation Model | Analyze and Elaboration | Simulation | Synthesis |
| GEMINI | AXI4                    | Verilog      | -               | Cocotb                 | -                | Raptor                  | Raptor     | Raptor    |

Table 1: Support Details

#### **Resource Utilization**

The parameters for computing the maximum and the minimum resource utilization are given in Table 2. Other parameters are kept at their default values.

| Tool               | Raptor Design Suite |                      |           |          |  |
|--------------------|---------------------|----------------------|-----------|----------|--|
| <b>FPGA Device</b> | GEMINI              |                      |           |          |  |
|                    | Configuratio        | Resource Utilization |           |          |  |
| Minimum            | Options             | Configuration        | Resources | Utilized |  |
| Resource           |                     | <b>3</b>             |           |          |  |
|                    | DATA_WIDTH          | 8                    | BRAMS     | 1        |  |
|                    | ADDR_WIDTH          | 1                    | REGISTERS | 94       |  |
|                    | ID_WIDTH            | 1                    | LUTS      | 42       |  |
|                    | AW_REG_TYPE         | Bypass               | -         | -        |  |
| Maximum            | Options             | Configuration        | Resources | Utilized |  |
| Resource           |                     | <b>3</b>             |           |          |  |
|                    | DATA_WIDTH          | 1024                 | BRAMS     | 1        |  |
|                    | ADDR_WIDTH          | 64                   | REGISTERS | 4854     |  |
|                    | ID_WIDTH            | 32                   | LUTS      | 2365     |  |
|                    | AW_REG_TYPE         | Skid_Buffer          | -         | -        |  |

Table 2: Resource Utilization



## **Ports**

Table 3 lists the top interface ports of the AXI Register.

| Signal Name                | I/O                         | Description                          |  |  |
|----------------------------|-----------------------------|--------------------------------------|--|--|
| clk                        | I                           | Clock Signal of Register             |  |  |
| rst                        | I                           | Active High Synchronous Reset Signal |  |  |
|                            | Slave Write Address Channel |                                      |  |  |
| s_axi_awid                 | I                           | Write address ID                     |  |  |
| s_axi_awaddr               | I                           | Write address                        |  |  |
| s_axi_awlen                | I                           | Burst length                         |  |  |
| s_axi_awsize               | I                           | Burst size                           |  |  |
| s_axi_awburst              | I                           | Burst type                           |  |  |
| s_axi_awlock               | I                           | Lock type                            |  |  |
| s_axi_awcache              | I                           | Memory type                          |  |  |
| s_axi_awprot               | I                           | Protection type                      |  |  |
| s_axi_awvalid              | I                           | Write address valid                  |  |  |
| s_axi_awready              | 0                           | Write address ready                  |  |  |
|                            | Slav                        | e Write Data Channel                 |  |  |
| s_axi_wdata                | I                           | Write data                           |  |  |
| s_axi_wstrb                | I                           | Write strobe                         |  |  |
| s_axi_wlast                | I                           | Write last                           |  |  |
| s_axi_wvalid               | I                           | Write valid                          |  |  |
| s_axi_wready               | 0                           | Write ready                          |  |  |
|                            | Slave V                     | Vrite Response Channel               |  |  |
| s_axi_bid                  | 0                           | Response ID tag                      |  |  |
| s_axi_bresp                | 0                           | Write response                       |  |  |
| s_axi_bvalid               | 0                           | Write response valid                 |  |  |
| s_axi_bready               | I                           | Write response ready                 |  |  |
| Slave Read Address Channel |                             |                                      |  |  |
| s_axi_arid                 | I                           | Read address ID                      |  |  |
| s_axi_araddr               | I                           | Read address                         |  |  |
| s_axi_arlen                | I                           | Burst length                         |  |  |
| s_axi_arsize               | I                           | Burst size                           |  |  |
| s_axi_arburst              | I                           | Burst type                           |  |  |
| s_axi_arlock               | I                           | Lock type                            |  |  |
| s_axi_arcache              | I                           | Memory type                          |  |  |
| s_axi_arprot               | I                           | Protection type                      |  |  |
| s_axi_arvalid              | I                           | Read address valid                   |  |  |
| s_axi_arready              | 0                           | Read address ready                   |  |  |
|                            | Slav                        | e Read Data Channel                  |  |  |
| s_axi_rid                  | 0                           | Read ID tag                          |  |  |
| s_axi_rdata                | 0                           | Read data                            |  |  |
| s_axi_rresp                | 0                           | Read response                        |  |  |



| Signal Name              | I/O                          | Description            |  |  |
|--------------------------|------------------------------|------------------------|--|--|
| s_axi_rlast              | 0                            | Read last              |  |  |
| s_axi_rvalid             | 0                            | Read valid             |  |  |
| s_axi_rready             | I                            | Read ready             |  |  |
|                          | Master Write Address Channel |                        |  |  |
| m_axi_awid               | 0                            | Write address ID       |  |  |
| m_axi_awaddr             | 0                            | Write address          |  |  |
| m_axi_awlen              | 0                            | Burst length           |  |  |
| m_axi_awsize             | 0                            | Burst size             |  |  |
| m_axi_awburst            | 0                            | Burst type             |  |  |
| m_axi_awlock             | 0                            | Lock type              |  |  |
| m_axi_awcache            | 0                            | Memory type            |  |  |
| m_axi_awprot             | 0                            | Protection type        |  |  |
| m_axi_awvalid            | 0                            | Write address valid    |  |  |
| m_axi_awready            |                              | Write address ready    |  |  |
|                          | Mast                         | er Write Data Channel  |  |  |
| m_axi_wdata              | 0                            | Write data             |  |  |
| m_axi_wstrb              | 0                            | Write strobe           |  |  |
| m_axi_wlast              | 0                            | Write last             |  |  |
| m_axi_wvalid             | 0                            | Write valid            |  |  |
| m_axi_wready             | I                            | Write ready            |  |  |
|                          | Master '                     | Write Response Channel |  |  |
| m_axi_bid                | I                            | Response ID tag        |  |  |
| m_axi_bresp              | l                            | Write response         |  |  |
| m_axi_bvalid             | ļ                            | Write response valid   |  |  |
| m_axi_bready             | 0                            | Write response ready   |  |  |
|                          | Master                       | Read Address Channel   |  |  |
| m_axi_arid               | 0                            | Read address ID        |  |  |
| m_axi_araddr             | 0                            | Read address           |  |  |
| m_axi_arlen              | 0                            | Burst length           |  |  |
| m_axi_arsize             | 0                            | Burst size             |  |  |
| m_axi_arburst            | 0                            | Burst type             |  |  |
| m_axi_arlock             | 0                            | Lock type              |  |  |
| m_axi_arcache            | 0                            | Memory type            |  |  |
| m_axi_arprot             | 0                            | Protection type        |  |  |
| m_axi_arvalid            | 0                            | Read address valid     |  |  |
| m_axi_arready            | l                            | Read address ready     |  |  |
| Master Read Data Channel |                              |                        |  |  |
| m_axi_rid                | <b>I</b>                     | Read ID tag            |  |  |
| m_axi_rdata              | <u> </u>                     | Read data              |  |  |
| m_axi_rresp              | <u> </u>                     | Read response          |  |  |
| m_axi_rlast              | <u> </u>                     | Read last              |  |  |
| m_axi_rvalid             | l                            | Read valid             |  |  |



| Signal Name  | I/O | Description |
|--------------|-----|-------------|
| m_axi_rready | 0   | Read ready  |

Table 3: Port List

#### **Parameters**

Table 4 lists the parameters of the AXI Register.

| Parameter     | Values                                   | Default Value | Description                  |
|---------------|------------------------------------------|---------------|------------------------------|
| DATA_WIDTH    | 8, 16, 32, 64,<br>128, 256, 512,<br>1024 | 32            | Data Width of Register       |
| ADDR_WIDTH    | 1 - 64                                   | 32            | Address Width of Register    |
| ID_WIDTH      | 1 - 32                                   | 32            | ID field of Register         |
| AW_USER_WIDTH | 1 - 1024                                 | 1             | User Field for AW Channel    |
| W_USER_WIDTH  | 1 - 1024                                 | 1             | User Field for W Channel     |
| B_USER_WIDTH  | 1 - 1024                                 | 1             | User Field for B Channel     |
| AR_USER_WIDTH | 1 - 1024                                 | 1             | User Field for AR Channel    |
| R_USER_WIDTH  | 1 - 1024                                 | 1             | User Field for R Channel     |
| AW_REG_TYPE   | Bypass,<br>Simple_Buffer,<br>Skid_Buffer | Simple_Buffer | Register Type for AW Channel |
| W_REG_TYPE    | Bypass,<br>Simple_Buffer,<br>Skid_Buffer | Skid_Buffer   | Register Type for W Channel  |
| B_REG_TYPE    | Bypass,<br>Simple_Buffer,<br>Skid_Buffer | Simple_Buffer | Register Type for B Channel  |
| AR_REG_TYPE   | Bypass,<br>Simple_Buffer,<br>Skid_Buffer | Simple_Buffer | Register Type for AR Channel |
| R_REG_TYPE    | Bypass,<br>Simple_Buffer,<br>Skid_Buffer | Skid_Buffer   | Register Type for R Channel  |

Table 4: Parameters



# **Design Flow**

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

AXI Register IP core is a part of the Raptor Design Suite Software. A customized register can be generated from the Raptor's IP configuration window as shown in figure 3.



Figure 3: IP List



#### **Parameters Customization**

From the IP configuration window, the parameters of the AXI Register can be configured and it's features can be enabled for generating a customized IP core that suits the user application requirements. All parameters are shown in figure 4. In Figure 4, the module name specifies the name of both the Verilog file and the top-level IP name that will be generated based on above configured parameters. The Output Dir is a directory option that allows the user to specify where they want the generated IP to be saved.



Figure 4: IP Configuration



## **Test Bench**

The AXI Register IP Core is provided with a testbench which is based upon Cocotb verification environment. For simulation, right click on generated IP Instance and then click "Simulate IP" as shown in Figure 5.



Figure 5: Simulate IP

In this test, slave interface is connected to AXI Master and master interface is connected with AXI Register. The input data is generated using a test data generator module. Input data is routed from master to slave through register. After running the simulation, you'll get pass/ fail status on console. The status of test is shown in Figure 6.

Figure 6: Simulation Results



You can view waveform of the results. To view waveform, right click on generated IP Instance and then click "View waveform" as shown in Figure 7.



Figure 7: View Waveform



# **Revision History**

| Date                      | Version | Revisions                               |
|---------------------------|---------|-----------------------------------------|
| Novem-<br>ber 20,<br>2023 | 0.1     | Initial version AXI Register User Guide |