Picoprog is a firmware for the Raspberry Pi Pico that provides a USB-to-serial and USB-to-SPI bridge. It allows you to communicate with UART and SPI peripherals via USB.
Before you can compile and use Picoprog, you need to install the following dependencies:
# Only Linux
sudo apt install build-essential libudev-dev pkg-config
# All systems
cargo install flip-link elf2uf2-rs
To compile the firmware, follow these steps:
git clone https://github.com/9elements/picoprog.git
cd picoprog
cargo run --release
target/thumbv6m-none-eabi/release
directory.To flash the firmware onto the Raspberry Pi Pico, follow these steps:
Connect the Raspberry Pi Pico to your computer while holding the BOOTSEL button. This will put the Pico into USB mass storage mode.
Copy the UF2 file to the Pico:
# Linux
cp target/thumbv6m-none-eabi/release/picoprog.uf2 /media/$USER/RPI-RP2/
# macOS
cp target/thumbv6m-none-eabi/release/picoprog.uf2 /Volumes/RPI-RP2/
Once the firmware is running on the Raspberry Pi Pico, you can use any terminal program to communicate with the UART and SPI peripherals via USB. The device will appear as a USB CDC (Communications Device Class) device. Currently /dev/ttyACM0
(macOS: /dev/tty.usbmodemOSFC20241
) is a debug console that prints information about the picos current operation.
To communicate with the UART peripheral, open the corresponding serial port (e.g., /dev/ttyACM1
on Linux, /dev/tty.usbmodemOSFC20243
on macOS) with your terminal program. For now the Baud is fixed at 115200 but can be changed in code. Dynamic reconfiguration is still planned.
To interact with the Raspberry Pi Pico for reading and writing SPI flash chips, you can use tools like flashrom
or flashprog
. These tools support the serprog
protocol, which allows communication over a serial interface.
flashrom
or flashprog
e.g.:# Debian or Debian-based Linux distributions
sudo apt-get install flashrom
# macOS with Homebrew
brew install flashrom
flashrom -p serprog:dev=/dev/ttyACM2 -r backup.bin
This command reads the contents of the SPI flash chip and saves it to backup.bin
.
flashrom -p serprog:dev=/dev/ttyACM2 -w firmware.bin
This command writes the contents of firmware.bin
to the SPI flash chip.
Make sure to replace /dev/ttyACM2
with the correct serial port if your device is connected to a different port or if you're on a different operating system (on macOS it will be /dev/tty.usbmodemOSFC20245
).
This project is licensed under the Apache 2.0 License. See the LICENSE file for details.