2021-12-29 23:32:55 +00:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <sdkconfig.h>
|
|
|
|
#include <esp_err.h>
|
|
|
|
#include <driver/spi_master.h>
|
|
|
|
#include "pca9555.h"
|
2022-01-01 02:06:55 +00:00
|
|
|
#include "bno055.h"
|
2022-01-01 04:51:12 +00:00
|
|
|
#include "ili9341.h"
|
2022-01-01 06:13:50 +00:00
|
|
|
#include "ice40.h"
|
2022-01-24 21:32:33 +00:00
|
|
|
#include "rp2040.h"
|
2021-12-29 23:32:55 +00:00
|
|
|
|
|
|
|
// Interrupts
|
2022-01-24 21:32:33 +00:00
|
|
|
#define GPIO_INT_RP2040 0
|
2021-12-29 23:32:55 +00:00
|
|
|
#define GPIO_INT_PCA9555 34
|
2022-01-01 02:06:55 +00:00
|
|
|
#define GPIO_INT_BNO055 36
|
2021-12-29 23:32:55 +00:00
|
|
|
#define GPIO_INT_FPGA 39
|
|
|
|
|
|
|
|
// SD card
|
|
|
|
#define SD_PWR 5
|
|
|
|
#define SD_D0 2
|
|
|
|
#define SD_CLK 14
|
|
|
|
#define SD_CMD 15
|
|
|
|
|
|
|
|
// I2S audio
|
|
|
|
#define GPIO_I2S_CLK 14
|
|
|
|
#define GPIO_I2S_DATA 13
|
|
|
|
#define GPIO_I2S_LR 4
|
|
|
|
|
|
|
|
// System I2C bus
|
|
|
|
#define GPIO_I2C_SYS_SCL 21
|
|
|
|
#define GPIO_I2C_SYS_SDA 22
|
|
|
|
#define I2C_BUS_SYS 0
|
2022-01-04 23:58:13 +00:00
|
|
|
#define I2C_SPEED_SYS 20000 // 20 kHz
|
2021-12-29 23:32:55 +00:00
|
|
|
|
|
|
|
// PCA9555 IO expander
|
2022-01-24 21:32:33 +00:00
|
|
|
#define PCA9555_ADDR 0x26
|
|
|
|
#define PCA9555_PIN_RP2040_RESET 0
|
|
|
|
#define PCA9555_PIN_RP2040_BOOTSEL 1
|
|
|
|
#define PCA9555_PIN_FPGA_RESET 2
|
|
|
|
#define PCA9555_PIN_FPGA_CDONE 3
|
|
|
|
#define PCA9555_PIN_BTN_START 5
|
|
|
|
#define PCA9555_PIN_BTN_SELECT 6
|
|
|
|
#define PCA9555_PIN_BTN_MENU 7
|
|
|
|
#define PCA9555_PIN_BTN_HOME 8
|
|
|
|
#define PCA9555_PIN_BTN_JOY_LEFT 9
|
|
|
|
#define PCA9555_PIN_BTN_JOY_PRESS 10
|
|
|
|
#define PCA9555_PIN_BTN_JOY_DOWN 11
|
|
|
|
#define PCA9555_PIN_BTN_JOY_UP 12
|
|
|
|
#define PCA9555_PIN_BTN_JOY_RIGHT 13
|
|
|
|
#define PCA9555_PIN_BTN_BACK 14
|
|
|
|
#define PCA9555_PIN_BTN_ACCEPT 15
|
|
|
|
|
|
|
|
// RP2040 co-processor
|
|
|
|
#define RP2040_ADDR 0x17
|
2021-12-29 23:32:55 +00:00
|
|
|
|
2022-01-01 02:06:55 +00:00
|
|
|
// BNO055 sensor
|
2022-01-24 21:32:33 +00:00
|
|
|
#define BNO055_ADDR 0x28
|
2022-01-01 02:06:55 +00:00
|
|
|
|
2021-12-29 23:32:55 +00:00
|
|
|
// User I2C bus
|
|
|
|
#define GPIO_I2C_EXT_SCL 25
|
|
|
|
#define GPIO_I2C_EXT_SDA 26
|
|
|
|
#define I2C_BUS_EXT 1
|
2022-01-04 23:58:13 +00:00
|
|
|
#define I2C_SPEED_EXT 100000 // 100 kHz
|
2021-12-29 23:32:55 +00:00
|
|
|
|
|
|
|
// SPI bus
|
|
|
|
#define GPIO_SPI_CLK 18
|
|
|
|
#define GPIO_SPI_MOSI 23
|
|
|
|
#define GPIO_SPI_MISO 35
|
2022-01-24 21:32:33 +00:00
|
|
|
#define GPIO_SPI_CS_RP2040 19
|
2021-12-29 23:32:55 +00:00
|
|
|
#define GPIO_SPI_CS_FPGA 27
|
|
|
|
#define GPIO_SPI_CS_LCD 32
|
|
|
|
#define GPIO_SPI_DC_LCD 33
|
|
|
|
#define SPI_BUS VSPI_HOST
|
|
|
|
#define SPI_MAX_TRANSFER_SIZE 4094
|
|
|
|
#define SPI_DMA_CHANNEL 2
|
2022-01-24 21:32:33 +00:00
|
|
|
|
|
|
|
esp_err_t board_init();
|
|
|
|
|
|
|
|
PCA9555* get_pca9555();
|
|
|
|
BNO055* get_bno055();
|
|
|
|
ILI9341* get_ili9341();
|
|
|
|
ICE40* get_ice40();
|
|
|
|
RP2040* get_rp2040();
|