1 | Patrick Beard's Notes for building GC v4.12 with CodeWarrior Pro 2:
|
---|
2 | ----------------------------------------------------------------------------
|
---|
3 | The current build environment for the collector is CodeWarrior Pro 2.
|
---|
4 | Projects for CodeWarrior Pro 2 (and for quite a few older versions)
|
---|
5 | are distributed in the file Mac_projects.sit.hqx. The project file
|
---|
6 | :Mac_projects:gc.prj builds static library versions of the collector.
|
---|
7 | :Mac_projects:gctest.prj builds the GC test suite.
|
---|
8 |
|
---|
9 | Configuring the collector is still done by editing the files
|
---|
10 | :Mac_files:MacOS_config.h and :Mac_files:MacOS_Test_config.h.
|
---|
11 |
|
---|
12 | Lars Farm's suggestions on building the collector:
|
---|
13 | ----------------------------------------------------------------------------
|
---|
14 | Garbage Collection on MacOS - a manual 'MakeFile'
|
---|
15 | -------------------------------------------------
|
---|
16 |
|
---|
17 | Project files and IDE's are great on the Macintosh, but they do have
|
---|
18 | problems when used as distribution media. This note tries to provide
|
---|
19 | porting instructions in pure TEXT form to avoid those problems. A manual
|
---|
20 | 'makefile' if you like.
|
---|
21 |
|
---|
22 | GC version: 4.12a2
|
---|
23 | Codewarrior: CWPro1
|
---|
24 | date: 18 July 1997
|
---|
25 |
|
---|
26 | The notes may or may not apply to earlier or later versions of the
|
---|
27 | GC/CWPro. Actually, they do apply to earlier versions of both except that
|
---|
28 | until recently a project could only build one target so each target was a
|
---|
29 | separate project. The notes will most likely apply to future versions too.
|
---|
30 | Possibly with minor tweaks.
|
---|
31 |
|
---|
32 | This is just to record my experiences. These notes do not mean I now
|
---|
33 | provide a supported port of the GC to MacOS. It works for me. If it works
|
---|
34 | for you, great. If it doesn't, sorry, try again...;-) Still, if you find
|
---|
35 | errors, please let me know.
|
---|
36 |
|
---|
37 | mailto: lars.farm@ite.mh.se
|
---|
38 |
|
---|
39 | address: Lars Farm
|
---|
40 | Krönvägen 33b
|
---|
41 | 856 44 Sundsvall
|
---|
42 | Sweden
|
---|
43 |
|
---|
44 | Porting to MacOS is a bit more complex than it first seems. Which MacOS?
|
---|
45 | 68K/PowerPC? Which compiler? Each supports both 68K and PowerPC and offer a
|
---|
46 | large number of (unique to each environment) compiler settings. Each
|
---|
47 | combination of compiler/68K/PPC/settings require a unique combination of
|
---|
48 | standard libraries. And the IDE's does not select them for you. They don't
|
---|
49 | even check that the library is built with compatible setting and this is
|
---|
50 | the major source of problems when porting the GC (and otherwise too).
|
---|
51 |
|
---|
52 | You will have to make choices when you configure the GC. I've made some
|
---|
53 | choices here, but there are other combinations of settings and #defines
|
---|
54 | that work too.
|
---|
55 |
|
---|
56 | As for target settings the major obstacles may be:
|
---|
57 | - 68K Processor: check "4-byte Ints".
|
---|
58 | - PPC Processor: uncheck "Store Static Data in TOC".
|
---|
59 |
|
---|
60 | What you need to do:
|
---|
61 | ===================
|
---|
62 |
|
---|
63 | 1) Build the GC as a library
|
---|
64 | 2) Test that the library works with 'test.c'.
|
---|
65 | 3) Test that the C++ interface 'gc_cpp.cc/h' works with 'test_cpp.cc'.
|
---|
66 |
|
---|
67 | 1) The Libraries:
|
---|
68 | =================
|
---|
69 | I made one project with four targets (68K/PPC tempmem or appheap). One target
|
---|
70 | will suffice if you're able to decide which one you want. I wasn't...
|
---|
71 |
|
---|
72 | Codewarrior allows a large number of compiler/linker settings. I used these:
|
---|
73 |
|
---|
74 | Settings shared by all targets:
|
---|
75 | ------------------------------
|
---|
76 | o Access Paths:
|
---|
77 | - User Paths: the GC folder
|
---|
78 | - System Paths: {Compiler}:Metrowerks Standard Library:
|
---|
79 | {Compiler}:MacOS Support:Headers:
|
---|
80 | {Compiler}:MacOS Support:MacHeaders:
|
---|
81 | o C/C++ language:
|
---|
82 | - inlining: normal
|
---|
83 | - direct to SOM: off
|
---|
84 | - enable/check: exceptions, RTTI, bool (and if you like pool strings)
|
---|
85 |
|
---|
86 | PowerPC target settings
|
---|
87 | -----------------------
|
---|
88 | o Target Settings:
|
---|
89 | - name of target
|
---|
90 | - MacOS PPC Linker
|
---|
91 | o PPC Target
|
---|
92 | - name of library
|
---|
93 | o C/C++ language
|
---|
94 | - prefix file as described below
|
---|
95 | o PPC Processor
|
---|
96 | - Struct Alignment: PowerPC
|
---|
97 | - uncheck "Store Static Data in TOC" -- important!
|
---|
98 | I don't think the others matter, I use full optimization and its ok
|
---|
99 | o PPC Linker
|
---|
100 | - Factory Settings (SYM file with full paths, faster linking, dead-strip
|
---|
101 | static init, Main: __start)
|
---|
102 |
|
---|
103 |
|
---|
104 | 68K target settings
|
---|
105 | -------------------
|
---|
106 | o Target Settings:
|
---|
107 | - name of target
|
---|
108 | - MacOS 68K Linker
|
---|
109 | o 68K Target
|
---|
110 | - name of library
|
---|
111 | - A5 relative data
|
---|
112 | o C/C++ language
|
---|
113 | - prefix file as described below
|
---|
114 | o 68K Processor
|
---|
115 | - Code model: smart
|
---|
116 | - Struct alignment: 68K
|
---|
117 | - FP: SANE
|
---|
118 | - enable 4-Byte Ints -- important!
|
---|
119 | I don't think the others matter. I selected...
|
---|
120 | - enable: 68020
|
---|
121 | - enable: global register allocation
|
---|
122 | o IR Optimizer
|
---|
123 | - enable: Optimize Space, Optimize Speed
|
---|
124 | I suppose the others would work too, but haven't tried...
|
---|
125 | o 68K Linker
|
---|
126 | - Factory Settings (New Style MacsBug,SYM file with full paths,
|
---|
127 | A6 Frames, fast link, Merge compiler glue into segment 1,
|
---|
128 | dead-strip static init)
|
---|
129 |
|
---|
130 | Prefix Files to configure the GC sources
|
---|
131 | ----------------------------------------
|
---|
132 | The Codewarrior equivalent of commandline compilers -DNAME=X is to use
|
---|
133 | prefix-files. A TEXT file that is automatically #included before the first byte
|
---|
134 | of every source file. I used these:
|
---|
135 |
|
---|
136 | ---- ( cut here ) ---- gc_prefix_tempmem.h -- 68K and PPC -----
|
---|
137 | #include "gc_prefix_common.h"
|
---|
138 | #undef USE_TEMPORARY_MEMORY
|
---|
139 | #define USE_TEMPORARY_MEMORY
|
---|
140 | ---- ( cut here ) ---- gc_prefix_appmem.h -- 68K and PPC -----
|
---|
141 | #include "gc_prefix_common.h"
|
---|
142 | #undef USE_TEMPORARY_MEMORY
|
---|
143 | // #define USE_TEMPORARY_MEMORY
|
---|
144 |
|
---|
145 | ---- ( cut here ) ---- gc_prefix_common.h --------------------
|
---|
146 | // gc_prefix_common.h
|
---|
147 | // ------------------
|
---|
148 | // Codewarrior prefix file to configure the GC libraries
|
---|
149 | //
|
---|
150 | // prefix files are the Codewarrior equivalent of the
|
---|
151 | // command line option -Dname=x frequently seen in makefiles
|
---|
152 |
|
---|
153 | #if !__MWERKS__
|
---|
154 | #error only tried this with Codewarrior
|
---|
155 | #endif
|
---|
156 |
|
---|
157 | #if macintosh
|
---|
158 | #define MSL_USE_PRECOMPILED_HEADERS 0
|
---|
159 | #include <ansi_prefix.mac.h>
|
---|
160 | #ifndef __STDC__
|
---|
161 | #define __STDC__ 0
|
---|
162 | #endif
|
---|
163 |
|
---|
164 | // See list of #defines to configure the library in: 'MakeFile'
|
---|
165 | // see also README
|
---|
166 |
|
---|
167 | #define SILENT // no collection messages. In case
|
---|
168 | // of trouble you might want this off
|
---|
169 | #define ALL_INTERIOR_POINTERS // follows interior pointers.
|
---|
170 | //#define DONT_ADD_BYTE_AT_END // disables the padding if defined.
|
---|
171 | //#define SMALL_CONFIG // whether to use a smaller heap.
|
---|
172 | #define NO_SIGNALS // signals aren't real on the Macintosh.
|
---|
173 | #define ATOMIC_UNCOLLECTABLE // GC_malloc_atomic_uncollectable()
|
---|
174 |
|
---|
175 | // define either or none as per personal preference
|
---|
176 | // used in malloc.c
|
---|
177 | #define REDIRECT_MALLOC GC_malloc
|
---|
178 | //#define REDIRECT_MALLOC GC_malloc_uncollectable
|
---|
179 | // if REDIRECT_MALLOC is #defined make sure that the GC library
|
---|
180 | // is listed before the ANSI/ISO libs in the Codewarrior
|
---|
181 | // 'Link order' panel
|
---|
182 | //#define IGNORE_FREE
|
---|
183 |
|
---|
184 | // mac specific configs
|
---|
185 | //#define USE_TEMPORARY_MEMORY // use Macintosh temporary memory.
|
---|
186 | //#define SHARED_LIBRARY_BUILD // build for use in a shared library.
|
---|
187 |
|
---|
188 | #else
|
---|
189 | // could build Win32 here too, or in the future
|
---|
190 | // Rhapsody PPC-mach, Rhapsody PPC-MacOS,
|
---|
191 | // Rhapsody Intel-mach, Rhapsody Intel-Win32,...
|
---|
192 | // ... ugh this will get messy ...
|
---|
193 | #endif
|
---|
194 |
|
---|
195 | // make sure ints are at least 32-bit
|
---|
196 | // ( could be set to 16-bit by compiler settings (68K) )
|
---|
197 |
|
---|
198 | struct gc_private_assert_intsize_{ char x[ sizeof(int)>=4 ? 1 : 0 ]; };
|
---|
199 |
|
---|
200 | #if __powerc
|
---|
201 | #if __option(toc_data)
|
---|
202 | #error turn off "store static data in TOC" when using GC
|
---|
203 | // ... or find a way to add TOC to the root set...(?)
|
---|
204 | #endif
|
---|
205 | #endif
|
---|
206 | ---- ( cut here ) ---- end of gc_prefix_common.h -----------------
|
---|
207 |
|
---|
208 | Files to build the GC libraries:
|
---|
209 | --------------------------------
|
---|
210 | allchblk.c
|
---|
211 | alloc.c
|
---|
212 | blacklst.c
|
---|
213 | checksums.c
|
---|
214 | dbg_mlc.c
|
---|
215 | finalize.c
|
---|
216 | headers.c
|
---|
217 | mach_dep.c
|
---|
218 | MacOS.c -- contains MacOS code
|
---|
219 | malloc.c
|
---|
220 | mallocx.c
|
---|
221 | mark.c
|
---|
222 | mark_rts.c
|
---|
223 | misc.c
|
---|
224 | new_hblk.c
|
---|
225 | obj_map.c
|
---|
226 | os_dep.c -- contains MacOS code
|
---|
227 | ptr_chck.c
|
---|
228 | reclaim.c
|
---|
229 | stubborn.c
|
---|
230 | typd_mlc.c
|
---|
231 | gc++.cc -- this is 'gc_cpp.cc' with less 'inline' and
|
---|
232 | -- throw std::bad_alloc when out of memory
|
---|
233 | -- gc_cpp.cc works just fine too
|
---|
234 |
|
---|
235 | 2) Test that the library works with 'test.c'.
|
---|
236 | =============================================
|
---|
237 |
|
---|
238 | The test app is just an ordinary ANSI-C console app. Make sure settings
|
---|
239 | match the library you're testing.
|
---|
240 |
|
---|
241 | Files
|
---|
242 | -----
|
---|
243 | test.c
|
---|
244 | the GC library to test -- link order before ANSI libs
|
---|
245 | suitable Mac+ANSI libraries
|
---|
246 |
|
---|
247 | prefix:
|
---|
248 | ------
|
---|
249 | ---- ( cut here ) ---- gc_prefix_testlib.h -- all libs -----
|
---|
250 | #define MSL_USE_PRECOMPILED_HEADERS 0
|
---|
251 | #include <ansi_prefix.mac.h>
|
---|
252 | #undef NDEBUG
|
---|
253 |
|
---|
254 | #define ALL_INTERIOR_POINTERS /* for GC_priv.h */
|
---|
255 | ---- ( cut here ) ----
|
---|
256 |
|
---|
257 | 3) Test that the C++ interface 'gc_cpp.cc/h' works with 'test_cpp.cc'.
|
---|
258 |
|
---|
259 | The test app is just an ordinary ANSI-C console app. Make sure settings match
|
---|
260 | the library you're testing.
|
---|
261 |
|
---|
262 | Files
|
---|
263 | -----
|
---|
264 | test_cpp.cc
|
---|
265 | the GC library to test -- link order before ANSI libs
|
---|
266 | suitable Mac+ANSI libraries
|
---|
267 |
|
---|
268 | prefix:
|
---|
269 | ------
|
---|
270 | same as for test.c
|
---|
271 |
|
---|
272 | For convenience I used one test-project with several targets so that all
|
---|
273 | test apps are build at once. Two for each library to test: test.c and
|
---|
274 | gc_app.cc. When I was satisfied that the libraries were ok. I put the
|
---|
275 | libraries + gc.h + the c++ interface-file in a folder that I then put into
|
---|
276 | the MSL hierarchy so that I don't have to alter access-paths in projects
|
---|
277 | that use the GC.
|
---|
278 |
|
---|
279 | After that, just add the proper GC library to your project and the GC is in
|
---|
280 | action! malloc will call GC_malloc and free GC_free, new/delete too. You
|
---|
281 | don't have to call free or delete. You may have to be a bit cautious about
|
---|
282 | delete if you're freeing other resources than RAM. See gc_cpp.h. You can
|
---|
283 | also keep coding as always with delete/free. That works too. If you want,
|
---|
284 | "include <gc.h> and tweak it's use a bit.
|
---|
285 |
|
---|
286 | Symantec SPM
|
---|
287 | ============
|
---|
288 | It has been a while since I tried the GC in SPM, but I think that the above
|
---|
289 | instructions should be sufficient to guide you through in SPM too. SPM
|
---|
290 | needs to know where the global data is. Use the files 'datastart.c' and
|
---|
291 | 'dataend.c'. Put 'datastart.c' at the top of your project and 'dataend.c'
|
---|
292 | at the bottom of your project so that all data is surrounded. This is not
|
---|
293 | needed in Codewarrior because it provides intrinsic variables
|
---|
294 | __datastart__, __data_end__ that wraps all globals.
|
---|
295 |
|
---|
296 | Source Changes (GC 4.12a2)
|
---|
297 | ==========================
|
---|
298 | Very few. Just one tiny in the GC, not strictly needed.
|
---|
299 | - MacOS.c line 131 in routine GC_MacFreeTemporaryMemory()
|
---|
300 | change # if !defined(SHARED_LIBRARY_BUILD)
|
---|
301 | to # if !defined(SILENT) && !defined(SHARED_LIBRARY_BUILD)
|
---|
302 | To turn off a message when the application quits (actually, I faked
|
---|
303 | this change by #defining SHARED_LIBRARY_BUILD in a statically linked
|
---|
304 | library for more than a year without ill effects but perhaps this is
|
---|
305 | better).
|
---|
306 |
|
---|
307 | - test_cpp.cc
|
---|
308 | made the first lines of main() look like this:
|
---|
309 | ------------
|
---|
310 | int main( int argc, char* argv[] ) {
|
---|
311 | #endif
|
---|
312 | #if macintosh // MacOS
|
---|
313 | char* argv_[] = {"test_cpp","10"}; // doesn't
|
---|
314 | argv=argv_; // have a
|
---|
315 | argc = sizeof(argv_)/sizeof(argv_[0]); // commandline
|
---|
316 | #endif //
|
---|
317 |
|
---|
318 | int i, iters, n;
|
---|
319 | # ifndef __GNUC__
|
---|
320 | alloc dummy_to_fool_the_compiler_into_doing_things_it_currently_cant_handle;
|
---|
321 | ------------
|
---|
322 |
|
---|
323 | - config.h [now gcconfig.h]
|
---|
324 | __MWERKS__ does not have to mean MACOS. You can use Codewarrior to
|
---|
325 | build a Win32 or BeOS library and soon a Rhapsody library. You may
|
---|
326 | have to change that #if...
|
---|
327 |
|
---|
328 |
|
---|
329 |
|
---|
330 | It worked for me, hope it works for you.
|
---|
331 |
|
---|
332 | Lars Farm
|
---|
333 | 18 July 1997
|
---|
334 | ----------------------------------------------------------------------------
|
---|
335 |
|
---|
336 |
|
---|
337 | Patrick Beard's instructions (may be dated):
|
---|
338 |
|
---|
339 | v4.3 of the collector now runs under Symantec C++/THINK C v7.0.4, and
|
---|
340 | Metrowerks C/C++ v4.5 both 68K and PowerPC. Project files are provided
|
---|
341 | to build and test the collector under both development systems.
|
---|
342 |
|
---|
343 | Configuration
|
---|
344 | -------------
|
---|
345 |
|
---|
346 | To configure the collector, under both development systems, a prefix file
|
---|
347 | is used to set preprocessor directives. This file is called "MacOS_config.h".
|
---|
348 | Also to test the collector, "MacOS_Test_config.h" is provided.
|
---|
349 |
|
---|
350 | Testing
|
---|
351 | -------
|
---|
352 |
|
---|
353 | To test the collector (always a good idea), build one of the gctest projects,
|
---|
354 | gctest.¹ (Symantec C++/THINK C), mw/gctest.68K.¹, or mw/gctest.PPC.¹. The
|
---|
355 | test will ask you how many times to run; 1 should be sufficient.
|
---|
356 |
|
---|
357 | Building
|
---|
358 | --------
|
---|
359 |
|
---|
360 | For your convenience project files for the major Macintosh development
|
---|
361 | systems are provided.
|
---|
362 |
|
---|
363 | For Symantec C++/THINK C, you must build the two projects gclib-1.¹ and
|
---|
364 | gclib-2.¹. It has to be split up because the collector has more than 32k
|
---|
365 | of static data and no library can have more than this in the Symantec
|
---|
366 | environment. (Future versions will probably fix this.)
|
---|
367 |
|
---|
368 | For Metrowerks C/C++ 4.5 you build gc.68K.¹/gc.PPC.¹ and the result will
|
---|
369 | be a library called gc.68K.lib/gc.PPC.lib.
|
---|
370 |
|
---|
371 | Using
|
---|
372 | -----
|
---|
373 |
|
---|
374 | Under Symantec C++/THINK C, you can just add the gclib-1.¹ and gclib-2.¹
|
---|
375 | projects to your own project. Under Metrowerks, you add gc.68K.lib or
|
---|
376 | gc.PPC.lib and two additional files. You add the files called datastart.c
|
---|
377 | and dataend.c to your project, bracketing all files that use the collector.
|
---|
378 | See mw/gctest.¹ for an example.
|
---|
379 |
|
---|
380 | Include the projects/libraries you built above into your own project,
|
---|
381 | #include "gc.h", and call GC_malloc. You don't have to call GC_free.
|
---|
382 |
|
---|
383 |
|
---|
384 | Patrick C. Beard
|
---|
385 | January 4, 1995
|
---|