diff options
author | Travis Tilley <lv@gentoo.org> | 2004-10-28 05:48:26 +0000 |
---|---|---|
committer | Travis Tilley <lv@gentoo.org> | 2004-10-28 05:48:26 +0000 |
commit | 002be68571326ee1a5976a5cdfa5a536215d348e (patch) | |
tree | eb7b409f3e0d9d57db8eb9adcc27ccf0d56069ba /sys-libs | |
parent | Version bump (diff) | |
download | historical-002be68571326ee1a5976a5cdfa5a536215d348e.tar.gz historical-002be68571326ee1a5976a5cdfa5a536215d348e.tar.bz2 historical-002be68571326ee1a5976a5cdfa5a536215d348e.zip |
keyworded 2.3.4.10041021 as testing on amd64, x86, and ppc64. removed the 1006 snapshot due to bug 67603, which 1021 fixes.
Diffstat (limited to 'sys-libs')
-rw-r--r-- | sys-libs/glibc/ChangeLog | 7 | ||||
-rw-r--r-- | sys-libs/glibc/Manifest | 6 | ||||
-rw-r--r-- | sys-libs/glibc/files/digest-glibc-2.3.4.20041006 | 5 | ||||
-rw-r--r-- | sys-libs/glibc/glibc-2.3.4.20041006.ebuild | 883 | ||||
-rw-r--r-- | sys-libs/glibc/glibc-2.3.4.20041021.ebuild | 5 |
5 files changed, 10 insertions, 896 deletions
diff --git a/sys-libs/glibc/ChangeLog b/sys-libs/glibc/ChangeLog index e9b9aec52d58..2f74e8432d56 100644 --- a/sys-libs/glibc/ChangeLog +++ b/sys-libs/glibc/ChangeLog @@ -1,6 +1,11 @@ # ChangeLog for sys-libs/glibc # Copyright 2002-2004 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/sys-libs/glibc/ChangeLog,v 1.281 2004/10/27 03:37:23 lv Exp $ +# $Header: /var/cvsroot/gentoo-x86/sys-libs/glibc/ChangeLog,v 1.282 2004/10/28 05:48:26 lv Exp $ + + 27 Oct 2004; Travis Tilley <lv@gentoo.org> -glibc-2.3.4.20041006.ebuild, + glibc-2.3.4.20041021.ebuild: + keyworded 2.3.4.10041021 as testing on amd64, x86, and ppc64. removed the 1006 + snapshot due to bug 67603, which 1021 fixes. *glibc-2.3.4.20041021 (26 Oct 2004) diff --git a/sys-libs/glibc/Manifest b/sys-libs/glibc/Manifest index cc77d10dd600..d83ab209c60c 100644 --- a/sys-libs/glibc/Manifest +++ b/sys-libs/glibc/Manifest @@ -4,9 +4,8 @@ MD5 daf5c4924c0a0ccc6e55f7588b1b4d52 glibc-2.3.3.20040420-r2.ebuild 21765 MD5 af6f1491a70a6ee80e8d867d8ee0f98f glibc-2.3.4.20040619-r2.ebuild 20997 MD5 567094e03359ffc1c95af7356395228d metadata.xml 162 MD5 ac8cbd194b0e622f368f12f876f732a7 glibc-2.3.4.20040808-r1.ebuild 23089 -MD5 ac704370dea38856c98d18c9c46bcc2d ChangeLog 58369 -MD5 e0ec086f0af0cfe48f5d5914aeb0eea6 glibc-2.3.4.20041006.ebuild 25746 -MD5 b9b82909d160ca9bbc5ce1e695d0102f glibc-2.3.4.20041021.ebuild 25820 +MD5 ead771f0df321265f2f02c5390ffb42e ChangeLog 58604 +MD5 abc1a5d68569d59213a1e4124d28e5d9 glibc-2.3.4.20041021.ebuild 25805 MD5 9cc1e6b6f749dba7c8759bd07266f7d9 files/digest-glibc-2.2.5-r9 143 MD5 e4393f4721a207750581d6265d5f7f40 files/fix-sysctl_h.patch 376 MD5 52cfc7627fc62dfb26d8d163aac361f6 files/glibc-2.2.2-test-lfs-timeout.patch 320 @@ -26,7 +25,6 @@ MD5 42af7e35fe2404a49954f91fd1aee891 files/digest-glibc-2.3.3.20040420-r2 312 MD5 123d66ef523985c88c77af1ab1fc2d56 files/digest-glibc-2.3.4.20041021 383 MD5 470f57fe18dd0a94cb4a4d6cf51528af files/digest-glibc-2.3.4.20040619-r2 307 MD5 2f05d3181e9a9ded61e074147af47e8e files/digest-glibc-2.3.4.20040808-r1 382 -MD5 add6c542940ecab2c890d642760d974b files/digest-glibc-2.3.4.20041006 383 MD5 f75ebd335c4b882013cc12229d39c9f7 files/2.2.5/glibc-2.2.5-alpha-gcc3-fix.diff 475 MD5 843eaa26ae2c49e894aa365b6f463546 files/2.2.5/glibc-2.2.5-alpha-pcdyn-fix.diff 471 MD5 5182f441608833569cb9e78536baf8af files/2.2.5/glibc-2.2.5-arm-errlist-fix.diff 2210 diff --git a/sys-libs/glibc/files/digest-glibc-2.3.4.20041006 b/sys-libs/glibc/files/digest-glibc-2.3.4.20041006 deleted file mode 100644 index 0a47cb377ebf..000000000000 --- a/sys-libs/glibc/files/digest-glibc-2.3.4.20041006 +++ /dev/null @@ -1,5 +0,0 @@ -MD5 84dabbf0b9b5370793a416687d7b5252 glibc-2.3.3.tar.bz2 13298567 -MD5 2a138a32ffdb52fc1be54088d5d49420 glibc-manpages-2.3.4.tar.bz2 14759 -MD5 eabe1f4779fc27cde985b0713f930827 glibc-infopages-2.3.4.tar.bz2 1175502 -MD5 20cba284227f9ab99e504a88b3759f3c glibc-hppa-patches-2004-09-30.tar.gz 16407 -MD5 f6ba229100111e7015b4d94e4b876263 glibc-2.3.4-branch-update-20041006.patch.bz2 2728382 diff --git a/sys-libs/glibc/glibc-2.3.4.20041006.ebuild b/sys-libs/glibc/glibc-2.3.4.20041006.ebuild deleted file mode 100644 index 8104933c5e48..000000000000 --- a/sys-libs/glibc/glibc-2.3.4.20041006.ebuild +++ /dev/null @@ -1,883 +0,0 @@ -# Copyright 1999-2004 Gentoo Foundation -# Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/sys-libs/glibc/glibc-2.3.4.20041006.ebuild,v 1.8 2004/10/27 03:37:23 lv Exp $ - -inherit eutils flag-o-matic gcc - -# Branch update support. Following will disable: -# BRANCH_UPDATE= -BRANCH_UPDATE="20041006" - -# Minimum kernel version we support -# (Recent snapshots fails with 2.6.5 and earlier) -# also, we do not have a single 2.4 kernel in the tree with backported -# support required to enable nptl. -MIN_KERNEL_VERSION="2.6.5" - - -if [ -z "${BRANCH_UPDATE}" ]; then - BASE_PV="${NEW_PV}" - NEW_PV="${NEW_PV}" -else - BASE_PV="2.3.3" - NEW_PV="${PV%.*}" -fi - - -S="${WORKDIR}/${PN}-${BASE_PV}" -DESCRIPTION="GNU libc6 (also called glibc2) C library" -HOMEPAGE="http://sources.redhat.com/glibc/" - -HPPA_PATCHES=2004-09-30 - -SRC_URI="http://dev.gentoo.org/~lv/${PN}-${BASE_PV}.tar.bz2 - http://dev.gentoo.org/~lv/${PN}-manpages-${NEW_PV}.tar.bz2 - http://dev.gentoo.org/~lv/glibc-infopages-${NEW_PV}.tar.bz2 - hppa? ( http://parisc-linux.org/~carlos/glibc-work/glibc-hppa-patches-${HPPA_PATCHES}.tar.gz )" - -[ ! -z "${BRANCH_UPDATE}" ] && SRC_URI="${SRC_URI} - http://dev.gentoo.org/~lv/${PN}-${NEW_PV}-branch-update-${BRANCH_UPDATE}.patch.bz2" - -LICENSE="LGPL-2" -SLOT="2.2" -KEYWORDS="-* ~x86 ~amd64 -hppa ~ppc64 -ppc" -IUSE="nls pic build nptl nptlonly erandom hardened multilib debug userlocales" -RESTRICT="nostrip" # we'll handle stripping ourself #46186 - -# We need new cleanup attribute support from gcc for NPTL among things ... -# We also need linux26-headers if using NPTL. Including kernel headers is -# incredibly unreliable, and this new linux-headers release from plasmaroo -# should work with userspace apps, at least on amd64 and ppc64. -DEPEND=">=sys-devel/gcc-3.2.3-r1 - nptl? ( >=sys-devel/gcc-3.3.1-r1 ) - >=sys-devel/binutils-2.14.90.0.6-r1 - virtual/os-headers - nptl? ( >=sys-kernel/linux26-headers-2.6.5 ) - nls? ( sys-devel/gettext )" -RDEPEND="virtual/os-headers - sys-apps/baselayout - nls? ( sys-devel/gettext )" -# until we compile the 32bit glibc here -PDEPEND="amd64? ( multilib? ( app-emulation/emul-linux-x86-glibc ) )" - -PROVIDE="virtual/glibc virtual/libc" - - -# (very) Theoretical cross-compiler support -[ -z "${CCHOST}" ] && CCHOST="${CHOST}" - -# We need to be able to set alternative headers for compiling for non-native -# platforms. -# Will also become useful for testing kernel-headers without screwing up -# the whole system. -# note: intentionally undocumented. -[ -z "${ALT_HEADERS}" ] && ALT_HEADERS="${ROOT}/usr/include" - - -setup_flags() { - # Over-zealous CFLAGS can often cause problems. What may work for one person may not - # work for another. To avoid a large influx of bugs relating to failed builds, we - # strip most CFLAGS out to ensure as few problems as possible. - strip-flags - strip-unsupported-flags - - # -freorder-blocks for all but ppc - use ppc || append-flags "-freorder-blocks" - - # Sparc/Sparc64 support - if use sparc; then - # Both sparc and sparc64 can use -fcall-used-g6. -g7 is bad, though. - filter-flags "-fcall-used-g7" - append-flags "-fcall-used-g6" - - # Sparc64 Only support... - if [ "${PROFILE_ARCH}" = "sparc64" ]; then - # Get rid of -mcpu options (the CHOST will fix this up) and flags known to fail - filter-flags "-mcpu=ultrasparc -mcpu=v9 -mvis" - - # Setup the CHOST properly to insure "sparcv9" - # This passes -mcpu=ultrasparc -Wa,-Av9a to the compiler - if [ "${CHOST}" = "sparc-unknown-linux-gnu" ]; then - export CHOST="sparcv9-unknown-linux-gnu" - export CCHOST="sparcv9-unknown-linux-gnu" - fi - fi - fi - - if [ "`gcc-major-version`" -ge "3" -a "`gcc-minor-version`" -ge "4" ]; then - # broken in 3.4.x - replace-flags -march=pentium-m -mtune=pentium3 - fi - - if gcc -v 2>&1 | grep -q 'gcc version 3.[0123]'; then - append-flags -finline-limit=2000 - fi - - # We don't want these flags for glibc - filter-flags -fomit-frame-pointer -malign-double - filter-ldflags -pie - - # Lock glibc at -O2 -- linuxthreads needs it and we want to be conservative here - append-flags -O2 - export LDFLAGS="${LDFLAGS//-Wl,--relax}" -} - - -check_kheader_version() { - local header="${ALT_HEADERS}/linux/version.h" - - [ -z "$1" ] && return 1 - - if [ -f "${header}" ]; then - local version="`grep 'LINUX_VERSION_CODE' ${header} | \ - sed -e 's:^.*LINUX_VERSION_CODE[[:space:]]*::'`" - - if [ "${version}" -ge "$1" ]; then - return 0 - fi - fi - - return 1 -} - - -check_nptl_support() { - local min_kernel_version="$(KV_to_int "${MIN_KERNEL_VERSION}")" - - echo - - einfon "Checking gcc for __thread support ... " - if ! gcc -c ${FILESDIR}/test-__thread.c -o ${T}/test2.o &> /dev/null; then - echo "no" - echo - eerror "Could not find a gcc that supports the __thread directive!" - eerror "please update to gcc-3.2.2-r1 or later, and try again." - die "No __thread support in gcc!" - else - echo "yes" - fi - - # Building fails on an non-supporting kernel - einfon "Checking kernel version (>=${MIN_KERNEL_VERSION}) ... " - if [ "`get_KV`" -lt "${min_kernel_version}" ]; then - echo "no" - echo - eerror "You need a kernel of at least version ${MIN_KERNEL_VERSION}" - eerror "for NPTL support!" - die "Kernel version too low!" - else - echo "yes" - fi - - # Building fails with too low linux-headers - einfon "Checking linux-headers version (>=${MIN_KERNEL_VERSION}) ... " - if ! check_kheader_version "${min_kernel_version}"; then - echo "no" - echo - eerror "You need linux-headers of at least version ${MIN_KERNEL_VERSION}" - eerror "for NPTL support!" - die "linux-headers version too low!" - else - echo "yes" - fi - - echo -} - - -want_nptl() { - if use nptl || use nptlonly ; then - # Archs that can use NPTL - if use amd64 || use ia64 || use ppc || \ - use ppc64 || use s390 || use sparc; then - return 0 - fi - - # Specific x86 CHOSTS that can use NPTL - if use x86; then - case "${CHOST/-*}" in - i486|i586|i686) return 0 ;; - esac - fi - fi - - return 1 -} - - -want_tls() { - # Archs that can use TLS (Thread Local Storage) - if use amd64 || use alpha || use ia64 || use ppc || \ - use ppc64 || use s390 || use sparc; then - return 0 - fi - - # Specific x86 CHOSTS that can use TLS - if use x86; then - case "${CHOST/-*}" in - i486|i586|i686) return 0 ;; - esac - - fi - - return 1 -} - - -do_makecheck() { - ATIME=`mount | awk '{ print $3,$6 }' | grep ^\/\ | grep noatime` - if [ "$ATIME" = "" ]; then - cd ${WORKDIR}/${MYMAINBUILDDIR} - make check || die - else - ewarn "remounting / without noatime option so that make check" - ewarn "does not fail!" - epause 2 - mount / -o remount,atime - cd ${WORKDIR}/${MYMAINBUILDDIR} - make check || die - einfo "remounting / with noatime" - mount / -o remount,noatime - fi -} - - -install_locales() { - unset LANGUAGE LANG LC_ALL - cd ${WORKDIR}/${MYMAINBUILDDIR} || die "${WORKDIR}/${MYMAINBUILDDIR}" - make PARALLELMFLAGS="${MAKEOPTS}" \ - install_root=${D} localedata/install-locales || die - keepdir /usr/lib/locale/ru_RU/LC_MESSAGES -} - - -setup_locales() { - if use !userlocales ; then - einfo "userlocales not enabled, installing -ALL- locales..." - install_locales || die - elif [ -e /etc/locales.build ]; then - einfo "Installing locales in /etc/locales.build..." - echo 'SUPPORTED-LOCALES=\' > SUPPORTED.locales - cat /etc/locales.build | grep -v -e ^$ -e ^\# | sed 's/$/\ \\/g' \ - >> SUPPORTED.locales - cat SUPPORTED.locales > ${S}/localedata/SUPPORTED || die - install_locales || die - elif [ -e ${FILESDIR}/locales.build ]; then - einfo "Installing locales in ${FILESDIR}/locales.build..." - echo 'SUPPORTED-LOCALES=\' > SUPPORTED.locales - cat ${FILESDIR}/locales.build | grep -v -e ^$ -e ^\# | sed 's/$/\ \\/g' \ - >> SUPPORTED.locales - cat SUPPORTED.locales > ${S}/localedata/SUPPORTED || die - install_locales || die - else - einfo "Installing -ALL- locales..." - install_locales || die - fi -} - - -pkg_setup() { - # give some sort of warning about the nptl logic changes... - if want_nptl && use !nptlonly ; then - ewarn "Warning! Gentoo's GLIBC with NPTL enabled now behaves like the" - ewarn "glibc from almost every other distribution out there. This means" - ewarn "that glibc is compiled -twice-, once with linuxthreads and once" - ewarn "with nptl. The NPTL version is installed to lib/tls and is still" - ewarn "used by default. If you do not need nor want the linuxthreads" - ewarn "fallback, you can disable this behavior by adding nptlonly to" - ewarn "USE to save yourself some compile time." - ebeep - epause - fi -} - - -do_arch_amd64_patches() { - cd ${S}; - # CONF_LIBDIR support - epatch ${FILESDIR}/2.3.4/glibc-gentoo-libdir.patch - sed -i -e "s:@GENTOO_LIBDIR@:$(get_libdir):g" ${S}/sysdeps/unix/sysv/linux/configure -} - - -do_arch_alpha_patches() { - cd ${S} - - # Fix compatability with compaq compilers by ifdef'ing out some - # 2.3.2 additions. - # <taviso@gentoo.org> (14 Jun 2003). - epatch ${FILESDIR}/2.3.2/${PN}-2.3.2-decc-compaq.patch - - # Fix compilation with >=gcc-3.2.3 (01 Nov 2003 agriffis) -# epatch ${FILESDIR}/2.3.2/${LOCAL_P}-alpha-pwrite.patch -} - - -do_arch_arm_patches() { - cd ${S}; - - # Any needed patches for arm go here - epatch ${FILESDIR}/2.3.4/${PN}-2.3.4-arm-ioperm.patch -} - - -do_arch_hppa_patches() { - einfo "Applying hppa specific path of ${HPPA_PATCHES} ..." - cd ${T} - unpack glibc-hppa-patches-${HPPA_PATCHES}.tar.gz - cd ${S} - export EPATCH_OPTS=-p1 - for i in ${T}/glibc-hppa-patches-${HPPA_PATCHES}/*.diff - do - epatch ${i} - done - - unset EPATCH_OPTS - - use hardened && epatch ${FILESDIR}/2.3.4/glibc-2.3.4-hppa-hardened-disable__init_arrays.patch - - einfo "Done with hppa patches." - -} - - -do_arch_ia64_patches() { - cd ${S}; - - # The basically problem is glibc doesn't store information about - # what the kernel interface is so that it can't efficiently set up - # parameters for system calls. This patch from H.J. Lu fixes it: - # - # http://sources.redhat.com/ml/libc-alpha/2003-09/msg00165.html - -# epatch ${FILESDIR}/2.3.2/${LOCAL_P}-ia64-LOAD_ARGS-fixup.patch -} - - -do_arch_mips_patches() { - cd ${S} - - # A few patches only for the MIPS platform. Descriptions of what they - # do can be found in the patch headers. - # <tuxus@gentoo.org> thx <dragon@gentoo.org> (11 Jan 2003) - # <kumba@gentoo.org> remove tst-rndseek-mips & ulps-mips patches - # <iluxa@gentoo.org> add n32/n64 patches, remove pread patch - epatch ${FILESDIR}/2.3.3/mips-addabi.diff - epatch ${FILESDIR}/2.3.3/mips-syscall.h.diff - epatch ${FILESDIR}/2.3.3/mips-sysify.diff - - # Need to install into /lib for n32-only userland for now. - # Propper solution is to make all userland /lib{32|64}-aware. - use multilib || epatch ${FILESDIR}/2.3.3/mips-nolib3264.diff -} - - -do_arch_ppc_patches() { - cd ${S}; - # Any needed patches for ppc go here -} - - -do_arch_ppc64_patches() { - cd ${S}; - # Any needed patches for ppc64 go here -} - - -do_arch_s390_patches() { - cd ${S}; - - # Any needed patches for s390 go here -} - - -do_arch_sparc_patches() { - cd ${S}; - - # Any needed patches for sparc go here -} - - -do_arch_x86_patches() { - cd ${S}; - # CONF_LIBDIR support - epatch ${FILESDIR}/2.3.4/glibc-gentoo-libdir.patch - sed -i -e "s:@GENTOO_LIBDIR@:$(get_libdir):g" ${S}/sysdeps/unix/sysv/linux/configure -} - - -do_pax_patches() { - cd ${S} - - # localedef contains nested function trampolines, which trigger - # segfaults under PaX -solar - # Debian Bug (#231438, #198099) - #epatch ${FILESDIR}/2.3.3/glibc-2.3.3-localedef-fix-trampoline.patch - # with the redhat patch included, the above is no longer needed. - - # With latest versions of glibc, a lot of apps failed on a PaX enabled - # system with: - # - # cannot enable executable stack as shared object requires: Permission denied - # - # This is due to PaX 'exec-protecting' the stack, and ld.so then trying - # to make the stack executable due to some libraries not containing the - # PT_GNU_STACK section. Bug #32960. <azarah@gentoo.org> (12 Nov 2003). - use mips || epatch ${FILESDIR}/2.3.4/${PN}-2.3.4-dl_execstack-PaX-support.patch - - # Program header support for PaX. - epatch ${FILESDIR}/2.3.3/${PN}-2.3.3_pre20040117-pt_pax.diff - - # Suppress unresolvable relocation against symbol `main' in Scrt1.o - # can be reproduced with compiling net-dns/bind-9.2.2-r3 using -pie - epatch ${FILESDIR}/2.3.4/glibc-2.3.4.20040808-i386-got-fix.diff -} - - -do_hardened_fixes() { - # this patch is needed to compile nptl with a hardened gcc - has_hardened && want_nptl && \ - epatch ${FILESDIR}/2.3.4/glibc-2.3.4-hardened-sysdep-shared.patch -} - - -do_ssp_patches() { - # To circumvent problems with propolice __guard and - # __guard_setup__stack_smash_handler - # - # http://www.gentoo.org/proj/en/hardened/etdyn-ssp.xml - if [ "${ARCH}" != "hppa" ] && [ "${ARCH}" != "hppa64" ]; then - epatch ${FILESDIR}/2.3.3/glibc-2.3.2-propolice-guard-functions-v3.patch - cp ${FILESDIR}/2.3.3/ssp.c ${S}/sysdeps/unix/sysv/linux || \ - die "failed to copy ssp.c to ${S}/sysdeps/unix/sysv/linux/" - fi - - # patch this regardless of architecture, although it's ssp-related - epatch ${FILESDIR}/2.3.3/glibc-2.3.3-frandom-detect.patch -} - - -do_fedora_patches() { - pushd ${S} > /dev/null - - # go team ramdom nptl stuff - want_nptl && epatch ${S}/fedora/glibc-nptl-check.patch - - #(use x86 || use alpha || use sparc) || rm -rf glibc-compat - rm -f sysdeps/alpha/alphaev6/memcpy.S - find . -type f -size 0 -o -name "*.orig" -exec rm -f {} \; - touch `find . -name configure` - - # If gcc supports __thread, test it even in --with-tls --without-__thread - # builds. - if echo '__thread int a;' | $GCC -xc - -S -o /dev/null 2>/dev/null; then - sed -i -e 's~0 ||~1 ||~' ./elf/tst-tls10.h ./linuxthreads/tst-tls1.h - fi - - popd > /dev/null -} - -src_unpack() { - # Check NPTL support _before_ we unpack things to save some time - want_nptl && check_nptl_support - - unpack ${PN}-${BASE_PV}.tar.bz2 - - # Extract pre-made man pages. - # Otherwise we need perl, which is bad (especially for stage1 bootstrap) - mkdir -p ${S}/man - cd ${S}/man - unpack ${PN}-manpages-${NEW_PV}.tar.bz2 - cd ${S} - - if [ -n "${BRANCH_UPDATE}" ]; then - epatch ${DISTDIR}/${PN}-${NEW_PV}-branch-update-${BRANCH_UPDATE}.patch.bz2 - - # Snapshot date patch - einfo "Patching version to display snapshot date ..." - sed -i -e "s:\(#define RELEASE\).*:\1 \"${BRANCH_UPDATE}\":" version.h - fi - # Version patch - sed -i -e "s:\(#define VERSION\).*:\1 \"${NEW_PV}\":" version.h - - # pre-generated info pages - unpack glibc-infopages-2.3.4.tar.bz2 - - # redhat stuffs - do_fedora_patches - - # SSP support in glibc (where it belongs) - do_ssp_patches - - # PaX-related Patches - do_pax_patches - - # disable binutils -as-needed - sed -e 's/^have-as-needed.*/have-as-needed = no/' -i ${S}/config.make.in - - # hardened toolchain/relro/nptl/security/etc fixes - do_hardened_fixes - - - # Arch specific patching - use amd64 && do_arch_amd64_patches - use alpha && do_arch_alpha_patches - use arm && do_arch_arm_patches - use hppa && do_arch_hppa_patches - use ia64 && do_arch_ia64_patches - use mips && do_arch_mips_patches - use ppc && do_arch_ppc_patches - use ppc64 && do_arch_ppc64_patches - use s390 && do_arch_s390_patches - use sparc && do_arch_sparc_patches - use x86 && do_arch_x86_patches - - - # Remaining patches - cd ${S} - epatch ${FILESDIR}/2.3.4/glibc-sec-hotfix-20040916.patch - - # multicast DNS aka rendezvous support - epatch ${FILESDIR}/2.3.4/glibc-2.3.3-mdns-resolver.diff - - # Improved handled temporary files. bug #66358 - epatch ${FILESDIR}/2.3.3/${PN}-2.3.3-tempfile.patch - - # Fix permissions on some of the scripts - chmod u+x ${S}/scripts/*.sh -} - - -glibc_do_configure() { - local myconf - - setup_flags - - # These should not be set, else the - # zoneinfo do not always get installed ... - unset LANGUAGE LANG LC_ALL - # silly users - unset LD_RUN_PATH - - # set addons - pushd ${S} > /dev/null - ADDONS=$(echo */configure | sed -e 's!/configure!!g;s!\(linuxthreads\|nptl\|rtkaio\)\( \|$\)!!g;s! \+$!!;s! !,!g;s!^!,!;/^,\*$/d') - popd > /dev/null - - use nls || myconf="${myconf} --disable-nls" - use erandom || myconf="${myconf} --disable-dev-erandom" - - if [ "$1" == "linuxthreads" ] ; then - want_tls && myconf="${myconf} --with-tls --without-__thread" - want_tls || myconf="${myconf} --without-tls --without-__thread" - myconf="${myconf} --enable-add-ons=linuxthreads${ADDONS}" - myconf="${myconf} --enable-kernel=2.4.1" - elif [ "$1" == "nptl" ] ; then - want_nptl && myconf="${myconf} --with-tls --with-__thread" - myconf="${myconf} --enable-add-ons=nptl${ADDONS}" - myconf="${myconf} --enable-kernel=${MIN_KERNEL_VERSION}" - else - die "invalid pthread option" - fi - - myconf="${myconf} --without-cvs - --enable-bind-now - --build=${CHOST} - --host=${CCHOST} - --disable-profile - --without-gd - --with-headers=${ALT_HEADERS} - --prefix=/usr - --mandir=/usr/share/man - --infodir=/usr/share/info - --libexecdir=/usr/lib/misc" - - GBUILDDIR="${WORKDIR}/build-${CCHOST}-$1" - rm -rf ${GBUILDDIR} - mkdir -p ${GBUILDDIR} - cd ${GBUILDDIR} - einfo "Configuring GLIBC for $1 with: ${myconf}" - ${S}/configure ${myconf} || die "failed to configure glibc" -} - - -src_compile() { - # do the linuxthreads build unless we're using nptlonly - if use !nptlonly ; then - glibc_do_configure linuxthreads - einfo "Building GLIBC with linuxthreads..." - make PARALLELMFLAGS="${MAKEOPTS}" || die - fi - if want_nptl ; then - # ...and then do the optional nptl build - unset LD_ASSUME_KERNEL || : - glibc_do_configure nptl - einfo "Building GLIBC with NPTL..." - make PARALLELMFLAGS="${MAKEOPTS}" || die - fi -} - -src_install() { - setup_flags - - # These should not be set, else the - # zoneinfo do not always get installed ... - unset LANGUAGE LANG LC_ALL - - if use nptlonly ; then - MYMAINBUILDDIR=build-${CCHOST}-nptl - else - MYMAINBUILDDIR=build-${CCHOST}-linuxthreads - fi - - if use !nptlonly ; then - cd ${WORKDIR}/build-${CCHOST}-linuxthreads - einfo "Installing GLIBC with linuxthreads..." - make PARALLELMFLAGS="${MAKEOPTS}" \ - install_root=${D} \ - install || die - elif use nptlonly ; then - cd ${WORKDIR}/build-${CCHOST}-nptl - einfo "Installing GLIBC with NPTL..." - make PARALLELMFLAGS="${MAKEOPTS}" \ - install_root=${D} \ - install || die - fi - - if use !nptlonly && want_nptl ; then - einfo "Installing NPTL to $(get_libdir)/tls/..." - cd ${WORKDIR}/build-${CCHOST}-nptl - mkdir -p ${D}/$(get_libdir)/tls/ - - libcsofile=$(basename ${D}/$(get_libdir)/libc-*.so) - cp -a libc.so ${D}/$(get_libdir)/tls/${libcsofile} || die - dosym ${libcsofile} /$(get_libdir)/tls/$(ls libc.so.*) - - libmsofile=$(basename ${D}/$(get_libdir)/libm-*.so) - pushd math > /dev/null - cp -a libm.so ${D}/$(get_libdir)/tls/${libmsofile} || die - dosym ${libmsofile} /$(get_libdir)/tls/$(ls libm.so.*) - popd > /dev/null - - librtsofile=$(basename ${D}/$(get_libdir)/librt-*.so) - pushd rt > /dev/null - cp -a librt.so ${D}/$(get_libdir)/tls/${librtsofile} || die - dosym ${librtsofile} /$(get_libdir)/tls/$(ls librt.so.*) - popd > /dev/null - - libthreaddbsofile=$(basename ${D}/$(get_libdir)/libthread_db-*.so) - pushd nptl_db > /dev/null - cp -a libthread_db.so ${D}/$(get_libdir)/tls/${libthreaddbsofile} || die - dosym ${libthreaddbsofile} /$(get_libdir)/tls/$(ls libthread_db.so.*) - popd > /dev/null - - libpthreadsofile=libpthread-${NEW_PV}.so - cp -a nptl/libpthread.so ${D}/$(get_libdir)/tls/${libpthreadsofile} || die - dosym ${libpthreadsofile} /$(get_libdir)/tls/libpthread.so.0 - - # and now for the static libs - mkdir -p ${D}/usr/$(get_libdir)/nptl - cp -a libc.a nptl/libpthread.a nptl/libpthread_nonshared.a rt/librt.a \ - ${D}/usr/$(get_libdir)/nptl - # linker script crap - sed "s~/$(get_libdir)/~/$(get_libdir)/tls/~" ${D}/usr/$(get_libdir)/libc.so \ - > ${D}/usr/$(get_libdir)/nptl/libc.so - - sed "s~/$(get_libdir)/~/$(get_libdir)/tls/~" ${D}/usr/$(get_libdir)/libpthread.so \ - > ${D}/usr/$(get_libdir)/nptl/libpthread.so - sed -i -e "s~/usr/lib64/~/usr/lib64/nptl/~" ${D}/usr/$(get_libdir)/nptl/libpthread.so - - dosym ../${librtsofile} /usr/$(get_libdir)/nptl/librt.so - - # last but not least... headers. - mkdir -p ${D}/nptl ${D}/usr/include/nptl - make install_root=${D}/nptl install-headers PARALLELMFLAGS="${MAKEOPTS}" - pushd ${D}/nptl/usr/include > /dev/null - for i in `find . -type f`; do - if ! [ -f ${D}/usr/include/$i ] \ - || ! cmp -s $i ${D}/usr/include/$i; then - mkdir -p ${D}/usr/include/nptl/`dirname $i` - cp -a $i ${D}/usr/include/nptl/$i - fi - done - rm -rf ${D}/nptl - fi - - # now, strip everything but the thread libs #46186 - mkdir -p ${T}/thread-backup - mv ${D}/$(get_libdir)/lib{pthread,thread_db}* ${T}/thread-backup/ - if use !nptlonly && want_nptl ; then - mkdir -p ${T}/thread-backup/tls - mv ${D}/$(get_libdir)/tls/lib{pthread,thread_db}* ${T}/thread-backup/tls - fi - env -uRESTRICT prepallstrip - cp -R -- ${T}/thread-backup/* ${D}/$(get_libdir)/ || die - - # If librt.so is a symlink, change it into linker script (Redhat) - if [ -L "${D}/usr/$(get_libdir)/librt.so" -a "${LIBRT_LINKERSCRIPT}" = "yes" ]; then - local LIBRTSO="`cd ${D}/$(get_libdir); echo librt.so.*`" - local LIBPTHREADSO="`cd ${D}/$(get_libdir); echo libpthread.so.*`" - - rm -f ${D}/usr/$(get_libdir)/librt.so - cat > ${D}/usr/$(get_libdir)/librt.so <<EOF -/* GNU ld script - librt.so.1 needs libpthread.so.0 to come before libc.so.6* - in search scope. */ -EOF - grep "OUTPUT_FORMAT" ${D}/usr/$(get_libdir)/libc.so >> ${D}/usr/$(get_libdir)/librt.so - echo "GROUP ( /$(get_libdir)/${LIBPTHREADSO} /$(get_libdir)/${LIBRTSO} )" \ - >> ${D}/usr/$(get_libdir)/librt.so - - for x in ${D}/usr/$(get_libdir)/librt.so.[1-9]; do - [ -L "${x}" ] && rm -f ${x} - done - fi - - if ! use build; then - cd ${WORKDIR}/${MYMAINBUILDDIR} - - if ! has noinfo ${FEATURES} ; then - einfo "Installing Info pages..." - make PARALLELMFLAGS="${MAKEOPTS}" \ - install_root=${D} \ - info -i - fi - - setup_locales - - einfo "Installing man pages and docs..." - # Install linuxthreads man pages even if nptl is enabled - dodir /usr/share/man/man3 - doman ${S}/man/*.3thr - - # Install nscd config file - insinto /etc ; doins ${FILESDIR}/nscd.conf - exeinto /etc/init.d ; doexe ${FILESDIR}/nscd - - cd ${S} - dodoc BUGS ChangeLog* CONFORMANCE FAQ INTERFACE \ - NEWS NOTES PROJECTS README* - else - rm -rf ${D}/usr/share ${D}/usr/$(get_libdir)/gconv - - einfo "Installing Timezone data..." - cd ${WORKDIR}/${MYMAINBUILDDIR} - make PARALLELMFLAGS="${MAKEOPTS}" \ - install_root=${D} \ - timezone/install-others || die - fi - - if use pic && ! use amd64 ; then - find ${S}/${buildtarget}/ -name "soinit.os" -exec cp {} ${D}/lib/soinit.o \; - find ${S}/${buildtarget}/ -name "sofini.os" -exec cp {} ${D}/lib/sofini.o \; - find ${S}/${buildtarget}/ -name "*_pic.a" -exec cp {} ${D}/lib \; - find ${S}/${buildtarget}/ -name "*.map" -exec cp {} ${D}/lib \; - - for i in ${D}/lib/*.map; do - mv ${i} ${i%.map}_pic.map - done - fi - - # Is this next line actually needed or does the makefile get it right? - # It previously has 0755 perms which was killing things. - fperms 4711 /usr/lib/misc/pt_chown - - rm -f ${D}/etc/ld.so.cache - - # Prevent overwriting of the /etc/localtime symlink. We'll handle the - # creation of the "factory" symlink in pkg_postinst(). - rm -f ${D}/etc/localtime - - # Some things want this, notably ash. - dosym /usr/lib/libbsd-compat.a /usr/lib/libbsd.a - - # This is our new config file for building locales - insinto /etc - doins ${FILESDIR}/locales.build - - must_exist /$(get_libdir)/ libpthread.so.0 -} - -must_exist() { - test -e ${D}/${1}/${2} || die "${1}/${2} was not installed" -} - -fix_lib64_symlinks() { - # the original Gentoo/AMD64 devs decided that since 64bit is the native - # bitdepth for AMD64, lib should be used for 64bit libraries. however, - # this ignores the FHS and breaks multilib horribly... especially - # since it wont even work without a lib64 symlink anyways. *rolls eyes* - # see bug 59710 for more information. - # Travis Tilley <lv@gentoo.org> (08 Aug 2004) - if [ -L ${ROOT}/lib64 ] ; then - ewarn "removing /lib64 symlink and moving lib to lib64..." - ewarn "dont hit ctrl-c until this is done" - addwrite ${ROOT}/ - rm ${ROOT}/lib64 - # now that lib64 is gone, nothing will run without calling ld.so - # directly. luckily the window of brokenness is almost non-existant - /lib/ld-linux-x86-64.so.2 /bin/mv ${ROOT}/lib ${ROOT}/lib64 - # all better :) - ldconfig - ln -s lib64 ${ROOT}/lib - einfo "done! :-)" - einfo "fixed broken lib64/lib symlink in ${ROOT}" - fi - if [ -L ${ROOT}/usr/lib64 ] ; then - addwrite ${ROOT}/usr - rm ${ROOT}/usr/lib64 - mv ${ROOT}/usr/lib ${ROOT}/usr/lib64 - ln -s lib64 ${ROOT}/usr/lib - einfo "fixed broken lib64/lib symlink in ${ROOT}/usr" - fi - if [ -L ${ROOT}/usr/X11R6/lib64 ] ; then - addwrite ${ROOT}/usr/X11R6 - rm ${ROOT}/usr/X11R6/lib64 - mv ${ROOT}/usr/X11R6/lib ${ROOT}/usr/X11R6/lib64 - ln -s lib64 ${ROOT}/usr/X11R6/lib - einfo "fixed broken lib64/lib symlink in ${ROOT}/usr/X11R6" - fi -} - -pkg_preinst() { - # PPC64+others may want to eventually be added to this logic if they - # decide to be multilib compatible and FHS compliant. note that this - # chunk of FHS compliance only applies to 64bit archs where 32bit - # compatibility is a major concern (not IA64, for example). - use amd64 && [ "$(get_libdir)" == "lib64" ] && fix_lib64_symlinks -} - -pkg_postinst() { - # Correct me if I am wrong here, but my /etc/localtime is a file - # created by zic .... - # I am thinking that it should only be recreated if no /etc/localtime - # exists, or if it is an invalid symlink. - # - # For invalid symlink: - # -f && -e will fail - # -L will succeed - # - if [ ! -e "${ROOT}/etc/localtime" ]; then - echo "Please remember to set your timezone using the zic command." - rm -f ${ROOT}/etc/localtime - ln -s ../usr/share/zoneinfo/Factory ${ROOT}/etc/localtime - fi - - if [ -x "${ROOT}/usr/sbin/iconvconfig" ]; then - # Generate fastloading iconv module configuration file. - ${ROOT}/usr/sbin/iconvconfig --prefix=${ROOT} - fi - - if [ ! -e "${ROOT}/ld.so.1" ] && use ppc64 - then - pushd ${ROOT} - cd ${ROOT}/lib - ln -s ld64.so.1 ld.so.1 - popd - fi - - # Reload init ... - if [ "${ROOT}" = "/" ]; then - /sbin/init U &> /dev/null - fi -} diff --git a/sys-libs/glibc/glibc-2.3.4.20041021.ebuild b/sys-libs/glibc/glibc-2.3.4.20041021.ebuild index f1b9ad529c3f..1327fe2128c7 100644 --- a/sys-libs/glibc/glibc-2.3.4.20041021.ebuild +++ b/sys-libs/glibc/glibc-2.3.4.20041021.ebuild @@ -1,6 +1,6 @@ # Copyright 1999-2004 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/sys-libs/glibc/glibc-2.3.4.20041021.ebuild,v 1.1 2004/10/27 03:37:23 lv Exp $ +# $Header: /var/cvsroot/gentoo-x86/sys-libs/glibc/glibc-2.3.4.20041021.ebuild,v 1.2 2004/10/28 05:48:26 lv Exp $ inherit eutils flag-o-matic gcc @@ -40,8 +40,7 @@ SRC_URI="http://dev.gentoo.org/~lv/${PN}-${BASE_PV}.tar.bz2 LICENSE="LGPL-2" SLOT="2.2" -#KEYWORDS="-* ~x86 ~amd64 -hppa ~ppc64 -ppc" -KEYWORDS="-*" +KEYWORDS="-* ~x86 ~amd64 -hppa ~ppc64 -ppc" IUSE="nls pic build nptl nptlonly erandom hardened multilib debug userlocales" RESTRICT="nostrip" # we'll handle stripping ourself #46186 |