Fixed binary search: no more infinite loops when vendor is unknown.
[tangerine.git] / tools / sfdc / SFDCompile.pod
blob21b55fa03015af2b310adfb300344aa0dd4b925d
2 ### Help message and manual page ##############################################
4 __END__
6 =head1 NAME
8 sfdc - Compile SFD files into someting useful
10 =head1 SYNOPSIS
12 sfdc [options] file1.sfd [file2.sfd ...]
14   Options:
15     --addvectors=TYPE       Add default functions
16     --gateprefix=PREFIX     Prefix for gatestub functions
17     --help -h               Show full help message and exit
18     --libarg=LOCATION       Where to pass the libbase
19     --libprefix=PREFIX      Prefix for library functions
20     --man                   Show full manual page and exit
21     --mode=MODE             What to do
22     --output=FILE -o FILE   Where to store the output
23     --quiet -q              Be quiet
24     --target=TARGET         Specifies the machine target
25     --version -v            Show version and exit
27 =head1 OPTIONS
29 =over 8
32 =item B<--addvectors>
34 This flag adds the standard library/device/BOOPSI functions to the
35 list of function entries to process. Possible values are B<none>,
36 B<library>, B<device> and B<boopsi>. The default is B<none>. Useful
37 when generating gate stub functions.
40 =item B<--gateprefix>
42 Sets a function name prefix for the gate stub functions when
43 generating gatestubs or gateproto files.
46 =item B<--help>
48 Show the full help message and exit.
50     
51 =item B<--libarg>
53 Specifies where to place the library base argument when generating
54 gatestubs or gateproto and libproto files. Possible values are
55 B<none>, B<first> and B<last>. The default is B<none>.
58 =item B<--libprefix>
60 Sets a function name prefix for the local library functions when
61 generating gatestubs or libproto files.
64 =item B<--man>
66 Show the complete manual page and exit.
69 =item B<--mode>
71 Instructs F<sfdc> what to do. F<sfdc> can handle the
72 following arguments:
74 =over 4
76 =item B<clib>
78 Generate C prototypes to be placed in F<Include/clib/>.
81 =item B<dump>
83 Dumps all information gathered from the SFD file.
86 =item B<fd>
88 Generate an old-style FD file.
90     
91 =item B<gateproto>
93 Generate a prototype header file for library gate stubs. Useful for
94 library and device developers.
97 =item B<gatestubs>
99 Generate library gate stubs. Useful for library and device developers.
102 =item B<libproto>
104 Generate a prototype header file for library functions. This is almost
105 like B<clib>, but for internal use by library and device developers.
108 =item B<lvo>
110 Generate an assembler LVO include file.
113 =item B<macros>
115 Generate a header file containing F<gcc> specific preprocessor macros,
116 similar to F<fd2inline>'s B<--new> switch. For AROS targets, it
117 generates a file suitable to be placed in the F<Include/defines/>
118 directory.
120     
121 =item B<proto>
123 Generate header file to be placed in F<Include/proto/> that includes
124 the C prototypes as well as compiler-specific inlines or pragma files.
127 =item B<pragmas>
129 Generate a F<SAS/C>/F<LATTICE>/F<DICE> and F<Maxon C>/F<Storm
130 C>/F<Aztec C> pragma file.
133 =item B<stubs>
135 Generate C library stubs suitable to be compiled and archived into
136 F<libamiga.a>, F<libamigastubs.a> or
137 F<libI<E<lt>moduleE<gt>>.a>. Using the B<%f> escape sequence in the
138 B<--output> switch or a tool like F<splitasm.awk> strongly is
139 recommended.
141 =item B<verify>
143 Just loads and parses the SFD file. This is the default.
145 =back
148 =item B<--output> 
150 Specifies where the result will be stored. The following escape
151 sequencies are allowed in the file name. If the sequence B<%f> is
152 present in the name, a new file will be created for each function
153 processed.
155 =over 4
157 =item B<%b>
159 The library base variable name (C<DOSBase>, for example).
161 =item B<%f>
163 The current funcion name (C<Open>, for example).
165 =item B<%l>
167 The name of the library or device (F<dos.library>, for example).
169 =item B<%n>
171 The base name of the library or device (C<dos>, for example).
173 =back
175 If omitted, the result will be sent to the standard output instead of
176 a file.
178 =item B<--quiet>
180 Be quiet.
183 =item B<--target>
185 Specifies the target when generating macros etc. The target names
186 follow the GNU autoconf standard. Some possible values are listed
187 below. The default is B<m68k-unknown-amigaos>.
189 =over 4
191 =item B<i?86-pc-aros>, B<i?86-linux-aros>, B<ppc-aros> ...
193 AROS. Anything goes, as long as it ends in C<-aros>.
196 =item B<i?86be-pc-amithlon>, B<i?86be-amithlon>
198 Amithlon/big endian IA32.
201 =item B<m68k-unknown-amigaos>, B<m68k-amigaos>
203 Traditional AmigaOS/m68k.
206 =item B<powerpc-unknown-morphos>, B<ppc-morphos>
208 MorphOS/PowerPC.
211 =back
215 =item B<--version>
217 Prints the version and exits.
220 =back
222 =head1 DESCRIPTION
224 F<sfdc> is an open source replacement for Amiga, Inc.'s F<sfd> tool,
225 distributed with B<NDK 3.9>. It is also an replacement for
226 F<fd2inline> from GeekGadgets and the MorphOS team, later improved to
227 death by Martin Blom. It's now a complete mess and needs a
228 replacement. SFD files and F<sfdc> might to be a good start.
230 For developers using F<gcc>, F<sfdc> aims to handle all your needs
231 when it comes to libraries, devices, datatypes, BOOPSI classes or
232 similar modules. F<sfdc> can also generate F<SAS/C>, F<DICE> and
233 F<Storm C> files for end users of such modules.
235 The basis for all work performed by F<sfdc> is the B<SFD> file, which
236 contains all required information about the module and the functions
237 provided. From this information, F<sfdc> can:
239 =over 4
241 =item *
243 Generate an old-style B<FD> file for futher processing with other tools.
246 =item *
248 Generate a B<C prototype file>, such as those normally found in the
249 F<Include/clib/> directory.
252 =item *
254 Generate F<gcc> B<inlines> (actually preprocessor macros) or
255 B<pragmas> for direct library function calls (without going via
256 library stubs).
259 =item *
261 Generate the F<Include/proto/> file, which includes the
262 F<Include/clib/> file and either the inlines or pragmas.
265 =item *
267 Generate an B<assembler LVO> file, which contains the library offset
268 of all functions in the library.
271 =item *
273 Generate B<C stubs>, which can be compiled and archived into a stub
274 library.
277 =item *
279 Generate library B<gateway stubs>, which can be used as part of your
280 module as glue between the module function table and your C functions.
283 =back
286 Additionally, F<sfdc> does all this for several Amiga-like operating
287 systems: traditional B<AmigaOS>, native B<Amithlon>, B<AROS> and
288 B<MorphOS>.
290 F<sfdc> uses F<autoconf> style identifies for the operating systems,
291 making it easy to generate the correct output. Just make sure
292 F<configure.in> contains the B<AC_CANONICAL_SYSTEM> command and use
293 B<@host@> in your F<Makefile.in>. Using F<autoconf> and F<sfdc>, it's
294 easy to make for example a library that can be compiled or
295 cross-compiiled for any of the mentioned architectures.
298 =head1 RETURN VALUE
300 Returns 0 on success and 10 on errors.
303 =head1 NOTES
305 Had I seen F<cvinclude.pl> before I started writing this program, I
306 might stillĀ have been using fd/clib files. Or maybe not.
308 =head1 AUTHOR
310 Martin Blom <martin@blom.org>
312 =head1 HISTORY
314 =item B<1.0 (2003-07-27)>
316 Initial release.
319 =item B<1.1 (2003-12-22)>
321 Added workaround for workbench.library (base name is "wb").
322 Added AmigaOS 4 support.
323 Added the --addvectors switch.
326 =item B<1.2 (2004-06-16)>
328 Generates files for mathieeedoub*, though probably broken. Well they
329 are the same as fd2inline generates at least.
332 =item B<1.2a (2004-06-20)>
334 Replace AROS_LP with AROS_LD. Because it is guaranteed to define the
335 function prototype. [verhaegs]
337 =item B<1.3 (2004-11-12)>
339 Correctly handle the argument C<type **arg>, where there is no
340 whitespace between the argument type and the argument name.
342 =item
344 Correctly handle the prototype C<void function (void)>, were there is
345 a whitespace between the function name and the parenthesis and "void"
346 is used to indicate no arguments.
348 =item
350 Replace C<-> with C<_> in base/library name.
352 =item
354 New special keyword for register specification (in addition to B<sysv>
355 and B<base>): B<autoreg>, which automatically allocates m68k registers
356 for the arguments.
358 =item
360 B<sysv> now works correctly with varargs functions. B<sysv> combined
361 with B<gatestubs> work for m68k and i386 only for now. For AROS
362 targets in B<macros>, the correct AROS macro is used to fetch the
363 function to be called.
365 =item
367 New B<--mode>: B<functable>. For proper code generation in AROS, make
368 sure gateprotos are included before you include the functable.
370 =item
372 B<proto> files now include F<Include/defines/> files when used in AROS.