nixpkgs/pkgs/stdenv/linux/scripts/unpack-bootstrap-tools.sh

49 lines
1.7 KiB
Bash
Raw Normal View History

set -e
# Unpack the bootstrap tools tarball.
echo Unpacking the bootstrap tools...
$mkdir $out
$bzip2 -d < $tarball | (cd $out && $cpio -V -i)
# Set the ELF interpreter / RPATH in the bootstrap binaries.
echo Patching the bootstrap tools...
# On x86_64, ld-linux-x86-64.so.2 barfs on patchelf'ed programs. So
# use a copy of patchelf.
LD_LIBRARY_PATH=$out/lib $out/lib/ld-linux*.so.2 $out/bin/cp $out/bin/patchelf .
for i in $out/bin/* $out/libexec/gcc/*/*/*; do
echo patching $i
if ! test -L $i; then
LD_LIBRARY_PATH=$out/lib $out/lib/ld-linux*.so.2 \
./patchelf --set-interpreter $out/lib/ld-linux*.so.2 --set-rpath $out/lib $i
fi
done
# Fix the libc linker script.
export PATH=$out/bin
cat $out/lib/libc.so | sed "s|/nix/store/e*-[^/]*/|$out/|g" > $out/lib/libc.so.tmp
mv $out/lib/libc.so.tmp $out/lib/libc.so
# Provide some additional symlinks.
ln -s bash $out/bin/sh
ln -s bzip2 $out/bin/bunzip2
# fetchurl needs curl.
bzip2 -d < $curl > $out/bin/curl
chmod +x $out/bin/curl
# Some libraries have libpthread in their DT_RUNPATH. PatchELF
# doesn't work on libraries, so we need to set LD_LIBRARY_PATH.
# However, setting LD_LIBRARY_PATH to $out/lib will confuse /bin/sh,
# since it might end up loading libraries from a different Glibc. So
# put *only* libpthread in LD_LIBRARY_PATH (via $out/lib2). !!! This
# is a temporary fix (since /bin/sh could have a dependency on
# libpthread as well). A better fix would be to make patchelf work on
# libraries, or to set the RPATH rather than the RUNPATH in the
# binaries in $out/bin (patchelf --force-rpath doesn't quite work,
# since it doesn't discard the existing RUNPATH).
mkdir $out/lib2
ln -s $out/lib/libpthread* $out/lib2