ESP8266 and ESP32(-C3) packages and development environments for Nix.
This repo contains derivations for:
- Toolchains (compiler, linker, GDB, etc.) for
xtensa-lx106-elf
(ESP8266) andxtensa-esp32-elf
(ESP32) using the official binaries from Espressif. - ESP-IDF
- OpenOCD for ESP32
Released into the public domain via CC0 (see COPYING
).
The easiest way to get started is to run one of these commands to get a development shell, without even needing to download the repository (requires Nix 2.4 or later):
nix --experimental-features 'nix-command flakes' develop github:mirrexagon/nixpkgs-esp-dev#esp32-idf
: for ESP32 development with esp-idf.- Includes the ESP32 toolchain, esptool, the OpenOCD fork supporting ESP32, and downloads and sets up ESP-IDF with everything ready to use
idf.py
.
- Includes the ESP32 toolchain, esptool, the OpenOCD fork supporting ESP32, and downloads and sets up ESP-IDF with everything ready to use
nix --experimental-features 'nix-command flakes' develop github:mirrexagon/nixpkgs-esp-dev#esp8266
: for ESP8266 development with eg. esp-open-rtos- Includes the ESP8266 toolchain and esptool.
If you're not using Nix 2.4+ or prefer not to need to enable flakes, you can clone the repo and use one of:
nix-shell shells/esp32c3-idf.nix
nix-shell shells/esp32s2-idf.nix
nix-shell shells/esp32-idf.nix
nix-shell shells/esp8266.nix
to get the same shells as with nix develop
.
Note: nix develop
will use the nixpkgs revision specified in flake.nix
/flake.lock
, while using nix-shell
will use your system nixpkgs by default.
You can create a standalone shell.nix
for your project that downloads nixpkgs-esp-dev
automatically and creates a shell with the necessary packages and environment setup to use ESP-IDF.
See examples/shell-standalone.nix
for an example.
There are default versions of ESP-IDF and the ESP32 toolchain versions specified in pkgs/esp32-toolchain-bin.nix
and pkgs/esp-idf/default.nix
. To use a different version of ESP-IDF or to pin the versions, override the derivations with the desired versions and the hashes for them. Note that given versions of ESP-IDF require specific versions of the toolchain, which is why the versions of both are customizable.
See examples/shell-override-versions.nix
for an example.
This repo contains an overlay in overlay.nix
containing all the packages defined by this repo. If you clone the repo into ~/.config/nixpkgs/overlays/
, nixpkgs will automatically pick up the overlay and effectively add the packages to your system nixpkgs.