

# AXI DPRAM (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  |
| Features                        | 3  |
| Overview                        | 4  |
| AXI DPRAM                       | 4  |
| IP Specification                | Ę  |
| Standards                       | 6  |
| IP Support Details              | 6  |
| Resource Utilization            |    |
| Port List                       |    |
| Parameters                      | 10 |
| Design Flow                     | 11 |
| IP Customization and Generation | 1  |
|                                 | 1  |
| Test Bench                      | 12 |
| Revision History                | 13 |



## **IP Summary**

#### Introduction

AXI DPRAM (Dual-Port RAM) is a type of memory block that uses the AXI (Advanced eXtensible Interface) protocol for data communication. The AXI protocol is a widely used interface standard for high-speed digital circuits, providing a high-bandwidth, low-latency communication link between hardware components. It is specialized type of RAM that has two independent ports for simultaneous read and write operations from two different sources. This feature allows for greater flexibility and efficiency in data transfer between different hardware components in a digital system. It is particularly useful in applications where multiple components need to access the memory block at the same time, without causing delays or conflicts. One of the key advantages of the AXI DPRAM is its ability to operate at high speeds. This makes it ideal for use in high-performance applications where fast data transfer is critical.

#### **Features**

- · AXI4 (memory mapped) one master and one slave interface
- Configurable data width 8, 16, 32, 64, 128, 256 bits
- Configurable address width 8 to 16 bits
- · Support ID width up to 32 bits
- Extra pipeline register for each port.
- Interleaving write and read burst cycles option for each port
- Compatible with AXI4 Interconnect



## **Overview**

#### **AXI DPRAM**

The AXI DPRAM IP Core is a part of Raptor Design Suite which is designed to be used in digital systems and is compatible with the AMBA AXI4 (Advanced eXtensible Interface 4) standard. It is a high-performance memory that features two independent data ports, allowing simultaneous read and write access from two different sources. It is commonly used in applications where high-speed data transfer is required, such as in graphics processing, video processing, and networking. It provides efficient data transfer between the memory and other components in the system. It includes features such as burst transfer support, configurable address width and data width.



Figure 1: AXI DPRAM Block Diagram



## **IP Specification**

The AXI DP RAM IP core is a high-performance, dual-port RAM memory block designed for use in FPGAs. It is based on the Advanced Microcontroller Bus Architecture (AMBA) AXI4 protocol and features two independent read/write ports, allowing for simultaneous access by multiple processors or peripherals. It supports a wide range of data widths, from 8 bits to 256 bits, and can be configured for different memory sizes up to a maximum of 16 terabytes. It also includes extra pipeline registers for each port and interleaving write and read burst cycles option for each port. This IP core is commonly used in a wide range of applications, including embedded systems, digital signal processing, network processing, and video processing. It is fully customizable and can be easily integrated into new or existing FPGA designs.



Figure 2: Top Module



#### **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 DPRAM.

| Com    | mpliance 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 |                      |           |          |  |
|-------------|---------------------|----------------------|-----------|----------|--|
| FPGA Device | GEMINI              |                      |           |          |  |
|             | Configuration       | Resource Utilization |           |          |  |
| Minimum     | Options             | Configuration        | Resources | Utilized |  |
| Resource    |                     | <b>3</b>             |           |          |  |
|             | DATA_WIDTH          | 8                    | BRAMS     | 1        |  |
|             | ADDR_WIDTH          | 8                    | REGISTERS | 115      |  |
|             | ID_WIDTH            | 1                    | LUTS      | 195      |  |
|             | A_PIP_OUT           | False                | -         | -        |  |
| Maximum     | Options             | Configuration        | Resources | Utilized |  |
| Resource    |                     | <b>3</b>             |           |          |  |
|             | DATA_WIDTH          | 256                  | BRAMS     | 16       |  |
|             | ADDR_WIDTH          | 16                   | REGISTERS | 976      |  |
|             | ID_WIDTH            | 32                   | LUTS      | 1287     |  |
|             | A_PIP_OUT           | True                 | -         | -        |  |

