generated from pimoroni/pico-boilerplate
-
Notifications
You must be signed in to change notification settings - Fork 5
/
sram.h
34 lines (28 loc) · 1.1 KB
/
sram.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
// Copyright 2023 (c) Michael Bell
// The BSD 3 clause license applies
#pragma once
#include <stdint.h>
// Configuration: GPIOs for the SPI interface
#define SIM_SRAM_SPI_MOSI 2
#define SIM_SRAM_SPI_SCK 3 // Must be MOSI + 1
#define SIM_SRAM_SPI_CS 4 // Must be MOSI + 2
#define SIM_SRAM_SPI_MISO 5
// The PIO SMs and DMA channels are hardcoded as using dynamic
// allocation and then reading the values from memory is slightly slower.
// Configuration: PIO and SMs to use
// A different PIO must be used for each of read and write
// as the total program size is too large to fit in one PIO
#define SIM_SRAM_pio_read_sm 1
#define SIM_SRAM_pio_read pio1
#define SIM_SRAM_pio_write_sm 1
#define SIM_SRAM_pio_write pio0
// Configuration: DMA channels
#define SIM_SRAM_rx_channel 0
#define SIM_SRAM_tx_channel 1
#define SIM_SRAM_tx_channel2 2
// Setup the simulated SRAM and launch core1 to service the commands.
//
// It is best to call this before other initialization, so that
// the hardcoded DMA channels and SMs are claimed before other resources
// are claimed.
uint8_t* setup_simulated_sram();