OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [trunk/] [newlib/] [mpw-README] - Blame information for rev 1768

Go to most recent revision | Details | Compare with Previous | View Log

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

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.