wok-current rev 8189

imported patch toolchain/glibc.patch
author Antoine Bodin <gokhlayeh@slitaz.org>
date Thu Jan 27 00:20:50 2011 +0100 (2011-01-27)
parents 85505c8dd53a
children 79a8dffadd9f
files glibc/receipt glibc/stuff/glibc-2.12.2-gcc_fix-1.patch
line diff
     1.1 --- a/glibc/receipt	Thu Jan 27 00:20:50 2011 +0100
     1.2 +++ b/glibc/receipt	Thu Jan 27 00:20:50 2011 +0100
     1.3 @@ -1,39 +1,96 @@
     1.4  # SliTaz package receipt.
     1.5  
     1.6  PACKAGE="glibc"
     1.7 -VERSION="2.11.2"
     1.8 +VERSION="2.12.2"
     1.9  CATEGORY="meta"
    1.10  SHORT_DESC="The GNU C libraries. This package is used to compile the libc."
    1.11  MAINTAINER="pankso@slitaz.org"
    1.12  DEPENDS="glibc-base glibc-locale glibc-dev"
    1.13 -BUILD_DEPENDS="slitaz-toolchain gawk perl"
    1.14 +BUILD_DEPENDS="linux-api-headers"
    1.15  TARBALL="$PACKAGE-$VERSION.tar.gz"
    1.16  WEB_SITE="http://www.gnu.org/software/libc/"
    1.17  WGET_URL="$GNU_MIRROR/$PACKAGE/$TARBALL"
    1.18 +# Genpkg order: glibc-base, glibc-locale, glibc-dev.
    1.19 +COOK_OPT="genpkg=glibc-base:glib-locale:glibc-dev"
    1.20 +	
    1.21 +# Rules to compile & install the temporary toolchain.
    1.22 +cook_tmp_toolchain()
    1.23 +{
    1.24 +	cd $src
    1.25 +
    1.26 +	# Fix a bug that prevents Glibc from building with GCC-4.5.2:
    1.27 +	patch -Np1 -i ../stuff/glibc-2.12.2-gcc_fix-1.patch
    1.28 +
    1.29 +	# Build in a separate directory.
    1.30 +	mkdir ../glibc-build && cd ../glibc-build
    1.31 +
    1.32 +	# glibc no longer support i386, so use -march=i486 for better compatibility.
    1.33 +	case $ARCH in
    1.34 +		i?86) echo "CFLAGS += -march=i486 -mtune=native" > configparms ;;
    1.35 +	esac
    1.36 +
    1.37 +	{ $src/configure \
    1.38 +		--host=$BUILD_HOST \
    1.39 +		--build=$($src/scripts/config.guess) \
    1.40 +		--disable-profile --enable-add-ons \
    1.41 +		--enable-kernel=2.6.22.5 --with-headers=/tools/include \
    1.42 +		libc_cv_forced_unwind=yes libc_cv_c_cleanup=yes &&
    1.43 +	make &&
    1.44 +	make install
    1.45 +	} || return 1
    1.46 +
    1.47 +	# Link compiler to this new glibc.
    1.48 +	SPECS=`dirname $($BUILD_HOST-gcc -print-libgcc-file-name)`/specs
    1.49 +	$BUILD_HOST-gcc -dumpspecs | sed \
    1.50 +		-e 's@/lib\(64\)\?/ld@/tools&@g' \
    1.51 +		-e "/^\*cpp:$/{n;s,$, -isystem /tools/include,}" > $SPECS 
    1.52 +	unset SPECS
    1.53 +}
    1.54  
    1.55  # Rules to configure and make the package.
    1.56 -#
    1.57 -# Build order: glibc, glibc-base, glibc-locale, glibc-dev.
    1.58 -#
    1.59  compile_rules()
    1.60  {
    1.61 -	mkdir glibc-build
    1.62 -	cd glibc-build
    1.63 +	# Some patch are needed to make things work correctly.
    1.64 +	# Following patches and sed fixes comes from LFS development book :
    1.65 +	# http://www.linuxfromscratch.org/lfs/view/development/chapter06/glibc.html
    1.66 +	cd $src
    1.67 +	DL=$(readelf -l /bin/sh | sed -n 's@.*interpret.*/tools\(.*\)]$@\1@p')
    1.68 +	sed -i "s|libs -o|libs -L/usr/lib -Wl,-dynamic-linker=$DL -o|" \
    1.69 +		scripts/test-installation.pl
    1.70 +	unset DL
    1.71 +	sed -i 's|@BASH@|/bin/bash|' elf/ldd.bash.in
    1.72 +
    1.73 +	# Fix a bug that prevents Glibc from building with GCC-4.5.2:
    1.74 +	patch -Np1 -i ../stuff/glibc-2.12.2-gcc_fix-1.patch
    1.75 +
    1.76 +	mkdir ../glibc-build
    1.77 +	cd ../glibc-build
    1.78 +
    1.79  	# Install in the build tree and then move all files
    1.80  	# to the source tree to keep $src and $_pkg for genpkg.
    1.81 -	mkdir -p ../$PACKAGE-$VERSION/_pkg/etc
    1.82 -	touch ../$PACKAGE-$VERSION/_pkg/etc/ld.so.conf
    1.83 -	#echo "CFLAGS += -march=i486 -mtune=native -O3 -pipe" > configparms
    1.84 -	../$PACKAGE-$VERSION/configure \
    1.85 -		--prefix=/usr \
    1.86 -		--infodir=/usr/share/info \
    1.87 +	mkdir -p $WOK/$PACKAGE/install/etc
    1.88 +	touch $WOK/$PACKAGE/install/etc/ld.so.conf
    1.89 +	echo "CFLAGS += $CFLAGS" > configparms
    1.90 +	{ $src/configure \
    1.91  		--disable-profile \
    1.92  		--enable-add-ons \
    1.93 -		--enable-kernel=2.6.18 \
    1.94 -		--libexecdir=/usr/lib/glibc \
    1.95 -		$CONFIGURE_ARGS &&
    1.96 -	make -j 4 &&
    1.97 -	make install_root=$(cd ../$PACKAGE-$VERSION ; pwd)/_pkg install
    1.98 +		--enable-kernel=2.6.22.5 \
    1.99 +		--libexecdir=/usr/lib/glibc &&
   1.100 +	make &&
   1.101 +	make install_root=$DESTDIR install
   1.102 +	} || return 1
   1.103 +
   1.104 +	# If temporary toolchain was previously used, switch to
   1.105 +	# regular toolchain.
   1.106 +	[ -d /tools ] || return
   1.107 +	mv /tools/bin/ld /tools/bin/ld-old
   1.108 +	mv /tools/$(gcc -dumpmachine)/bin/ld /tools/$(gcc -dumpmachine)/bin/ld-old
   1.109 +	mv /tools/bin/ld-new /tools/bin/ld
   1.110 +	ln -s /tools/bin/ld /tools/$(gcc -dumpmachine)/bin/ld
   1.111 +	gcc -dumpspecs | sed -e 's@/tools@@g' \
   1.112 +		-e '/\*startfile_prefix_spec:/{n;s@.*@/usr/lib/ @}' \
   1.113 +		-e '/\*cpp:/{n;s@$@ -isystem /usr/include@}' > \
   1.114 +		`dirname $(gcc --print-libgcc-file-name)`/specs
   1.115  }
   1.116  
   1.117  # Rules to gen a SliTaz package suitable for Tazpkg.
   1.118 @@ -41,10 +98,7 @@
   1.119  {
   1.120  	LOCALE=""
   1.121  	mkdir -p $fs/var
   1.122 -	for i in $(grep -l '^WANTED="glibc"' $WOK/*/receipt); do
   1.123 -		tazwok genpkg $(basename $(dirname $i))
   1.124 -	done
   1.125 -	echo ""
   1.126 -	echo "--> Install glibc-base, glibc-dev and cook busybox"
   1.127 -	echo ""
   1.128 +
   1.129 +	# Remove build directory.
   1.130 +	rm -r $WOK/$PACKAGE/$PACKAGE-build
   1.131  }
     2.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     2.2 +++ b/glibc/stuff/glibc-2.12.2-gcc_fix-1.patch	Thu Jan 27 00:20:50 2011 +0100
     2.3 @@ -0,0 +1,49 @@
     2.4 +Submitted By:            Matt Burgess <matthew_at_linuxfromscratch_dot_org>
     2.5 +Date:                    2010-04-18
     2.6 +Initial Package Version: 2.11.1
     2.7 +Upstream Status:         Not Submitted
     2.8 +Origin:                  http://www.eglibc.org/archives/patches/msg00073.html
     2.9 +Description:             Fixes the following build problem with GCC-4.5.0:
    2.10 +
    2.11 +/mnt/lfs/sources/libc-build/math/s_frexp.os.dt -MT /mnt/lfs/sources/libc-build/math/s_frexp.os
    2.12 +./sysdeps/i386/fpu/s_frexp.S: Assembler messages:
    2.13 +./sysdeps/i386/fpu/s_frexp.S:66: Error: invalid identifier for ".ifdef"
    2.14 +./sysdeps/i386/fpu/s_frexp.S:66: Error: junk at end of line, first unrecognized character is `1'
    2.15 +./sysdeps/i386/fpu/s_frexp.S:66: Error: junk at end of line, first unrecognized character is `1'
    2.16 +./sysdeps/i386/fpu/s_frexp.S:66: Error: junk at end of line, first unrecognized character is `1'
    2.17 +./sysdeps/i386/fpu/s_frexp.S:66: Error: junk at end of line, first unrecognized character is `.'
    2.18 +./sysdeps/i386/fpu/s_frexp.S:66: Error: junk at end of line, first unrecognized character is `1'
    2.19 +./sysdeps/i386/fpu/s_frexp.S:66: Error: expected comma after name `' in .size directive
    2.20 +./sysdeps/i386/fpu/s_frexp.S:66: Error: ".endif" without ".if"
    2.21 +./sysdeps/i386/fpu/s_frexp.S:66: Error: junk `.get_pc_thunk.dx' after expression
    2.22 +make[2]: *** [/mnt/lfs/sources/libc-build/math/s_frexp.os] Error 1
    2.23 +
    2.24 +diff -Naur glibc-2.11.1.orig/nptl/sysdeps/pthread/pt-initfini.c glibc-2.11.1/nptl/sysdeps/pthread/pt-initfini.c
    2.25 +--- glibc-2.11.1.orig/nptl/sysdeps/pthread/pt-initfini.c	2009-12-08 20:10:20.000000000 +0000
    2.26 ++++ glibc-2.11.1/nptl/sysdeps/pthread/pt-initfini.c	2010-04-17 11:34:06.882681001 +0000
    2.27 +@@ -45,6 +45,11 @@
    2.28 + /* Embed an #include to pull in the alignment and .end directives. */
    2.29 + asm ("\n#include \"defs.h\"");
    2.30 + 
    2.31 ++asm ("\n#if defined __i686 && defined __ASSEMBLER__");
    2.32 ++asm ("\n#undef __i686");
    2.33 ++asm ("\n#define __i686 __i686");
    2.34 ++asm ("\n#endif");
    2.35 ++
    2.36 + /* The initial common code ends here. */
    2.37 + asm ("\n/*@HEADER_ENDS*/");
    2.38 + 
    2.39 +diff -Naur glibc-2.11.1.orig/sysdeps/unix/sysv/linux/i386/sysdep.h glibc-2.11.1/sysdeps/unix/sysv/linux/i386/sysdep.h
    2.40 +--- glibc-2.11.1.orig/sysdeps/unix/sysv/linux/i386/sysdep.h	2009-12-08 20:10:20.000000000 +0000
    2.41 ++++ glibc-2.11.1/sysdeps/unix/sysv/linux/i386/sysdep.h	2010-04-17 11:34:06.882681001 +0000
    2.42 +@@ -29,6 +29,10 @@
    2.43 + #include <dl-sysdep.h>
    2.44 + #include <tls.h>
    2.45 + 
    2.46 ++#if defined __i686 && defined __ASSEMBLER__
    2.47 ++#undef __i686
    2.48 ++#define __i686 __i686
    2.49 ++#endif
    2.50 + 
    2.51 + /* For Linux we can use the system call table in the header file
    2.52 + 	/usr/include/asm/unistd.h