source: trunk/gcc/boehm-gc/doc/README.solaris2@ 2946

Last change on this file since 2946 was 2, checked in by bird, 23 years ago

Initial revision

  • Property cvs2svn:cvs-rev set to 1.1
  • Property svn:eol-style set to native
  • Property svn:executable set to *
File size: 3.3 KB
Line 
1The collector supports both incremental collection and threads under
2Solaris 2. The incremental collector normally retrieves page dirty information
3through the appropriate /proc calls. But it can also be configured
4(by defining MPROTECT_VDB instead of PROC_VDB in gcconfig.h) to use mprotect
5and signals. This may result in shorter pause times, but it is no longer
6safe to issue arbitrary system calls that write to the heap.
7
8Under other UNIX versions,
9the collector normally obtains memory through sbrk. There is some reason
10to expect that this is not safe if the client program also calls the system
11malloc, or especially realloc. The sbrk man page strongly suggests this is
12not safe: "Many library routines use malloc() internally, so use brk()
13and sbrk() only when you know that malloc() definitely will not be used by
14any library routine." This doesn't make a lot of sense to me, since there
15seems to be no documentation as to which routines can transitively call malloc.
16Nonetheless, under Solaris2, the collector now (since 4.12) allocates
17memory using mmap by default. (It defines USE_MMAP in gcconfig.h.)
18You may want to reverse this decisions if you use -DREDIRECT_MALLOC=...
19
20
21SOLARIS THREADS:
22
23The collector must be compiled with -DGC_SOLARIS_THREADS (thr_ functions)
24or -DGC_SOLARIS_PTHREADS (pthread_ functions) to be thread safe.
25It is also essential that gc.h be included in files that call thr_create,
26thr_join, thr_suspend, thr_continue, or dlopen. Gc.h macro defines
27these to also do GC bookkeeping, etc. Gc.h must be included with
28one or both of these macros defined, otherwise
29these replacements are not visible.
30A collector built in this way way only be used by programs that are
31linked with the threads library.
32
33In this mode, the collector contains various workarounds for older Solaris
34bugs. Mostly, these should not be noticeable unless you look at system
35call traces. However, it cannot protect a guard page at the end of
36a thread stack. If you know that you will only be running Solaris2.5
37or later, it should be possible to fix this by compiling the collector
38with -DSOLARIS23_MPROTECT_BUG_FIXED.
39
40Since 5.0 alpha5, dlopen disables collection temporarily,
41unless USE_PROC_FOR_LIBRARIES is defined. In some unlikely cases, this
42can result in unpleasant heap growth. But it seems better than the
43race/deadlock issues we had before.
44
45If solaris_threads are used on an X86 processor with malloc redirected to
46GC_malloc, it is necessary to call GC_thr_init explicitly before forking the
47first thread. (This avoids a deadlock arising from calling GC_thr_init
48with the allocation lock held.)
49
50It appears that there is a problem in using gc_cpp.h in conjunction with
51Solaris threads and Sun's C++ runtime. Apparently the overloaded new operator
52is invoked by some iostream initialization code before threads are correctly
53initialized. As a result, call to thr_self() in garbage collector
54initialization segfaults. Currently the only known workaround is to not
55invoke the garbage collector from a user defined global operator new, or to
56have it invoke the garbage-collector's allocators only after main has started.
57(Note that the latter requires a moderately expensive test in operator
58delete.)
59
60Hans-J. Boehm
61(The above contains my personal opinions, which are probably not shared
62by anyone else.)
Note: See TracBrowser for help on using the repository browser.