A segfault-creating state of the branch.
svn path=/nixpkgs/branches/stdenv-bootstrap-20100825/; revision=23413
This commit is contained in:
parent
f16353b6f2
commit
1c51aeea02
|
@ -1,54 +1,75 @@
|
||||||
{stdenv, fetchurl, linuxHeaders, libiconv, cross ? null, gccCross ? null}:
|
{stdenv, fetchurl, linuxHeaders, libiconv, cross ? null, gccCross ? null,
|
||||||
|
extraConfig ? ""}:
|
||||||
|
|
||||||
assert stdenv.isLinux;
|
assert stdenv.isLinux;
|
||||||
assert cross != null -> gccCross != null;
|
assert cross != null -> gccCross != null;
|
||||||
|
|
||||||
let
|
let
|
||||||
enableArmEABI = (cross == null && stdenv.platform.kernelArch == "arm")
|
configParser = ''
|
||||||
|| (cross != null && cross.arch == "arm");
|
function parseconfig {
|
||||||
|
set -x
|
||||||
|
while read LINE; do
|
||||||
|
NAME=`echo "$LINE" | cut -d \ -f 1`
|
||||||
|
OPTION=`echo "$LINE" | cut -d \ -f 2`
|
||||||
|
|
||||||
configArmEABI = if enableArmEABI then
|
if test -z "$NAME"; then
|
||||||
''-e 's/.*CONFIG_ARM_OABI.*//' \
|
continue
|
||||||
-e 's/.*CONFIG_ARM_EABI.*/CONFIG_ARM_EABI=y/' '' else "";
|
fi
|
||||||
|
|
||||||
enableBigEndian = (cross != null && cross.bigEndian);
|
if test "$NAME" == "CLEAR"; then
|
||||||
|
echo "parseconfig: CLEAR"
|
||||||
|
echo > .config
|
||||||
|
fi
|
||||||
|
|
||||||
configBigEndian = if enableBigEndian then ""
|
echo "parseconfig: removing $NAME"
|
||||||
else
|
sed -i /^$NAME=/d .config
|
||||||
''-e 's/.*ARCH_BIG_ENDIAN.*/#ARCH_BIG_ENDIAN=y/' \
|
|
||||||
-e 's/.*ARCH_WANTS_BIG_ENDIAN.*/#ARCH_WANTS_BIG_ENDIAN=y/' \
|
if test "$OPTION" != n; then
|
||||||
-e 's/.*ARCH_WANTS_LITTLE_ENDIAN.*/ARCH_WANTS_LITTLE_ENDIAN=y/' '';
|
echo "parseconfig: setting $NAME=$OPTION"
|
||||||
|
echo "$NAME=$OPTION" >> .config
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
set +x
|
||||||
|
}
|
||||||
|
'';
|
||||||
|
|
||||||
archMakeFlag = if (cross != null) then "ARCH=${cross.arch}" else "";
|
archMakeFlag = if (cross != null) then "ARCH=${cross.arch}" else "";
|
||||||
crossMakeFlag = if (cross != null) then "CROSS=${cross.config}-" else "";
|
crossMakeFlag = if (cross != null) then "CROSS=${cross.config}-" else "";
|
||||||
|
|
||||||
|
nixConfig = ''
|
||||||
|
RUNTIME_PREFIX "/"
|
||||||
|
DEVEL_PREFIX "/"
|
||||||
|
UCLIBC_HAS_WCHAR y
|
||||||
|
UCLIBC_HAS_FTW y
|
||||||
|
UCLIBC_HAS_RPC y
|
||||||
|
DO_C99_MATH y
|
||||||
|
UCLIBC_HAS_PROGRAM_INVOCATION_NAME y
|
||||||
|
KERNEL_HEADERS "${linuxHeaders}/include"
|
||||||
|
|
||||||
|
UCLIBC_SUSV3_LEGACY y
|
||||||
|
UCLIBC_SUSV4_LEGACY y
|
||||||
|
'';
|
||||||
|
|
||||||
in
|
in
|
||||||
stdenv.mkDerivation {
|
stdenv.mkDerivation {
|
||||||
name = "uclibc-0.9.30.3" + stdenv.lib.optionalString (cross != null)
|
name = "uclibc-0.9.31" + stdenv.lib.optionalString (cross != null)
|
||||||
("-" + cross.config);
|
("-" + cross.config);
|
||||||
|
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
url = http://www.uclibc.org/downloads/uClibc-0.9.30.3.tar.bz2;
|
url = http://www.uclibc.org/downloads/uClibc-0.9.31.tar.bz2;
|
||||||
sha256 = "0f1fpdwampbw7pf79i64ipj0azk4kbc9wl81ynlp19p92k4klz0h";
|
sha256 = "1yk328fnz0abgh2vm2r68y65ckfkx97rdp8hbg4xvmx5s94kblw0";
|
||||||
};
|
};
|
||||||
|
|
||||||
# 'ftw' needed to build acl, a coreutils dependency
|
# 'ftw' needed to build acl, a coreutils dependency
|
||||||
configurePhase = ''
|
configurePhase = ''
|
||||||
make defconfig ${archMakeFlag}
|
make defconfig ${archMakeFlag}
|
||||||
sed -e s@/usr/include@${linuxHeaders}/include@ \
|
${configParser}
|
||||||
-e 's@^RUNTIME_PREFIX.*@RUNTIME_PREFIX="/"@' \
|
cat << EOF | parseconfig
|
||||||
-e 's@^DEVEL_PREFIX.*@DEVEL_PREFIX="/"@' \
|
${nixConfig}
|
||||||
-e 's@.*UCLIBC_HAS_WCHAR.*@UCLIBC_HAS_WCHAR=y@' \
|
${extraConfig}
|
||||||
-e 's@.*UCLIBC_HAS_FTW.*@UCLIBC_HAS_FTW=y@' \
|
${if cross != null then cross.uclibc.extraConfig else ""}
|
||||||
-e 's@.*UCLIBC_HAS_RPC.*@UCLIBC_HAS_RPC=y@' \
|
$extraCrossConfig
|
||||||
-e 's@.*DO_C99_MATH.*@DO_C99_MATH=y@' \
|
EOF
|
||||||
-e 's@.*UCLIBC_HAS_PROGRAM_INVOCATION_NAME.*@UCLIBC_HAS_PROGRAM_INVOCATION_NAME=y@' \
|
|
||||||
-e 's@.*CONFIG_MIPS_ISA_1.*@#CONFIG_MIPS_ISA_1=y@' \
|
|
||||||
-e 's@.*CONFIG_MIPS_ISA_3.*@CONFIG_MIPS_ISA_3=y@' \
|
|
||||||
-e 's@.*CONFIG_MIPS_O32_ABI.*@#CONFIG_MIPS_O32_ABI=y@' \
|
|
||||||
-e 's@.*CONFIG_MIPS_N32_ABI.*@CONFIG_MIPS_N32_ABI=y@' \
|
|
||||||
${configArmEABI} \
|
|
||||||
${configBigEndian} \
|
|
||||||
-i .config
|
|
||||||
make oldconfig
|
make oldconfig
|
||||||
'';
|
'';
|
||||||
|
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
|
|
||||||
{
|
{
|
||||||
bootstrapTools = {
|
bootstrapTools = {
|
||||||
url = http://nixos.org/tarballs/stdenv-linux/x86_64/r16022/bootstrap-tools.cpio.bz2;
|
url = http://nixos.org/tarballs/stdenv-linux/x86_64/r23302/bootstrap-tools.cpio.bz2;
|
||||||
sha256 = "1hwmyd9x9lhmb1ckwap2lvf7wi34p1j23v5bw41drym4mfp97ynz";
|
sha256 = "0w89kqhx47yl0jifp2vffp073pyrqha5f312kp971smi4h41drna";
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,6 +31,49 @@ rec {
|
||||||
|
|
||||||
#gccNoShared = wrapGCC ( gcc.gcc.override { enableShared = false; } );
|
#gccNoShared = wrapGCC ( gcc.gcc.override { enableShared = false; } );
|
||||||
|
|
||||||
|
busyboxStaticSh = busybox.override {
|
||||||
|
extraConfig = ''
|
||||||
|
CLEAR
|
||||||
|
CONFIG_STATIC y
|
||||||
|
|
||||||
|
CONFIG_ASH y
|
||||||
|
CONFIG_BASH_COMPAT y
|
||||||
|
CONFIG_ASH_ALIAS y
|
||||||
|
CONFIG_ASH_GETOPTS y
|
||||||
|
CONFIG_ASH_CMDCMD y
|
||||||
|
CONFIG_ASH_JOB_CONTROL y
|
||||||
|
CONFIG_ASH_BUILTIN_ECHO y
|
||||||
|
CONFIG_ASH_BUILTIN_PRINTF y
|
||||||
|
CONFIG_ASH_BUILTIN_TEST y
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
busyboxStaticLn = busybox.override {
|
||||||
|
extraConfig = ''
|
||||||
|
CLEAR
|
||||||
|
CONFIG_STATIC y
|
||||||
|
CONFIG_LN y
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
busyboxStaticMkdir = busybox.override {
|
||||||
|
extraConfig = ''
|
||||||
|
CLEAR
|
||||||
|
CONFIG_STATIC y
|
||||||
|
CONFIG_MKDIR y
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
busyboxStaticCpio = busybox.override {
|
||||||
|
extraConfig = ''
|
||||||
|
CLEAR
|
||||||
|
CONFIG_STATIC y
|
||||||
|
CONFIG_CPIO y
|
||||||
|
CONFIG_FEATURE_CPIO_O y
|
||||||
|
CONFIG_FEATURE_CPIO_P y
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
build =
|
build =
|
||||||
|
|
||||||
stdenv.mkDerivation {
|
stdenv.mkDerivation {
|
||||||
|
@ -43,7 +86,7 @@ rec {
|
||||||
ensureDir $out/bin $out/lib $out/libexec
|
ensureDir $out/bin $out/lib $out/libexec
|
||||||
|
|
||||||
# Copy what we need of Glibc.
|
# Copy what we need of Glibc.
|
||||||
cp -d ${glibc}/lib/ld-*.so* $out/lib
|
cp -d ${glibc}/lib/ld*.so* $out/lib
|
||||||
cp -d ${glibc}/lib/libc*.so* $out/lib
|
cp -d ${glibc}/lib/libc*.so* $out/lib
|
||||||
cp -d ${glibc}/lib/libc_nonshared.a $out/lib
|
cp -d ${glibc}/lib/libc_nonshared.a $out/lib
|
||||||
cp -d ${glibc}/lib/libm*.so* $out/lib
|
cp -d ${glibc}/lib/libm*.so* $out/lib
|
||||||
|
@ -97,6 +140,7 @@ rec {
|
||||||
rm -f $out/lib/gcc/*/*/include*/sound
|
rm -f $out/lib/gcc/*/*/include*/sound
|
||||||
rm -rf $out/lib/gcc/*/*/include*/root
|
rm -rf $out/lib/gcc/*/*/include*/root
|
||||||
rm -f $out/lib/gcc/*/*/include-fixed/asm
|
rm -f $out/lib/gcc/*/*/include-fixed/asm
|
||||||
|
rm -rf $out/lib/gcc/*/*/plugin
|
||||||
#rm -f $out/lib/gcc/*/*/*.a
|
#rm -f $out/lib/gcc/*/*/*.a
|
||||||
cp -rd ${gcc.gcc}/libexec/* $out/libexec
|
cp -rd ${gcc.gcc}/libexec/* $out/libexec
|
||||||
mkdir $out/include
|
mkdir $out/include
|
||||||
|
@ -105,10 +149,13 @@ rec {
|
||||||
rm -rf $out/include/c++/*/ext/pb_ds
|
rm -rf $out/include/c++/*/ext/pb_ds
|
||||||
rm -rf $out/include/c++/*/ext/parallel
|
rm -rf $out/include/c++/*/ext/parallel
|
||||||
|
|
||||||
cp -d ${gmp}/lib/libgmp*.so* $out/lib
|
cp -d ${gmpxx}/lib/libgmp*.so* $out/lib
|
||||||
cp -d ${mpfr}/lib/libmpfr*.so* $out/lib
|
cp -d ${mpfr}/lib/libmpfr*.so* $out/lib
|
||||||
cp -d ${ppl}/lib/libppl*.so* $out/lib
|
cp -d ${ppl}/lib/libppl*.so* $out/lib
|
||||||
cp -d ${cloogppl}/lib/libcloog*.so* $out/lib
|
cp -d ${cloogppl}/lib/libcloog*.so* $out/lib
|
||||||
|
cp -d ${mpc}/lib/libmpc*.so* $out/lib
|
||||||
|
cp -d ${zlib}/lib/libz.so* $out/lib
|
||||||
|
cp -d ${libelf}/lib/libelf.so* $out/lib
|
||||||
|
|
||||||
# Copy binutils.
|
# Copy binutils.
|
||||||
for i in as ld ar ranlib nm strip readelf objdump; do
|
for i in as ld ar ranlib nm strip readelf objdump; do
|
||||||
|
@ -137,10 +184,10 @@ rec {
|
||||||
(cd $out/pack && (find | cpio -o -H newc)) | bzip2 > $out/on-server/bootstrap-tools.cpio.bz2
|
(cd $out/pack && (find | cpio -o -H newc)) | bzip2 > $out/on-server/bootstrap-tools.cpio.bz2
|
||||||
|
|
||||||
mkdir $out/in-nixpkgs
|
mkdir $out/in-nixpkgs
|
||||||
cp ${klibc}/lib/klibc/bin.static/sh $out/in-nixpkgs
|
cp ${busyboxStaticSh}/bin/busybox $out/in-nixpkgs/sh
|
||||||
cp ${klibc}/lib/klibc/bin.static/cpio $out/in-nixpkgs
|
cp ${busyboxStaticCpio}/bin/busybox $out/in-nixpkgs/cpio
|
||||||
cp ${klibc}/lib/klibc/bin.static/mkdir $out/in-nixpkgs
|
cp ${busyboxStaticMkdir}/bin/busybox $out/in-nixpkgs/mkdir
|
||||||
cp ${klibc}/lib/klibc/bin.static/ln $out/in-nixpkgs
|
cp ${busyboxStaticLn}/bin/busybox $out/in-nixpkgs/ln
|
||||||
cp ${curlStatic}/bin/curl $out/in-nixpkgs
|
cp ${curlStatic}/bin/curl $out/in-nixpkgs
|
||||||
cp ${bzip2Static}/bin/bzip2 $out/in-nixpkgs
|
cp ${bzip2Static}/bin/bzip2 $out/in-nixpkgs
|
||||||
chmod u+w $out/in-nixpkgs/*
|
chmod u+w $out/in-nixpkgs/*
|
||||||
|
|
|
@ -39,7 +39,7 @@ for i in $out/lib/librt* ; do
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
for i in $out/lib/libgmp* $out/lib/libppl* $out/lib/libcloog* $out/lib/libmpc*; do
|
for i in $out/lib/libgmp* $out/lib/libppl* $out/lib/libcloog* $out/lib/libmpc* $out/lib/libpcre* $out/lib/libstdc++*.so.*[0-9]; do
|
||||||
echo trying to patch $i
|
echo trying to patch $i
|
||||||
if test -f $i -a ! -L $i; then
|
if test -f $i -a ! -L $i; then
|
||||||
LD_LIBRARY_PATH=$out/lib $LD_BINARY \
|
LD_LIBRARY_PATH=$out/lib $LD_BINARY \
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
{ stdenv, fetchurl
|
{ stdenv, fetchurl
|
||||||
, zlibSupport ? false, zlib
|
, zlibSupport ? false, zlib ? null
|
||||||
, sslSupport ? false, openssl
|
, sslSupport ? false, openssl ? null
|
||||||
, scpSupport ? false, libssh2
|
, scpSupport ? false, libssh2 ? null
|
||||||
, linkStatic ? false
|
, linkStatic ? false
|
||||||
}:
|
}:
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user