summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTravis Tilley <lv@gentoo.org>2004-11-05 02:56:41 +0000
committerTravis Tilley <lv@gentoo.org>2004-11-05 02:56:41 +0000
commitaf79179f1932564f9a9226c8edd5b9d668b40527 (patch)
tree836635ff17919f86b3a58b889577ccfc105a498d /sys-libs
parentUsing the toolchain-funcs eclass for handling the detection of CC version, ra... (diff)
downloadhistorical-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/ChangeLog15
-rw-r--r--sys-libs/glibc/Manifest25
-rw-r--r--sys-libs/glibc/files/2.3.4/glibc-2.3.4-features-header-fix.patch11
-rw-r--r--sys-libs/glibc/files/2.3.4/glibc-2.3.4-fedora-branch-nomalloccheck.patch11
-rw-r--r--sys-libs/glibc/files/2.3.4/glibc-2.3.4-mdns-resolver-20041102.diff463
-rw-r--r--sys-libs/glibc/files/digest-glibc-2.3.4.200411025
-rw-r--r--sys-libs/glibc/glibc-2.3.4.20041102.ebuild900
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
+}
+