The Raspberry Pi Pico 2 is Raspberry Pi's first board fitted with their RP2350A SoC. This adds a minimal board definition, sufficient to build and run `samples/hello_world` and `samples/basic/blinky` on the board. Images can be run on the target using OpenOCD. Raspberry Pi's `picotool` can create a UF2 binary, which ensures that errata RP2350-E10 is avoided e.g. ``` > picotool uf2 convert build\rpi_pico2\hello_world\zephyr\zephyr.elf \ build\rpi_pico2\hello_world\zephyr\zephyr.uf2 \ --family rp2350-arm-s --abs-block` ``` Raspberry Pi Pico 2 is a low-cost, high-performance microcontroller board with flexible digital interfaces. Key features include: - RP2350A microcontroller chip designed by Raspberry Pi in the United Kingdom - Dual Cortex-M33 or Hazard3 processors at up to 150MHz - 520KB of SRAM, and 4MB of on-board flash memory - USB 1.1 with device and host support - Low-power sleep and dormant modes - Drag-and-drop programming using mass storage over USB - 26x multi-function GPIO pins including 3 that can be used for ADC - 2x SPI, 2x I2C, 2x UART, 3x 12-bit 500ksps Analogue to Digital Converter (ADC), 24x controllable PWM channels - 2x Timer with 4 alarms, 1x AON Timer - Temperature sensor - 3x Programmable IO (PIO) blocks, 12 state machines total for custom peripheral support - Flexible, user-programmable high-speed IO - Can emulate interfaces such as SD Card and VGA The Raspberry Pi Pico 2 comes as a castellated module which allows soldering direct to carrier boards. Only enable timer 0 for now. Timer 1 won't work correctly until the rpi_pico HAL has picked up the fix for `hardware_alarm_irq_handler`. See https://github.com/raspberrypi/pico-sdk/pull/1949 . Added some documentation for the board itself (mostly aiming to refer to canonical sources of information rather duplicate). Add entries in the release notes where applicable. boards/raspberrypi/rpi_pico2/doc/img/rpi_pico2.webp is a cropped and compressed version of https://www.raspberrypi.com/documentation/microcontrollers/images/pico-2.png which is released under the CC-BY-SA-4.0 license. See https://github.com/raspberrypi/documentation/blob/develop/LICENSE.md Signed-off-by: Andrew Featherstone <andrew.featherstone@gmail.com> Signed-off-by: Benjamin Cabé <benjamin@zephyrproject.org>
144 lines
3 KiB
Text
144 lines
3 KiB
Text
/*
|
|
* Copyright (c) 2024 Andrew Featherstone
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
#include <freq.h>
|
|
|
|
#include <zephyr/dt-bindings/i2c/i2c.h>
|
|
#include <zephyr/dt-bindings/pwm/pwm.h>
|
|
|
|
#include "rpi_pico2-pinctrl.dtsi"
|
|
#include "../common/rpi_pico-led.dtsi"
|
|
|
|
/ {
|
|
chosen {
|
|
zephyr,sram = &sram0;
|
|
zephyr,flash = &flash0;
|
|
zephyr,console = &uart0;
|
|
zephyr,shell-uart = &uart0;
|
|
zephyr,code-partition = &code_partition;
|
|
};
|
|
|
|
aliases {
|
|
watchdog0 = &wdt0;
|
|
};
|
|
|
|
pico_header: connector {
|
|
compatible = "raspberrypi,pico-header";
|
|
#gpio-cells = <2>;
|
|
gpio-map-mask = <0xffffffff 0xffffffc0>;
|
|
gpio-map-pass-thru = <0 0x3f>;
|
|
gpio-map = <0 0 &gpio0 0 0>, /* GP0 */
|
|
<1 0 &gpio0 1 0>, /* GP1 */
|
|
<2 0 &gpio0 2 0>, /* GP2 */
|
|
<3 0 &gpio0 3 0>, /* GP3 */
|
|
<4 0 &gpio0 4 0>, /* GP4 */
|
|
<5 0 &gpio0 5 0>, /* GP5 */
|
|
<6 0 &gpio0 6 0>, /* GP6 */
|
|
<7 0 &gpio0 7 0>, /* GP7 */
|
|
<8 0 &gpio0 8 0>, /* GP8 */
|
|
<9 0 &gpio0 9 0>, /* GP9 */
|
|
<10 0 &gpio0 10 0>, /* GP10 */
|
|
<11 0 &gpio0 11 0>, /* GP11 */
|
|
<12 0 &gpio0 12 0>, /* GP12 */
|
|
<13 0 &gpio0 13 0>, /* GP13 */
|
|
<14 0 &gpio0 14 0>, /* GP14 */
|
|
<15 0 &gpio0 15 0>, /* GP15 */
|
|
<16 0 &gpio0 16 0>, /* GP16 */
|
|
<17 0 &gpio0 17 0>, /* GP17 */
|
|
<18 0 &gpio0 18 0>, /* GP18 */
|
|
<19 0 &gpio0 19 0>, /* GP19 */
|
|
<20 0 &gpio0 20 0>, /* GP20 */
|
|
<21 0 &gpio0 21 0>, /* GP21 */
|
|
<22 0 &gpio0 22 0>, /* GP22 */
|
|
<26 0 &gpio0 26 0>, /* GP26 */
|
|
<27 0 &gpio0 27 0>, /* GP27 */
|
|
<28 0 &gpio0 28 0>; /* GP28 */
|
|
};
|
|
};
|
|
|
|
&flash0 {
|
|
reg = <0x10000000 DT_SIZE_M(4)>;
|
|
|
|
partitions {
|
|
compatible = "fixed-partitions";
|
|
#address-cells = <1>;
|
|
#size-cells = <1>;
|
|
|
|
/* Reserved memory for an image definition block. The block is much
|
|
* smaller than 256 bytes, but in practice the linker places the vector
|
|
* table at a much larger alignment offset.
|
|
*/
|
|
image_def: partition@0 {
|
|
label = "image_def";
|
|
reg = <0x00000000 0x100>;
|
|
read-only;
|
|
};
|
|
|
|
/*
|
|
* Usable flash. Starts at 0x100, after the image definition block.
|
|
* The partition size is 4MB minus the 0x100 bytes taken by the
|
|
* image definition.
|
|
*/
|
|
code_partition: partition@100 {
|
|
label = "code-partition";
|
|
reg = <0x100 (DT_SIZE_M(4) - 0x100)>;
|
|
read-only;
|
|
};
|
|
};
|
|
};
|
|
|
|
&uart0 {
|
|
current-speed = <115200>;
|
|
status = "okay";
|
|
pinctrl-0 = <&uart0_default>;
|
|
pinctrl-names = "default";
|
|
};
|
|
|
|
&gpio0 {
|
|
status = "okay";
|
|
};
|
|
|
|
&spi0 {
|
|
clock-frequency = <DT_FREQ_M(8)>;
|
|
pinctrl-0 = <&spi0_default>;
|
|
pinctrl-names = "default";
|
|
};
|
|
|
|
&i2c0 {
|
|
clock-frequency = <I2C_BITRATE_STANDARD>;
|
|
pinctrl-0 = <&i2c0_default>;
|
|
pinctrl-names = "default";
|
|
status = "okay";
|
|
};
|
|
|
|
&i2c1 {
|
|
clock-frequency = <I2C_BITRATE_STANDARD>;
|
|
pinctrl-0 = <&i2c1_default>;
|
|
pinctrl-names = "default";
|
|
status = "okay";
|
|
};
|
|
|
|
&adc {
|
|
pinctrl-0 = <&adc_default>;
|
|
pinctrl-names = "default";
|
|
status = "okay";
|
|
};
|
|
|
|
&pwm {
|
|
pinctrl-0 = <&pwm_ch4b_default>;
|
|
pinctrl-names = "default";
|
|
divider-int-0 = <255>;
|
|
};
|
|
|
|
&timer0 {
|
|
status = "okay";
|
|
};
|
|
|
|
zephyr_udc0: &usbd {
|
|
status = "okay";
|
|
};
|
|
|
|
pico_serial: &uart0 {};
|