| 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
|
|---|