nixpkgs-suyu/pkgs/tools/misc/ipxe/default.nix

100 lines
2.9 KiB
Nix
Raw Normal View History

2021-05-25 20:10:54 +02:00
{ stdenv, lib, fetchFromGitHub, perl, cdrkit, xz, openssl, gnu-efi, mtools
, syslinux ? null
, embedScript ? null
, additionalTargets ? {}
}:
2014-12-02 07:06:10 +01:00
let
targets = additionalTargets // lib.optionalAttrs stdenv.isx86_64 {
"bin-x86_64-efi/ipxe.efi" = null;
"bin-x86_64-efi/ipxe.efirom" = null;
"bin-x86_64-efi/ipxe.usb" = "ipxe-efi.usb";
2021-05-25 20:10:54 +02:00
} // lib.optionalAttrs (stdenv.isi686 || stdenv.isx86_64) {
"bin/ipxe.dsk" = null;
"bin/ipxe.usb" = null;
"bin/ipxe.iso" = null;
"bin/ipxe.lkrn" = null;
"bin/undionly.kpxe" = null;
2021-05-25 20:10:54 +02:00
} // lib.optionalAttrs stdenv.isAarch32 {
"bin-arm32-efi/ipxe.efi" = null;
"bin-arm32-efi/ipxe.efirom" = null;
"bin-arm32-efi/ipxe.usb" = "ipxe-efi.usb";
} // lib.optionalAttrs stdenv.isAarch64 {
"bin-arm64-efi/ipxe.efi" = null;
"bin-arm64-efi/ipxe.efirom" = null;
"bin-arm64-efi/ipxe.usb" = "ipxe-efi.usb";
};
2014-12-02 07:06:10 +01:00
in
2020-01-22 10:20:35 +01:00
stdenv.mkDerivation rec {
pname = "ipxe";
2021-01-04 11:29:14 +01:00
version = "1.21.1";
2014-12-02 07:06:10 +01:00
2021-05-25 20:10:54 +02:00
nativeBuildInputs = [ perl cdrkit xz openssl gnu-efi mtools ] ++ lib.optional (stdenv.isi686 || stdenv.isx86_64) syslinux;
2014-12-02 07:06:10 +01:00
2020-01-22 10:20:35 +01:00
src = fetchFromGitHub {
owner = "ipxe";
repo = "ipxe";
rev = "v${version}";
2021-01-04 11:29:14 +01:00
sha256 = "1pkf1n1c0rdlzfls8fvjvi1sd9xjd9ijqlyz3wigr70ijcv6x8i9";
2014-12-02 07:06:10 +01:00
};
# not possible due to assembler code
hardeningDisable = [ "pic" "stackprotector" ];
NIX_CFLAGS_COMPILE = "-Wno-error";
2014-12-02 07:06:10 +01:00
makeFlags =
[ "ECHO_E_BIN_ECHO=echo" "ECHO_E_BIN_ECHO_E=echo" # No /bin/echo here.
2021-05-25 20:10:54 +02:00
] ++ lib.optionals (stdenv.isi686 || stdenv.isx86_64) [
2014-12-02 07:06:10 +01:00
"ISOLINUX_BIN_LIST=${syslinux}/share/syslinux/isolinux.bin"
"LDLINUX_C32=${syslinux}/share/syslinux/ldlinux.c32"
] ++ lib.optional (embedScript != null) "EMBED=${embedScript}";
2014-12-02 07:06:10 +01:00
enabledOptions = [
"PING_CMD"
"IMAGE_TRUST_CMD"
"DOWNLOAD_PROTO_HTTP"
"DOWNLOAD_PROTO_HTTPS"
];
configurePhase = ''
runHook preConfigure
for opt in $enabledOptions; do echo "#define $opt" >> src/config/general.h; done
sed -i '/cp \''${ISOLINUX_BIN}/s/$/ --no-preserve=mode/' src/util/geniso
2019-03-07 16:11:54 +01:00
substituteInPlace src/Makefile.housekeeping --replace '/bin/echo' echo
runHook postConfigure
'';
preBuild = "cd src";
buildFlags = lib.attrNames targets;
2019-03-07 16:11:54 +01:00
installPhase = ''
2021-07-14 11:46:41 +02:00
runHook preInstall
mkdir -p $out
${lib.concatStringsSep "\n" (lib.mapAttrsToList (from: to:
if to == null
then "cp -v ${from} $out"
else "cp -v ${from} $out/${to}") targets)}
2017-09-24 15:08:23 +02:00
# Some PXE constellations especially with dnsmasq are looking for the file with .0 ending
# let's provide it as a symlink to be compatible in this case.
ln -s undionly.kpxe $out/undionly.kpxe.0
2021-07-14 11:46:41 +02:00
runHook postInstall
'';
2014-12-02 07:06:10 +01:00
enableParallelBuilding = true;
2021-01-15 10:19:50 +01:00
meta = with lib;
2014-12-02 07:06:10 +01:00
{ description = "Network boot firmware";
homepage = "https://ipxe.org/";
2021-07-14 11:46:41 +02:00
license = licenses.gpl2Only;
maintainers = with maintainers; [ ehmry ];
2021-05-25 20:10:54 +02:00
platforms = platforms.linux;
2014-12-02 07:06:10 +01:00
};
}