

# PICORV32 SRAM SPECIFICATION

| Port list | Direction | Description                                                                                                                                 |
|-----------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------|
| clk       | input     | IP clock (125 MHZ)                                                                                                                          |
| resetn    | input     | synchronous active low reset                                                                                                                |
| mem_valid | input     | 0: no memory access request<br>1: request for accessing memory, mem_addr, mem_wdata, mem_wstrb, mem_instr are valid when mem_valid = 1      |
| mem_ready | output    | In read access<br>0: output rdata is not valid<br>1: output rdata is valid<br>In write access<br>0: write not complete<br>1: write complete |
| mem_addr  | input     | 16 bit memory address                                                                                                                       |
| mem_wdata | input     | 32 bit write data from CPU for write access                                                                                                 |
| mem_rdata | output    | 32 bit read data from SRAM for read access                                                                                                  |
| mem_wstrb | input     | 4'b0000: read access<br>Another is write access.<br>This signal has 4 bits to mask 4 bytes, LSB                                             |

|           |       |                                                                                                                                                                                                     |
|-----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           |       | bit is LSB byte, MSB bit is MSB byte. If bit is 0, meaning that this byte in memory does not change. If bit is 1, meaning that this byte in memory is written with corresponding byte in mem_wdata. |
| mem_instr | input | 1: access for instruction<br>0: access for data                                                                                                                                                     |

## WRITE ACCESS



**Explanation:** When master or CPU requests write access, CPU drives mem\_valid to 1, drives mem\_addr, mem\_wdata and mem\_wstrb to a valid value. And then the CPU keeps these values until mem\_ready is asserted to 1, after that CPU stops requesting and drives mem\_valid to 0. In this system, because we know and define ourselves where to store instructions and where to store data in this unified memory, we don't use the mem\_instr signal.

## READ ACCESS



### Explanation:

When master or CPU requests read access, CPU drives **mem\_valid** to 1, drives **mem\_addr** to a valid value and drives **mem\_wstrb** to 4'b0. And then the CPU keeps these values until **mem\_ready** is asserted to 1, after that CPU stops requesting and drives **mem\_valid** to 0, CPU reads data from **core\_rdata**. In this system, there is a register **core\_rdata** that stores stable data of memory and UART read access, the data of **mem\_rdata** must go through this **core\_rdata** register before going to the CPU, so the read data is delayed 1 cycle and **mem\_ready** must delay 1 cycle and is asserted to 1 when **core\_rdata** is valid, not **mem\_rdata**. **core\_rdata** register is defined in `picorv32_top` module.

## LITTLE ENDIAN

| 0x34 | 0x12 | 0xCD | 0xAB | DATA    |
|------|------|------|------|---------|
| 8    | 9    | 10   | 11   | ADDRESS |

**Explanation:** When the CPU writes 1 word (a chunk of 4 bytes) 32'hABCD\_1234 at address 8, LSB byte 0x34 must be stored at lowest address (that is 8), MSB byte 0xAB must be stored at highest address (that is 11) as shown in the above figure. Meaning that when the CPU later executes load byte instruction at address 10, read data must be 0xCD.