Build before installing
Zephyr Dev Environment using Codespaces
Mike Szczys
golioth.io
What if you could build Zephyr apps without any setup?
data:image/s3,"s3://crabby-images/ac2e0/ac2e0881648ac43b53725008e5de0204e5a27247" alt=""
Mike Szczys
https://chaos.social/@szczys
- Firmware Engineer at Golioth
- 15 years of firmware experience
- Previously: Editor in Chief of Hackaday
Golioth is an IoT Cloud Company
-
We make it easy to connect MCUs to the internet
-
Device Management
- OTA, fleet settings, RPC, remote logging
-
Data Routing
- Time-series and stateful data
- Cloud integrations with numerous cloud platforms and database hosts
- REST API, Webhook, Websockets
Challenge:
-
Our device SDK functions as a Zephyr module
-
For a potential user to validate Golioth, they need to be able to build Zephyr applications
What if you could build Zephyr apps without any setup?
How we can use Codespaces
-
Free monthly Zephyr training
-
Enable prospective customers to build code samples without waiting
Built on Development Containers
-
Open standard easily added to repo
-
Can be run locally (and easily) via VS Code
Codespaces Demo:
Building a Zephyr app within 90 seconds during free Golioth Zephyr trainning
(Try it yourself: https://github.com/golioth/zephyr-training)
Demo: Big Green 'Code'Button
GitHub repos that have devcontainers have a Codespaces tab
data:image/s3,"s3://crabby-images/1c0fd/1c0fdb8bc686c0261df1159f1367214ef33e4a5c" alt=""
Demo: VS Code in a Browser
You get the VS Code with a complete build environment
data:image/s3,"s3://crabby-images/9cf6d/9cf6d863fbb0a154e2f3854fd471374570093a83" alt=""
Demo: Cloud != USB
Binaries must be downloaded and flashed locally
data:image/s3,"s3://crabby-images/c049a/c049a12bdfd2ba8851d8e423858457198201ffe1" alt=""
Dev Containers
Docker + JSON Config
Adding a Dev Container
data:image/s3,"s3://crabby-images/7e561/7e561465365e139dc41a00fa62abd0d47afcd96e" alt=""
- Required: .devcontainer subdirectory
- Required: devcontainer.json
- Optional: helper files (we'll get to that)
devcontainer.json
The entirety of what was shown in the demo
data:image/s3,"s3://crabby-images/16888/168886cdc29cc3821c173736628fb5a6bbcf26f9" alt=""
Choose Docker image and mounts
- Debian-based image with bare minimum of Zephyr toolchain
- Optional:
- Set a mount point for the parent repository
- Set default path for the workspace
data:image/s3,"s3://crabby-images/d0270/d02700a68341a6e9ace4a1207a73644fac3c974f" alt=""
Call Script to Complete Build
Perform the repo-setup steps
data:image/s3,"s3://crabby-images/1fdd2/1fdd20c706370eaf36a0e3e2aea17dd4e07caad3" alt=""
data:image/s3,"s3://crabby-images/4c486/4c486ce18a3b7d56ac25f362e822625e4159ee45" alt=""
This is a manifest repository, so west update pulls in all dependencies (like the Zephyr tree).
Customize VS Code Itself
Install extensions and configure settings
data:image/s3,"s3://crabby-images/61c94/61c94b3452f44a3ca8b7bf7de20ee4b4ec534a9d" alt=""
Solving for binary download
Custom west command used to rename binaries
data:image/s3,"s3://crabby-images/2355f/2355f2d622bb6f1c49baff77afdc0b260ea9aa80" alt=""
data:image/s3,"s3://crabby-images/f6bf0/f6bf0a6eec3f1f6539011f750a491c5ed5fbae7c" alt=""
- "West Extension" included in this repo
- west download finds correct binary, renames and timestamps, moves to a Download folder for easy location
- Local flashing tools used to program device after binary download
Pre-builds
Speed up the creation process
data:image/s3,"s3://crabby-images/0b214/0b21491e96b0af6ef7184b3280456c795e512d84" alt=""
A prebuild means the configuration step is already done.
You won't have to wait for west update to clone all repos each time you start a new instance.
Running Dev Containers Locally
VS Code Knows!
data:image/s3,"s3://crabby-images/d7abc/d7abc7208671c75857625eadc79742dfd23b7077" alt=""
VS Code recognizes the devcontainer and prompts:
- To install the dev container extension
- To build the container
- To reopen container on subsequent loads
Devcontainers in VS Code
What to know
-
You must have Docker preinstalled
-
Wait for download and build the first time
-
Containers continue to run after you exit VS Code
Hacking: Can I use west flash?
-
Windows: No
-
Mac: No
-
Linux: Yes*
*if you don't mind running in priviledged mode
USB: devcontainer.json
data:image/s3,"s3://crabby-images/cd065/cd065061332778725fd98dd3d30f53839e3be977" alt=""
- Connect USB to the container
- Give the container privileges to access the ports
USB: add flashing tools
- Better option: add these tools to the container image
Adding SEGGER/Nordic tools to container
data:image/s3,"s3://crabby-images/8e62e/8e62e54717d7eb92816ed93c9c375ce4db4f2483" alt=""
USB: not ready for Codespaces
What about WebUSB?
- WebUSB is a promising option, but...
- Not currently supported in Codespaces
- Only supported by Chrome Browser
Dev Containers
What are they good for?
-
Online Zephyr training using CodeSpaces
-
Allow protential customers to build sample code
-
Deliver version controlled build environments to target specific sdk-ng toolchains
Thank you!
Try Golioth: golioth.io
References:
- Try Codespaces: https://github.com/golioth/zephyr-training/
- Free Zephyr training: https://golioth.io/training-signup
- Development Containers: https://containers.dev/
- Codespaces: https://github.com/features/codespaces
Mike Szczys
mike@golioth.io
chaos.social/@szczys
Build before installing
By Golioth
Build before installing
- 94