elfutils: 0.182 -> 0.185, cleanup
Remove obsolete musl patches & musl-specific autoreconfHook (same as https://git.alpinelinux.org/aports/commit/main/elfutils?id=a8779348058ef0f42d31c814d2792ccdc8062007) Also add zstd support, enable tests, and allow "format" hardening. Co-authored-by: Sergei Trofimovich <slyich@gmail.com>
This commit is contained in:
parent
06f968ff54
commit
4794a8aeee
1 changed files with 22 additions and 34 deletions
|
@ -1,5 +1,5 @@
|
||||||
{ lib, stdenv, fetchurl, fetchpatch, pkg-config, autoreconfHook, musl-fts
|
{ lib, stdenv, fetchurl, fetchpatch, pkg-config, musl-fts
|
||||||
, musl-obstack, m4, zlib, bzip2, bison, flex, gettext, xz, setupDebugInfoDirs
|
, musl-obstack, m4, zlib, zstd, bzip2, bison, flex, gettext, xz, setupDebugInfoDirs
|
||||||
, argp-standalone
|
, argp-standalone
|
||||||
, enableDebuginfod ? false, sqlite, curl, libmicrohttpd_0_9_70, libarchive
|
, enableDebuginfod ? false, sqlite, curl, libmicrohttpd_0_9_70, libarchive
|
||||||
}:
|
}:
|
||||||
|
@ -7,11 +7,11 @@
|
||||||
# TODO: Look at the hardcoded paths to kernel, modules etc.
|
# TODO: Look at the hardcoded paths to kernel, modules etc.
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation rec {
|
||||||
pname = "elfutils";
|
pname = "elfutils";
|
||||||
version = "0.182";
|
version = "0.185";
|
||||||
|
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
url = "https://sourceware.org/elfutils/ftp/${version}/${pname}-${version}.tar.bz2";
|
url = "https://sourceware.org/elfutils/ftp/${version}/${pname}-${version}.tar.bz2";
|
||||||
sha256 = "7MQGkU7fM18Lf8CE6+bEYMTW1Rdb/dZojBx42RRriFg=";
|
sha256 = "sha256-3I0+dKsglGXn9Wjhs7uaWhQvhlbitX0QBJpz2irmtaY=";
|
||||||
};
|
};
|
||||||
|
|
||||||
patches = [
|
patches = [
|
||||||
|
@ -27,43 +27,29 @@ stdenv.mkDerivation rec {
|
||||||
url = "https://git.alpinelinux.org/aports/plain/main/elfutils/musl-asm-ptrace-h.patch?id=2e3d4976eeffb4704cf83e2cc3306293b7c7b2e9";
|
url = "https://git.alpinelinux.org/aports/plain/main/elfutils/musl-asm-ptrace-h.patch?id=2e3d4976eeffb4704cf83e2cc3306293b7c7b2e9";
|
||||||
sha256 = "8D1wPcdgAkE/TNBOgsHaeTZYhd9l+9TrZg8d5C7kG6k=";
|
sha256 = "8D1wPcdgAkE/TNBOgsHaeTZYhd9l+9TrZg8d5C7kG6k=";
|
||||||
})
|
})
|
||||||
(fetchpatch {
|
|
||||||
name = "musl-fts-obstack.patch";
|
|
||||||
url = "https://git.alpinelinux.org/aports/plain/main/elfutils/musl-fts-obstack.patch?id=2e3d4976eeffb4704cf83e2cc3306293b7c7b2e9";
|
|
||||||
sha256 = "3lbC0UtscTIJgT7kOXnnjWrpPAVt2PYMbW+uJK6K350=";
|
|
||||||
})
|
|
||||||
(fetchpatch {
|
(fetchpatch {
|
||||||
name = "musl-macros.patch";
|
name = "musl-macros.patch";
|
||||||
url = "https://git.alpinelinux.org/aports/plain/main/elfutils/musl-macros.patch?id=2e3d4976eeffb4704cf83e2cc3306293b7c7b2e9";
|
url = "https://git.alpinelinux.org/aports/plain/main/elfutils/musl-macros.patch?id=2e3d4976eeffb4704cf83e2cc3306293b7c7b2e9";
|
||||||
sha256 = "tp6O1TRsTAMsFe8vw3LMENT/vAu6OmyA8+pzgThHeA8=";
|
sha256 = "tp6O1TRsTAMsFe8vw3LMENT/vAu6OmyA8+pzgThHeA8=";
|
||||||
})
|
})
|
||||||
(fetchpatch {
|
|
||||||
name = "musl-qsort_r.patch";
|
|
||||||
url = "https://git.alpinelinux.org/aports/plain/main/elfutils/musl-qsort_r.patch?id=2e3d4976eeffb4704cf83e2cc3306293b7c7b2e9";
|
|
||||||
sha256 = "FPWCkdtFT3zw8aNnz0Jz5Vmu8B/mRfNgfhbM/ej7d8M=";
|
|
||||||
})
|
|
||||||
(fetchpatch {
|
|
||||||
name = "musl-strerror_r.patch";
|
|
||||||
url = "https://git.alpinelinux.org/aports/plain/main/elfutils/musl-strerror_r.patch?id=2e3d4976eeffb4704cf83e2cc3306293b7c7b2e9";
|
|
||||||
sha256 = "QF6YwWkcT12dZHKzfqFgxy/1fkIllo0AAosbV0sM5PU=";
|
|
||||||
})
|
|
||||||
(fetchpatch {
|
(fetchpatch {
|
||||||
name = "musl-strndupa.patch";
|
name = "musl-strndupa.patch";
|
||||||
url = "https://git.alpinelinux.org/aports/plain/main/elfutils/musl-strndupa.patch?id=2e3d4976eeffb4704cf83e2cc3306293b7c7b2e9";
|
url = "https://git.alpinelinux.org/aports/plain/main/elfutils/musl-strndupa.patch?id=2e3d4976eeffb4704cf83e2cc3306293b7c7b2e9";
|
||||||
sha256 = "sha256-7daehJj1t0wPtQzTv+/Rpuqqs5Ng/EYnZzrcf2o/Lb0=";
|
sha256 = "sha256-7daehJj1t0wPtQzTv+/Rpuqqs5Ng/EYnZzrcf2o/Lb0=";
|
||||||
})
|
})
|
||||||
] ++ lib.optional stdenv.hostPlatform.isMusl [ ./musl-error_h.patch ];
|
] ++ lib.optionals stdenv.hostPlatform.isMusl [ ./musl-error_h.patch ];
|
||||||
|
|
||||||
|
postPatch = ''
|
||||||
|
patchShebangs tests/*.sh
|
||||||
|
'';
|
||||||
|
|
||||||
outputs = [ "bin" "dev" "out" "man" ];
|
outputs = [ "bin" "dev" "out" "man" ];
|
||||||
|
|
||||||
hardeningDisable = [ "format" ];
|
|
||||||
|
|
||||||
# We need bzip2 in NativeInputs because otherwise we can't unpack the src,
|
# We need bzip2 in NativeInputs because otherwise we can't unpack the src,
|
||||||
# as the host-bzip2 will be in the path.
|
# as the host-bzip2 will be in the path.
|
||||||
nativeBuildInputs = [ m4 bison flex gettext bzip2 ]
|
nativeBuildInputs = [ m4 bison flex gettext bzip2 ]
|
||||||
++ lib.optional stdenv.hostPlatform.isMusl autoreconfHook
|
++ lib.optional enableDebuginfod pkg-config;
|
||||||
++ lib.optional (enableDebuginfod || stdenv.hostPlatform.isMusl) pkg-config;
|
buildInputs = [ zlib zstd bzip2 xz ]
|
||||||
buildInputs = [ zlib bzip2 xz ]
|
|
||||||
++ lib.optionals stdenv.hostPlatform.isMusl [
|
++ lib.optionals stdenv.hostPlatform.isMusl [
|
||||||
argp-standalone
|
argp-standalone
|
||||||
musl-fts
|
musl-fts
|
||||||
|
@ -77,22 +63,24 @@ stdenv.mkDerivation rec {
|
||||||
|
|
||||||
propagatedNativeBuildInputs = [ setupDebugInfoDirs ];
|
propagatedNativeBuildInputs = [ setupDebugInfoDirs ];
|
||||||
|
|
||||||
preConfigure = lib.optionalString stdenv.hostPlatform.isMusl ''
|
NIX_CFLAGS_COMPILE = lib.optionals stdenv.hostPlatform.isMusl [
|
||||||
NIX_CFLAGS_COMPILE+=" -Wno-null-dereference"
|
"-Wno-null-dereference"
|
||||||
'';
|
];
|
||||||
|
|
||||||
configureFlags = [
|
configureFlags = [
|
||||||
"--program-prefix=eu-" # prevent collisions with binutils
|
"--program-prefix=eu-" # prevent collisions with binutils
|
||||||
"--enable-deterministic-archives"
|
"--enable-deterministic-archives"
|
||||||
] ++ lib.optionals (!enableDebuginfod) [
|
(lib.enableFeature enableDebuginfod "libdebuginfod")
|
||||||
"--disable-libdebuginfod"
|
(lib.enableFeature enableDebuginfod "debuginfod")
|
||||||
"--disable-debuginfod"
|
|
||||||
];
|
];
|
||||||
|
|
||||||
enableParallelBuilding = true;
|
enableParallelBuilding = true;
|
||||||
|
|
||||||
doCheck = false; # fails 3 out of 174 tests
|
# Backtrace unwinding tests rely on glibc-internal symbol names.
|
||||||
doInstallCheck = false; # fails 70 out of 174 tests
|
# Musl provides slightly different forms and fails.
|
||||||
|
# Let's disable tests there until musl support is fully upstreamed.
|
||||||
|
doCheck = !stdenv.hostPlatform.isMusl;
|
||||||
|
doInstallCheck = !stdenv.hostPlatform.isMusl;
|
||||||
|
|
||||||
meta = with lib; {
|
meta = with lib; {
|
||||||
homepage = "https://sourceware.org/elfutils/";
|
homepage = "https://sourceware.org/elfutils/";
|
||||||
|
@ -101,6 +89,6 @@ stdenv.mkDerivation rec {
|
||||||
# licenses are GPL2 or LGPL3+ for libraries, GPL3+ for bins,
|
# licenses are GPL2 or LGPL3+ for libraries, GPL3+ for bins,
|
||||||
# but since this package isn't split that way, all three are listed.
|
# but since this package isn't split that way, all three are listed.
|
||||||
license = with licenses; [ gpl2Only lgpl3Plus gpl3Plus ];
|
license = with licenses; [ gpl2Only lgpl3Plus gpl3Plus ];
|
||||||
maintainers = [ maintainers.eelco ];
|
maintainers = with maintainers; [ eelco r-burns ];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue