# **ARM**<sup>®</sup>

PrimeCell® Infrastructure AMBA™ 3 AXI™ Internal Memory Interface (BP140)

Revision: r0p0

**Technical Overview** 

This technical overview describes the functionality of the AXI internal memory interface in the following sections:

- Preliminary material on page 2
- About the internal memory interface on page 3
- Functional description on page 4
- Physical data on page 6
- Signal descriptions on page 8.

1

### 1 Preliminary material

Copyright © 2004 ARM Limited. All rights reserved.

#### 1.1 Release information

Changes to this document are listed in Table 1.

**Table 1 Change history** 

| Date             | Issue | Change               |
|------------------|-------|----------------------|
| 26 November 2004 | A     | First issue for r0p0 |

#### 1.2 Proprietary notice

Words and logos marked with  $^{\circledR}$  or  $^{\intercal M}$  are registered trademarks or trademarks owned by ARM Limited, except as otherwise stated below in this proprietary notice. Other brands and names mentioned herein may be the trademarks of their respective owners.

Neither the whole nor any part of the information contained in, or the product described in, this document may be adapted or reproduced in any material form except with the prior written permission of the copyright holder.

The product described in this document is subject to continuous developments and improvements. All particulars of the product and its use contained in this document are given by ARM in good faith. However, all warranties implied or expressed, including but not limited to implied warranties of merchantability, or fitness for purpose, are excluded.

This document is intended only to assist the reader in the use of the product. ARM Limited shall not be liable for any loss or damage arising from the use of any information in this document, or any error or omission in such information, or any incorrect use of the product.

#### 1.3 Confidentiality status

This document is Non-Confidential. The right to use, copy and disclose this document may be subject to licence restrictions in accordance with the terms of the agreement entered into by ARM and the party ARM delivered this document to.

#### 1.4 Product status

The information in this document is for an final product, that is a developed product.

#### 1.5 Web address

http://www.arm.com

# 2 About the internal memory interface

The AXI internal memory interface, IntMemAxi, has the following features:

- It provides a single-port memory interface configurable for synchronous SRAM or ROM.
- The HDL code is supplied as Verilog.
- The memory footprint is that of the connected SRAM or ROM.
- It accepts a single address for each of the read and write channels.
- It uses round-robin arbitration between read and write transactions, the default is read.
- For write transactions, the first data transfer can take place 2 cycles after the address is accepted. Subsequent data transfers can complete in consecutive cycles.
- For read transactions:

With one wait state

The first data transfer can take place 2 cycles after the address is accepted. Subsequent data transfers can complete in consecutive cycles.

With zero wait states

The first data transfer can take place 3 cycles after the address is accepted. Subsequent data transfers take 2 cycles.

- It supports:
  - all AMBA AXI channels except the low power channel
  - all AXI burst types
  - aligned and unaligned transfer types.
- You can configure the following parameters:
  - data width of 64 bits or 32 bits
  - ID width
  - wait states, single or none, for SRAM and ROM reads
  - whether the interface is to be used with SRAM or ROM
  - memory read access to be zero or one wait-state
  - MEM\_ADDR\_WIDTH, MEM\_INIT\_FILE\_0, and MEM\_INIT\_FILE\_1 for IntMemBhavAxi.

# 3 Functional description

Figure 1 shows how you can use the IntMemAxi component to interface to a synthesized SRAM. It can also be connected to ROM.



Figure 1 Internal memory interface connected to compiled SRAM

Figure 2 shows how you can use the internal memory behavioral component, IntMemBhavAxi. This includes the memory interface and a behavioral SRAM model. You can use this as a memory slave for behavioral testbenches.



Figure 2 Behavioral memory interface

The interface does not have an AXI low-power interface because it does not initiate transactions or have a low-power mode of operation.

### 3.1 Interface attributes

Table 1 lists the slave interface attributes for the IntMemAxi.

**Table 1 Slave interface attributes** 

| Attribute                   | Description                                                                                                                  | Value |
|-----------------------------|------------------------------------------------------------------------------------------------------------------------------|-------|
| Write acceptance capability | The maximum number of active write transactions that a slave can accept.                                                     | 1     |
| Read acceptance capability  | The maximum number of active read transactions that a slave can accept.                                                      | 1     |
| Write interleave depth      | The number of active write transactions for which the slave can receive data. This is counted from the earliest transaction. | 1     |
| Read data reorder depth     | The number of active read transactions for which a slave may transmit data. This is counted from the earliest transaction.   | 1     |

# 4 Physical data

Physical data is provided in:

- AC characteristics
- Gate count on page 7.

#### 4.1 AC characteristics

The interface conforms to the following timing guidelines:

- AXI inputs must be valid for 30% of the cycle before the rising edge of **CLK** and outputs must become valid within 20% of cycle after the rising edge of **CLK**.
- Timing characteristics are confirmed by performing synthesis on the block using the slow-slow process point of the Artisan SAGE HS library for the TSMC CL013G process at a target speed of 200MHz.

The signals on the memory port of the interface conform to the timing requirements required by the single ported synchronous memory component produced by RAM Compiler for the TSMC CL013G process technology with the following compiled features:

- 16384x32
- Mux 32
- Drive 6
- 8-bit mask write.

#### 4.2 Gate count

Table 2 lists estimated NAND2X1 equivalent gate counts for the target frequency and library specified in *AC characteristics* on page 6.

**Table 2 Gate count estimates** 

| Data bus width | Read wait-state implementation | Gate count |
|----------------|--------------------------------|------------|
| 64-bit         | zero                           | 1720       |
|                | single                         | 1720       |
| 32-bit         | zero                           | 1720       |
|                | single                         | 1720       |

| Note                        | _                                  |
|-----------------------------|------------------------------------|
| The gate count estimates in | Table 2 do not include scan logic. |

# 5 Signal descriptions

The AXI interface of the internal memory interface uses the signals described in the *AMBA AXI Protocol Specification*. The memory interface signals are described in *Memory interface* on page 9. Figure 3 shows the interface signal connections.



Figure 3 Internal memory interface signal connections

| Note            |                       |
|-----------------|-----------------------|
| WDATA and RDATA | bypass the component. |

### 5.1 Memory interface

Table 3 lists the connection information for the memory interface signals.

### **Table 3 Memory interface signal descriptions**

| SRAM<br>signal   | Connection                          | SRAM | SROM | Interface signal name | Signal<br>direction |
|------------------|-------------------------------------|------|------|-----------------------|---------------------|
| CLK              | Connect to ACLK                     | Yes  | Yes  | -                     | -                   |
| CEna             | Output from IntMemAxi               | Yes  | Yes  | MEMCEn                | Output              |
| WEna             | Output from IntMemAxi               | Yes  | No   | MEMWEn[STRB_MAX:0]    | Output              |
| OEn <sup>a</sup> | Tied permanently enabled if present | -    | -    | -                     | -                   |
| Q                | Connect to RDATA                    | Yes  | Yes  | -                     | -                   |
| D                | Connect to WDATA                    | Yes  | No   | -                     | -                   |
| A                | Output from IntMemAxi               | Yes  | Yes  | MEMADDR[31:0]         | Output              |

a. Active-LOW.

