Skip to content

A header-only C library to allow access to SPI PSRAM via PIO on the RP2040 microcontroller.

License

Notifications You must be signed in to change notification settings

polpo/rp2040-psram

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

24 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

rp2040-psram

A header-only C library to allow access to SPI PSRAM via PIO on the RP2040 microcontroller as used on the Raspberry Pi Pico. Due to the timing requirements of these PSRAM devices, reading data from them at high speed (>84MHz) requires the following clock behavior:

  • Read data needs to be sampled on the clock falling edge.
  • An extra "fudge factor" clock cycle is required before reading data.

I could not get the hardware SPI interface on the RP2040 to work at high speed with this behavior, so I created a PIO SPI implementation specifically tailored to the behavior of the PSRAM chips and optimized for the highest speed possible:

  • A read or write command is given, followed by an optional read of data.
  • Chip select is driven by PIO.
  • DMA is used so CPU cycles are not used to service the PIO TX and RX FIFOs.
  • Special optimized functions are provided for writing 8, 16, and 32 bit data as fast as possible.
  • All functions are tagged with __force_inline for the fastest speed possible.

Tested PSRAM chips:

  • apmemory APS6404L
  • Lyontek LY68L6400
  • IPUS IPS6404
  • Espressif ESP-PSRAM64H

These chips have been tested as stable up to an RP2040 clock speed of 280MHz, creating an effecitve SPI clock speed of 140MHz.

Examples

An example that tests the PSRAM by writing and reading 8MB of data with 8, 16, 32, and 128 bit access sizes is included in the examples/ directory.

Using this library

Hardware connections

Due to using sideset to drive the CS and SCK signals, those two pins must be on consecutive GPIOs. For example, if CS is on GPIO 0, SCK must be on GPIO 1. MOSI and MISO may be on any pin and do not need to be adjacent.

QSPI support is on the roadmap for the future. If you plan on using QSPI, SIO[0] through SIO[3] must be on consecutive GPIOs.

Including in the build

Clone this repository and copy to a subdirectory or add as a submodule in your project. In your project's CMakeLists.txt file, add the following:

add_subdirectory(${CMAKE_CURRENT_LIST_DIR}/rp2040-psram rp2040-psram)

And then add rp2040-psram to your project's target_link_libraries.

Using in your code

Include psram_spi.h in your file. See the documentation for this file for how to initialize and use this library.

The following defines MUST be defined:

  • PSRAM_PIN_CS - GPIO number of the chip select pin
  • PSRAM_PIN_SCK - GPIO number of the clock pin
  • PSRAM_PIN_MOSI - GPIO number of the MOSI pin
  • PSRAM_PIN_MISO - GPIO number of the MISO pin

Optional define:

  • PSRAM_MUTEX - Define this to put PSRAM access behind a mutex. This must be used if the PSRAM is to be used by multiple cores.

Projects that use rp2040-psram

PicoGUS - uses PSRAM to emulate the Gravis Ultrasound's 1MB sample RAM

License

rp2040-psram is licensed under the MIT license (see LICENSE)

About

A header-only C library to allow access to SPI PSRAM via PIO on the RP2040 microcontroller.

Topics

Resources

License

Stars

Watchers

Forks