glibc: Drop hurd support

This hasn't been maintained since 2012.

Also, renamed glibc's kernelHeaders argument to linuxHeaders.
This commit is contained in:
Eelco Dolstra 2016-02-18 21:11:15 +01:00
parent f98a5946b7
commit 1ab14aad7a
9 changed files with 43 additions and 108 deletions

View file

@ -22,22 +22,11 @@ postInstall() {
test -f $out/etc/ld.so.cache && rm $out/etc/ld.so.cache test -f $out/etc/ld.so.cache && rm $out/etc/ld.so.cache
# FIXME: Use `test -n $linuxHeaders' when `kernelHeaders' has been if test -n "$linuxHeaders"; then
# renamed.
if test -z "$hurdHeaders"; then
# Include the Linux kernel headers in Glibc, except the `scsi' # Include the Linux kernel headers in Glibc, except the `scsi'
# subdirectory, which Glibc provides itself. # subdirectory, which Glibc provides itself.
(cd $out/include && \ (cd $out/include && \
ln -sv $(ls -d $kernelHeaders/include/* | grep -v 'scsi$') .) ln -sv $(ls -d $linuxHeaders/include/* | grep -v 'scsi$') .)
fi
if test -f "$out/lib/libhurduser.so"; then
# libc.so, libhurduser.so, and libmachuser.so depend on each
# other, so add them to libc.so (a RUNPATH on libc.so.0.3
# would be ignored by the cross-linker.)
echo "adding \`libhurduser.so' and \`libmachuser.so' to the \`libc.so' linker script..."
sed -i "$out/lib/libc.so" \
-e"s|\(libc\.so\.[^ ]\+\>\)|\1 $out/lib/libhurduser.so $out/lib/libmachuser.so|g"
fi fi
# Fix for NIXOS-54 (ldd not working on x86_64). Make a symlink # Fix for NIXOS-54 (ldd not working on x86_64). Make a symlink

View file

@ -3,10 +3,8 @@
cross: cross:
{ name, fetchurl, fetchgit ? null, stdenv, installLocales ? false { name, fetchurl, lib, stdenv, installLocales ? false
, gccCross ? null, kernelHeaders ? null , gccCross ? null, linuxHeaders ? null
, machHeaders ? null, hurdHeaders ? null, libpthreadHeaders ? null
, mig ? null
, profilingLibraries ? false, meta , profilingLibraries ? false, meta
, withGd ? false, gd ? null, libpng ? null , withGd ? false, gd ? null, libpng ? null
, preConfigure ? "", ... }@args: , preConfigure ? "", ... }@args:
@ -18,12 +16,9 @@ let
in in
assert cross != null -> gccCross != null; assert cross != null -> gccCross != null;
assert mig != null -> machHeaders != null;
assert machHeaders != null -> hurdHeaders != null;
assert hurdHeaders != null -> libpthreadHeaders != null;
stdenv.mkDerivation ({ stdenv.mkDerivation ({
inherit kernelHeaders installLocales; inherit linuxHeaders installLocales;
# The host/target system. # The host/target system.
crossConfig = if cross != null then cross.config else null; crossConfig = if cross != null then cross.config else null;
@ -32,9 +27,7 @@ stdenv.mkDerivation ({
enableParallelBuilding = true; enableParallelBuilding = true;
/* Don't try to apply these patches to the Hurd's snapshot, which is patches =
older. */
patches = stdenv.lib.optionals (hurdHeaders == null)
[ /* Have rpcgen(1) look for cpp(1) in $PATH. */ [ /* Have rpcgen(1) look for cpp(1) in $PATH. */
./rpcgen-path.patch ./rpcgen-path.patch
@ -96,36 +89,35 @@ stdenv.mkDerivation ({
"--sysconfdir=/etc" "--sysconfdir=/etc"
"--localedir=/var/run/current-system/sw/lib/locale" "--localedir=/var/run/current-system/sw/lib/locale"
"libc_cv_ssp=no" "libc_cv_ssp=no"
(if kernelHeaders != null (if linuxHeaders != null
then "--with-headers=${kernelHeaders}/include" then "--with-headers=${linuxHeaders}/include"
else "--without-headers") else "--without-headers")
(if profilingLibraries (if profilingLibraries
then "--enable-profile" then "--enable-profile"
else "--disable-profile") else "--disable-profile")
] ++ stdenv.lib.optionals (cross == null && kernelHeaders != null) [ ] ++ lib.optionals (cross == null && linuxHeaders != null) [
"--enable-kernel=2.6.32" "--enable-kernel=2.6.32"
] ++ stdenv.lib.optionals (cross != null) [ ] ++ lib.optionals (cross != null) [
(if cross.withTLS then "--with-tls" else "--without-tls") (if cross.withTLS then "--with-tls" else "--without-tls")
(if cross.float == "soft" then "--without-fp" else "--with-fp") (if cross.float == "soft" then "--without-fp" else "--with-fp")
] ++ stdenv.lib.optionals (cross != null ] ++ lib.optionals (cross != null
&& cross.platform ? kernelMajor && cross.platform ? kernelMajor
&& cross.platform.kernelMajor == "2.6") [ && cross.platform.kernelMajor == "2.6") [
"--enable-kernel=2.6.0" "--enable-kernel=2.6.0"
"--with-__thread" "--with-__thread"
] ++ stdenv.lib.optionals (cross == null && stdenv.isArm) [ ] ++ lib.optionals (cross == null && stdenv.isArm) [
"--host=arm-linux-gnueabi" "--host=arm-linux-gnueabi"
"--build=arm-linux-gnueabi" "--build=arm-linux-gnueabi"
# To avoid linking with -lgcc_s (dynamic link) # To avoid linking with -lgcc_s (dynamic link)
# so the glibc does not depend on its compiler store path # so the glibc does not depend on its compiler store path
"libc_cv_as_needed=no" "libc_cv_as_needed=no"
] ++ stdenv.lib.optional withGd "--with-gd"; ] ++ lib.optional withGd "--with-gd";
installFlags = [ "sysconfdir=$(out)/etc" ]; installFlags = [ "sysconfdir=$(out)/etc" ];
buildInputs = stdenv.lib.optionals (cross != null) [ gccCross ] buildInputs = lib.optionals (cross != null) [ gccCross ]
++ stdenv.lib.optional (mig != null) mig ++ lib.optionals withGd [ gd libpng ];
++ stdenv.lib.optionals withGd [ gd libpng ];
# Needed to install share/zoneinfo/zone.tab. Set to impure /bin/sh to # Needed to install share/zoneinfo/zone.tab. Set to impure /bin/sh to
# prevent a retained dependency on the bootstrap tools in the stdenv-linux # prevent a retained dependency on the bootstrap tools in the stdenv-linux
@ -137,32 +129,22 @@ stdenv.mkDerivation ({
# I.e. when gcc is compiled with --with-arch=i686, then the # I.e. when gcc is compiled with --with-arch=i686, then the
# preprocessor symbol `__i686' will be defined to `1'. This causes # preprocessor symbol `__i686' will be defined to `1'. This causes
# the symbol __i686.get_pc_thunk.dx to be mangled. # the symbol __i686.get_pc_thunk.dx to be mangled.
NIX_CFLAGS_COMPILE = stdenv.lib.optionalString (stdenv.system == "i686-linux") "-U__i686" NIX_CFLAGS_COMPILE = lib.optionalString (stdenv.system == "i686-linux") "-U__i686"
+ " -Wno-error=strict-prototypes"; + " -Wno-error=strict-prototypes";
} }
# Remove the `gccCross' attribute so that the *native* glibc store path # Remove the `gccCross' attribute so that the *native* glibc store path
# doesn't depend on whether `gccCross' is null or not. # doesn't depend on whether `gccCross' is null or not.
// (removeAttrs args [ "gccCross" "fetchurl" "fetchgit" "withGd" "gd" "libpng" ]) // // (removeAttrs args [ "lib" "gccCross" "fetchurl" "withGd" "gd" "libpng" ]) //
{ {
name = name + "-${version}" + name = name + "-${version}" +
stdenv.lib.optionalString (cross != null) "-${cross.config}"; lib.optionalString (cross != null) "-${cross.config}";
src = src = fetchurl {
if hurdHeaders != null url = "mirror://gnu/glibc/glibc-${version}.tar.gz";
then fetchgit { sha256 = "1rcby0cqgswgqaxyqz0yqc4zizb1kvpi5vlfqp7dh3sa132109m6";
# Shamefully the "official" glibc won't build on GNU, so use the one };
# maintained by the Hurd folks, `tschwinge/Roger_Whittaker' branch.
# See <http://www.gnu.org/software/hurd/source_repositories/glibc.html>.
url = "git://git.sv.gnu.org/hurd/glibc.git";
sha256 = "cecec9dd5a2bafc875c56b058b6d7628a22b250b53747513dec304f31ffdb82d";
rev = "d3cdecf18e6550b0984a42b43ed48c5fb26501e1";
}
else fetchurl {
url = "mirror://gnu/glibc/glibc-${version}.tar.gz";
sha256 = "1rcby0cqgswgqaxyqz0yqc4zizb1kvpi5vlfqp7dh3sa132109m6";
};
# Remove absolute paths from `configure' & co.; build out-of-tree. # Remove absolute paths from `configure' & co.; build out-of-tree.
preConfigure = '' preConfigure = ''
@ -178,17 +160,18 @@ stdenv.mkDerivation ({
configureScript="`pwd`/../$sourceRoot/configure" configureScript="`pwd`/../$sourceRoot/configure"
${stdenv.lib.optionalString (stdenv.cc.libc != null) ${lib.optionalString (stdenv.cc.libc != null)
''makeFlags="$makeFlags BUILD_LDFLAGS=-Wl,-rpath,${stdenv.cc.libc}/lib"'' ''makeFlags="$makeFlags BUILD_LDFLAGS=-Wl,-rpath,${stdenv.cc.libc}/lib"''
} }
${preConfigure} ${preConfigure}
''; '';
preBuild = lib.optionalString withGd "unset NIX_DONT_SET_RPATH";
meta = { meta = {
homepage = http://www.gnu.org/software/libc/; homepage = http://www.gnu.org/software/libc/;
description = "The GNU C Library" description = "The GNU C Library";
+ stdenv.lib.optionalString (hurdHeaders != null) ", for GNU/Hurd";
longDescription = longDescription =
'' Any Unix-like operating system needs a C library: the library which '' Any Unix-like operating system needs a C library: the library which
@ -199,24 +182,9 @@ stdenv.mkDerivation ({
most systems with the Linux kernel. most systems with the Linux kernel.
''; '';
license = stdenv.lib.licenses.lgpl2Plus; license = lib.licenses.lgpl2Plus;
maintainers = [ ]; maintainers = [ lib.maintainers.eelco ];
#platforms = stdenv.lib.platforms.linux; #platforms = lib.platforms.linux;
} // meta; } // meta;
}
// stdenv.lib.optionalAttrs withGd {
preBuild = "unset NIX_DONT_SET_RPATH";
}
// stdenv.lib.optionalAttrs (hurdHeaders != null) {
# Work around the fact that the configure snippet that looks for
# <hurd/version.h> does not honor `--with-headers=$sysheaders' and that
# glibc expects Mach, Hurd, and pthread headers to be in the same place.
CPATH = "${hurdHeaders}/include:${machHeaders}/include:${libpthreadHeaders}/include";
# Install NSS stuff in the right place.
# XXX: This will be needed for all new glibcs and isn't Hurd-specific.
makeFlags = ''vardbdir="$out/var/db"'';
}) })

View file

@ -1,6 +1,4 @@
{ stdenv, fetchurl, fetchgit ? null, kernelHeaders { lib, stdenv, fetchurl, linuxHeaders
, machHeaders ? null, hurdHeaders ? null, libpthreadHeaders ? null
, mig ? null
, installLocales ? true , installLocales ? true
, profilingLibraries ? false , profilingLibraries ? false
, gccCross ? null , gccCross ? null
@ -16,11 +14,10 @@ let
in in
build cross ({ build cross ({
name = "glibc" name = "glibc"
+ stdenv.lib.optionalString (hurdHeaders != null) "-hurd" + lib.optionalString debugSymbols "-debug"
+ stdenv.lib.optionalString debugSymbols "-debug" + lib.optionalString withGd "-gd";
+ stdenv.lib.optionalString withGd "-gd";
inherit fetchurl fetchgit stdenv kernelHeaders installLocales inherit lib stdenv fetchurl linuxHeaders installLocales
profilingLibraries gccCross withGd gd libpng; profilingLibraries gccCross withGd gd libpng;
builder = ./builder.sh; builder = ./builder.sh;
@ -58,23 +55,6 @@ in
// //
(if hurdHeaders != null
then rec {
inherit machHeaders hurdHeaders libpthreadHeaders mig fetchgit;
propagatedBuildInputs = [ machHeaders hurdHeaders libpthreadHeaders ];
passthru = {
# When building GCC itself `propagatedBuildInputs' above is not
# honored, so we pass it here so that the GCC builder can do the right
# thing.
inherit propagatedBuildInputs;
};
}
else { })
//
(if cross != null (if cross != null
then { then {
preConfigure = '' preConfigure = ''

View file

@ -1,4 +1,4 @@
{ stdenv, fetchurl, texinfo, perl }: { lib, stdenv, fetchurl, texinfo, perl }:
let build = import ./common.nix; in let build = import ./common.nix; in
@ -6,7 +6,7 @@ let build = import ./common.nix; in
build null { build null {
name = "glibc-info"; name = "glibc-info";
inherit fetchurl stdenv; inherit fetchurl stdenv lib;
configureFlags = [ "--enable-add-ons" ]; configureFlags = [ "--enable-add-ons" ];

View file

@ -6,14 +6,14 @@
http://sourceware.org/cgi-bin/cvsweb.cgi/libc/localedata/SUPPORTED?cvsroot=glibc http://sourceware.org/cgi-bin/cvsweb.cgi/libc/localedata/SUPPORTED?cvsroot=glibc
*/ */
{ stdenv, fetchurl, writeText, allLocales ? true, locales ? ["en_US.UTF-8/UTF-8"] }: { lib, stdenv, fetchurl, writeText, allLocales ? true, locales ? ["en_US.UTF-8/UTF-8"] }:
let build = import ./common.nix; in let build = import ./common.nix; in
build null { build null {
name = "glibc-locales"; name = "glibc-locales";
inherit fetchurl stdenv; inherit fetchurl stdenv lib;
installLocales = true; installLocales = true;
builder = ./locales-builder.sh; builder = ./locales-builder.sh;

View file

@ -21,7 +21,7 @@ stdenv.mkDerivation rec {
-i Makefile -i Makefile
''; '';
buildInputs = [ stdenv.cc.libc.kernelHeaders libtool gettext ]; buildInputs = [ stdenv.cc.libc.linuxHeaders libtool gettext ];
meta = { meta = {
description = "Tools to display or change the CPU governor settings"; description = "Tools to display or change the CPU governor settings";

View file

@ -11,7 +11,7 @@ stdenv.mkDerivation {
builder = ./builder.sh; builder = ./builder.sh;
inherit glibc; inherit glibc;
kernelHeaders = glibc.kernelHeaders; kernelHeaders = glibc.linuxHeaders;
patches = [ patches = [

View file

@ -8,7 +8,9 @@ stdenv.mkDerivation rec {
sha256 = "1pkkid657zgjymwxv3fm32cxnq9llfz29rl15vp6mn42vnzbj1di"; sha256 = "1pkkid657zgjymwxv3fm32cxnq9llfz29rl15vp6mn42vnzbj1di";
}; };
buildInputs = [ pkgconfig glib ] ++ stdenv.lib.optional (stdenv ? glibc) stdenv.glibc.kernelHeaders; buildInputs =
[ pkgconfig glib ]
++ stdenv.lib.optional (stdenv ? glibc) stdenv.glibc.linuxHeaders;
postInstall = '' postInstall = ''
mkdir -p "$out/share/doc/${name}" mkdir -p "$out/share/doc/${name}"

View file

@ -6707,22 +6707,18 @@ let
glfw3 = callPackage ../development/libraries/glfw/3.x.nix { }; glfw3 = callPackage ../development/libraries/glfw/3.x.nix { };
glibc = callPackage ../development/libraries/glibc { glibc = callPackage ../development/libraries/glibc {
kernelHeaders = linuxHeaders;
installLocales = config.glibc.locales or false; installLocales = config.glibc.locales or false;
machHeaders = null;
hurdHeaders = null;
gccCross = null; gccCross = null;
}; };
glibc_memusage = callPackage ../development/libraries/glibc { glibc_memusage = callPackage ../development/libraries/glibc {
kernelHeaders = linuxHeaders;
installLocales = false; installLocales = false;
withGd = true; withGd = true;
}; };
glibcCross = forceNativeDrv (glibc.override { glibcCross = forceNativeDrv (glibc.override {
gccCross = gccCrossStageStatic; gccCross = gccCrossStageStatic;
kernelHeaders = linuxHeadersCross; linuxHeaders = linuxHeadersCross;
}); });
# We can choose: # We can choose: