How to Enable HyperRAM with i.MX RT Rev. 4 — 29 September 2022

**Application note** 

#### **Document information**

| Information | Content                                                                                                                                                                |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Keywords    | MIMXRT1050 EVKB, HyperRAM, FlexSPI, HyperBus, Memory region and<br>Look-Up-Table, LUT, i.MX RT, i.MX RT Crossover MCUs, System-on-Chip,<br>SoC, application processors |
| Abstract    | This document describes how to use the HyperRAM with the i.MX RT MCU, including hardware connections, HyperRAM protocol, source code, and performance.                 |



## 1 Introduction

The i.MX RT series MCU is a crossover product from NXP. It includes a Flexible Serial Peripheral Interface (FlexSPI) controller which supports HyperBus devices (HyperFlash/ HyperRAM). This application note describes how to use the HyperRAM with the i.MX RT MCU, including hardware connections, HyperRAM protocol, source code, and performance.

The SDK used for the example in this application note is SDK\_2.3.1\_EVKB-IMXRT1050. The development environment is IAR Embedded Workbench<sup>®</sup> 8.22.1 IDE. The hardware environment is the MIMXRT1050-EVKB board. The HyperRAM chip is S27KS0641 from Cypress<sup>®</sup>.

## 2 MIMXRT1050 EVKB board setting

By default, the HyperFlash chip (Cypress S26KS512SDPBHI02) is connected to the FlexSPI interface on the MIMXRT1050-EVKB board. The HyperFlash chip (as shown in Figure 1) is replaced with the HyperRAM.



Figure 1. Replacing HyperFlash with HyperRAM

### 2.1 Board rework for HyperRAM device

The Cypress S27KS0641 HyperRAM has the same package as the default on-board Cypress S26KS512SDPBHI02 HyperFlash. To swap these devices, the following hardware changes are required: DNP R425, R426 and Mount R424, R427. Figure 2 shows the detailed PIN information for the replacement.

### How to Enable HyperRAM with i.MX RT



### 2.2 HyperRAM device

The Cypress S27KS0641 HyperRAM device features include:

