diff options
author | Matsuu Takuto <matsuu@gentoo.org> | 2005-08-06 21:38:41 +0000 |
---|---|---|
committer | Matsuu Takuto <matsuu@gentoo.org> | 2005-08-06 21:38:41 +0000 |
commit | 5ee94332dd66b67004a5cd9fb85577134cea2220 (patch) | |
tree | ade489b5b71a6fd451aa84568b71b76d5f5f857a /dev-libs/boehm-gc | |
parent | ~ppc-macos (diff) | |
download | gentoo-2-5ee94332dd66b67004a5cd9fb85577134cea2220.tar.gz gentoo-2-5ee94332dd66b67004a5cd9fb85577134cea2220.tar.bz2 gentoo-2-5ee94332dd66b67004a5cd9fb85577134cea2220.zip |
Added boehm-gc-6.5-gentoo.patch. Bug 75414.
(Portage version: 2.0.51.22-r2)
Diffstat (limited to 'dev-libs/boehm-gc')
-rw-r--r-- | dev-libs/boehm-gc/ChangeLog | 6 | ||||
-rw-r--r-- | dev-libs/boehm-gc/boehm-gc-6.5.ebuild | 5 | ||||
-rw-r--r-- | dev-libs/boehm-gc/files/boehm-gc-6.5-gentoo.patch | 83 |
3 files changed, 92 insertions, 2 deletions
diff --git a/dev-libs/boehm-gc/ChangeLog b/dev-libs/boehm-gc/ChangeLog index 7b4318e928d7..e66ca15fd1c1 100644 --- a/dev-libs/boehm-gc/ChangeLog +++ b/dev-libs/boehm-gc/ChangeLog @@ -1,6 +1,10 @@ # ChangeLog for dev-libs/boehm-gc # Copyright 2002-2005 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/dev-libs/boehm-gc/ChangeLog,v 1.36 2005/07/03 10:03:16 kloeri Exp $ +# $Header: /var/cvsroot/gentoo-x86/dev-libs/boehm-gc/ChangeLog,v 1.37 2005/08/06 21:38:41 matsuu Exp $ + + 06 Aug 2005; MATSUU Takuto <matsuu@gentoo.org> + +files/boehm-gc-6.5-gentoo.patch, boehm-gc-6.5.ebuild: + Added boehm-gc-6.5-gentoo.patch. Bug 75414. 03 Jul 2005; Bryan Østergaard <kloeri@gentoo.org> boehm-gc-6.4.ebuild: Stable on alpha. diff --git a/dev-libs/boehm-gc/boehm-gc-6.5.ebuild b/dev-libs/boehm-gc/boehm-gc-6.5.ebuild index d7e46e9e0fce..127f7b063fe6 100644 --- a/dev-libs/boehm-gc/boehm-gc-6.5.ebuild +++ b/dev-libs/boehm-gc/boehm-gc-6.5.ebuild @@ -1,6 +1,8 @@ # Copyright 1999-2005 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/dev-libs/boehm-gc/boehm-gc-6.5.ebuild,v 1.1 2005/06/20 14:09:07 matsuu Exp $ +# $Header: /var/cvsroot/gentoo-x86/dev-libs/boehm-gc/boehm-gc-6.5.ebuild,v 1.2 2005/08/06 21:38:41 matsuu Exp $ + +inherit eutils MY_P=gc${PV/_/} S=${WORKDIR}/${MY_P} @@ -23,6 +25,7 @@ src_unpack() { unpack ${A} cd ${S} sed -i -e '/^SUBDIRS/s/doc//' Makefile.in || die + epatch ${FILESDIR}/${P}-gentoo.patch } src_compile() { diff --git a/dev-libs/boehm-gc/files/boehm-gc-6.5-gentoo.patch b/dev-libs/boehm-gc/files/boehm-gc-6.5-gentoo.patch new file mode 100644 index 000000000000..72eb881eef7d --- /dev/null +++ b/dev-libs/boehm-gc/files/boehm-gc-6.5-gentoo.patch @@ -0,0 +1,83 @@ +diff -ur gc6.5.orig/include/private/gcconfig.h gc6.5/include/private/gcconfig.h +--- gc6.5.orig/include/private/gcconfig.h 2005-08-05 00:03:00.000000000 +0200 ++++ gc6.5/include/private/gcconfig.h 2005-08-05 00:08:42.000000000 +0200 +@@ -1100,6 +1100,9 @@ + # endif + # define OS_TYPE "LINUX" + # define LINUX_STACKBOTTOM ++ /* On I386 Linux, enable HEURISTIC2 as a backup to /proc data */ ++ /* for the case where /proc is missing or nobbled (grsec) */ ++# define HEURISTIC2 + # if 0 + # define HEURISTIC1 + # undef STACK_GRAN +@@ -1901,6 +1904,9 @@ + # ifdef LINUX + # define OS_TYPE "LINUX" + # define LINUX_STACKBOTTOM ++ /* On x86_64 Linux, enable HEURISTIC2 as a backup to /proc data */ ++ /* for the case where /proc is missing or nobbled (grsec) */ ++# define HEURISTIC2 + # if !defined(GC_LINUX_THREADS) || !defined(REDIRECT_MALLOC) + # define MPROTECT_VDB + # else +diff -ur gc6.5.orig/os_dep.c gc6.5/os_dep.c +--- gc6.5.orig/os_dep.c 2005-08-05 00:03:00.000000000 +0200 ++++ gc6.5/os_dep.c 2005-08-05 00:07:56.000000000 +0200 +@@ -967,7 +967,13 @@ + # endif + f = open("/proc/self/stat", O_RDONLY); + if (f < 0 || STAT_READ(f, stat_buf, STAT_BUF_SIZE) < 2 * STAT_SKIP) { ++ /* if /proc/self/stat isn't available, and HEURISTIC2 is possible, */ ++ /* return NULL so that HEURISTIC2 will be tried. Otherwise bail. */ ++# ifdef HEURISTIC2 ++ return (ptr_t)NULL; ++# else + ABORT("Couldn't read /proc/self/stat"); ++# endif + } + c = stat_buf[buf_offset++]; + /* Skip the required number of fields. This number is hopefully */ +@@ -983,7 +989,16 @@ + c = stat_buf[buf_offset++]; + } + close(f); +- if (result < 0x10000000) ABORT("Absurd stack bottom value"); ++ if (result < 0x10000000) { ++ /* if stack base result is silly (e.g. is 0 due to grsec), and */ ++ /* HEURISTIC2 is enabled, return NULL so that HEURISTIC2 will be */ ++ /* tried. Otherwise bail. */ ++# ifdef HEURISTIC2 ++ return (ptr_t)NULL; ++# else ++ ABORT("Absurd stack bottom value"); ++# endif ++ } + return (ptr_t)result; + } + +@@ -1045,6 +1060,12 @@ + result = GC_freebsd_stack_base(); + # endif + # ifdef HEURISTIC2 ++/* if both LINUX_STACKBOTTOM and HEURISTIC2 are enabled, try HEURISTIC2 */ ++/* when the LINUX_STACKBOTTOM returns NULL (indicating failure to get */ ++/* a sensible result from /proc/self/stat) */ ++# ifdef LINUX_STACKBOTTOM ++ if (result == (ptr_t)NULL) { ++# endif + # ifdef STACK_GROWS_DOWN + result = GC_find_limit((ptr_t)(&dummy), TRUE); + # ifdef HEURISTIC2_LIMIT +@@ -1062,6 +1083,11 @@ + } + # endif + # endif ++/* tail of extra 'if' condition when both LINUX_STACKBOTTOM and */ ++/* HEURISTIC are configured. */ ++# ifdef LINUX_STACKBOTTOM ++ } ++# endif + + # endif /* HEURISTIC2 */ + # ifdef STACK_GROWS_DOWN |