Table 2: Resource Utilization



### **Ports**

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

| Signal Name              | I/O | Description                                            |  |  |
|--------------------------|-----|--------------------------------------------------------|--|--|
| a_clk                    | I   | Clock Signal for Port A of RAM                         |  |  |
| a_rst                    | I   | Active High Synchronous Reset Signal for Port A of RAM |  |  |
| b_clk                    | I   | Clock Signal for Port B of RAM                         |  |  |
| b_rst                    | I   | Active High Synchronous Reset Signal for Port B of RAM |  |  |
|                          | N   | laster 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                                    |  |  |
|                          |     | Master 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                                            |  |  |
|                          | M   | aster Write 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                                   |  |  |
|                          | N   | laster 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                                     |  |  |
| Master Read Data Channel |     |                                                        |  |  |
| s_axi_rid                | 0   | Read ID tag                                            |  |  |



| Signal Name   | I/O                        | Description               |  |
|---------------|----------------------------|---------------------------|--|
| s_axi_rdata   | 0                          | Read data                 |  |
| s_axi_rresp   | 0                          | Read response             |  |
| s_axi_rlast   | 0                          | Read last                 |  |
| s_axi_rvalid  | 0                          | Read valid                |  |
| s_axi_rready  | I                          | Read ready                |  |
|               | SI                         | ave 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 | I                          | Write address ready       |  |
|               |                            | Slave 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               |  |
|               | Sla                        | ve Write Response Channel |  |
| m_axi_bid     | I                          | Response ID tag           |  |
| m_axi_bresp   | I                          | Write response            |  |
| m_axi_bvalid  | I                          | Write response valid      |  |
| m_axi_bready  | 0                          | Write response ready      |  |
|               | Slave 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 | I                          | Read address ready        |  |
|               |                            | Slave Read Data Channel   |  |
| m_axi_rid     | l                          | Read ID tag               |  |
| m_axi_rdata   | l ·                        | Read data                 |  |
| m_axi_rresp   | I                          | Read response             |  |



| Signal Name  | I/O | Description |
|--------------|-----|-------------|
| m_axi_rlast  | I   | Read last   |
| m_axi_rvalid | I   | Read valid  |
| m_axi_rready | 0   | Read ready  |

Table 3: Port List



### **Parameters**

Table 4 lists the parameters of the AXI DPRAM.

| Parameter    | Values                     | Default<br>Value | Description                                      |
|--------------|----------------------------|------------------|--------------------------------------------------|
| DATA_WIDTH   | 8, 16, 32, 64,<br>128, 256 | 32               | Data Width of RAM                                |
| ADDR_WIDTH   | 8 - 16                     | 16               | Address Width of RAM                             |
| ID_WIDTH     | 1 - 32                     | 32               | ID field of RAM                                  |
| A_PIP_OUT    | True/False                 | True             | Piplelined Output for Port A                     |
| B_PIP_OUT    | True/False                 | True             | Piplelined Output for Port B                     |
| A_INTERLEAVE | True/False                 | True             | Interleave write and read burst cycles on Port A |
| B_INTERLEAVE | True/False                 | True             | Interleave write and read burst cycles on Port B |

Table 4: Parameters



## **Design Flow**

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

AXI DPRAM IP core is a part of the Raptor Design Suite Software. A customized memory 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 DPRAM 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 DPRAM IP is provided with a testbench which is based upon Cocotb verification environment. In this test, multiple read/write transactions are performed by two masters. The input data is generated using a test data generator module. The output data is compared with the expected output data to verify the correctness of the IP core's operation. The dump file is generated to view the output of the test. In the end, there is status for passing or failure of the test.



# **Revision History**

| Date         | Version | Revisions                            |
|--------------|---------|--------------------------------------|
| May 11, 2023 | 0.1     | Initial version AXI DPRAM User Guide |