diff options
author | Alyssa Ross <hi@alyssa.is> | 2023-08-23 10:09:14 +0000 |
---|---|---|
committer | Alyssa Ross <hi@alyssa.is> | 2023-08-26 09:07:03 +0000 |
commit | 63dabcc77ef9a56655e1ca2ab2e25e6163a72c1f (patch) | |
tree | d58934cb48f9c953b19a0d0d5cffc0d0c5561471 /nixpkgs/pkgs/development/embedded/openocd-rp2040/default.nix | |
parent | c4eef3dacb2a3d359561f30917d9e3cc4e041be9 (diff) | |
parent | 91a22f76cd1716f9d0149e8a5c68424bb691de15 (diff) | |
download | nixlib-63dabcc77ef9a56655e1ca2ab2e25e6163a72c1f.tar nixlib-63dabcc77ef9a56655e1ca2ab2e25e6163a72c1f.tar.gz nixlib-63dabcc77ef9a56655e1ca2ab2e25e6163a72c1f.tar.bz2 nixlib-63dabcc77ef9a56655e1ca2ab2e25e6163a72c1f.tar.lz nixlib-63dabcc77ef9a56655e1ca2ab2e25e6163a72c1f.tar.xz nixlib-63dabcc77ef9a56655e1ca2ab2e25e6163a72c1f.tar.zst nixlib-63dabcc77ef9a56655e1ca2ab2e25e6163a72c1f.zip |
Merge branch 'nixos-unstable' of https://github.com/NixOS/nixpkgs
Conflicts: nixpkgs/pkgs/build-support/go/module.nix nixpkgs/pkgs/development/python-modules/django-mailman3/default.nix
Diffstat (limited to 'nixpkgs/pkgs/development/embedded/openocd-rp2040/default.nix')
-rw-r--r-- | nixpkgs/pkgs/development/embedded/openocd-rp2040/default.nix | 81 |
1 files changed, 81 insertions, 0 deletions
diff --git a/nixpkgs/pkgs/development/embedded/openocd-rp2040/default.nix b/nixpkgs/pkgs/development/embedded/openocd-rp2040/default.nix new file mode 100644 index 000000000000..a7e2bb65953c --- /dev/null +++ b/nixpkgs/pkgs/development/embedded/openocd-rp2040/default.nix @@ -0,0 +1,81 @@ +{ lib +, stdenv +, fetchgit +, fetchurl +, pkg-config +, hidapi +, libftdi1 +, libusb1 +, which +, libtool +, autoconf +, automake +, texinfo +, git +, libgpiod +}: + +stdenv.mkDerivation { + pname = "openocd-rp2040"; + version = "0.12.0"; + src = fetchgit { + url = "https://github.com/raspberrypi/openocd"; + rev = "4d87f6dcae77d3cbcd8ac3f7dc887adf46ffa504"; + sha256 = "sha256-SYC0qqNx09yO/qeKDDN8dF/9d/dofJ5B1h/PofhG8Jw="; + fetchSubmodules = true; + }; + + nativeBuildInputs = [ + pkg-config + ]; + + buildInputs = [ + hidapi + libftdi1 + libusb1 + which + libtool + autoconf + automake + texinfo + git + ] + ++ + # tracking issue for v2 api changes https://sourceforge.net/p/openocd/tickets/306/ + lib.optional stdenv.isLinux (libgpiod.overrideAttrs (old: rec { + version = "1.6.4"; + src = fetchurl { + url = "https://git.kernel.org/pub/scm/libs/libgpiod/libgpiod.git/snapshot/libgpiod-${version}.tar.gz"; + sha256 = "sha256-gp1KwmjfB4U2CdZ8/H9HbpqnNssqaKYwvpno+tGXvgo="; + }; + })); + + configurePhase = '' + SKIP_SUBMODULE=1 ./bootstrap + ./configure --prefix=$out + ''; + + enableParallelBuilding = true; + + postInstall = lib.optionalString stdenv.isLinux '' + mkdir -p "$out/etc/udev/rules.d" + rules="$out/share/openocd/contrib/60-openocd.rules" + if [ ! -f "$rules" ]; then + echo "$rules is missing, must update the Nix file." + exit 1 + fi + ln -s "$rules" "$out/etc/udev/rules.d/" + ''; + + meta = with lib; { + description = "OpenOCD fork for rp2040 microcontroller"; + longDescription = '' + This is a fork of OpenOCD by Raspberry Pi, + which brings support to the rp2040 microcontroller. + ''; + homepage = "https://github.com/raspberrypi/openocd"; + license = licenses.gpl2Plus; + maintainers = with maintainers; [ lu15w1r7h ]; + platforms = platforms.linux; + }; +} |