mirror of
https://github.com/lukstep/raspberry-pi-pico-docker-sdk.git
synced 2025-12-22 18:45:56 +03:00
Compare commits
16 Commits
container-
...
debugging
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
0d802ea304 | ||
|
|
3d8b06e9b7 | ||
|
|
ee42c6f1df | ||
|
|
ecea0809ad | ||
|
|
17a8f90fef | ||
|
|
ad8789bee0 | ||
|
|
ac4a91fe9c | ||
|
|
8330c3c482 | ||
|
|
fb5f876583 | ||
|
|
b874fd5682 | ||
|
|
9181e64866 | ||
|
|
4043da22f1 | ||
|
|
90483caaef | ||
|
|
989cd790e4 | ||
|
|
1f37ffef34 | ||
|
|
b067ae75eb |
47
.github/workflows/sdk-ci.yml
vendored
Normal file
47
.github/workflows/sdk-ci.yml
vendored
Normal file
@@ -0,0 +1,47 @@
|
||||
name: Raspberry PI Pico Docker SDK CI
|
||||
|
||||
on:
|
||||
push:
|
||||
branches:
|
||||
- main
|
||||
pull_request:
|
||||
branches:
|
||||
- main
|
||||
release:
|
||||
types: [published]
|
||||
|
||||
env:
|
||||
TEST_TAG: pico_test_sdk
|
||||
|
||||
jobs:
|
||||
sdk_container:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v3
|
||||
- name: Build SDK
|
||||
uses: docker/build-push-action@v4
|
||||
with:
|
||||
context: .
|
||||
load: true
|
||||
tags: ${{ env.TEST_TAG }}
|
||||
- name: Test SDK
|
||||
run: bash ./test_sdk.sh ${{ env.TEST_TAG }}
|
||||
- name: Log into Docker Hub
|
||||
uses: docker/login-action@v2
|
||||
with:
|
||||
username: ${{ github.actor }}
|
||||
password: ${{ secrets.DOCKER_HUB_TOKEN }}
|
||||
- name: Extract SDK metadata
|
||||
id: meta
|
||||
uses: docker/metadata-action@v4
|
||||
with:
|
||||
images: lukstep/raspberry-pi-pico-sdk
|
||||
- name: Push SDK image
|
||||
if: github.event_name == 'release' && github.event.action == 'published'
|
||||
uses: docker/build-push-action@v4
|
||||
with:
|
||||
context: .
|
||||
push: true
|
||||
tags: ${{ steps.meta.outputs.tags }}
|
||||
labels: ${{ steps.meta.outputs.labels }}
|
||||
@@ -1,18 +0,0 @@
|
||||
cmake_minimum_required(VERSION 3.13)
|
||||
|
||||
include($ENV{PICO_SDK_PATH}/external/pico_sdk_import.cmake)
|
||||
|
||||
project(sample C CXX ASM)
|
||||
|
||||
set(CMAKE_C_STANDARD 11)
|
||||
set(CMAKE_CXX_STANDARD 17)
|
||||
|
||||
pico_sdk_init()
|
||||
|
||||
add_executable(sample main.c)
|
||||
|
||||
pico_enable_stdio_usb(sample 1)
|
||||
pico_enable_stdio_uart(sample 1)
|
||||
pico_add_extra_outputs(sample)
|
||||
|
||||
target_link_libraries(sample pico_stdlib)
|
||||
@@ -1,4 +1,4 @@
|
||||
FROM alpine:3.16.2
|
||||
FROM alpine:3.17.0
|
||||
|
||||
# Install toolchain
|
||||
RUN apk update && \
|
||||
@@ -11,18 +11,19 @@ RUN apk update && \
|
||||
libusb-dev \
|
||||
bsd-compat-headers \
|
||||
newlib-arm-none-eabi \
|
||||
gcc-arm-none-eabi
|
||||
gcc-arm-none-eabi \
|
||||
gdb-multiarch
|
||||
|
||||
# Raspberry Pi Pico SDK
|
||||
ARG SDK_PATH=/usr/share/pico_sdk
|
||||
RUN git clone https://github.com/raspberrypi/pico-sdk $SDK_PATH && \
|
||||
RUN git clone --depth 1 --branch 1.5.1 https://github.com/raspberrypi/pico-sdk $SDK_PATH && \
|
||||
cd $SDK_PATH && \
|
||||
git submodule update --init
|
||||
|
||||
ENV PICO_SDK_PATH=$SDK_PATH
|
||||
|
||||
# Picotool installation
|
||||
RUN git clone -b master https://github.com/raspberrypi/picotool.git /home/picotool && \
|
||||
RUN git clone --depth 1 --branch 1.1.2 https://github.com/raspberrypi/picotool.git /home/picotool && \
|
||||
cd /home/picotool && \
|
||||
mkdir build && \
|
||||
cd build && \
|
||||
21
LICENSE
Normal file
21
LICENSE
Normal file
@@ -0,0 +1,21 @@
|
||||
MIT License
|
||||
|
||||
Copyright (c) 2022 lukstep
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in all
|
||||
copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
SOFTWARE.
|
||||
128
README.md
128
README.md
@@ -1,18 +1,23 @@
|
||||
[](https://github.com/lukstep/raspberry-pi-pico-docker-sdk/actions/workflows/sdk-ci.yml)
|
||||
|
||||
# Raspberry Pi Pico Docker SDK
|
||||
|
||||
## Run Docker container
|
||||
Lightweight Raspberry Pi Pico C++ SDK container.
|
||||
|
||||
## Pull container from Docker Hub and run
|
||||
|
||||
The latest version of the image is stored on [Docker Hub](https://hub.docker.com/repository/docker/lukstep/raspberry-pi-pico-sdk/general)
|
||||
and can be used for container runs.
|
||||
Commands below show how to run a container, using an image from Docker Hub
|
||||
```
|
||||
docker build ./docker --tag pico-sdk
|
||||
|
||||
docker run -d -it --name pico-sdk --mount type=bind,source=${PWD},target=/home/dev pico-sdk
|
||||
docker run -d -it --name pico-sdk --mount type=bind,source=${PWD},target=/home/dev lukstep/raspberry-pi-pico-sdk:latest
|
||||
|
||||
docker exec -it pico-sdk /bin/sh
|
||||
```
|
||||
|
||||
## Project build
|
||||
The directory from which the `docker run` command was called will be mounted to /home/dev in the container.
|
||||
So after attaching to the SDK container you can build your project following the steps:
|
||||
|
||||
After attaching to SDK container run the following command to build the project:
|
||||
```
|
||||
cd /home/dev
|
||||
|
||||
@@ -21,5 +26,116 @@ mkdir build
|
||||
cd build
|
||||
|
||||
cmake .. && make -j4
|
||||
```
|
||||
|
||||
## Build image and run container:
|
||||
|
||||
To build your own SDK image, You need to clone this repository and run the following commands:
|
||||
|
||||
```
|
||||
cd raspberry-pi-pico-docker-sdk
|
||||
|
||||
docker build . --tag pico-sdk
|
||||
|
||||
docker run -d -it --name pico-sdk --mount type=bind,source=${PWD},target=/home/dev pico-sdk
|
||||
|
||||
docker exec -it pico-sdk /bin/sh
|
||||
```
|
||||
|
||||
## Visual Studio Code as Rassberry Pi PICO projects IDE
|
||||
|
||||
You can use the SDK container with Visual Studio Code as Raspberry Pi Pico projects IDE.
|
||||
|
||||
### Attaching VSCode to SDK Docker container
|
||||
|
||||
Follow the instruction below to set up VSCode:
|
||||
|
||||
1. Install [Visual Studio Code](https://code.visualstudio.com) and next [Remote Development](https://marketplace.visualstudio.com/items?itemName=ms-vscode-remote.vscode-remote-extensionpack) extensions.
|
||||
|
||||

|
||||
|
||||
2. Open the terminal and go to the projects you want to open in VSCode.
|
||||
|
||||
3. Pull SDK image from Docker HUB and run SDK container via the following command. The container must be running while you attach to it via VSCode.
|
||||
|
||||
```
|
||||
docker run -d -it --name pico-sdk --mount type=bind,source=${PWD},target=/home/dev lukstep/raspberry-pi-pico-sdk:latest
|
||||
|
||||
docker exec -it pico-sdk /bin/sh
|
||||
```
|
||||
|
||||
4. When the container is launched, go to VSCode, click the green button in the lower left corner of VSCode and select options: Attach to Running Container...
|
||||
|
||||

|
||||
|
||||
5. Select the SDK container.
|
||||
|
||||

|
||||
|
||||
6. Then a new VSCode window will open. At the bottom window, you can see that it is attached to the SDK container.
|
||||
|
||||

|
||||
|
||||
7. Now, there is needed to open project files. Your project is mounted to `/home/dev` in the container. Go to EXPLORE tab in VSCode and click Open Folder. In opened window write `/home/dev` and click the OK button.
|
||||
|
||||

|
||||
|
||||
8. Now You can explore, develop and build your Raspberry Pi Pico project via Visual Studio Code!
|
||||
|
||||

|
||||
|
||||
### Pico SDK aware Intellisense
|
||||
|
||||
For an IntelliSense that will be aware of Raspberry Pi Pico SDK dependencies, we will use [Clangd](https://clangd.llvm.org). Clangd is a C/C++ language server provided by the LLVM project. To Setup Clang as Intellisense engine follow instruction below:
|
||||
|
||||
1. To begin with, you need to install the server itself (Clangd is not installed by default in the SDK container image), to do this in the terminal call the command:
|
||||
|
||||
```
|
||||
apk add clang-extra-tools
|
||||
```
|
||||
|
||||
2. Next is needed to install the Visual Studio Code [Clangd extension](https://marketplace.visualstudio.com/items?itemName=llvm-vs-code-extensions.vscode-clangd).
|
||||
|
||||

|
||||
|
||||
1. To set-up The Clangd extension, in the project root directory, create folder .vcode with file settings.json. To settings.json past configuration from the snippet below:
|
||||
|
||||
```json
|
||||
{
|
||||
"C_Cpp.intelliSenseEngine": "Disabled",
|
||||
"clangd.path": "/usr/bin/clangd",
|
||||
"clangd.checkUpdates": false,
|
||||
"clangd.restartAfterCrash": true,
|
||||
"clangd.detectExtensionConflicts": true,
|
||||
"clangd.arguments": ["-log=verbose",
|
||||
"-pretty",
|
||||
"--background-index",
|
||||
"--query-driver=/usr/bin/arm-none-eabi-gcc",
|
||||
"--compile-commands-dir=/home/dev/build"]
|
||||
}
|
||||
```
|
||||
|
||||

|
||||
|
||||
|
||||
4. For clangd to work, it needs a `compile_commands.json` file. This file contains the compilation and dependency information of each file in the project. To create it you need to add to the CMake command, `-DCMAKE_EXPORT_COMPILE_COMMANDS=1`. So You need to build your project with the command:
|
||||
|
||||
```
|
||||
mkdir build
|
||||
|
||||
cd build
|
||||
|
||||
cmake -DCMAKE_EXPORT_COMPILE_COMMANDS=1 ..
|
||||
|
||||
make
|
||||
```
|
||||
|
||||
5. Now IntelliSense should work!. Now you should see a prompt when you start typing. If you hover your cursor over a function from the SDK you should see its documentation, You can go to the function definition by pressing F12.
|
||||
|
||||

|
||||
|
||||

|
||||
|
||||

|
||||
|
||||
|
||||
|
||||
20
sdk_session.sh
Normal file
20
sdk_session.sh
Normal file
@@ -0,0 +1,20 @@
|
||||
#!/bin/bash
|
||||
|
||||
docker run --rm -d -it --name pico-sdk --network=host --mount type=bind,source=${PWD},target=/home/dev pico-sdk-debug
|
||||
|
||||
session="Pico-sdk"
|
||||
|
||||
tmux new-session -d -s $session
|
||||
|
||||
window=0
|
||||
tmux rename-window -t $session:$window 'Docker'
|
||||
tmux send-keys -t $session:$window 'docker exec -it pico-sdk ./bin/sh' C-m
|
||||
|
||||
window=1
|
||||
tmux new-window -t $session:$window -n 'OpenOCD'
|
||||
tmux send-keys -t $session:$window 'sudo openocd -f interface/cmsis-dap.cfg -f target/rp2040.cfg -c "bindto 0.0.0.0"' C-m
|
||||
|
||||
window=2
|
||||
tmux new-window -t $session:$window -n 'UART'
|
||||
|
||||
tmux attach-session -t $session
|
||||
8
test_poject/.vscode/extensions.json
vendored
Normal file
8
test_poject/.vscode/extensions.json
vendored
Normal file
@@ -0,0 +1,8 @@
|
||||
{
|
||||
"recommendations": ["llvm-vs-code-extensions.vscode-clangd",
|
||||
"marus25.cortex-debug",
|
||||
"ms-vscode.cmake-tools",
|
||||
"ms-vscode.cpptools",
|
||||
"ms-vscode.cpptools-extension-pack"
|
||||
]
|
||||
}
|
||||
25
test_poject/.vscode/launch.json
vendored
Normal file
25
test_poject/.vscode/launch.json
vendored
Normal file
@@ -0,0 +1,25 @@
|
||||
{
|
||||
// Use IntelliSense to learn about possible attributes.
|
||||
// Hover to view descriptions of existing attributes.
|
||||
// For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
|
||||
"version": "0.2.0",
|
||||
"configurations": [
|
||||
{
|
||||
"name": "Pico debug",
|
||||
"cwd": "${workspaceFolder}",
|
||||
"gdbPath": "/usr/bin/gdb-multiarch",
|
||||
"executable": "/home/dev/build/sample.elf",
|
||||
"request": "launch",
|
||||
"type": "cortex-debug",
|
||||
"runToEntryPoint": "main",
|
||||
"servertype": "external",
|
||||
"gdbTarget": "host.docker.internal:3333",
|
||||
"overrideLaunchCommands": [
|
||||
"monitor adapter speed 5000",
|
||||
"monitor reset init",
|
||||
"load ${command:cmake.launchTargetPath}"
|
||||
],
|
||||
|
||||
}
|
||||
]
|
||||
}
|
||||
13
test_poject/.vscode/settings.json
vendored
Normal file
13
test_poject/.vscode/settings.json
vendored
Normal file
@@ -0,0 +1,13 @@
|
||||
{
|
||||
"C_Cpp.intelliSenseEngine": "disabled",
|
||||
"clangd.path": "/usr/bin/clangd",
|
||||
"clangd.checkUpdates": false,
|
||||
"clangd.restartAfterCrash": true,
|
||||
"clangd.detectExtensionConflicts": true,
|
||||
"clangd.arguments": ["-log=verbose",
|
||||
"-pretty",
|
||||
"--background-index",
|
||||
"--query-driver=/usr/bin/arm-none-eabi-gcc",
|
||||
"--compile-commands-dir=/home/dev/build"],
|
||||
"cmake.sourceDirectory": "/home/dev"
|
||||
}
|
||||
29
test_poject/CMakeLists.txt
Normal file
29
test_poject/CMakeLists.txt
Normal file
@@ -0,0 +1,29 @@
|
||||
cmake_minimum_required(VERSION 3.13)
|
||||
|
||||
include($ENV{PICO_SDK_PATH}/external/pico_sdk_import.cmake)
|
||||
|
||||
project(sample C CXX ASM)
|
||||
|
||||
set(CMAKE_C_COMPILER /usr/bin/arm-none-eabi-gcc CACHE PATH "" FORCE)
|
||||
set(CMAKE_CXX_COMPILER /usr/bin/arm-none-eabi-g++ CACHE PATH "" FORCE)
|
||||
|
||||
set(CMAKE_C_STANDARD 11)
|
||||
set(CMAKE_CXX_STANDARD 17)
|
||||
set(CMAKE_EXPORT_COMPILE_COMMANDS ON)
|
||||
add_compile_options(-Wall -g -O1)
|
||||
|
||||
pico_sdk_init()
|
||||
|
||||
add_executable(sample main.c)
|
||||
|
||||
pico_enable_stdio_usb(sample 0)
|
||||
pico_enable_stdio_uart(sample 1)
|
||||
pico_add_extra_outputs(sample)
|
||||
|
||||
target_link_libraries(sample
|
||||
pico_stdlib
|
||||
hardware_pio
|
||||
hardware_timer
|
||||
hardware_clocks
|
||||
hardware_pwm
|
||||
)
|
||||
@@ -3,12 +3,11 @@
|
||||
#include "hardware/gpio.h"
|
||||
#include "pico/binary_info.h"
|
||||
|
||||
const int LED_PIN = 25;
|
||||
const int LED_PIN = 0;
|
||||
|
||||
int main ()
|
||||
{
|
||||
bi_decl(bi_program_description("Sample binary"));
|
||||
bi_decl(bi_1pin_with_name(LED_PIN, "on-board PIN"));
|
||||
int test = 0;
|
||||
|
||||
stdio_init_all();
|
||||
|
||||
@@ -20,8 +19,9 @@ int main ()
|
||||
gpio_put(LED_PIN, 0);
|
||||
sleep_ms(250);
|
||||
gpio_put(LED_PIN, 1);
|
||||
puts("Hello Word\n");
|
||||
printf("Hello Word %d\n", test);
|
||||
sleep_ms(1000);
|
||||
test++;
|
||||
}
|
||||
}
|
||||
|
||||
9
test_sdk.sh
Normal file
9
test_sdk.sh
Normal file
@@ -0,0 +1,9 @@
|
||||
if [[ -z $1 ]]; then
|
||||
echo "Please provide an SDK image you want to test"
|
||||
fi
|
||||
|
||||
docker run -d -it --name pico-sdk --mount type=bind,source=${PWD}/test_poject,target=/home/dev $1
|
||||
docker exec pico-sdk /bin/sh -c "cd /home/dev && mkdir build && cd build && cmake .. && make -j4"
|
||||
docker exec pico-sdk /bin/sh -c "picotool"
|
||||
docker container kill pico-sdk
|
||||
docker container rm pico-sdk
|
||||
Reference in New Issue
Block a user