summary refs log tree commit diff
path: root/pkgs/stdenv
diff options
context:
space:
mode:
authorLluís Batlle i Rossell <viric@vicerveza.homeunix.net>2010-08-01 22:00:14 +0000
committerLluís Batlle i Rossell <viric@vicerveza.homeunix.net>2010-08-01 22:00:14 +0000
commit9724fb271b4cdcd18b8ff9fc4d5ff934c328e2a9 (patch)
tree264bc3be225816a2f1dcf5b7b34fdb72121407d1 /pkgs/stdenv
parent0f4673788ef286ab623d95f407d08eb38d97f057 (diff)
downloadnixlib-9724fb271b4cdcd18b8ff9fc4d5ff934c328e2a9.tar
nixlib-9724fb271b4cdcd18b8ff9fc4d5ff934c328e2a9.tar.gz
nixlib-9724fb271b4cdcd18b8ff9fc4d5ff934c328e2a9.tar.bz2
nixlib-9724fb271b4cdcd18b8ff9fc4d5ff934c328e2a9.tar.lz
nixlib-9724fb271b4cdcd18b8ff9fc4d5ff934c328e2a9.tar.xz
nixlib-9724fb271b4cdcd18b8ff9fc4d5ff934c328e2a9.tar.zst
nixlib-9724fb271b4cdcd18b8ff9fc4d5ff934c328e2a9.zip
Fixing the unpack bootstrap tools script so it works not only for mips.
svn path=/nixpkgs/branches/stdenv-updates/; revision=22855
Diffstat (limited to 'pkgs/stdenv')
-rw-r--r--pkgs/stdenv/linux/scripts/unpack-bootstrap-tools.sh32
1 files changed, 20 insertions, 12 deletions
diff --git a/pkgs/stdenv/linux/scripts/unpack-bootstrap-tools.sh b/pkgs/stdenv/linux/scripts/unpack-bootstrap-tools.sh
index da787d2036d3..b3f5dbb546db 100644
--- a/pkgs/stdenv/linux/scripts/unpack-bootstrap-tools.sh
+++ b/pkgs/stdenv/linux/scripts/unpack-bootstrap-tools.sh
@@ -8,35 +8,43 @@ $bzip2 -d < $tarball | (cd $out && $cpio -i)
 # Set the ELF interpreter / RPATH in the bootstrap binaries.
 echo Patching the bootstrap tools...
 
+if test -f $out/lib/ld.so.?; then
+   # MIPS case
+   LD_BINARY=$out/lib/ld.so.?
+else
+   # i686, x86_64 and armv5tel
+   LD_BINARY=$out/lib/ld-*so.?
+fi
+
 # 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.so.? $out/bin/cp $out/bin/patchelf .
+LD_LIBRARY_PATH=$out/lib $LD_BINARY $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.so.? \
-             $out/bin/patchelf --set-interpreter $out/lib/ld.so.? --set-rpath $out/lib --force-rpath $i
-         LD_LIBRARY_PATH=$out/lib $out/lib/ld.so.? \
-             $out/bin/patchelf --set-interpreter $out/lib/ld.so.? --set-rpath $out/lib --force-rpath $i
+         LD_LIBRARY_PATH=$out/lib $LD_BINARY \
+             $out/bin/patchelf --set-interpreter $LD_BINARY --set-rpath $out/lib --force-rpath $i
+         LD_LIBRARY_PATH=$out/lib $LD_BINARY \
+             $out/bin/patchelf --set-interpreter $LD_BINARY --set-rpath $out/lib --force-rpath $i
     fi
 done
 for i in $out/lib/librt* ; do
     echo patching $i
     if ! test -L $i; then
-         LD_LIBRARY_PATH=$out/lib $out/lib/ld.so.? \
-             $out/bin/patchelf --set-interpreter $out/lib/ld.so.? --set-rpath $out/lib --force-rpath $i
-         LD_LIBRARY_PATH=$out/lib $out/lib/ld.so.? \
-             $out/bin/patchelf --set-interpreter $out/lib/ld.so.? --set-rpath $out/lib --force-rpath $i
+         LD_LIBRARY_PATH=$out/lib $LD_BINARY \
+             $out/bin/patchelf --set-interpreter $LD_BINARY --set-rpath $out/lib --force-rpath $i
+         LD_LIBRARY_PATH=$out/lib $LD_BINARY \
+             $out/bin/patchelf --set-interpreter $LD_BINARY --set-rpath $out/lib --force-rpath $i
     fi
 done
 
 for i in $out/lib/libgmp* $out/lib/libppl* $out/lib/libcloog* $out/lib/libmpc*; do
-    echo patching $i
+    echo trying to patch $i
     if test -f $i -a ! -L $i; then
-         LD_LIBRARY_PATH=$out/lib $out/lib/ld.so.? \
+         LD_LIBRARY_PATH=$out/lib $LD_BINARY \
              $out/bin/patchelf --set-rpath $out/lib --force-rpath $i
-         LD_LIBRARY_PATH=$out/lib $out/lib/ld.so.? \
+         LD_LIBRARY_PATH=$out/lib $LD_BINARY \
              $out/bin/patchelf --set-rpath $out/lib --force-rpath $i
     fi
 done