-
Notifications
You must be signed in to change notification settings - Fork 972
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add board file for Pimoroni Pico Plus 2 W (#2092)
* Add board pimoroni_pico_plus2_w_rp2350.
- Loading branch information
1 parent
58e253c
commit b7e255d
Showing
1 changed file
with
143 additions
and
0 deletions.
There are no files selected for viewing
143 changes: 143 additions & 0 deletions
143
src/boards/include/boards/pimoroni_pico_plus2_w_rp2350.h
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,143 @@ | ||
/* | ||
* Copyright (c) 2020 Raspberry Pi (Trading) Ltd. | ||
* | ||
* SPDX-License-Identifier: BSD-3-Clause | ||
*/ | ||
|
||
// ----------------------------------------------------- | ||
// NOTE: THIS HEADER IS ALSO INCLUDED BY ASSEMBLER SO | ||
// SHOULD ONLY CONSIST OF PREPROCESSOR DIRECTIVES | ||
// ----------------------------------------------------- | ||
|
||
// This header may be included by other board headers as "boards/pimoroni_pico_plus2_w_rp2350.h" | ||
|
||
// pico_cmake_set PICO_PLATFORM=rp2350 | ||
// pico_cmake_set PICO_CYW43_SUPPORTED = 1 | ||
|
||
#ifndef _BOARDS_PIMORONI_PICO_PLUS2_W_RP2350_H | ||
#define _BOARDS_PIMORONI_PICO_PLUS2_W_RP2350_H | ||
|
||
// For board detection | ||
#define PIMORONI_PICO_PLUS2_W_RP2350 | ||
|
||
// --- BOARD SPECIFIC --- | ||
#define PIMORONI_PICO_PLUS2_W_USER_SW_PIN 45 | ||
#define PIMORONI_PICO_PLUS2_W_PSRAM_CS_PIN 47 | ||
|
||
// --- UART --- | ||
#ifndef PICO_DEFAULT_UART | ||
#define PICO_DEFAULT_UART 0 | ||
#endif | ||
#ifndef PICO_DEFAULT_UART_TX_PIN | ||
#define PICO_DEFAULT_UART_TX_PIN 0 | ||
#endif | ||
#ifndef PICO_DEFAULT_UART_RX_PIN | ||
#define PICO_DEFAULT_UART_RX_PIN 1 | ||
#endif | ||
|
||
// --- LED --- | ||
// no PICO_DEFAULT_LED_PIN - LED is on Wireless chip | ||
// no PICO_DEFAULT_WS2812_PIN | ||
|
||
// --- I2C --- | ||
#ifndef PICO_DEFAULT_I2C | ||
#define PICO_DEFAULT_I2C 0 | ||
#endif | ||
#ifndef PICO_DEFAULT_I2C_SDA_PIN | ||
#define PICO_DEFAULT_I2C_SDA_PIN 4 | ||
#endif | ||
#ifndef PICO_DEFAULT_I2C_SCL_PIN | ||
#define PICO_DEFAULT_I2C_SCL_PIN 5 | ||
#endif | ||
|
||
// --- SPI --- | ||
#ifndef PICO_DEFAULT_SPI | ||
#define PICO_DEFAULT_SPI 0 | ||
#endif | ||
#ifndef PICO_DEFAULT_SPI_SCK_PIN | ||
#define PICO_DEFAULT_SPI_SCK_PIN 18 | ||
#endif | ||
#ifndef PICO_DEFAULT_SPI_TX_PIN | ||
#define PICO_DEFAULT_SPI_TX_PIN 19 | ||
#endif | ||
#ifndef PICO_DEFAULT_SPI_RX_PIN | ||
#define PICO_DEFAULT_SPI_RX_PIN 16 | ||
#endif | ||
#ifndef PICO_DEFAULT_SPI_CSN_PIN | ||
#define PICO_DEFAULT_SPI_CSN_PIN 17 | ||
#endif | ||
|
||
// --- FLASH --- | ||
|
||
#define PICO_BOOT_STAGE2_CHOOSE_W25Q080 1 | ||
|
||
#ifndef PICO_FLASH_SPI_CLKDIV | ||
#define PICO_FLASH_SPI_CLKDIV 2 | ||
#endif | ||
|
||
// pico_cmake_set_default PICO_FLASH_SIZE_BYTES = (16 * 1024 * 1024) | ||
#ifndef PICO_FLASH_SIZE_BYTES | ||
#define PICO_FLASH_SIZE_BYTES (16 * 1024 * 1024) | ||
#endif | ||
|
||
// The GPIO Pin used to monitor VSYS. Typically you would use this with ADC. | ||
// There is an example in adc/read_vsys in pico-examples. | ||
#ifndef PICO_VSYS_PIN | ||
#define PICO_VSYS_PIN 43 | ||
#endif | ||
|
||
// pico_cmake_set_default PICO_RP2350_A2_SUPPORTED = 1 | ||
#ifndef PICO_RP2350_A2_SUPPORTED | ||
#define PICO_RP2350_A2_SUPPORTED 1 | ||
#endif | ||
|
||
// --- CYW43 --- | ||
|
||
// gpio pin to power up the cyw43 chip | ||
#ifndef CYW43_DEFAULT_PIN_WL_REG_ON | ||
#define CYW43_DEFAULT_PIN_WL_REG_ON 23 | ||
#endif | ||
|
||
// gpio pin for spi data out to the cyw43 chip | ||
#ifndef CYW43_DEFAULT_PIN_WL_DATA_OUT | ||
#define CYW43_DEFAULT_PIN_WL_DATA_OUT 24 | ||
#endif | ||
|
||
// gpio pin for spi data in from the cyw43 chip | ||
#ifndef CYW43_DEFAULT_PIN_WL_DATA_IN | ||
#define CYW43_DEFAULT_PIN_WL_DATA_IN 24 | ||
#endif | ||
|
||
// gpio (irq) pin for the irq line from the cyw43 chip | ||
#ifndef CYW43_DEFAULT_PIN_WL_HOST_WAKE | ||
#define CYW43_DEFAULT_PIN_WL_HOST_WAKE 24 | ||
#endif | ||
|
||
// gpio pin for the spi clock line to the cyw43 chip | ||
#ifndef CYW43_DEFAULT_PIN_WL_CLOCK | ||
#define CYW43_DEFAULT_PIN_WL_CLOCK 29 | ||
#endif | ||
|
||
#ifndef CYW43_WL_GPIO_COUNT | ||
#define CYW43_WL_GPIO_COUNT 3 | ||
#endif | ||
|
||
#ifndef CYW43_WL_GPIO_LED_PIN | ||
#define CYW43_WL_GPIO_LED_PIN 0 | ||
#endif | ||
|
||
// If CYW43_WL_GPIO_VBUS_PIN is defined then a CYW43 GPIO has to be used to read VBUS. | ||
// This can be passed to cyw43_arch_gpio_get to determine if the device is battery powered. | ||
// PICO_VBUS_PIN and CYW43_WL_GPIO_VBUS_PIN should not both be defined. | ||
#ifndef CYW43_WL_GPIO_VBUS_PIN | ||
#define CYW43_WL_GPIO_VBUS_PIN 2 | ||
#endif | ||
|
||
// If CYW43_USES_VSYS_PIN is defined then CYW43 uses the VSYS GPIO (defined by PICO_VSYS_PIN) for other purposes. | ||
// If this is the case, to use the VSYS GPIO it's necessary to ensure CYW43 is not using it. | ||
// This can be achieved by wrapping the use of the VSYS GPIO in cyw43_thread_enter / cyw43_thread_exit. | ||
#ifndef CYW43_USES_VSYS_PIN | ||
#define CYW43_USES_VSYS_PIN 1 | ||
#endif | ||
|
||
#endif |