# **EF PSRAM CTRL**

A Controller for Quad I/O SPI PSRAM Pseudostatic RAM (PSRAM) is DRAM combined with a self-refresh circuit. It appears externally as slower SRAM, albeit with a density/cost advantage over true SRAM, and without the access complexity of DRAM. The controller was designed after:

- https://www.issi.com/WW/pdf/66-67WVS4M8ALL-BLL.pdf and
- https://www.microchip.com/en-us/parametric-search/514

utilizing SPI, QSPI and QPI modes.

The controller was verified against the Verilog model of Microchip M23LC1024 for SPI and QPI modes only.

#### Features:

- Small in size (800 cells)
- Supports PSRAM or serial SRAM memories up to 8MBytes.
- Programmable to configure: read/write commands, number of wait states, enter and exist quad i/o commands.

# The wrapped IP

The IP comes with an AHBL Wrapper

#### Wrapped IP System Integration

```
EF_PSRAM_CTRL_AHBL INST (
        .HCLK(CLK),
        .HRESETn(RESETn),
        .HADDR(HADDR),
        .HWRITE(HWRITE),
        .HSEL(HSEL),
        .HTRANS(HTRANS),
        .HWDATA(HWDATA),
        .HRDATA(HRDATA),
        .HREADY(HREADY),
        .HREADYOUT(HREADYOUT),
        .sck(sck),
        .ce_n(ce_n),
        .din(din),
        .dout(dout),
        .douten(douten)
);
```

### **External IO interfaces**

| IO name | Direction | Width | Description                    |
|---------|-----------|-------|--------------------------------|
| sck     | output    | 1     | SPI master output clock        |
| ce_n    | output    | 1     | SPI Master slave select.       |
| din     | input     | 4     | SPI Master data in , slave out |
| dout    | output    | 4     | SPI Master data out , slave in |
| douten  | output    | 4     | SPI Master data out enable     |

# Implementation example

The following table is the result for implementing the EF\_PSRAM\_CTRL IP with different wrappers using Sky130 HD library and OpenLane2 flow.

| Module             | Number of cells | Max. freq |
|--------------------|-----------------|-----------|
| EF_PSRAM_CTRL      | TBD             | TBD       |
| EF_PSRAM_CTRL_AHBL | TBD             | TBD       |

# The Programmer's Interface

# **Memory Map**

| Region                    | Description             |
|---------------------------|-------------------------|
| 0x07FF_FFFF - 0x0000_0000 | Data Access             |
| 0x0FFF_FFFF - 0x0800_0000 | Configuration Registers |

# **Registers**

| Name        | Offset | Reset Value | Access Mode | Description                                     |
|-------------|--------|-------------|-------------|-------------------------------------------------|
| rd_cmd      | 800100 | 0x00000003  | W           | RD Command Register                             |
| wr_cmd      | 800200 | 0x00000002  | W           | WR Command Register                             |
| eqpi_cmd    | 800400 | 0x00000035  | W           | Enter QPI Command Register                      |
| xqpi_cmd    | 800800 | 0x000000FE  | W           | Exit QPI Command Register                       |
| wait_states | 801000 | 0x00000000  | W           | Wait States Register                            |
| mode        | 802000 | 0x00000000  | W           | I/O Mode Register, {qpi, qspi}                  |
| enter_qpi   | 804000 | 0x00000000  | W           | Initiate Enter QPI (EQPI) Mode process Register |
| exit_qpi    | 808000 | 0x00000000  | W           | Initiate Exit QPI (XQPI) Mode process Register  |

# rd\_cmd Register [Offset: 0x800100, mode: w]

**RD Command Register** 



# wr\_cmd Register [Offset: 0x800200, mode: w]

WR Command Register

| 15 | _ |  |  | 8 | 7 |   |     |     |  | 0  |
|----|---|--|--|---|---|---|-----|-----|--|----|
|    |   |  |  |   |   |   | wr_ | cmd |  |    |
| 31 |   |  |  |   |   |   |     |     |  | 16 |
|    |   |  |  |   | 1 | 1 |     |     |  |    |

eqpi\_cmd Register [Offset: 0x800400, mode: w]

| Enter OPI Command Regist | er |
|--------------------------|----|
|--------------------------|----|

| 15 |  |  |   | 8 | 7 |   |   |       |     |  | 0  |
|----|--|--|---|---|---|---|---|-------|-----|--|----|
|    |  |  |   |   |   |   |   | eqpi_ | cmd |  |    |
| 31 |  |  |   |   |   |   |   |       |     |  | 16 |
|    |  |  | ' |   |   | ' | ' |       |     |  |    |