- 64 Mb (8 MB) self-refresh DRAM.
- 3.0 V I/O, 11 bus signals (CK); 1.8 V I/O, 12 bus signals (differential clock (CK, CK#)).
- 166 MHz clock rate (333 MB/s) at 1.8 V VCC; 100 MHz clock rate (200 MB/s) at 3.0 V VCC.
- Double-Data Rate (DDR) two data transfers per clock.
- 8-bit data bus (DQ[7:0]).
- Read-Write Data Strobe (RWDS).
- Sequential burst transactions.
- Configurable burst characteristics.
- · Low-power modes.
- 24-ball FBGA package.

Table 1 shows the Cypress S27KS0641 HyperRAM signal descriptions.

#### Table 1. S27KS0641 HyperRAM signal descriptions

| Symbol  | Туре                         | Description                                                                                                                                                                       |  |  |  |
|---------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|         |                              | Chip Select                                                                                                                                                                       |  |  |  |
| CS#     | Master Output<br>Slave Input | Bus transactions are initiated with a HIGH-to-LOW transition. Bus transactions are terminated with a LOW-to-HIGH transition. The master device has a separate CS# for each slave. |  |  |  |
|         |                              | Differential Clock                                                                                                                                                                |  |  |  |
| CK. CK# | Master Output<br>Slave Input | Command, Address, and Data information are output regarding the crossing of the CK and CK# signals. Differential clock is used on 1.8 V I/O devices.                              |  |  |  |
|         |                              | Single Ended Clock                                                                                                                                                                |  |  |  |
|         |                              | CK# is not used on 3.0 V devices. Only a single ended CK is used.                                                                                                                 |  |  |  |
|         |                              | The clock is not required to be free-running.                                                                                                                                     |  |  |  |

#### How to Enable HyperRAM with i.MX RT

| Symbol            | Туре                                             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------------|--------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DQ[7:0]           | Input/Output                                     | <b>Data Input/Output</b><br>Command, Address, and Data information are transferred on these<br>signals during Read and Write transaction.                                                                                                                                                                                                                                                                                                       |
| RWDS              | Input/Output                                     | <ul> <li>Read Write Data Strobe</li> <li>During the Command/Address portion of all bus transactions, RWDS is a slave output. It indicates whether additional initial latency is required. Slave output is during the read data transfer. Data is edge aligned with RWDS. Slave input is during the data transfer in write transactions to function as a data mask.</li> <li>(HIGH = additional latency, LOW = no additional latency)</li> </ul> |
| RESET#            | Master Output<br>Slave Input<br>Internal Pull-up | Hardware RESET<br>When LOW, the slave device self-initializes and returns to the<br>Standby state. Place RWDS and DQ[7:0] into the HI-Z state when<br>RESET# is LOW. The slave RESET# input includes a weak pull-up.<br>If RESET# is left unconnected, it is pulled up to the HIGH state.                                                                                                                                                       |
| V <sub>cc</sub>   | Power Supply                                     | Power                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| V <sub>cc</sub> Q | Power Supply                                     | Input/Output Power                                                                                                                                                                                                                                                                                                                                                                                                                              |
| V <sub>ss</sub>   | Power Supply                                     | Ground                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| V <sub>ss</sub> Q | Power Supply                                     | Input/Output Ground                                                                                                                                                                                                                                                                                                                                                                                                                             |
| RFU               | No Connect                                       | <b>Reserved for Future Use</b><br>May or may not be connected internally. The signal/ball location<br>should be left unconnected and unused by PCB routing channel for<br>future compatibility. The signal/ball is used by a signal in the future.                                                                                                                                                                                              |

#### Table 1. S27KS0641 HyperRAM signal descriptions...continued

For more information about the Cypress S27KS0641 HyperRAM, see Datasheet.

## 3 FlexSPI controller and HyperBus

#### 3.1 FlexSPI host controller

FlexSPI is a flexible SPI host controller which supports two SPI channels and up to four external devices. Each channel supports the single/dual/quad modes of data transfer (1/2/4 bi-directional data lines). On the i.MX RT1050, the octal mode is supported by combining SIOA[3:0] and SIOB[3:0]. Figure 3 shows the block diagram of the FlexSPI host controller.



The FlexSPI host controller features:

- Flexible sequence engine (LUT table) to support various vendor devices.
- Flash access modes: single/dual/quad/octal, SDR/DDR, and individual/parallel.
- Read strobe clock sampling.
- Memory-mapped read/write access by the AHB bus:
  - The AHB RX buffer is implemented to reduce read latency. The total AHB RX buffer size is 128 × 64 bits.
  - The AHB TX buffer is implemented to buffer all write data from one AHB burst. The AHB TX buffer size is 8 × 64 bits.
- Software-triggered flash read/write access by the IP bus:
  - The IP RX FIFO is implemented to buffer all read data from the external device. Its size is 16 × 64 bits.
  - IP TX FIFO is implemented to buffer all write data to the external device. Its size is 16 × 64 bits.

## 3.2 HyperBus protocol

HyperBus has a low signal count and the Double Data Rate (DDR) interface. The interface achieves high read-and-write throughput while reducing the number of device I/ O connections and signal routing congestion in a system.

The HyperBus interface features include:

- 3.0 V I/O, 11 bus signals, single-ended clock (CK).
- 1.8 V I/O, 12 bus signals, differential clock (CK, CK#).
- Chip Select (CS#).
- 8-bit data bus (DQ[7:0]).
- Read-Write Data Strobe (RWDS).
- Double-Data Rate (DDR) two data transfers per clock.
- Up to 200 MHz clock rate (400 MB/s) at 1.8 V/3.0 V VCC.
- Sequential burst transactions, configurable burst characteristics.

For the HyperBus protocol, to define the transaction characteristics, the first three clock cycles transfer three words (48 bits in total) of the command/address (CA0, CA1, CA2) information. The command/address words are presented with the DDR timing, using the first six clock edges. <u>Table 2</u> describes the command/address information defining the characteristics. <u>Figure 4</u> shows the clock sequence of the command/address words.

### How to Enable HyperRAM with i.MX RT

| Table 2. | CA | bit | characteristics  |
|----------|----|-----|------------------|
| 10010 11 |    |     | 0110100001100100 |

| CA Bit# | Bit name                      | Bit function                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
|---------|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 47      | R/W#                          | Identifies the transaction as Read or Write.<br>R/W# = 1 indicates a Read transaction.<br>R/W# = 0 indicates a Write transaction.                                                                                                                                                                                                                    |  |  |  |  |
| 46      | Address Space (AS)            | Indicates whether the read or write transaction accesses the memory<br>or register space.<br>AS = 0 indicates the memory space.<br>AS = 1 indicates the register space.<br>The register space is used to access device ID and Configuration<br>registers.                                                                                            |  |  |  |  |
| 45      | Burst Type                    | Indicates whether the burst is linear or wrapped.<br>Burst Type = 0 indicates wrapped burst.<br>Burst Type = 1 indicates linear burst.                                                                                                                                                                                                               |  |  |  |  |
| 44-16   | Row & Upper<br>Column Address | Row & Upper Column component of the target address: System word<br>address bits A31-A3.<br>Any upper Row address bits not used by a particular device density<br>should be set to 0 by the host controller master interface. The size<br>of Rows and therefore the address bit boundary between Row and<br>Column address is slave device dependent. |  |  |  |  |
| 15-3    | Reserved                      | Reserved for future column address expansion.<br>Reserved bits are not cared in current HyperBus devices but set to <b>0</b> by the host controller master interface for future compatibility.                                                                                                                                                       |  |  |  |  |
| 2-0     | Lower Column Address          | Lower Column component of the target address: System word address bits A2-0 selecting the starting word within a half-page.                                                                                                                                                                                                                          |  |  |  |  |



Figure 5 and Figure 6 show the HyperBus read/write clock sequence with the single initial latency count.

Figure 5 shows the read transactions with the single latency.

#### How to Enable HyperRAM with i.MX RT



Figure 5. Read transaction, single initial latency count

Figure 6 shows the write transactions with the single latency.



For more information about the HyperBus protocol, see <u>Specifications</u>.

## 4 Memory region and Look-Up-Table (LUT)

There are four key memory regions related to the FlexSPI controller and HyperRAM access in the i.MX RT1050 platform. The most important memory region is LUT.

### 4.1 FlexSPI register memory region

- Base address: 0x402A\_8000h
- Size: 16 KB

The FlexSPI controller register memory region includes all the configuration registers. The first step is to set the right FlexSPI controller mode, flash parameters, AHB/IP mode, LUT block, and so on, in the controller memory region.

### 4.2 AHB access memory region

- Base address: 0x6000 0000h
- Size: 512 MB

The HyperBus device can be accessed by the AHB bus directly in the AHB address space of  $0 \times 60000000$  -  $0 \times 80000000$ . This address space is mapped in the serial flash/

RAM memory in the FlexSPI. The AHB bus access to this address space triggers the flash/RAM access command sequence as needed.

- For the AHB read access to the serial flash/RAM memory, the FlexSPI fetches the data from the flash/RAM to the AHB RX buffers and then returns the data to the AHB Bus.
- For the AHB write access to the serial flash/RAM memory, the FlexSPI buffers the write data from the AHB bus to the AHB TX buffers and then transmits it to the serial flash/ RAM memory.

There is no software configuration or polling needed for the AHB command except for the FlexSPI initialization.

The AHB bus access features include:

- Cacheable and non-cacheable access for reading. When set to cacheable, the FlexSPI checks whether the reading address hit the AHB TX buffer first.
- Bufferable and non-bufferable access for writing.
- Pre-fetch enable/disable.
- Burst size: 8/16/32/64 bits.
- All burst types: SINGLE/INCR/WRAP4/INCR4/WRAP8/INCR8/WRAP16/INCR16.

#### 4.3 IP command access memory region

- IP RX FIFO base address is:
  - 0x402A\_8100h 0x402A\_817Ch (by IPS bus).
  - 0x7FC0 0000h 0x7FC0 007Ch (by AHB bus).
- Size: 128 B

The FlexSPI puts the read data from the external device into the IP RX FIFO for the IP command. The data can be read out using either of the two above-mentioned memory spaces. MCR0 [ARDFEN] defines the read memory space and method.

- IP TX FIFO base address is:
  - 0x402A 8180h 0x402A 81FCh (by IPS bus).
  - 0x7F80\_0000h 0x7F80\_007Ch (by AHB Bus).
- Size: 128 B

The write data should be put into the IP TX FIFO and then transmitted to the external device by the IP command. The data can be written into either of the two above-mentioned memory spaces.

MCR0 [ATDFEN] defines the write memory space and method. The IP command access consists of these key steps:

- 1. Fill the IP TX FIFO with the write data if it is a write command.
- 2. Set the flash/RAM access start address (IPCR0), read/program data size, sequence index in LUT, and sequence number (IPCR1).
- 3. Trigger the flash access command by writing 1 to the register bit IPCMD[TRG].
- 4. Poll the IPCMDDONE register bit to wait for the IP command to finish in the FlexSPI interface.

#### 4.4 LUT memory region

- Base address: 0x402A 8200h
- Size: 256 B

The LUT is an internal memory region to store a number of pre-programmed sequences. Each sequence consists of up to eight instructions which are executed sequentially. When an IP or AHB command triggers a flash/RAM access, according to the index/ number values in the configuration register, the FlexSPI controller fetches the defined sequence from the LUT memory region and executes it to generate a valid flash/RAM transaction on the SPI interface. Figure 7 shows the structure of the LUT and the sequences and instructions.



For detailed instruction information, see Chapter 30.7.8 in *i.MX RT1050 Reference Manual* (document IMXRT1050RM).

## 5 Source code and performance

### 5.1 Running the HyperRAM example

The HyperRAM example source code is based on the i.MX RT1050 SDK V2.3.1. Download the code package *hyper\_ram.zip* from NXP website.

 Set up the hardware environment. To replace the Cypress S26KS512SDPBHI02 HyperFlash device with the Cypress S27KS0641 HyperRAM device, rework the MIMXRT1050 EVKB board, as shown in <u>Section 2</u>. Then, connect the OpenSDA/UART interface to the host PC and make sure that it powers on properly.

How to Enable HyperRAM with i.MX RT



Figure 8. HyperRAM test board

2. Create the HyperRAM project.

Unzip the *hyper\_ram.zip* package and extract the source code of the HyperRAM example. Copy the *hyper\_ram* folder into the *SDK\_2.3.1\_EVKB-IMXRT1050\boards* \*evkbimxrt1050\driver\_examples\flexspi* folder of the i.MX RT1050 SDK V2.3.1.

| nxrt1050 > sdk > SDK_2.3.1_EVK | 8-IMXRT1050 > boards > evkbi | mxrt1050 > driver_ | examples > flexspi |
|--------------------------------|------------------------------|--------------------|--------------------|
| Name                           | ✓ Date modified              | Туре               | Size               |
| hyper_flash                    | 2018/4/18 13:52              | File folder        |                    |
| hyper_ram                      | 2018/5/15 11:33              | File folder        |                    |
| nor                            | 2018/4/18 13:52              | File folder        |                    |

Figure 9. HyperRAM source code

- Main blocks of the HyperRAM example code. In this example, the FlexSPI sends data and operates the external HyperRAM device connected to the FlexSPI interface.
  - a. The example implements the necessary configurations of the i.MX RT1050 platform and configures the FlexSPI controller according to the HyperRAM device.
  - b. The example implements the read/write operations from/to the HyperRAM device using the AHB and IP commands.
  - c. A simple performance test is implemented and the results are displayed over the UART terminal connection. To open the HyperRAM IAR project, double-click the *flexspi\_hyper\_ram\_polling\_transfer.eww* file.

#### How to Enable HyperRAM with i.MX RT

| Vame                                     | Date modified   | Туре              | Size   |  |
|------------------------------------------|-----------------|-------------------|--------|--|
| sdram_debug                              | 2018/7/11 15:34 | File folder       |        |  |
| settings                                 | 2018/7/3 14:42  | File folder       |        |  |
| evkbimxrt1050.mac                        | 2018/4/17 5:40  | MacPaint Image    | 3 KB   |  |
| evkbimxrt1050_sdram_init.mac             | 2018/6/19 15:58 | MacPaint Image    | 10 KB  |  |
| ] flexspi_hyper_ram_polling_transfer.dep | 2018/7/11 16:13 | DEP File          | 52 KB  |  |
| ] flexspi_hyper_ram_polling_transfer.ewd | 2018/7/3 16:00  | EWD File          | 206 KB |  |
| ] flexspi_hyper_ram_polling_transfer.ewp | 2018/7/3 15:51  | EWP File          | 151 KB |  |
| flexspi_hyper_ram_polling_transfer.ewt   | 2018/5/30 9:56  | EWT File          | 346 KB |  |
| flexspi_hyper_ram_polling_transfer.eww   | 2018/5/30 9:55  | IAR IDE Workspace | 2 KB   |  |
| MIMXRT1052xxxx_ram.icf                   | 2018/4/17 5:40  | ICF File          | 5 KB   |  |
| MIMXRT1052xxxx_sdram.icf                 | 2018/7/3 18:53  | ICF File          | 6 KB   |  |

Figure 10. HyperRAM IAR project

 Build and run the example. Find the MIMXRT1050 EVKB OpenSDA-UART port on the host PC and open a serial terminal with these settings:

- 115200 baud rate.
- · Eight data bits.
- No parity.
- One stop bit.
- No flow control.



5. Set the compiling optimizations level to None.

How to Enable HyperRAM with i.MX RT

| File Edit View Project                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | CMSIS-DAP Tools                         |                                   | < Q > Category.<br>General Options                                                                                         | Mulifik              | e Compilation                                                        | Factory Setting                              |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------|----------------------|----------------------------------------------------------------------|----------------------------------------------|
| Vorkspace<br>sdram_debug                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ★ # ×                                   | flexspi_hyper_ram_polli<br>main() | C/C++ Comple<br>Assembler                                                                                                  | H List               | Icard Unused Publics<br>Preprocessor Diagnost<br>RA-C:1998 Encodings | Fatra Options                                |
| Files<br>⊐ <b>∮flexspi_hyper_r</b> a<br>— ∎ <b>i</b> board                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Options                                 |                                   | RINTF ("AF Output Conver<br>Custom Buid<br>Buid Actions<br>Linker<br>Debugger<br>Simulator                                 | Level<br>No<br>O Lov | ne 4 Enabled transfo                                                 | bexpression elimination ing                  |
| Boold     Control     Contro     Control     Control     Control     Control     Cont | Make<br>Compile<br>Rebuild All<br>Clean |                                   | ADI<br>CADI<br>CONSTANT<br>HB Commar<br>G08 Server<br>1-yet/JTAGE<br>Ahb_addr<br>TI Stelars<br>Nutrik<br>PE micro<br>STUMK |                      | dum Code motion                                                      | n<br>I alias analysis<br>eting<br>scheduling |
| L⊞ ∎ Output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | C-STAT Static A                         | naiysis                           | AM vrite Timsper<br>Config (col Tixos                                                                                      | river                |                                                                      |                                              |

Figure 12. Setting the compiling optimization level to None

6. Make, download, and debug.

The information shown in Figure 14 appears in the serial terminal.

- a. To make sure that the test data are put into the DTCM and the code is put into the ITCM, select the debug project.
- b. Make the project.
- c. Download and debug.
- d. Click Go to run the project.



Figure 13. Building and running the HyperRAM project

| coreclk: 600000000; ahbclk: 150000000; hyperbusclk: 332307684                                                 |
|---------------------------------------------------------------------------------------------------------------|
| FlexSPI HyperRAM example started!                                                                             |
| Vendor ID: 0x810c                                                                                             |
| IP Command Read/Write data succeed at all address range !                                                     |
| AHB Command Read/Write data succeed at all address range !                                                    |
| ##HyperRAM AHB write perf##t1: 599889; t2: 599920; diff: 69; ns: 115, datasize: 4 byte; perf: 34MB/s; q ms: 0 |
| ##HyperkAM AHB write perf##t1: 599989; t2: 599920; diff: 69; ns: 115, datasize: 4 byte; perf: 34MB/s; g_Ms: 0 |
| ##HyperRAM AHB read perf###t1: 599985; t2: 599932; diff: 53; ns: 88, datasize: 4 byte; perf: 45MB/s; g ms: 0  |
| 0x60000000: 0x5a5a5a5a 0x 7060504 0x b0a0908 0x f0e0d0c                                                       |
| 0x60000004: 0x 7060504 0x b0a0908 0x f0e0d0c 0x13121110                                                       |
| 0x60000008: 0x b0a0908 0x f0e0d0c 0x13121110 0x17161514                                                       |
| 0x600000c: 0x f0e0d0c 0x13121110 0x17161514 0x1b1a1918                                                        |
|                                                                                                               |
|                                                                                                               |
|                                                                                                               |

Figure 14. HyperRAM demo print information

#### 5.2 Performance and analysis

The HyperRAM project described above includes the performance test cases. <u>Table 3</u> shows the software configurations for the test.

 Table 3. HyperRAM test environment

| _                          | Module                                                                                                                              | Freq               |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------|--------------------|
| Core                       | Arm <sup>®</sup> Cortex <sup>®</sup> -M7                                                                                            | 600 MHz            |
| AHB to FlexSPI             | 64-bit                                                                                                                              | 150 MHz            |
| IPS to FlexSPI             | 32-bit                                                                                                                              | 150 MHz            |
| HyperRAM chip              | S27KS0641 @ 1.8 V                                                                                                                   | 166 MHz (332 MB/s) |
| L1 Dcache                  | Total 32 KB/one-line 32 B                                                                                                           | —                  |
| HyperRAM space setting     | MPU:<br>Normal memory type<br>Non-shareable/cacheable/wb                                                                            | _                  |
| FlexSPI controller setting | Read: Enable Prefetch<br>Write: Enable Bufferable                                                                                   | _                  |
| Code                       | Text region in ITCM<br>Data region in HyperRAM<br>CStack region in DTCM<br>Disable/enable Dcache<br>Turn off compiling optimization |                    |

**Note:** The test cases in the HyperRAM project interact with each other. Deactivate the other accesses, except for the target case. For example, to test the HyperRAM read performance, deactivate the AHB access verification, IP access verification, and write performance cases.

There are two types of the performance test case: Dcache disable and Dcache enable.

- The **Dcache disable** test case shows the pure FlexSPI and HyperRAM performance. The analysis of the results expounds the mechanism to improve the performance and basic configurations.
- The **Dcache enable** test case shows how to promote the read performance via Dcache and why the performance can be promoted so significantly.

Following the above test cases, different configurations can be selected according to a specific use case. Table 4 and Figure 15 show the performance results with **Dcache disable**.

| Tuble 4. Typertytal eele read and performance with beache alcablea |             |     |     |     |      |      |       |        |        |
|--------------------------------------------------------------------|-------------|-----|-----|-----|------|------|-------|--------|--------|
| —                                                                  | Byte        | 4   | 8   | 32  | 128  | 512  | 1024  | 16 K   | 32 K   |
| Read                                                               | Time (ns)   | 278 | 338 | 696 | 2140 | 7896 | 15576 | 248876 | 497730 |
| Reau                                                               | Perf (MB/S) | 14  | 23  | 45  | 59   | 64   | 65    | 65     | 65     |
| Write                                                              | Time (ns)   | 115 | 121 | 188 | 1075 | 4648 | 9401  | 152155 | 304415 |
| write                                                              | Perf (MB/S) | 34  | 66  | 170 | 119  | 110  | 108   | 107    | 107    |

Table 4. HyperRAM core read/write performance with Dcache disabled



The analysis is based on the above-mentioned performance results.

• The HyperRAM memory space attributes defined in the MPU model:

The original SDK code sets the HyperRAM memory space type to the **Device** mode. The setting limits the AHB burst write to the single mode and causes a very poor write performance.

Chang the HyperRAM memory space type to the **Normal** mode in the MPU. The change enables the AHB write bursts to the INCR and greatly improves the write performance.

In the board.c file:

```
/* Setting Memory with Normal type, not shareable, outer/inner
write back. */
MPU->RBAR = ARM_MPU_RBAR(2, 0x600000000);
MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 0, 0, 1, 1, 0,
ARM_MPU_REGION_SIZE_512MB);
```

• Enable the FlexSPI write access bufferable feature:

The FlexSPI optionally buffers the AHB write. The AHB write returns the AHB bus ready when an arbitrator grants the AHB command and does not wait for the AHB command to complete. The use of this feature improves the write performance. The FlexSPI AHB TX buffer has 64 bytes. The internal AHB can implement a write access burst with a maximum size of 32 bytes. Therefore, the result of the write access performance is higher when transferring 32 bytes.

In the *flexspi\_hyper\_ram\_polling\_transfer.c* file:

config.ahbConfig.enableAHBBufferable = true;

• Enable the FlexSPI read access prefetch feature:

When the FlexSPI AHB read prefetch is enabled, the FlexSPI fetches more flash/RAM read data than needed for the current AHB burst. The fetch reduces the latency for the next AHB read access and improves the read access performance. In the *flexspi\_hyper\_ram\_polling\_transfer.c* file:

config.ahbConfig.enableAHBPrefetch = true;

Even with the FlexSPI read prefetch enabled, the read access performance is not as good as it could be. The key reason is the invalidation of the internal AHB read burst. The disabled Dcache limits the AHB read access in the single mode. When the **Dcache** is enabled, to improve the performance, implement the AHB read access in the INCR burst mode, as shown in <u>Table 5</u> and <u>Figure 16</u>.

In the flexspi\_hyper\_ram\_polling\_transfer.c file:

```
/* SCB DisableDCache(); */
```

#### Table 5. HyperRAM core read performance with Dcache enabled

| —             | Byte        | 4   | 8   | 32  | 128  | 512  | 1024  | 16 K   | 32 K   |
|---------------|-------------|-----|-----|-----|------|------|-------|--------|--------|
| Read (Disable | Time (ns)   | 278 | 338 | 696 | 2140 | 7896 | 15576 | 248876 | 497730 |
| DCache)       | Perf (MB/S) | 14  | 23  | 45  | 59   | 64   | 65    | 65     | 65     |
| Read (Enable  | Time (ns)   | 275 | 285 | 351 | 671  | 1955 | 3661  | 58248  | 116501 |
| DCache)       | Perf (MB/S) | 14  | 28  | 91  | 190  | 261  | 279   | 281    | 281    |



## 6 Validated HyperRAM devices

To validate whether they can work well with i.MX RT series, HyperRAM devices from different vendors are tested.

<u>Table 6</u> lists the test results of all HyperRAM devices. As shown in <u>Table 6</u>, some HyperRAM device, such as **7KS0641DPHI02**, cannot pass the test. Therefore, when using HyperRAM on i.MX RT series, use all devices with the **PASS** results in <u>Table 6</u>.

| Table 6. | HyperRam | device | test results |
|----------|----------|--------|--------------|
|----------|----------|--------|--------------|

| RT part number  | HyperRAM vendor | HyperRAM part number | Results |
|-----------------|-----------------|----------------------|---------|
| PIMXRT1176DVMAA | Cypress         | 7KL0642DPHB02 (8 MB) | PASS    |

© NXP B.V. 2022. All rights reserved.

AN12239

| RT part number  | HyperRAM vendor | HyperRAM part number    | Results |
|-----------------|-----------------|-------------------------|---------|
| PIMXRT1064DVL6A | Cypress         | 7KS0642GAHI02 (8 MB)    | PASS    |
| PIMXRT1052DVL6B | Cypress         | 7KS0641DPHI02 (8 MB)    | FAIL    |
| PIMXRT1064DVL6A | Cypress         | 7KS0641DPHI02 (8 MB)    | FAIL    |
| PIMXRT1064DVL6A | Winbond         | W956x8MBYA (8 MB)       | PASS    |
| PIMXRT1064DVL6A | ISSI            | IS66WVH32M8DALL (32 MB) | PASS    |
| PIMXRT1176DVMAA | ISSI            | IS66WVH32M8DALL (32 MB) | PASS    |

#### Table 6. HyperRam device test results...continued

## 7 Conclusion

This application note describes how to enable the HyperRAM device with the i.MX RT1050 FlexSPI interface, provides the example source code for a quick reference, and also analyzes the performance of the HyperRAM access according to the test results. For more details, see the following:

- i.MX RT1050 Reference Manual (document IMXRT1050RM)
- HyperBus TM Specification Low Signal Count High Performance DDR Bus
- S27KS0641 user manual from Cypress

## 8 Revision history

| Revision number | Date              | Substantive changes                                                                                                                                                                 |
|-----------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4               | 29 September 2022 | <ul> <li>Updated MIMXRT1050 EVK to MIMXRT1050 EVKB.</li> <li>Updated description in <u>Section 2.1</u>.</li> <li>Updated <u>Figure 1</u>, Figure 1, and <u>Figure 8</u>.</li> </ul> |
| 3               | 29 November 2021  | Updated Section 6                                                                                                                                                                   |
| 2               | 7 May 2021        | Updated Section 6                                                                                                                                                                   |
| 1               | August 2020       | Added Section 6                                                                                                                                                                     |
| 0               | August 2018       | Initial release                                                                                                                                                                     |

#### How to Enable HyperRAM with i.MX RT

## 9 Legal information

### 9.1 Definitions

**Draft** — A draft status on a document indicates that the content is still under internal review and subject to formal approval, which may result in modifications or additions. NXP Semiconductors does not give any representations or warranties as to the accuracy or completeness of information included in a draft version of a document and shall have no liability for the consequences of use of such information.

### 9.2 Disclaimers

Limited warranty and liability — Information in this document is believed to be accurate and reliable. However, NXP Semiconductors does not give any representations or warranties, expressed or implied, as to the accuracy or completeness of such information and shall have no liability for the consequences of use of such information. NXP Semiconductors takes no responsibility for the content in this document if provided by an information source outside of NXP Semiconductors.

In no event shall NXP Semiconductors be liable for any indirect, incidental, punitive, special or consequential damages (including - without limitation lost profits, lost savings, business interruption, costs related to the removal or replacement of any products or rework charges) whether or not such damages are based on tort (including negligence), warranty, breach of contract or any other legal theory.

Notwithstanding any damages that customer might incur for any reason whatsoever, NXP Semiconductors' aggregate and cumulative liability towards customer for the products described herein shall be limited in accordance with the Terms and conditions of commercial sale of NXP Semiconductors.

**Right to make changes** — NXP Semiconductors reserves the right to make changes to information published in this document, including without limitation specifications and product descriptions, at any time and without notice. This document supersedes and replaces all information supplied prior to the publication hereof.

Suitability for use — NXP Semiconductors products are not designed, authorized or warranted to be suitable for use in life support, life-critical or safety-critical systems or equipment, nor in applications where failure or malfunction of an NXP Semiconductors product can reasonably be expected to result in personal injury, death or severe property or environmental damage. NXP Semiconductors and its suppliers accept no liability for inclusion and/or use of NXP Semiconductors products in such equipment or applications and therefore such inclusion and/or use is at the customer's own risk.

**Applications** — Applications that are described herein for any of these products are for illustrative purposes only. NXP Semiconductors makes no representation or warranty that such applications will be suitable for the specified use without further testing or modification.

Customers are responsible for the design and operation of their applications and products using NXP Semiconductors products, and NXP Semiconductors accepts no liability for any assistance with applications or customer product design. It is customer's sole responsibility to determine whether the NXP Semiconductors product is suitable and fit for the customer's applications and products planned, as well as for the planned application and use of customer's third party customer(s). Customers should provide appropriate design and operating safeguards to minimize the risks associated with their applications and products.

NXP Semiconductors does not accept any liability related to any default, damage, costs or problem which is based on any weakness or default in the customer's applications or products, or the application or use by customer's third party customer(s). Customer is responsible for doing all necessary testing for the customer's applications and products using NXP Semiconductors products in order to avoid a default of the applications and the products or of the application or use by customer's third party customer(s). NXP does not accept any liability in this respect.

Terms and conditions of commercial sale — NXP Semiconductors products are sold subject to the general terms and conditions of commercial sale, as published at http://www.nxp.com/profile/terms, unless otherwise agreed in a valid written individual agreement. In case an individual agreement is concluded only the terms and conditions of the respective agreement shall apply. NXP Semiconductors hereby expressly objects to applying the customer's general terms and conditions with regard to the purchase of NXP Semiconductors products by customer.

**Export control** — This document as well as the item(s) described herein may be subject to export control regulations. Export might require a prior authorization from competent authorities.

Suitability for use in non-automotive qualified products — Unless this data sheet expressly states that this specific NXP Semiconductors product is automotive qualified, the product is not suitable for automotive use. It is neither qualified nor tested in accordance with automotive testing or application requirements. NXP Semiconductors accepts no liability for inclusion and/or use of non-automotive qualified products in automotive equipment or applications.

In the event that customer uses the product for design-in and use in automotive applications to automotive specifications and standards, customer (a) shall use the product without NXP Semiconductors' warranty of the product for such automotive applications, use and specifications, and (b) whenever customer uses the product for automotive applications beyond NXP Semiconductors' specifications such use shall be solely at customer's own risk, and (c) customer fully indemnifies NXP Semiconductors for any liability, damages or failed product claims resulting from customer design and use of the product for automotive applications beyond NXP Semiconductors' standard warranty and NXP Semiconductors' product specifications.

**Translations** — A non-English (translated) version of a document, including the legal information in that document, is for reference only. The English version shall prevail in case of any discrepancy between the translated and English versions.

Security — Customer understands that all NXP products may be subject to unidentified vulnerabilities or may support established security standards or specifications with known limitations. Customer is responsible for the design and operation of its applications and products throughout their lifecycles to reduce the effect of these vulnerabilities on customer's applications and products. Customer's responsibility also extends to other open and/or proprietary technologies supported by NXP products for use in customer's applications. NXP accepts no liability for any vulnerability. Customer should regularly check security updates from NXP and follow up appropriately. Customer shall select products with security features that best meet rules, regulations, and standards of the intended application and make the ultimate design decisions regarding its products and is solely responsible for compliance with all legal, regulatory, and security related requirements concerning its products, regardless of any information or support that may be provided by NXP.

NXP has a Product Security Incident Response Team (PSIRT) (reachable at <u>PSIRT@nxp.com</u>) that manages the investigation, reporting, and solution release to security vulnerabilities of NXP products.

## 9.3 Trademarks

Notice: All referenced brands, product names, service names, and trademarks are the property of their respective owners.

NXP — wordmark and logo are trademarks of NXP B.V.

## How to Enable HyperRAM with i.MX RT

## Contents

| 1   | Introduction                          | 2  |
|-----|---------------------------------------|----|
| 2   | MIMXRT1050 EVKB board setting         | 2  |
| 2.1 | Board rework for HyperRAM device      | 2  |
| 2.2 | HyperRAM device                       | 3  |
| 3   | FlexSPI controller and HyperBus       |    |
| 3.1 | FlexSPI host controller               |    |
| 3.2 | HyperBus protocol                     | 5  |
| 4   | Memory region and Look-Up-Table (LUT) |    |
| 4.1 | FlexSPI register memory region        | 7  |
| 4.2 | AHB access memory region              | 7  |
| 4.3 | IP command access memory region       | 8  |
| 4.4 | LUT memory region                     | 8  |
| 5   | Source code and performance           | 9  |
| 5.1 | Running the HyperRAM example          | 9  |
| 5.2 | Performance and analysis              | 13 |
| 6   | Validated HyperRAM devices            | 15 |
| 7   | Conclusion                            | 16 |
| 8   | Revision history                      | 16 |
| 9   | Legal information                     |    |

Please be aware that important notices concerning this document and the product(s) described herein, have been included in section 'Legal information'.

© NXP B.V. 2022.

All rights reserved.

For more information, please visit: http://www.nxp.com For sales office addresses, please send an email to: salesaddresses@nxp.com

Date of release: 29 September 2022 Document identifier: AN12239