Merge pull request #317153 from NixOS/revert-317030-fix/syslinux-gnu-efi-awkwardness

Revert "syslinux: Use Nixpkgs' gnu-efi"
This commit is contained in:
K900 2024-06-04 12:18:57 +03:00 committed by GitHub
commit 356406aff9
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -1,9 +1,7 @@
{ lib { lib
, stdenv , stdenv
, fetchFromRepoOrCz , fetchgit
, gnu-efi
, fetchurl , fetchurl
, fetchpatch
, libuuid , libuuid
, makeWrapper , makeWrapper
, mtools , mtools
@ -18,10 +16,11 @@ stdenv.mkDerivation {
# This is syslinux-6.04-pre3^1; syslinux-6.04-pre3 fails to run. # This is syslinux-6.04-pre3^1; syslinux-6.04-pre3 fails to run.
# Same issue here https://www.syslinux.org/archives/2019-February/026330.html # Same issue here https://www.syslinux.org/archives/2019-February/026330.html
src = fetchFromRepoOrCz { src = fetchgit {
repo = "syslinux"; url = "https://repo.or.cz/syslinux";
rev = "759fe3d75276aac5c7f9dd7dcbfb56323a85fff1"; rev = "b40487005223a78c3bb4c300ef6c436b3f6ec1f7";
hash = "sha256-NNA8Q7+rQ/TdcB6rgtjWjtoXxLJtI4HjV+2UVKqTSR0="; sha256 = "sha256-GqvRTr9mA2yRD0G0CF11x1X0jCgqV4Mh+tvE0/0yjqk=";
fetchSubmodules = true;
}; };
patches = let patches = let
@ -66,21 +65,19 @@ stdenv.mkDerivation {
"0018-prevent-pow-optimization.patch" "0018-prevent-pow-optimization.patch"
"26f0e7b2" "26f0e7b2"
"sha256-dVzXBi/oSV9vYgU85mRFHBKuZdup+1x1BipJX74ED7E=") "sha256-dVzXBi/oSV9vYgU85mRFHBKuZdup+1x1BipJX74ED7E=")
(fetchpatch {
# Fixes build with "modern" gnu-efi
# https://github.com/samueldr/syslinux/commit/68defee52f4eba82eefaeea17f21c7498448dd6b
url = "https://github.com/samueldr/syslinux/commit/68defee52f4eba82eefaeea17f21c7498448dd6b.patch";
hash = "sha256-5xIqM8Gq8D86HL1i7fBTHRB/ZR2XtCz5VsT4bI5vneo=";
})
]; ];
postPatch = '' postPatch = ''
substituteInPlace Makefile --replace-fail /bin/pwd $(type -P pwd) substituteInPlace Makefile --replace /bin/pwd $(type -P pwd)
substituteInPlace utils/ppmtolss16 --replace-fail /usr/bin/perl $(type -P perl) substituteInPlace utils/ppmtolss16 --replace /usr/bin/perl $(type -P perl)
# fix tests # fix tests
substituteInPlace tests/unittest/include/unittest/unittest.h \ substituteInPlace tests/unittest/include/unittest/unittest.h \
--replace-fail /usr/include/ "" --replace /usr/include/ ""
# Hack to get `gcc -m32' to work without having 32-bit Glibc headers.
mkdir gnu-efi/inc/ia32/gnu
touch gnu-efi/inc/ia32/gnu/stubs-32.h
''; '';
nativeBuildInputs = [ nativeBuildInputs = [
@ -92,7 +89,6 @@ stdenv.mkDerivation {
buildInputs = [ buildInputs = [
libuuid libuuid
gnu-efi
]; ];
# Fails very rarely with 'No rule to make target: ...' # Fails very rarely with 'No rule to make target: ...'
@ -115,22 +111,8 @@ stdenv.mkDerivation {
"MANDIR=$(out)/share/man" "MANDIR=$(out)/share/man"
"PERL=perl" "PERL=perl"
"HEXDATE=0x00000000" "HEXDATE=0x00000000"
# Works around confusing (unrelated) error messages when upx is not made available
"UPX=false"
# Configurations needed to make use of external gnu-efi
"LIBEFI=${gnu-efi}/lib/libefi.a"
"LIBDIR=${gnu-efi}/lib/"
"EFIINC=${gnu-efi}/include/efi"
# Legacy bios boot target is always built
"bios"
] ]
# Build "ia32" EFI for i686 ++ lib.optionals stdenv.hostPlatform.isi686 [ "bios" "efi32" ];
++ lib.optional stdenv.hostPlatform.isi686 "efi32"
# Build "x86_64" EFI for x86_64
++ lib.optional stdenv.hostPlatform.isx86_64 "efi64"
;
# Some tests require qemu, some others fail in a sandboxed environment # Some tests require qemu, some others fail in a sandboxed environment
doCheck = false; doCheck = false;
@ -144,7 +126,7 @@ stdenv.mkDerivation {
''; '';
meta = with lib; { meta = with lib; {
homepage = "https://www.syslinux.org/"; homepage = "http://www.syslinux.org/";
description = "A lightweight bootloader"; description = "A lightweight bootloader";
license = licenses.gpl2Plus; license = licenses.gpl2Plus;
maintainers = [ maintainers.samueldr ]; maintainers = [ maintainers.samueldr ];