# xqpi\_cmd Register [Offset: 0x800800, mode: w]

#### Exit QPI Command Register

| 15 |  |  |   | 8 | 7 |   |       |     |  | 0  |
|----|--|--|---|---|---|---|-------|-----|--|----|
|    |  |  |   |   |   |   | xqpi_ | cmd |  |    |
| 31 |  |  | • |   |   | • |       |     |  | 16 |
|    |  |  |   |   |   |   |       |     |  |    |

# wait\_states Register [Offset: 0x801000, mode: w]

Wait States Register

| 15 |  |  |   |   |  | 4 | 3 |        |        | 0  |
|----|--|--|---|---|--|---|---|--------|--------|----|
|    |  |  | ' | ' |  |   |   | wait_s | states |    |
| 31 |  |  |   |   |  |   |   |        |        | 16 |
|    |  |  |   |   |  |   |   |        |        |    |

## mode Register [Offset: 0x802000, mode: w]

I/O Mode Register, {qpi, qspi}

| <br>15 |   |   |   |   |   |   |  |   |   |   | 2 | 1  | 0   |
|--------|---|---|---|---|---|---|--|---|---|---|---|----|-----|
|        |   |   |   | 1 | 1 |   |  |   |   |   |   | mo | ode |
| 31     |   |   |   |   |   |   |  |   |   |   |   |    | 16  |
|        | 1 | • | • | 1 | 1 | ' |  |   |   | ' |   |    |     |
|        | 1 |   | 1 | 1 | 1 | 1 |  | 1 | 1 | 1 |   |    | 1   |

## enter\_qpi Register [Offset: 0x804000, mode: w]

Initiate Enter QPI (EQPI) Mode process Register

| 15 |   | <br> |  |  |   |   |   | 1 | 0        |
|----|---|------|--|--|---|---|---|---|----------|
|    |   |      |  |  |   |   |   |   | enter_qp |
| 31 |   |      |  |  |   |   |   |   | 16       |
|    | 1 |      |  |  | • | ' | 1 |   |          |

## exit\_qpi Register [Offset: 0x808000, mode: w]

Initiate Exit QPI (XQPI) Mode process Register

| 15 |   |   |  |  |   |   |   |   | 1 | 0        |
|----|---|---|--|--|---|---|---|---|---|----------|
|    |   |   |  |  |   |   |   |   |   | exit_qpi |
| 31 |   |   |  |  |   |   |   |   |   | 16       |
|    | ' | ' |  |  | • | ' | • | ' | ' |          |
|    |   |   |  |  |   |   |   |   |   |          |

## **Firmware Drivers:**

Firmware drivers for EF\_PSRAM\_CTRL can be found in the <u>Drivers</u> directory in the <u>EFIS</u> (Efabless Firmware Interface Standard) repo. EF\_PSRAM\_CTRL driver documentation is available <u>here</u>. You can also find an example C application using the EF\_PSRAM\_CTRL drivers <u>here</u>.

## Installation:

You can install the IP either by cloning this repository or by using IPM.

## 1. Using IPM:

- [Optional] If you do not have IPM installed, follow the installation guide here
- $\bullet$  After installing IPM, execute the following command  $\,$  ipm install  $\,$  EF\_PSRAM\_CTRL .

Note: This method is recommended as it automatically installs **EF\_IP\_UTIL** as a dependency.

## 2. Cloning this repo:

- Clone <u>EF\_IP\_UTIL</u> repository, which includes the required modules from the common modules library, <u>ef\_util\_lib.v.</u> git clone https://github.com/efabless/EF\_IP\_UTIL.git
- Clone the IP repository git clone github.com/efabless/EF\_PSRAM\_CTRL

## The Wrapped IP Interface

**NOTE:** This section is intended for advanced users who wish to gain more information about the interface of the wrapped IP, in case they want to create their own wrappers.



#### **Ports**

| Port   | Direction | Width | Description                    |
|--------|-----------|-------|--------------------------------|
| sck    | output    | 1     | SPI master output clock        |
| ce_n   | output    | 1     | SPI Master slave select.       |
| din    | input     | 4     | SPI Master data in , slave out |
| dout   | output    | 4     | SPI Master data out , slave in |
| douten | output    | 4     | SPI Master data out enable     |