summary refs log tree commit diff
path: root/pkgs
diff options
context:
space:
mode:
authorLinus Heckemann <git@sphalerite.org>2020-02-03 08:11:31 +0100
committerGitHub <noreply@github.com>2020-02-03 08:11:31 +0100
commit2df6898bb527d72968b1d495a2d931dd7dd49e49 (patch)
treea87f78c625548d9b4341c29ebf93e17f794fa926 /pkgs
parent2be2f861474d2976bc18d00cebf671d5ce750f49 (diff)
parentf1221507f37279e8e3e70582603107e3dd6d5b70 (diff)
downloadnixpkgs-2df6898bb527d72968b1d495a2d931dd7dd49e49.tar
nixpkgs-2df6898bb527d72968b1d495a2d931dd7dd49e49.tar.gz
nixpkgs-2df6898bb527d72968b1d495a2d931dd7dd49e49.tar.bz2
nixpkgs-2df6898bb527d72968b1d495a2d931dd7dd49e49.tar.lz
nixpkgs-2df6898bb527d72968b1d495a2d931dd7dd49e49.tar.xz
nixpkgs-2df6898bb527d72968b1d495a2d931dd7dd49e49.tar.zst
nixpkgs-2df6898bb527d72968b1d495a2d931dd7dd49e49.zip
Merge pull request #79020 from helsinki-systems/wimboot-init
wimboot: Init at 2.6.0
Diffstat (limited to 'pkgs')
-rw-r--r--pkgs/tools/misc/wimboot/default.nix47
-rw-r--r--pkgs/top-level/all-packages.nix2
2 files changed, 49 insertions, 0 deletions
diff --git a/pkgs/tools/misc/wimboot/default.nix b/pkgs/tools/misc/wimboot/default.nix
new file mode 100644
index 00000000000..a63fa410634
--- /dev/null
+++ b/pkgs/tools/misc/wimboot/default.nix
@@ -0,0 +1,47 @@
+{ stdenv, fetchFromGitHub, fetchpatch, libbfd, zlib, libiberty }:
+
+stdenv.mkDerivation rec {
+  pname = "wimboot";
+  version = "2.6.0";
+
+  src = fetchFromGitHub {
+    owner = "ipxe";
+    repo = "wimboot";
+    rev = "v${version}";
+    sha256 = "134wqqr147az5vbj4szd0xffwa99b4rar7w33zm3119zsn7sd79k";
+  };
+
+  NIX_CFLAGS_COMPILE = "-Wno-address-of-packed-member"; # Fails on gcc9
+
+  patches = [
+    # Fix for newer binutils
+    (fetchpatch {
+      url =
+        "https://github.com/ipxe/wimboot/commit/91be50c17d4d9f463109d5baafd70f9fdadd86db.patch";
+      sha256 = "113448n49hmk8nz1dxbhxiciwl281zwalvb8z5p9xfnjvibj8274";
+    })
+  ];
+
+  # We cannot use sourceRoot because the patch wouldn't apply
+  postPatch = ''
+    cd src
+  '';
+
+  hardeningDisable = [ "pic" ];
+
+  buildInputs = [ libbfd zlib libiberty ];
+  makeFlags = [ "wimboot.x86_64.efi" ];
+
+  installPhase = ''
+    mkdir -p $out/share/wimboot/
+    cp wimboot.x86_64.efi $out/share/wimboot
+  '';
+
+  meta = with stdenv.lib; {
+    homepage = "https://ipxe.org/wimboot";
+    description = "Windows Imaging Format bootloader";
+    license = licenses.gpl2;
+    maintainers = with maintainers; [ das_j ajs124 ];
+    platforms = platforms.x86; # Fails on aarch64
+  };
+}
diff --git a/pkgs/top-level/all-packages.nix b/pkgs/top-level/all-packages.nix
index 59146fb7261..7b71a755bb2 100644
--- a/pkgs/top-level/all-packages.nix
+++ b/pkgs/top-level/all-packages.nix
@@ -7183,6 +7183,8 @@ in
 
   wifite2 = callPackage ../tools/networking/wifite2 { };
 
+  wimboot = callPackage ../tools/misc/wimboot { };
+
   wireguard-tools = callPackage ../tools/networking/wireguard-tools { };
 
   woff2 = callPackage ../development/web/woff2 { };