diff options
author | Travis Tilley <lv@gentoo.org> | 2004-11-05 02:56:41 +0000 |
---|---|---|
committer | Travis Tilley <lv@gentoo.org> | 2004-11-05 02:56:41 +0000 |
commit | af79179f1932564f9a9226c8edd5b9d668b40527 (patch) | |
tree | 836635ff17919f86b3a58b889577ccfc105a498d /sys-libs | |
parent | Using the toolchain-funcs eclass for handling the detection of CC version, ra... (diff) | |
download | historical-af79179f1932564f9a9226c8edd5b9d668b40527.tar.gz historical-af79179f1932564f9a9226c8edd5b9d668b40527.tar.bz2 historical-af79179f1932564f9a9226c8edd5b9d668b40527.zip |
fedora-branch update. converted version checks to versionator.eclass. moved all instances of CCHOST over to CTARGET. added the ability to disable the malloc check at build-time with USE=nomalloccheck. remove /$(get_libdir)/tls/ in preinst if migrating from nptl to nptlonly (bug 69258)
Diffstat (limited to 'sys-libs')
-rw-r--r-- | sys-libs/glibc/ChangeLog | 15 | ||||
-rw-r--r-- | sys-libs/glibc/Manifest | 25 | ||||
-rw-r--r-- | sys-libs/glibc/files/2.3.4/glibc-2.3.4-features-header-fix.patch | 11 | ||||
-rw-r--r-- | sys-libs/glibc/files/2.3.4/glibc-2.3.4-fedora-branch-nomalloccheck.patch | 11 | ||||
-rw-r--r-- | sys-libs/glibc/files/2.3.4/glibc-2.3.4-mdns-resolver-20041102.diff | 463 | ||||
-rw-r--r-- | sys-libs/glibc/files/digest-glibc-2.3.4.20041102 | 5 | ||||
-rw-r--r-- | sys-libs/glibc/glibc-2.3.4.20041102.ebuild | 900 |
7 files changed, 1419 insertions, 11 deletions
diff --git a/sys-libs/glibc/ChangeLog b/sys-libs/glibc/ChangeLog index 1e0ffdfbf549..08ad1437f858 100644 --- a/sys-libs/glibc/ChangeLog +++ b/sys-libs/glibc/ChangeLog @@ -1,6 +1,19 @@ # 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.285 2004/10/31 15:51:47 tgall Exp $ +# $Header: /var/cvsroot/gentoo-x86/sys-libs/glibc/ChangeLog,v 1.286 2004/11/05 02:56:41 lv Exp $ + +*glibc-2.3.4.20041102 (04 Nov 2004) + + 04 Nov 2004; Travis Tilley <lv@gentoo.org> + +files/2.3.4/glibc-2.3.4-features-header-fix.patch, + +files/2.3.4/glibc-2.3.4-fedora-branch-nomalloccheck.patch, + +files/2.3.4/glibc-2.3.4-mdns-resolver-20041102.diff, + +glibc-2.3.4.20041102.ebuild: + fedora-branch update. converted version checks to versionator.eclass. moved + all instances of CCHOST over to CTARGET. added the ability to disable the + malloc check at build-time with USE=nomalloccheck. remove + /$(get_libdir)/tls/ in preinst if migrating from nptl to nptlonly (bug + 69258) 31 Oct 2004; Tom Gall <tgall@gentoo.org> glibc-2.3.4.20041021.ebuild: build fix for ppc64 diff --git a/sys-libs/glibc/Manifest b/sys-libs/glibc/Manifest index 74793585930d..54e340e59619 100644 --- a/sys-libs/glibc/Manifest +++ b/sys-libs/glibc/Manifest @@ -1,16 +1,13 @@ -MD5 315287a8b43c0bdce7b51bf92ef33d08 ChangeLog 59174 MD5 7cf88dee2671dcc30659d07241b8d918 glibc-2.2.5-r9.ebuild 10915 +MD5 3603fa6448052edcf78a329d10746461 glibc-2.3.2-r12.ebuild 20530 MD5 daf5c4924c0a0ccc6e55f7588b1b4d52 glibc-2.3.3.20040420-r2.ebuild 21765 MD5 af6f1491a70a6ee80e8d867d8ee0f98f glibc-2.3.4.20040619-r2.ebuild 20997 -MD5 3603fa6448052edcf78a329d10746461 glibc-2.3.2-r12.ebuild 20530 MD5 567094e03359ffc1c95af7356395228d metadata.xml 162 MD5 ac8cbd194b0e622f368f12f876f732a7 glibc-2.3.4.20040808-r1.ebuild 23089 +MD5 3419b759a4f1870619e56c44ce1b3509 ChangeLog 59754 MD5 a5f6f51d7ac26314a1b29e3231b88abe glibc-2.3.4.20041021.ebuild 26793 +MD5 a960e55a7f79cfc7a14d7aafecab7388 glibc-2.3.4.20041102.ebuild 26533 MD5 9cc1e6b6f749dba7c8759bd07266f7d9 files/digest-glibc-2.2.5-r9 143 -MD5 42af7e35fe2404a49954f91fd1aee891 files/digest-glibc-2.3.3.20040420-r2 312 -MD5 470f57fe18dd0a94cb4a4d6cf51528af files/digest-glibc-2.3.4.20040619-r2 307 -MD5 2f05d3181e9a9ded61e074147af47e8e files/digest-glibc-2.3.4.20040808-r1 382 -MD5 2d5306ef875573750af642a9f93b634a files/digest-glibc-2.3.2-r12 312 MD5 e4393f4721a207750581d6265d5f7f40 files/fix-sysctl_h.patch 376 MD5 52cfc7627fc62dfb26d8d163aac361f6 files/glibc-2.2.2-test-lfs-timeout.patch 320 MD5 135f8145885a2f4f9876fe973f33ddf6 files/glibc-2.2.4-string2.h.diff 5221 @@ -24,7 +21,12 @@ MD5 bedcd868a9462009158714238594173c files/nscd 964 MD5 2013443f5192d4b999953ba4248d288c files/nscd.conf 1158 MD5 d8830438ea871dbfd1acf7a3d0299159 files/test-__thread.c 53 MD5 4404ee4b6e3017819d8f36082e0265e5 files/test-sysctl_h.c 54 +MD5 2d5306ef875573750af642a9f93b634a files/digest-glibc-2.3.2-r12 312 +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 75b85b24e4ded1b0e8a0a762d5805818 files/digest-glibc-2.3.4.20041102 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 @@ -112,16 +114,19 @@ MD5 03e0e9a2235886c0abbe98bdafd0d5ce files/2.3.4/glibc-2.3.4-hardened-sysdep-sha MD5 659a9d64935d67a5938d0cb4e5fe4899 files/2.3.4/glibc-2.3.4-hppa-hardened-disable__init_arrays.patch 2310 MD5 16f18501efd56811e724231470dc5d00 files/2.3.4/glibc-2.3.4-ld.so-brk-fix.patch 2562 MD5 207e313566b3fc24e0a5ca2ffd2da1d9 files/2.3.4/glibc-2.3.4-nptl-altivec.patch 6140 +MD5 7960564130a698073bdd3597a781e39b files/2.3.4/glibc-2.3.4-nptl-pthread.h-g++-fix.patch 3304 MD5 340825c77e38e88e0ceaa12f154cbfa3 files/2.3.4/glibc-2.3.4.20040808-i386-got-fix.diff 4203 MD5 e109c03013bd08a2b96e2c2ca9017a4b files/2.3.4/glibc-gentoo-libdir.patch 1347 MD5 1185022e9a50560d1bf9116a0461e011 files/2.3.4/mips-sysdep-cancel.diff 2402 -MD5 7960564130a698073bdd3597a781e39b files/2.3.4/glibc-2.3.4-nptl-pthread.h-g++-fix.patch 3304 -MD5 9db90105eb74d75834d25a599cba97ea files/2.3.4/glibc-2.3.3-mdns-resolver2.diff 12272 MD5 9ee1438ba6ac30363130330c996dbb84 files/2.3.4/glibc-2.3.4-dl_execstack-PaX-support.patch 1443 +MD5 bbe355d94c5a36e11f543d12b70b5702 files/2.3.4/glibc-sec-hotfix-20040916.patch 3080 MD5 7fca8a203196513f13e519903dedbfd5 files/2.3.4/glibc-2.3.4-getcontext.patch 9854 MD5 d490f38bd9ca9c48a9799f1e48629f6e files/2.3.4/glibc-2.3.4-mips-generate-syscall_h.patch 8230 -MD5 bbe355d94c5a36e11f543d12b70b5702 files/2.3.4/glibc-sec-hotfix-20040916.patch 3080 MD5 fe21fd44628b90f50e5024462cf4c348 files/2.3.4/glibc-2.3.4-res_init.patch 3417 -MD5 ad71dc5c3f84f026c6e28865b2e90fbb files/2.3.4/glibc-2.3.4-fedora-branch-no-force-nontls.patch 2337 MD5 973e31ce24c9622234c4293b367de6b3 files/2.3.4/glibc-2.3.4-fedora-branch-no-libnoversion.patch 2288 +MD5 ad71dc5c3f84f026c6e28865b2e90fbb files/2.3.4/glibc-2.3.4-fedora-branch-no-force-nontls.patch 2337 +MD5 9db90105eb74d75834d25a599cba97ea files/2.3.4/glibc-2.3.3-mdns-resolver2.diff 12272 MD5 edcaf42f72d84a2cbbd911bfbcd4161a files/2.3.4/host.conf 1300 +MD5 076484ade8a834efb73190b687196392 files/2.3.4/glibc-2.3.4-mdns-resolver-20041102.diff 12809 +MD5 d902a9d990ee2970dd55dd805f352fa7 files/2.3.4/glibc-2.3.4-features-header-fix.patch 449 +MD5 1974267b1382fb38be7495b12c847f70 files/2.3.4/glibc-2.3.4-fedora-branch-nomalloccheck.patch 372 diff --git a/sys-libs/glibc/files/2.3.4/glibc-2.3.4-features-header-fix.patch b/sys-libs/glibc/files/2.3.4/glibc-2.3.4-features-header-fix.patch new file mode 100644 index 000000000000..f4b88fc7f593 --- /dev/null +++ b/sys-libs/glibc/files/2.3.4/glibc-2.3.4-features-header-fix.patch @@ -0,0 +1,11 @@ +--- include/features.h.orig 2004-11-04 15:42:23.777521424 -0500 ++++ include/features.h 2004-11-04 15:43:16.734470744 -0500 +@@ -262,7 +262,7 @@ + # define __USE_REENTRANT 1 + #endif + +-#if _FORTIFY_SOURCE > 0 && __OPTIMIZE__ > 0 \ ++#if (_FORTIFY_SOURCE > 0) && defined(__OPTIMIZE__) \ + && (__GNUC_PREREQ (4, 1) \ + || (defined __GNUC_RH_RELEASE__ && __GNUC_PREREQ (4, 0)) \ + || (defined __GNUC_RH_RELEASE__ && __GNUC_PREREQ (3, 4) \ diff --git a/sys-libs/glibc/files/2.3.4/glibc-2.3.4-fedora-branch-nomalloccheck.patch b/sys-libs/glibc/files/2.3.4/glibc-2.3.4-fedora-branch-nomalloccheck.patch new file mode 100644 index 000000000000..f163d2c93517 --- /dev/null +++ b/sys-libs/glibc/files/2.3.4/glibc-2.3.4-fedora-branch-nomalloccheck.patch @@ -0,0 +1,11 @@ +--- malloc/malloc.c.fedora 2004-11-04 16:45:51.365618552 -0500 ++++ malloc/malloc.c 2004-11-04 16:46:43.132748752 -0500 +@@ -2355,7 +2355,7 @@ + /* ---------------- Error behavior ------------------------------------ */ + + #ifndef DEFAULT_CHECK_ACTION +-#define DEFAULT_CHECK_ACTION 3 ++#define DEFAULT_CHECK_ACTION 0 + #endif + + static int check_action = DEFAULT_CHECK_ACTION; diff --git a/sys-libs/glibc/files/2.3.4/glibc-2.3.4-mdns-resolver-20041102.diff b/sys-libs/glibc/files/2.3.4/glibc-2.3.4-mdns-resolver-20041102.diff new file mode 100644 index 000000000000..d22e0cbc7e6a --- /dev/null +++ b/sys-libs/glibc/files/2.3.4/glibc-2.3.4-mdns-resolver-20041102.diff @@ -0,0 +1,463 @@ +diff -Nru glibc-2.3.3/resolv/res_hconf.c libc-mdns/resolv/res_hconf.c +--- glibc-2.3.3/resolv/res_hconf.c 2004-11-04 15:14:48.265197552 -0500 ++++ libc-mdns/resolv/res_hconf.c 2004-11-04 15:01:40.000000000 -0500 +@@ -59,6 +59,7 @@ + #define ENV_TRIM_ADD "RESOLV_ADD_TRIM_DOMAINS" + #define ENV_MULTI "RESOLV_MULTI" + #define ENV_REORDER "RESOLV_REORDER" ++#define ENV_MDNS "RESOLV_MDNS" + + static const char *arg_service_list (const char *, int, const char *, + unsigned int); +@@ -81,7 +82,8 @@ + {"multi", arg_bool, HCONF_FLAG_MULTI}, + {"nospoof", arg_bool, HCONF_FLAG_SPOOF}, + {"spoofalert", arg_bool, HCONF_FLAG_SPOOFALERT}, +- {"reorder", arg_bool, HCONF_FLAG_REORDER} ++ {"reorder", arg_bool, HCONF_FLAG_REORDER}, ++ {"mdns", arg_bool, HCONF_FLAG_MDNS} + }; + + /* Structure containing the state. */ +@@ -431,6 +433,9 @@ + + memset (&_res_hconf, '\0', sizeof (_res_hconf)); + ++ /* Default for mdns is "on". */ ++ _res_hconf.flags |= HCONF_FLAG_MDNS; ++ + hconf_name = getenv (ENV_HOSTCONF); + if (hconf_name == NULL) + hconf_name = _PATH_HOSTCONF; +@@ -483,6 +488,10 @@ + arg_trimdomain_list (ENV_TRIM_OVERR, 1, envval, 0); + } + ++ envval = getenv (ENV_MDNS); ++ if (envval) ++ arg_bool (ENV_MDNS, 1, envval, HCONF_FLAG_MDNS); ++ + _res_hconf.initialized = 1; + } + +diff -Nru glibc-2.3.3/resolv/res_hconf.h libc-mdns/resolv/res_hconf.h +--- glibc-2.3.3/resolv/res_hconf.h 2001-07-06 00:55:39.000000000 -0400 ++++ libc-mdns/resolv/res_hconf.h 2004-11-04 15:01:40.000000000 -0500 +@@ -44,6 +44,7 @@ + # define HCONF_FLAG_SPOOFALERT (1 << 2) /* syslog warning of spoofed */ + # define HCONF_FLAG_REORDER (1 << 3) /* list best address first */ + # define HCONF_FLAG_MULTI (1 << 4) /* see comments for gethtbyname() */ ++# define HCONF_FLAG_MDNS (1 << 5) /* Disable MDNS support */ + }; + extern struct hconf _res_hconf; + +diff -Nru glibc-2.3.3/resolv/res_query.c libc-mdns/resolv/res_query.c +--- glibc-2.3.3/resolv/res_query.c 2004-11-04 15:14:48.268197096 -0500 ++++ libc-mdns/resolv/res_query.c 2004-11-04 15:01:40.000000000 -0500 +@@ -82,6 +82,8 @@ + #include <stdlib.h> + #include <string.h> + ++#include "res_hconf.h" ++ + /* Options. Leave them on. */ + /* #undef DEBUG */ + +@@ -280,6 +282,13 @@ + *domain && !done; + domain++) { + ++ if ((_res_hconf.flags & HCONF_FLAG_MDNS) != 0) { ++ /* don't add "local" domain if query contains a dot */ ++ if (dots && (!__strcasecmp(*domain, "local") || ++ !__strcasecmp(*domain, "local."))) ++ continue; ++ } ++ + if (domain[0][0] == '\0' || + (domain[0][0] == '.' && domain[0][1] == '\0')) + root_on_list++; +diff -Nru glibc-2.3.3/resolv/res_send.c libc-mdns/resolv/res_send.c +--- glibc-2.3.3/resolv/res_send.c 2004-11-04 15:14:48.269196944 -0500 ++++ libc-mdns/resolv/res_send.c 2004-11-04 15:06:31.000000000 -0500 +@@ -85,6 +85,9 @@ + #include <arpa/nameser.h> + #include <arpa/inet.h> + #include <sys/ioctl.h> ++#if defined(_LIBC) && defined(linux) ++#include <net/if.h> ++#endif + + #include <errno.h> + #include <fcntl.h> +@@ -96,6 +99,8 @@ + #include <string.h> + #include <unistd.h> + ++#include "res_hconf.h" ++ + #if PACKETSZ > 65536 + #define MAXPACKET PACKETSZ + #else +@@ -180,6 +185,9 @@ + static int send_dg(res_state, const u_char *, int, + u_char **, int *, int *, int, + int *, int *, u_char **); ++static int send_dg_mdns(res_state, const u_char *, int, ++ u_char **, int *, int *, struct sockaddr_in6 *, ++ int *, int *, u_char **); + #ifdef DEBUG + static void Aerror(const res_state, FILE *, const char *, int, + const struct sockaddr *); +@@ -332,6 +340,35 @@ + u_char *ans, int anssiz, u_char **ansp) + { + int gotsomewhere, terrno, try, v_circuit, resplen, ns, n; ++ int usemdns; ++ HEADER *qhp = (HEADER *) buf; ++ ++ usemdns = 0; ++ if ((_res_hconf.flags & HCONF_FLAG_MDNS) != 0 && ++ qhp->qr == 0 && qhp->opcode == QUERY && qhp->qdcount == htons(1)) { ++ /* got one simple query */ ++ const u_char *bp, *be; ++ be = buf + buflen; ++ for (bp = buf + NS_HFIXEDSZ; bp < be; ) ++ if ((*bp & NS_CMPRSFLGS) != 0) ++ break; ++ else if (*bp) { ++ if (*bp == 5 && !strncasecmp(bp, "\005local\000", 7)) { ++ usemdns = 1; ++ break; ++ } ++ if (*bp == 3 && !strncasecmp(bp, "\003254\003169\007in-addr\004arpa\000", 22)) { ++ usemdns = 1; ++ break; ++ } ++ if (*bp == 1 && !strncasecmp(bp, "\0010\0018\001e\001f\003ip6\004arpa\000", 18)) { ++ usemdns = 2; ++ break; ++ } ++ bp += *bp + 1; ++ } else ++ break; ++ } + + if (statp->nscount == 0) { + __set_errno (ESRCH); +@@ -465,10 +502,27 @@ + * Send request, RETRY times, or until successful. + */ + for (try = 0; try < statp->retry; try++) { +- for (ns = 0; ns < MAXNS; ns++) ++ for (ns = 0; ns < (usemdns ? 1 : MAXNS); ns++) + { + struct sockaddr_in6 *nsap = EXT(statp).nsaddrs[ns]; + ++ if (usemdns == 1) { ++ static struct sockaddr_in mdns4; ++ mdns4.sin_family = AF_INET; ++ mdns4.sin_port = htons(5353); ++ mdns4.sin_addr.s_addr = htonl(0xe00000fb); ++ nsap = (struct sockaddr_in6 *)&mdns4; ++ } ++ if (usemdns == 2) { ++ static struct sockaddr_in6 mdns6; ++ mdns6.sin6_family = AF_INET6; ++ mdns6.sin6_port = htons(5353); ++ mdns6.sin6_addr.s6_addr32[0] = htonl(0xff020000); ++ mdns6.sin6_addr.s6_addr32[3] = htonl(0x000000fb); ++ nsap = &mdns6; ++ } ++ ++ + if (nsap == NULL) + goto next_ns; + same_ns: +@@ -525,8 +579,11 @@ + resplen = n; + } else { + /* Use datagrams. */ +- n = send_dg(statp, buf, buflen, &ans, &anssiz, &terrno, +- ns, &v_circuit, &gotsomewhere, ansp); ++ if (usemdns) ++ n = send_dg_mdns(statp, buf, buflen, &ans, &anssiz, &terrno, nsap, &v_circuit, &gotsomewhere, ansp); ++ else ++ n = send_dg(statp, buf, buflen, &ans, &anssiz, &terrno, ++ ns, &v_circuit, &gotsomewhere, ansp); + if (n < 0) + return (-1); + if (n == 0) +@@ -593,8 +650,15 @@ + if (!v_circuit) { + if (!gotsomewhere) + __set_errno (ECONNREFUSED); /* no nameservers found */ +- else ++ else if (!usemdns) { + __set_errno (ETIMEDOUT); /* no answer obtained */ ++ } else { ++ /* treat timeout as host not found */ ++ HEADER *anhp = (HEADER *) ans; ++ memset(ans, 0, HFIXEDSZ); ++ anhp->rcode = NXDOMAIN; ++ return HFIXEDSZ; ++ } + } else + __set_errno (terrno); + return (-1); +@@ -1035,6 +1099,255 @@ + } + } + ++static int ++send_dg_mdns(res_state statp, ++ const u_char *buf, int buflen, u_char **ansp, int *anssizp, ++ int *terrno, struct sockaddr_in6 *nsap, int *v_circuit, int *gotsomewhere, u_char **anscp) ++{ ++ const HEADER *hp = (HEADER *) buf; ++ u_char *ans = *ansp; ++ int anssiz = *anssizp; ++ HEADER *anhp = (HEADER *) ans; ++ struct timespec now, timeout, finish; ++ struct pollfd pfd[32]; ++ int ptimeout; ++ int fromlen, resplen, seconds, n, s; ++ int on = 1; ++ struct msghdr mhdr; ++ struct iovec iov; ++ u_char cmsgbuf[CMSG_SPACE(sizeof(int))]; ++ struct cmsghdr *cmsg; ++ int ttl; ++ struct ifconf ifconf; ++ struct ifreq ifreq[64]; ++ int ifreqn; ++ int i, j; ++ int ifidx[32], ifidxn; ++ struct ip_mreqn mreqn; ++ ++ s = socket(nsap->sin6_family == AF_INET ? PF_INET : PF_INET6, SOCK_DGRAM, 0); ++ if (s < 0) { ++ *terrno = errno; ++ Perror(statp, stderr, "socket(dg)", errno); ++ return (-1); ++ } ++ ifconf.ifc_len = sizeof(ifreq); ++ ifconf.ifc_req = ifreq; ++ ifidxn = 0; ++ if (ioctl(s, SIOCGIFCONF, &ifconf) == 0) { ++ ifreqn = ifconf.ifc_len / sizeof(*ifreq); ++ for (i = 0 ; i < ifreqn; i++) { ++ if (ioctl(s, SIOCGIFFLAGS, ifreq + i)) ++ continue; ++ if (!(ifreq[i].ifr_flags & IFF_MULTICAST)) ++ continue; ++ if (ioctl(s, SIOCGIFINDEX, ifreq + i)) ++ continue; ++ for (j = 0; j < ifidxn; j++) ++ if (ifidx[j] == ifreq[i].ifr_ifindex) ++ break; ++ if (j < ifidxn) ++ continue; ++ ifidx[ifidxn++] = ifreq[i].ifr_ifindex; ++ if (ifidxn == sizeof(ifidx)/sizeof(*ifidx)) ++ break; ++ } ++ } ++ j = 0; ++ for (i = 0; i < (ifidxn ? ifidxn : 1); i++) { ++ if (i) { ++ s = socket(nsap->sin6_family == AF_INET ? PF_INET : PF_INET6, SOCK_DGRAM, 0); ++ if (!s) ++ continue; ++ } ++ if (setsockopt(s, SOL_IP, IP_RECVTTL, &on, sizeof(on))) { ++ *terrno = errno; ++ Perror(statp, stderr, "IP_RECVTTL(dg)", errno); ++ close(s); ++ continue; ++ } ++ if (ifidxn) { ++ memset(&mreqn, 0, sizeof(mreqn)); ++ mreqn.imr_ifindex = ifidx[i]; ++ if (setsockopt(s, SOL_IP, IP_MULTICAST_IF, &mreqn, sizeof(mreqn))) { ++ *terrno = errno; ++ Perror(statp, stderr, "IP_MULTICAST_IF", errno); ++ close(s); ++ continue; ++ } ++ } ++ if (sendto(s, (char*)buf, buflen, 0, ++ (struct sockaddr *)nsap, sizeof *nsap) != buflen) { ++ Aerror(statp, stderr, "sendto", errno, *(struct sockaddr_in *)nsap); ++ close(s); ++ continue; ++ } ++ pfd[j].fd = s; ++ pfd[j].events = POLLIN; ++ j++; ++ } ++ /* ++ * Wait for reply. ++ */ ++ seconds = statp->retrans; ++ if (seconds <= 0) ++ seconds = 1; ++ evNowTime(&now); ++ evConsTime(&timeout, seconds, 0); ++ evAddTime(&finish, &now, &timeout); ++ wait: ++ if (j == 0) { ++ return (0); ++ } ++ ++ /* Convert struct timespec in milliseconds. */ ++ ptimeout = timeout.tv_sec * 1000 + timeout.tv_nsec / 1000000; ++ n = __poll (pfd, j, ptimeout); ++ if (n == 0) { ++ Dprint(statp->options & RES_DEBUG, (stdout, ";; timeout\n")); ++ *gotsomewhere = 1; ++ for (i = 0; i < j; i++) ++ close(pfd[i].fd); ++ return (0); ++ } ++ if (n < 0) { ++ if (errno == EINTR) { ++ evNowTime(&now); ++ if (evCmpTime(finish, now) > 0) { ++ evSubTime(&timeout, &finish, &now); ++ goto wait; ++ } ++ } ++ Perror(statp, stderr, "select", errno); ++ for (i = 0; i < j; i++) ++ close(pfd[i].fd); ++ res_nclose(statp); ++ return (0); ++ } ++ for (i = 0; i < j - 1; i++) ++ if (pfd[j].revents == POLLIN) ++ break; ++ s = pfd[i].fd; ++ __set_errno (0); ++ fromlen = sizeof(struct sockaddr_in6); ++ if (anssiz < MAXPACKET ++ && anscp ++ && (ioctl (s, FIONREAD, &resplen) < 0 ++ || anssiz < resplen)) { ++ ans = malloc (MAXPACKET); ++ if (ans == NULL) ++ ans = *ansp; ++ else { ++ anssiz = MAXPACKET; ++ *anssizp = MAXPACKET; ++ *ansp = ans; ++ *anscp = ans; ++ anhp = (HEADER *) ans; ++ } ++ } ++ iov.iov_base = ans; ++ iov.iov_len = anssiz; ++ mhdr.msg_name = 0; ++ mhdr.msg_namelen = 0; ++ mhdr.msg_iov = &iov; ++ mhdr.msg_iovlen = 1; ++ mhdr.msg_control = cmsgbuf; ++ mhdr.msg_controllen = sizeof(cmsgbuf); ++ mhdr.msg_flags = 0; ++ resplen = recvmsg(s, &mhdr, 0); ++ if (resplen <= 0) { ++ if (errno == EAGAIN) ++ goto wait; ++ Perror(statp, stderr, "recvfrom", errno); ++wait2: ++ close(s); ++ if (i < j) ++ memmove(pfd + i, pfd + i + 1, sizeof(*pfd) * (j - i)); ++ j--; ++ goto wait; ++ } ++ cmsg = CMSG_FIRSTHDR(&mhdr); ++ for (cmsg = CMSG_FIRSTHDR(&mhdr); cmsg; CMSG_NXTHDR(&mhdr, cmsg)) ++ if (cmsg->cmsg_level == SOL_IP && cmsg->cmsg_type == IP_TTL) ++ break; ++ if (!cmsg) { ++ Dprint(statp->options & RES_DEBUG, ++ (stdout, ";; no TTL found\n")); ++ goto wait2; ++ } ++ ttl = *(int *)CMSG_DATA(cmsg); ++ if (ttl != 255) { ++ Dprint(statp->options & RES_DEBUG, ++ (stdout, ";; answer with bad TTL: %d \n", ttl)); ++ goto wait; ++ } ++ *gotsomewhere = 1; ++ if (resplen < HFIXEDSZ) { ++ /* ++ * Undersized message. ++ */ ++ Dprint(statp->options & RES_DEBUG, ++ (stdout, ";; undersized: %d\n", ++ resplen)); ++ *terrno = EMSGSIZE; ++ goto wait; ++ } ++ if (hp->id != anhp->id) { ++ /* ++ * response from old query, ignore it. ++ * XXX - potential security hazard could ++ * be detected here. ++ */ ++ DprintQ((statp->options & RES_DEBUG) || ++ (statp->pfcode & RES_PRF_REPLY), ++ (stdout, ";; old answer:\n"), ++ ans, (resplen > anssiz) ? anssiz : resplen); ++ goto wait; ++ } ++ if (!(statp->options & RES_INSECURE2) && ++ !res_queriesmatch(buf, buf + buflen, ++ ans, ans + anssiz)) { ++ /* ++ * response contains wrong query? ignore it. ++ * XXX - potential security hazard could ++ * be detected here. ++ */ ++ DprintQ((statp->options & RES_DEBUG) || ++ (statp->pfcode & RES_PRF_REPLY), ++ (stdout, ";; wrong query name:\n"), ++ ans, (resplen > anssiz) ? anssiz : resplen); ++ goto wait; ++ } ++ if (anhp->rcode == SERVFAIL || ++ anhp->rcode == NOTIMP || ++ anhp->rcode == REFUSED) { ++ DprintQ(statp->options & RES_DEBUG, ++ (stdout, "server rejected query:\n"), ++ ans, (resplen > anssiz) ? anssiz : resplen); ++ goto wait; ++ } ++ for (i = 0; i < j; i++) ++ close(pfd[i].fd); ++#if 0 ++ if (!(statp->options & RES_IGNTC) && anhp->tc) { ++ /* ++ * To get the rest of answer, ++ * use TCP with same server. ++ */ ++ Dprint(statp->options & RES_DEBUG, ++ (stdout, ";; truncated answer\n")); ++ *v_circuit = 1; ++ res_nclose(statp); ++ return (1); ++ } ++#endif ++ /* ++ * All is well, or the error is fatal. Signal that the ++ * next nameserver ought not be tried. ++ */ ++ return (resplen); ++} ++ + #ifdef DEBUG + static void + Aerror(const res_state statp, FILE *file, const char *string, int error, diff --git a/sys-libs/glibc/files/digest-glibc-2.3.4.20041102 b/sys-libs/glibc/files/digest-glibc-2.3.4.20041102 new file mode 100644 index 000000000000..f6ea61e66e96 --- /dev/null +++ b/sys-libs/glibc/files/digest-glibc-2.3.4.20041102 @@ -0,0 +1,5 @@ +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 387bbf301b35fa5ff5b3edaf45c323d8 glibc-2.3.4-branch-update-20041102.patch.bz2 3034626 diff --git a/sys-libs/glibc/glibc-2.3.4.20041102.ebuild b/sys-libs/glibc/glibc-2.3.4.20041102.ebuild new file mode 100644 index 000000000000..20b3fe8f7a22 --- /dev/null +++ b/sys-libs/glibc/glibc-2.3.4.20041102.ebuild @@ -0,0 +1,900 @@ +# 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.20041102.ebuild,v 1.1 2004/11/05 02:56:41 lv Exp $ + +inherit eutils flag-o-matic gcc versionator + +# Branch update support. Following will disable: +# BRANCH_UPDATE= +BRANCH_UPDATE="20041102" + +# 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="~amd64 ~ppc64 -hppa ~ia64 -ppc ~x86 -*" +KEYWORDS="-*" +IUSE="nls pic build nptl nptlonly erandom hardened multilib debug userlocales nomalloccheck" +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 "${CTARGET}" ] && CTARGET="${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 CTARGET="sparcv9-unknown-linux-gnu" + fi + fi + fi + + if version_is_at_least 3.4.0 ; 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 +} + + +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 + + # setup lib -- seems like a good place to set this up + get_libdir_override lib64 +} + + +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 + + # remove the fedora-branch glibc 2.0 compat stuff. + rm -rf glibc-compat + epatch ${FILESDIR}/2.3.4/glibc-2.3.4-fedora-branch-no-libnoversion.patch + epatch ${FILESDIR}/2.3.4/glibc-2.3.4-fedora-branch-no-force-nontls.patch + + 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 + # ...patch updated to make mdns optional + epatch ${FILESDIR}/2.3.4/glibc-2.3.4-mdns-resolver-20041102.diff + + # if __OPTIMIZE__ isnt defined, the comparison in this header + # fails. + epatch ${FILESDIR}/2.3.4/glibc-2.3.4-features-header-fix.patch + + # whine whine whine, this patch sets the default for the malloc check + # to 0, disabling it. + use nomalloccheck && epatch ${FILESDIR}/2.3.4/glibc-2.3.4-fedora-branch-nomalloccheck.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=${CTARGET} + --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-${CTARGET}-$1" + 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-${CTARGET}-nptl + else + MYMAINBUILDDIR=build-${CTARGET}-linuxthreads + fi + + if use !nptlonly ; then + cd ${WORKDIR}/build-${CTARGET}-linuxthreads + einfo "Installing GLIBC with linuxthreads..." + make PARALLELMFLAGS="${MAKEOPTS}" \ + install_root=${D} \ + install || die + elif use nptlonly ; then + cd ${WORKDIR}/build-${CTARGET}-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-${CTARGET}-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 + + insinto /etc + # This is our new config file for building locales + doins ${FILESDIR}/locales.build + # example host.conf with multicast dns disabled by default + doins ${FILESDIR}/2.3.4/host.conf + + 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 + + # it appears that /lib/tls is sometimes not removed. See bug + # 69258 for more info. + if [ -d /${ROOT}/$(get_libdir)/tls ] && use nptlonly ; then + addwrite /${ROOT}/$(get_libdir)/ + ewarn "nptlonly in USE, removing /${ROOT}/$(get_libdir)/tls..." + rm -rf /${ROOT}/$(get_libdir)/tls || die + fi +} + +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 + + # warn the few multicast-dns-by-default users we've had about the change + # in behavior... + echo + einfo "Gentoo's glibc now disables multicast dns by default in our" + einfo "example host.conf. To re-enable this functionality, simply" + einfo "remove the line that disables it (mdns off)." + echo +} + |