From a5d01131120f538292cbbf831006ae4db80b0f7a Mon Sep 17 00:00:00 2001 From: andromeda Date: Mon, 6 Apr 2026 16:31:34 +0200 Subject: [PATCH] use rust-overlay --- flake.lock | 29 ++++++-- flake.nix | 24 ++++--- nix/esp-rs.nix | 178 ------------------------------------------------- 3 files changed, 41 insertions(+), 190 deletions(-) delete mode 100644 nix/esp-rs.nix diff --git a/flake.lock b/flake.lock index 536fb1d..3db9376 100644 --- a/flake.lock +++ b/flake.lock @@ -2,11 +2,11 @@ "nodes": { "nixpkgs": { "locked": { - "lastModified": 1775373274, - "narHash": "sha256-rL4F2+/ixLRzbgewGRpxTqfQNmaHi+VbLTkUcedyZRw=", + "lastModified": 1775403759, + "narHash": "sha256-cGyKiTspHEUx3QwAnV3RfyT+VOXhHLs+NEr17HU34Wo=", "owner": "nixos", "repo": "nixpkgs", - "rev": "bd48fcede9287ff448ecc84c4e94a4fca4bd0d72", + "rev": "5e11f7acce6c3469bef9df154d78534fa7ae8b6c", "type": "github" }, "original": { @@ -18,7 +18,28 @@ }, "root": { "inputs": { - "nixpkgs": "nixpkgs" + "nixpkgs": "nixpkgs", + "rust-overlay": "rust-overlay" + } + }, + "rust-overlay": { + "inputs": { + "nixpkgs": [ + "nixpkgs" + ] + }, + "locked": { + "lastModified": 1775445266, + "narHash": "sha256-3fgIj85WHQbOamrpIw9WY3ZL1PoEvjPOjmzMYNsEQJo=", + "owner": "oxalica", + "repo": "rust-overlay", + "rev": "61747bc3cf2da179b9af356ae9e70f3b895b0c24", + "type": "github" + }, + "original": { + "owner": "oxalica", + "repo": "rust-overlay", + "type": "github" } } }, diff --git a/flake.nix b/flake.nix index 1b20e74..08806f4 100644 --- a/flake.nix +++ b/flake.nix @@ -1,23 +1,31 @@ { inputs = { nixpkgs.url = "github:nixos/nixpkgs/nixpkgs-unstable"; + rust-overlay = { + inputs.nixpkgs.follows = "nixpkgs"; + url = "github:oxalica/rust-overlay"; + }; }; - outputs = {nixpkgs, ...}: let - pkgs = nixpkgs.legacyPackages.x86_64-linux; - esp-rs = pkgs.callPackage ./nix/esp-rs.nix {}; + outputs = { + nixpkgs, + rust-overlay, + ... + }: let + pkgs = import nixpkgs { + system = "x86_64-linux"; + overlays = [(import rust-overlay)]; + }; + rust-bin = pkgs.rust-bin.fromRustupToolchainFile ./rust-toolchain.toml; in { devShells.x86_64-linux.default = pkgs.mkShell { buildInputs = [ - pkgs.pkg-config - pkgs.libudev-zero - pkgs.libusb1 pkgs.espflash pkgs.esp-generate pkgs.rust-analyzer - esp-rs + rust-bin ]; shellHook = '' - export RUSTUP_TOOLCHAIN=${esp-rs} + export RUSTUP_TOOLCHAIN=${rust-bin} ''; }; }; diff --git a/nix/esp-rs.nix b/nix/esp-rs.nix deleted file mode 100644 index 619c6c4..0000000 --- a/nix/esp-rs.nix +++ /dev/null @@ -1,178 +0,0 @@ -# MIT licensed -# code taken from https://git.sr.ht/~olk/esp-rs-nix/blob/main/esp-rs.nix -{ - pkgs ? import {}, - lib ? pkgs.lib, -}: let - versions = { - esp-rust = { - version = "1.93.0.0"; - hash = "sha256-837shgsDonrmUqZsIhUoR+93IR8tUat67PiHfShilJc="; - }; - rust-src = { - version = "1.93.0.0"; - hash = "sha256-upKiKRDvubE8obME4OVewTr6PjS/p0QOqjpQfEWBfE0="; - }; - gcc = { - version = "14.2.0_20241119"; - xtensa-hash = "sha256-pX2KCnUoGZtgqFmZEuNRJxDMQgqYYPRpswL3f3T0nWE="; - riscv32-hash = "sha256-67O34FYUnVG2nfkfQj2yH874qDSYx4F/16xxPi0kNbY="; - }; - defaultArch = "x86_64-unknown-linux-gnu"; - gccArch = "x86_64-linux-gnu"; - }; - - mkGccToolchain = { - name, - arch, - hash, - }: - pkgs.stdenv.mkDerivation { - pname = "esp-${name}-gcc"; - version = versions.gcc.version; - - src = pkgs.fetchzip { - url = "https://github.com/espressif/crosstool-NG/releases/download/esp-${versions.gcc.version}/${arch}-esp-elf-${versions.gcc.version}-${versions.gccArch}.tar.xz"; - inherit hash; - }; - - installPhase = '' - runHook preInstall - mkdir -p $out - cp -r ./* $out/ - runHook postInstall - ''; - - meta = with lib; { - description = "ESP32 ${name} GCC toolchain"; - homepage = "https://github.com/espressif/crosstool-NG"; - license = licenses.gpl2Plus; - platforms = ["x86_64-linux"]; - }; - }; - - esp-rust-build = pkgs.stdenv.mkDerivation { - pname = "esp-rust-build"; - version = versions.esp-rust.version; - - src = pkgs.fetchzip { - url = "https://github.com/esp-rs/rust-build/releases/download/v${versions.esp-rust.version}/rust-${versions.esp-rust.version}-${versions.defaultArch}.tar.xz"; - hash = versions.esp-rust.hash; - }; - - nativeBuildInputs = with pkgs; [autoPatchelfHook]; - buildInputs = with pkgs; [ - stdenv.cc.cc - zlib - ]; - - patchPhase = '' - patchShebangs ./install.sh - ''; - - installPhase = '' - runHook preInstall - mkdir -p $out - ./install.sh --destdir=$out --prefix="" --disable-ldconfig --without=rust-docs-json-preview,rust-docs - runHook postInstall - ''; - - meta = with lib; { - description = "ESP32 Rust toolchain"; - homepage = "https://github.com/esp-rs/rust-build"; - license = with licenses; [ - mit - asl20 - ]; - platforms = ["x86_64-linux"]; - }; - }; - - esp-xtensa-gcc = mkGccToolchain { - name = "xtensa"; - arch = "xtensa"; - hash = versions.gcc.xtensa-hash; - }; - - esp-riscv32-gcc = mkGccToolchain { - name = "riscv32"; - arch = "riscv32"; - hash = versions.gcc.riscv32-hash; - }; - - rust-src = pkgs.fetchzip { - url = "https://github.com/esp-rs/rust-build/releases/download/v${versions.rust-src.version}/rust-src-${versions.rust-src.version}.tar.xz"; - hash = versions.rust-src.hash; - }; - - esp-rs-base = pkgs.symlinkJoin { - name = "esp-rs-base-${versions.esp-rust.version}"; - paths = [ - esp-rust-build - esp-xtensa-gcc - esp-riscv32-gcc - ]; - meta = { - description = "Base ESP32 toolchain components"; - platforms = ["x86_64-linux"]; - }; - }; -in - pkgs.stdenv.mkDerivation { - pname = "esp-rs"; - version = versions.esp-rust.version; - - src = rust-src; - - nativeBuildInputs = with pkgs; [ - autoPatchelfHook - pkg-config - ]; - - buildInputs = with pkgs; [ - stdenv.cc.cc - zlib - ]; - - autoPatchelfIgnoreMissingDeps = ["*"]; - - patchPhase = '' - patchShebangs ./install.sh - ''; - - installPhase = '' - runHook preInstall - - # Start with the base toolchain - mkdir -p $out - cp -rL ${esp-rs-base}/* $out/ - chmod -R u+w $out - - # Install rust-src on top - ./install.sh --destdir=$out --prefix="" --disable-ldconfig - - runHook postInstall - ''; - - passthru = { - inherit esp-rust-build esp-xtensa-gcc esp-riscv32-gcc; - version = versions.esp-rust.version; - }; - - meta = with lib; { - description = "Complete ESP32 Rust development toolchain"; - longDescription = '' - A complete toolchain for developing Rust applications on ESP32 microcontrollers. - Includes Rust compiler with ESP32 targets, Xtensa and RISC-V GCC toolchains, - and all necessary components for no_std ESP-HAL development. - ''; - homepage = "https://github.com/esp-rs"; - license = with licenses; [ - mit - asl20 - gpl2Plus - ]; - platforms = ["x86_64-linux"]; - maintainers = []; - }; - }