source: trunk/gcc/boehm-gc/doc/README.linux@ 3101

Last change on this file since 3101 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: 4.6 KB
Line 
1See README.alpha for Linux on DEC AXP info.
2
3This file applies mostly to Linux/Intel IA32. Ports to Linux on an M68K
4and PowerPC are also integrated. They should behave similarly, except that
5the PowerPC port lacks incremental GC support, and it is unknown to what
6extent the Linux threads code is functional. See below for M68K specific
7notes.
8
9Incremental GC is supported on Intel IA32 and M68K.
10
11Dynamic libraries are supported on an ELF system. A static executable
12should be linked with the gcc option "-Wl,-defsym,_DYNAMIC=0".
13
14The collector appears to work with Linux threads. We have seen
15intermittent hangs in sem_wait. So far we have been unable to reproduce
16these unless the process was being debugged or traced. Thus it's
17possible that the only real issue is that the debugger loses
18signals on rare occasions.
19
20The garbage collector uses SIGPWR and SIGXCPU if it is used with
21Linux threads. These should not be touched by the client program.
22
23To use threads, you need to abide by the following requirements:
24
251) You need to use LinuxThreads (which are included in libc6).
26
27 The collector relies on some implementation details of the LinuxThreads
28 package. It is unlikely that this code will work on other
29 pthread implementations (in particular it will *not* work with
30 MIT pthreads).
31
322) You must compile the collector with -DGC_LINUX_THREADS and -D_REENTRANT
33 specified in the Makefile.
34
353a) Every file that makes thread calls should define GC_LINUX_THREADS and
36 _REENTRANT and then include gc.h. Gc.h redefines some of the
37 pthread primitives as macros which also provide the collector with
38 information it requires.
39
403b) A new alternative to (3a) is to build the collector and compile GC clients
41 with -DGC_USE_LD_WRAP, and to link the final program with
42
43 (for ld) --wrap read --wrap dlopen --wrap pthread_create \
44 --wrap pthread_join --wrap pthread_detach \
45 --wrap pthread_sigmask --wrap sleep
46
47 (for gcc) -Wl,--wrap -Wl,read -Wl,--wrap -Wl,dlopen -Wl,--wrap \
48 -Wl,pthread_create -Wl,--wrap -Wl,pthread_join -Wl,--wrap \
49 -Wl,pthread_detach -Wl,--wrap -Wl,pthread_sigmask \
50 -Wl,--wrap -Wl,sleep
51
52 In any case, _REENTRANT should be defined during compilation.
53
544) Dlopen() disables collection during its execution. (It can't run
55 concurrently with the collector, since the collector looks at its
56 data structures. It can't acquire the allocator lock, since arbitrary
57 user startup code may run as part of dlopen().) Under unusual
58 conditions, this may cause unexpected heap growth.
59
605) The combination of GC_LINUX_THREADS, REDIRECT_MALLOC, and incremental
61 collection fails in seemingly random places. This hasn't been tracked
62 down yet, but is perhaps not completely astonishing. The thread package
63 uses malloc, and thus can presumably get SIGSEGVs while inside the
64 package. There is no real guarantee that signals are handled properly
65 at that point.
66
676) Thread local storage may not be viewed as part of the root set by the
68 collector. This probably depends on the linuxthreads version. For the
69 time being, any collectable memory referenced by thread local storage should
70 also be referenced from elsewhere, or be allocated as uncollectable.
71 (This is really a bug that should be fixed somehow.)
72
73
74M68K LINUX:
75(From Richard Zidlicky)
76The bad news is that it can crash every linux-m68k kernel on a 68040,
77so an additional test is needed somewhere on startup. I have meanwhile
78patches to correct the problem in 68040 buserror handler but it is not
79yet in any standard kernel.
80
81Here is a simple test program to detect whether the kernel has the
82problem. It could be run as a separate check in configure or tested
83upon startup. If it fails (return !0) than mprotect can't be used
84on that system.
85
86/*
87 * test for bug that may crash 68040 based Linux
88 */
89
90#include <sys/mman.h>
91#include <signal.h>
92#include <unistd.h>
93#include <stdio.h>
94#include <stdlib.h>
95
96
97char *membase;
98int pagesize=4096;
99int pageshift=12;
100int x_taken=0;
101
102int sighandler(int sig)
103{
104 mprotect(membase,pagesize,PROT_READ|PROT_WRITE);
105 x_taken=1;
106}
107
108main()
109{
110 long l;
111
112 signal(SIGSEGV,sighandler);
113 l=(long)mmap(NULL,pagesize,PROT_READ,MAP_PRIVATE | MAP_ANON,-1,0);
114 if (l==-1)
115 {
116 perror("mmap/malloc");
117 abort();
118 }
119 membase=(char*)l;
120 *(long*)(membase+sizeof(long))=123456789;
121 if (*(long*)(membase+sizeof(long)) != 123456789 )
122 {
123 fprintf(stderr,"writeback failed !\n");
124 exit(1);
125 }
126 if (!x_taken)
127 {
128 fprintf(stderr,"exception not taken !\n");
129 exit(1);
130 }
131 fprintf(stderr,"vmtest Ok\n");
132 exit(0);
133}
134
135
Note: See TracBrowser for help on using the repository browser.