Build system and configuration files for generating and building ZMK firmware
I've included my personal configuration for my Sofle RGB in this repository, but the Nix flake provides generalized builders that can be used from downstream flakes.
Use the default flake template to create a fully working downstream repository that uses the zmk-nix flake to build your own ZMK config.
$ mkdir zmk-config && cd zmk-config
$ git init
$ nix flake init --template github:lilyinstarlight/zmk-nix
$ nix flake lock
$ git add .
Follow the welcome text below that is printed when initializing from the template for using this new repository:
- Change
buildSplitKeyboard
tobuildKeyboard
inflake.nix
if not using a split keyboard- Edit for the desired ZMK board and shield(s) in
flake.nix
- Create and edit
config/<shield>.conf
andconfig/<shield>.keymap
to your liking- Run
nix run .#flash
to flash firmware
- Run
nix run .#update
to update West dependencies, including ZMK version, and bump thezephyrDepsHash
on the derivation- GitHub Actions to automatically PR flake lockfile bumps and West dependency bumps are included
- Using something like Mergify to automatically merge these PRs is recommended - see https://github.com/lilyinstarlight/zmk-nix/blob/main/.github/mergify.yml for an example Mergify configuration
The fetchZephyrDeps
function takes the following arguments and fetches the dependencies required for the provided west
workspace:
src
- source tree to build in, which includes your west manifesthash
- fixed-output hash for the west dependencieswestRoot
- directory within the source tree that contains your west manifest, defaults to"."
The buildZephyrPackage
function takes the following arguments and builds the Zephyr RTOS into .uf2
firmware files using the west
tooling and a provided west.yml
manifest:
src
- source tree to build in, which includes your west manifestzephyrDepsHash
- output hash for thefetchZephyrDeps
fetcherwestRoot
- directory within the source tree that contains your west manifest, defaults to"."
westBuildFlags
- flags to pass to thewest build
command, defaults to[]
(a-DBUILD_VERSION=
CMake flag also gets automatically added by default for Zephyr-based builds)
The buildKeyboard
function takes the following arguments and performs a ZMK build that outputs a zmk.uf2
file based on the provided parameters:
board
- ZMK board valueshield
- ZMK shield valuesrc
- source tree to build in, which includes your west manifest and configuration fileszephyrDepsHash
- output hash for thefetchZephyrDeps
fetcherconfig
- directory within the source tree that contains your west manifest, defaults to"config"
extraCmakeFlags
- list of extra CMake flags to pass to the ZMK build, defaults to[]
The buildSplitKeyboard
function takes the following arguments and outputs a directory with multiple .uf2
files, one for each keyboard part:
board
- ZMK board valueshield
- ZMK shield value, the special string%PART%
will be replaced in eachbuildKeyboard
invocation to match the part being built forparts
- enumeration of parts to the keyboard that matches the shield naming, default is[ "left" "right" ]
src
- source tree to build in, which includes your west manifest and configuration fileszephyrDepsHash
- output hash for thefetchZephyrDeps
fetcherconfig
- directory within the source tree that contains your west manifest, defaults to"config"
extraCmakeFlags
- list of extra CMake flags to pass to the ZMK build, defaults to[]
My Sofle RGB's firmware, built with the configuration I have in this repository.
A flashing script that automatically handles prompting and copying .uf2
firmware files to the controllers.
A updater script that automatically bumps West dependencies and bumps the zephyrDepsHash
value for the .#firmware
derivation in the current directory.