diff options
author | ro <ro@138bc75d-0d04-0410-961f-82ee72b054a4> | 2013-03-06 15:08:58 +0000 |
---|---|---|
committer | ro <ro@138bc75d-0d04-0410-961f-82ee72b054a4> | 2013-03-06 15:08:58 +0000 |
commit | 9618cef10cf5822dc3f72363d27f94606942939f (patch) | |
tree | b2c8d5ade6c2bace942e02d93986a6fe0c08df2e /boehm-gc | |
parent | 59fd55c6a94bc9206f412fe2fcaf31143d1510bf (diff) | |
download | gcc-9618cef10cf5822dc3f72363d27f94606942939f.tar.gz |
Use thr_stksegment to determine Solaris stack base
* os_dep.c [SOLARIS_STACKBOTTOM] (GC_solaris_stack_base): New
function.
[!BEOS && !AMIGA && !MSWIN32 && !MSWINCE && !OS2 && !NOSYS &&
!ECOS] (GC_get_stack_base): Use it.
* include/private/gcconfig.h [SPARC && SUNOS5]
(SOLARIS_STACKBOTTOM): Define.
(STACKBOTTOM, HEURISTIC2): Remove.
[I386 && SUNOS5]
(SOLARIS_STACKBOTTOM): Define.
(STACKBOTTOM): Remove.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@196490 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'boehm-gc')
-rw-r--r-- | boehm-gc/ChangeLog | 13 | ||||
-rw-r--r-- | boehm-gc/include/private/gcconfig.h | 21 | ||||
-rw-r--r-- | boehm-gc/os_dep.c | 54 |
3 files changed, 68 insertions, 20 deletions
diff --git a/boehm-gc/ChangeLog b/boehm-gc/ChangeLog index 7759258ab33..be2a484249d 100644 --- a/boehm-gc/ChangeLog +++ b/boehm-gc/ChangeLog @@ -1,3 +1,16 @@ +2013-03-06 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE> + + * os_dep.c [SOLARIS_STACKBOTTOM] (GC_solaris_stack_base): New + function. + [!BEOS && !AMIGA && !MSWIN32 && !MSWINCE && !OS2 && !NOSYS && + !ECOS] (GC_get_stack_base): Use it. + * include/private/gcconfig.h [SPARC && SUNOS5] + (SOLARIS_STACKBOTTOM): Define. + (STACKBOTTOM, HEURISTIC2): Remove. + [I386 && SUNOS5] + (SOLARIS_STACKBOTTOM): Define. + (STACKBOTTOM): Remove. + 2012-11-04 Samuel Thibault <samuel.thibault@gnu.org> * configure.ac: Add stanza for *-*-gnu* threads configuration. diff --git a/boehm-gc/include/private/gcconfig.h b/boehm-gc/include/private/gcconfig.h index 594ce431e02..9420c7caf8f 100644 --- a/boehm-gc/include/private/gcconfig.h +++ b/boehm-gc/include/private/gcconfig.h @@ -927,18 +927,7 @@ # define HEAP_START DATAEND # endif # define PROC_VDB -/* HEURISTIC1 reportedly no longer works under 2.7. */ -/* HEURISTIC2 probably works, but this appears to be preferable. */ -/* Apparently USRSTACK is defined to be USERLIMIT, but in some */ -/* installations that's undefined. We work around this with a */ -/* gross hack: */ -# include <sys/vmparam.h> -# ifdef USERLIMIT - /* This should work everywhere, but doesn't. */ -# define STACKBOTTOM USRSTACK -# else -# define HEURISTIC2 -# endif +# define SOLARIS_STACKBOTTOM # include <unistd.h> # define GETPAGESIZE() sysconf(_SC_PAGESIZE) /* getpagesize() appeared to be missing from at least one */ @@ -1067,13 +1056,7 @@ extern ptr_t GC_SysVGetDataStart(); # define DATASTART GC_SysVGetDataStart(0x1000, _etext) # define DATAEND (_end) -/* # define STACKBOTTOM ((ptr_t)(_start)) worked through 2.7, */ -/* but reportedly breaks under 2.8. It appears that the stack */ -/* base is a property of the executable, so this should not break */ -/* old executables. */ -/* HEURISTIC2 probably works, but this appears to be preferable. */ -# include <sys/vm.h> -# define STACKBOTTOM USRSTACK +# define SOLARIS_STACKBOTTOM /* At least in Solaris 2.5, PROC_VDB gives wrong values for dirty bits. */ /* It appears to be fixed in 2.8 and 2.9. */ # ifdef SOLARIS25_PROC_VDB_BUG_FIXED diff --git a/boehm-gc/os_dep.c b/boehm-gc/os_dep.c index a2dd3046dad..470d4fc14dd 100644 --- a/boehm-gc/os_dep.c +++ b/boehm-gc/os_dep.c @@ -1008,13 +1008,62 @@ ptr_t GC_get_stack_base() #endif /* FREEBSD_STACKBOTTOM */ +#ifdef SOLARIS_STACKBOTTOM + +# include <thread.h> +# include <signal.h> +# include <pthread.h> + + /* These variables are used to cache ss_sp value for the primordial */ + /* thread (it's better not to call thr_stksegment() twice for this */ + /* thread - see JDK bug #4352906). */ + static pthread_t stackbase_main_self = 0; + /* 0 means stackbase_main_ss_sp value is unset. */ + static void *stackbase_main_ss_sp = NULL; + + ptr_t GC_solaris_stack_base(void) + { + stack_t s; + pthread_t self = pthread_self(); + if (self == stackbase_main_self) + { + /* If the client calls GC_get_stack_base() from the main thread */ + /* then just return the cached value. */ + GC_ASSERT(stackbase_main_ss_sp != NULL); + return stackbase_main_ss_sp; + } + + if (thr_stksegment(&s)) { + /* According to the manual, the only failure error code returned */ + /* is EAGAIN meaning "the information is not available due to the */ + /* thread is not yet completely initialized or it is an internal */ + /* thread" - this shouldn't happen here. */ + ABORT("thr_stksegment failed"); + } + /* s.ss_sp holds the pointer to the stack bottom. */ + GC_ASSERT((void *)&s HOTTER_THAN s.ss_sp); + + if (!stackbase_main_self) + { + /* Cache the stack base value for the primordial thread (this */ + /* is done during GC_init, so there is no race). */ + stackbase_main_ss_sp = s.ss_sp; + stackbase_main_self = self; + } + + return s.ss_sp; + } + +#endif /* GC_SOLARIS_THREADS */ + #if !defined(BEOS) && !defined(AMIGA) && !defined(MSWIN32) \ && !defined(MSWINCE) && !defined(OS2) && !defined(NOSYS) && !defined(ECOS) ptr_t GC_get_stack_base() { # if defined(HEURISTIC1) || defined(HEURISTIC2) || \ - defined(LINUX_STACKBOTTOM) || defined(FREEBSD_STACKBOTTOM) + defined(LINUX_STACKBOTTOM) || defined(FREEBSD_STACKBOTTOM) || \ + defined(SOLARIS_STACKBOTTOM) word dummy; ptr_t result; # endif @@ -1040,6 +1089,9 @@ ptr_t GC_get_stack_base() # ifdef FREEBSD_STACKBOTTOM result = GC_freebsd_stack_base(); # endif +# ifdef SOLARIS_STACKBOTTOM + result = GC_solaris_stack_base(); +# endif # ifdef HEURISTIC2 # ifdef STACK_GROWS_DOWN result = GC_find_limit((ptr_t)(&dummy), TRUE); |