source: trunk/src/binutils/mpw-README@ 821

Last change on this file since 821 was 10, 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: 14.5 KB
Line 
1This is basic information about the Macintosh(tm) MPW(tm) port of the
2GNU tools. The information below applies to both native and cross
3compilers.
4
5(Please note that there are two versions of this file; "mpw-README"
6is the source form, and "Read Me for MPW" is the distribution form.
7"Read Me for MPW" has 8-bit chars such as \Option-d embedded in it.)
8
9INSTALLING GNU TOOLS
10
11* System Requirements
12
13To use these tools, you will need a Mac with a 68020 or better or else
14any PowerMac, System 7.1 or later, and MPW 3.3 or 3.4. You will *not*
15need any other MPW compiler unless you want to rebuild from sources,
16nor even any include files, unless you are building actual Mac
17applications. For PowerMac native you will need PPCLink, however;
18also the executables are PowerPC-only.
19
20* Automated Installation
21
22The simplest way to install GNU tools is to run the Install script.
23The script will copy things to where you want to keep them, will build
24a UserStartup file with settings corresponding to where things were
25copied, and offer to put that UserStartup file in your MPW folder.
26
27The Install script does not alter anything in the System Folder, and
28it does not take any action without confirmation.
29
30The Install script will be at the top level of the binary
31distribution, or at the top level of the object directory if
32rebuilding from source. (The sources include a file called
33"mpw-install" at the top level, but it is the source to the Install
34script and cannot be run directly.)
35
36* Manual Installation
37
38If you don't want to run the Install script, you can do installation
39manually; this section describes the steps involved.
40
41The GNU tools can go in any directory that is in your {Commands} list.
42We generally put all the tools somewhere like {Boot}Cygnus:latest:bin,
43and then add to a UserStartup file:
44
45 set Commands "{Boot}Cygnus:latest:bin:,{Commands}"
46
47However, the cpp and cc1 programs of GCC are not normally stored here.
48Instead, they will be in a "lib" directory that is alongside "bin",
49and organized by target and version underneath, with names like
50
51 :lib:gcc-lib:<target>:cygnus-<version>:
52
53If you build and install everything yourself according to the build
54instructions below, then you will not have any problems. However, you
55may discover that GCC seems unable to find the right cpp and cc1;
56usually this will be because directory names have changed. (Even
57renaming your hard disk will make this happen.) In such cases, you
58have several choices. One is just to add this directory to
59{Commands}, but then you will not be able to get any other cpp or cc1,
60such as those used by a different target or version. Another way is
61to rename your disk and directories to match the prefix used when the
62tools were compiled. Finally, you can set the variable
63GCC_EXEC_PREFIX to point to the library directory:
64
65 set GCC_EXEC_PREFIX MyDisk:Stuff:lib:gcc-lib:
66 export GCC_EXEC_PREFIX
67
68You may also want to edit MPW's HEXA 128 resource. When GCC is built
69using a native GCC, it is compiled to use a special stack allocator
70function alloca(). While this is very efficient, it means that GCC
71will need considerable stack space to run, especially when compiling
72large programs with optimization turned on. You give MPW more stack
73by editing the HEXA 128 resource of the MPW Shell. A value of "0008
740000" gives 512K of stack size, which is usually sufficient.
75
76USING GNU TOOLS
77
78* Using Native PowerMac GCC
79
80Using a native PowerMac GCC to produce MPW tools or MacOS applications
81is more complicated than just "gC foo.c", although no more complicated
82than with other Mac compilers.
83
84To build a native PowerMac MPW tool, use this sequence, where hello.c
85is the usual "hello world" program, and genericcfrg.r is the Rez file
86with the code fragment resource:
87
88gC -I{CIncludes} -fno-builtin -Dpascal= -c -g hello.c
89PPCLink hello.o -o hello \Option-d
90 "{PPCLibraries}"StdCRuntime.o \Option-d
91 "{SharedLibraries}"InterfaceLib \Option-d
92 "{SharedLibraries}"StdCLib \Option-d
93 "{PPCLibraries}"PPCToolLibs.o \Option-d
94 "{PPCLibraries}"PPCCRuntime.o \Option-d
95 "{GCCPPCLibraries}"libgcc.xcoff
96rez -d APPNAME='"'hello'"' GenericCFRG.r -o hello
97setfile -t 'MPST' -c 'MPS ' hello
98
99The same sequence works to build a MacOS application, but you set the file
100type to 'APPL' and don't link in PPCToolLibs.o. For further details on
101using MPW to build Mac applications, see the general MPW documentation.
102
103Recent versions of PPCLink have an option to generate the code
104fragment resource and automatically set creator and file type;
105here is what GenericCFRG.r should look like if you have an older
106PPCLink or are using GNU ld:
107
108#include "CodeFragmentTypes.r"
109
110resource 'cfrg' (0) {
111 {
112 kPowerPC,
113 kFullLib,
114 kNoVersionNum,kNoVersionNum,
115 0,0,
116 kIsApp,kOnDiskFlat,kZeroOffset,kWholeFork,
117 APPNAME // must be defined on Rez command line with -d option
118 }
119};
120
121In general this port of GCC supports the same option syntax and
122behavior as its Unix counterpart. It also has similar compilation
123rules, so it will run the assembler on .s files and so forth.
124
125The GCC manual includes full information on the available options.
126One option that may be especially useful is "-v", which shows you what
127tools and options are being used; unlike most Mac C compilers, GCC
128directs assembly and linking in addition to compilation.
129
130MPW GCC does feature two extensions to the option syntax; '-d macro=name'
131works just as '-Dmacro=name' does in Unix, and '-i directory' works the
132same as '-Idirectory'.
133
134MPW GCC supports the usual Pascal-style strings and alignment pragmas.
135
136To find standard include files you can set the variable GCCIncludes:
137
138 set GCCIncludes MyDisk:MyIncludes:
139 export GCCIncludes
140
141GCCIncludes is similar to MPW's CIncludes or CW's MWCIncludes. In
142order to use MPW's usual include files, just say:
143
144 set GCCIncludes "{CIncludes}"
145 export GCCIncludes
146
147* Using GCC as a Cross-Compiler
148
149If you have a cross-compiler, and you have all of the correct
150target-side crt0 and libraries available, then to compile and link a
151file "foo.c", you can say just
152
153 gC foo.c
154
155The output file will be an MPW binary file named "a.out"; the format
156of the contents will depend on which target is in use, so for instance
157a MIPS-targeting GCC will produce ECOFF or ELF executables.
158
159Note that using MPW include files with a cross-compiler is somewhat
160dangerous.
161
162* Using the Assembler and Friends
163
164The assembler ("as") and linker ("ld") are faithful ports of their
165Unix counterparts. Similarly, the binutils "ar", "cplusfilt", "nm",
166"objcopy", "objdump", "ranlib", "size", "strings", and "strip" are all
167like they are under Unix. (Note that "cplusfilt" is usually called
168"c++filt" under Unix.)
169
170* Using GDB
171
172There are two flavors of GDB. "gdb" is an MPW tool that works very
173much like it does in Unix; put a command into the MPW worksheet and
174type the <enter> key to send it to GDB. While "gdb" is running, you
175cannot do anything else in MPW, although you can switch to other
176Mac applications and use them.
177
178"SiowGDB" is also a Mac application, but it is GDB using the SIOW
179package to provide console emulation. Commands are exactly as for the
180MPW tool, but since this is its own application, you can switch
181between it and MPW.
182
183BUILDING GNU TOOLS
184
185This port of the GNU tools uses a configure script similar to
186that used for GNU tools under Unix, but rewritten for MPW. As with
187Unix configuration, there is an "object" directory that may be
188different from the "source" directory. In the example commands below,
189we will assume that we are currently in the object directory, and that
190the source directory is "{Boot}Cygnus:src:".
191
192* Requirements for Building
193
194In addition to the sources, you will need a set of tools that the
195configure and build scripts assume to be available. These tools
196(and their versions, if relevant) are as follows:
197
198 byacc tool
199 flex (2.3.7) tool (and Flex.skel file)
200 forward-include script
201 MoveIfChange script
202 mpw-touch script
203 mpw-true script
204 NewFolderRecursive script
205 null-command script
206 open-brace script
207 sed (1.13) tool
208 tr-7to8 script
209 true script
210
211The scripts are in the sources, under utils:mpw:. You must arrange to
212get the other tools yourself (they are readily available from the
213"usual" net sites, and are also on many CDROMS). In addition, there
214will usually be a set of these available at ftp.cygnus.com, in pub/mac.
215
216You may put the build tools in your usual Tools or Scripts
217directories, or keep them in a separate directories. We prefer to
218make a directory called "buildtools" and we put this in one of our
219UserStartup files:
220
221 set Commands "{Boot}Cygnus:buildtools:,{Commands}"
222
223Flex uses an environment variable FLEX_SKELETON to locate its skeleton
224file, so you need to do something like this, preferably in a UserStartup:
225
226 Set FLEX_SKELETON "{Boot}"Cygnus:buildtools:Flex.skel
227 Export FLEX_SKELETON
228
229* Configuring
230
231Before you can build anything, you must configure. You do this by
232creating an directory where object files will be stored, setdirectory
233to that directory and do a configure command:
234
235 {Boot}Cygnus:src:mpw-configure --target <name> --cc <compiler> --srcdir {Boot}Cygnus:src: --prefix <whatever>
236
237If the source directory is not in your {Commands} list, then you must
238supply a full pathname to mpw-configure, since mpw-configure invokes
239itself after switching into each subdirectory. Using a relative
240pathname, even something like ':mpw-configure', will therefore not work.
241
242<name> must be a known target. Valid ones include "m68k-apple-macos",
243"powerpc-apple-macos", "i386-unknown-go32", "mips-idt-ecoff", and
244"sh-hitachi-hms". Not all target types are accepted for all of the
245tools yet.
246
247<compiler> must be the name of the compiler to use. It defaults to "mpwc".
248
249 (m68k)
250 mpwc MPW C
251 sc68k Symantec C
252 mwc68k Metrowerks C (Codewarrior)
253 gcc68k GCC
254
255 (powerpc)
256 ppcc PPCC
257 mrc Macintosh on RisC (Mister C, aka(?) Frankenstein)
258 scppc Symantec C
259 mwcppc Metrowerks C (Codewarrior)
260 gccppc GCC
261
262Not all compilers will compile all tools equally well! For m68k Macs,
263MPW C has the best record so far (it has problems, but they can be
264worked around), while for PowerMacs, CodeWarrior is the only compiler
265that has successfully compiled everything into running code.
266
267<prefix> is the path that "gcc" will prepend when looking for tools
268to execute. GCC_EXEC_PREFIX overrides this value, so you need not
269include it if you plan to use GCC_EXEC_PREFIX.
270
271As an example, here is the configure line that you could use to build
272native PowerMac GCC:
273
274"{Boot}"Cygnus:src:mpw-configure --cc mwcppc --target powerpc-apple-macos --srcdir "{Boot}"Cygnus:src: --prefix "{Boot}"GNUTools:
275
276* Building
277
278If you use CodeWarrior, you *must* first set MWCIncludes to
279{CIncludes}. This is because you will be building MPW tools, and
280their standard I/O works by making references to data that is part of
281the MPW Shell, which means that the code must be compiled and linked
282with macros that refer to that data, and those macros are in
283{CIncludes}, not the default {MWCIncludes}. Without this change, you
284will encounter problems compiling libiberty/mpw.c, but tweaking that
285file only masks the real problem, and does not fix it.
286
287The command
288
289 mpw-build
290
291will build everything. Building will take over an hour on a Quadra 800
292or PowerMac 8100/110, longer if the sources are on a shared volume.
293
294You may see some warnings; these are mostly likely benign, typically
295disagreements about declarations of library and system functions.
296
297* Installing
298
299To install the just-built tools, use the command
300
301 mpw-build install
302
303This part of the installation procedure just copies files to the
304location specified at configure time by <prefix>, and, in some cases,
305renames them from temporary internal names to their usual names. This
306install process is *not* the same as what the Install script does;
307Install can copy tools from the installation location chosen at
308configuration time to a user-chosen place, and sets up a UserStartup
309file. Note that while the Install script is optional, the install
310build action performs some tasks would be very hard to replicate
311manually, so you should always do it before using the tools.
312
313* Known Problems With Using Various Compilers to Build
314
315Most versions of MPW C have problems with compiling GNU software.
316
317MPW C 3.2.x has preprocessing bugs that render it incapable of
318compiling the BFD library, so it can't be used at all for building BFD.
319
320MPW C 3.3, 3.3.1, and 3.3.2 will spontaneously claim to have found
321errors in the source code, but in fact the code is perfectly fine. If
322this happens, just set the working directory back to the top-level
323objdir (where the configure command above was performed), and type
324"mpw-build all" again. If it goes on through the supposed error, then
325you got one of the spurious errors. A full build may require a number
326of these restarts.
327
328MPW C 3.3.3 seems to work OK, at least with the aid of a number of
329workarounds that are in the sources (look for #ifdef MPW_C).
330
331Versions of MPW Make earlier than 4.0d2 have exhibited bizarre behavior,
332failure to substitute variables and the like.
333
334Metrowerks CW6 PPC linker (MWLinkPPC) seems to do bad things with memory
335if the "Modern Memory Manager" is turned on (in the Memory control panel),
336but works OK if it is turned off.
337
338Metrowerks CW6 loses bigtime compiling opcodes:ppc-opc.c, which has
339some deeply nested macros. (CW7 is OK.) There is a way to patch the
340file, by substituting constant values. If you need to do this,
341contact shebs@cygnus.com for details.
342
343<Gestalt.h> is missing from {CIncludes} in the MPW version that comes
344with CW7. You can just copy the one in CW7's {MWCIncludes}.
345
346CW8 and later have changes to headers and such that will require changes
347to the source in order to be able to use them to rebuild.
348
349KNOWN BUGS
350
351The declarations for memcpy and memcmp in some versions of header files
352may conflict with GCC's builtin definition. Either use -fno-builtin
353or ignore the warnings.
354
355This is not a bug, but - watch out for cr/nl translation! For instance,
356if config/mpw-mh-mpw is not properly translated because it has been
357copied or updated separately, then everything will almost build, but
358you will get puzzling error messages from make or the compiler.
359
360'/' or ' ' embedded in any device, directory, or file name may or may
361not work.
362
363objcopy -O srec foo.o makes random output filenames.
364
365Mac-x-mips requires -mgas but Unix hosts don't.
366
367GDB will frequently require a '/' on the front of a device name in order
368to recognize it as an absolute rather than a relative pathname.
369
370GDB doesn't seem to use the printer port correctly, although it tries.
371
372The cursor doesn't always spin as much as it should. To get elaborate
373statistics and warnings about spin rates, add this to UserStartup:
374
375 set MEASURE_SPIN all
376 export MEASURE_SPIN
Note: See TracBrowser for help on using the repository browser.