marco f1c5e0c8f9 *version update to 3.2.0rc1 5 anni fa
..
aarch64 4fbb2d9cf0 --- Merging r42809 into '.': 5 anni fa
arm 1f20cfe991 Merge of several commits related to enhancements in PPU writing 5 anni fa
avr 1f20cfe991 Merge of several commits related to enhancements in PPU writing 5 anni fa
generic 1f20cfe991 Merge of several commits related to enhancements in PPU writing 5 anni fa
html fa0d3d79e0 no message 23 anni fa
i386 e70c001dad --- Merging r42115 into '.': 5 anni fa
i8086 3ac703506c * rest of the previous accidental partial commit 6 anni fa
jvm d24f4b0926 --- Merging r42998 into '.': 5 anni fa
llvm 3ac703506c * rest of the previous accidental partial commit 6 anni fa
m68k 030e93414c Merge commit r43165 5 anni fa
mips 1f20cfe991 Merge of several commits related to enhancements in PPU writing 5 anni fa
msg f1c5e0c8f9 *version update to 3.2.0rc1 5 anni fa
powerpc 1f20cfe991 Merge of several commits related to enhancements in PPU writing 5 anni fa
powerpc64 1f20cfe991 Merge of several commits related to enhancements in PPU writing 5 anni fa
ppcgen 22f48c207e 6 anni fa
sparc 1f20cfe991 Merge of several commits related to enhancements in PPU writing 5 anni fa
sparc64 1f20cfe991 Merge of several commits related to enhancements in PPU writing 5 anni fa
sparcgen 3ac703506c * rest of the previous accidental partial commit 6 anni fa
systems abe5757702 Merged revision(s) 44002 from trunk: 5 anni fa
utils 8efb6f8970 --- Merging r41184 into '.': 5 anni fa
x86 319b575012 -- Aufzeichnung der Informationen für Zusammenführung von r43503 in ».«: 5 anni fa
x86_64 1f20cfe991 Merge of several commits related to enhancements in PPU writing 5 anni fa
COPYING.txt e5a1231931 * updated FSF address (mantis #30198, patch by Paul Gevers) 8 anni fa
MPWMake 05d6f0e94d macos: added a fake sysutils for use by compiler, and fixed some tests 19 anni fa
Makefile f1c5e0c8f9 *version update to 3.2.0rc1 5 anni fa
Makefile.fpc f1c5e0c8f9 *version update to 3.2.0rc1 5 anni fa
README.txt 4bf254bc32 * added .txt extensions to all README, TODO and COPYING files 16 anni fa
aasmbase.pas 29558a74cd + support exporting labels from asm blocks in intel syntax asm blocks via the 7 anni fa
aasmcnst.pas edf32cd5dc The Important Ones: 6 anni fa
aasmdata.pas edf32cd5dc The Important Ones: 6 anni fa
aasmdef.pas c1db48c8c6 * add ability to disable the generation of an indirect symbol if needed (useful if that's done by the constant builder) 8 anni fa
aasmsym.pas a25ebbba3e + added volatility information to all memory references 8 anni fa
aasmtai.pas 22f48c207e 6 anni fa
aggas.pas 22f48c207e 6 anni fa
aopt.pas b1dff29cbf * removed unused units 8 anni fa
aoptbase.pas 7f286eb54e + define cpudelayslot: set during compiler compilation for CPUs having branch instructions with delay slot (MIPS, SPARC) 8 anni fa
aoptda.pas b1dff29cbf * removed unused units 8 anni fa
aoptobj.pas d8b0ded10c Marge of more trunk fixes into fixes branch. 6 anni fa
aoptutils.pas 4a43d992f5 * unified usage of MatchOpType 8 anni fa
assemble.pas 68eb921d46 * broken compilation after r39347 fixed 7 anni fa
blockutl.pas d24f4b0926 --- Merging r42998 into '.': 5 anni fa
browcol.pas 2370669f86 Avoid infinite recursion on generic classes for IDE browser 11 anni fa
catch.pas fd070544db - disabled installation of SIGINT signal handler for Darwin, because 16 anni fa
ccharset.pas 1f20cfe991 Merge of several commits related to enhancements in PPU writing 5 anni fa
cclasses.pas 68eb921d46 * broken compilation after r39347 fixed 7 anni fa
cfidwarf.pas 23ff1e0681 * fix error in cfidwarf rev 16062 for non-windows systems 15 anni fa
cfileutl.pas 153ddaffc9 --- Merging r43279 into '.': 5 anni fa
cg64f32.pas 256dc546ac + implemented the in_neg_assign_x and in_not_assign_x inline nodes, which will 8 anni fa
cgbase.pas b6e7ebdd3c -- Zusammenführen von r42272 in ».«: 5 anni fa
cghlcpu.pas 67b8aceaee * synchronized with privatetrunk till r30095 10 anni fa
cgobj.pas 846da37c9f --- Merging r41243 into '.': 6 anni fa
cgutils.pas 4686f61002 * keep track of the temp position separately from the offset in references, 7 anni fa
cmsgs.pas a34f531661 + implemented support for codepage aware compiler messages. It can be enabled 8 anni fa
comphook.pas 72e1443081 + don't abuse status.currentsourcepath to pass on PPU names if the source is unavailable, causes side effects with other frontends (like the IDE). Improved solution for Mantis #27588 10 anni fa
compiler.pas 576a50f690 * print used unit scopes 7 anni fa
compinnr.pas ab533f43aa # revisions: 43409,43473,43474,43482 5 anni fa
comprsrc.pas e6aed467b5 renamed script unit to cscript to avoid namespace conflict with univint package on Darwin. this makes it possible to build the textmode IDE on Darwin 7 anni fa
constexp.pas d081d9fdc0 Fix cycle for x86_64-win64 target with -Cr option 9 anni fa
cpid.pas 091627883f merge r14347 from cpstrnew branch by florian: 14 anni fa
crefs.pas 4d5119bf1c * fixes several issues which cause warnings by the dfa code when using it to detect uninitialized variables 11 anni fa
cresstr.pas b1dff29cbf * removed unused units 8 anni fa
cscript.pas 3dda26b3b5 * quote assembly filenames in Unix script, fixes sh errors with smartlinked small filenames like unitname(1), etc 7 anni fa
cstreams.pas 68eb921d46 * broken compilation after r39347 fixed 7 anni fa
cutils.pas ea32ddd5b2 * avoid overflows of execution weight 7 anni fa
cwindirs.pp 0bdd15e0da + added cwindirs for the time being to the compiler dir till a release with windirs in the rtl is released 14 anni fa
dbgbase.pas ecda183153 * revert r37968: it does more harm than good 7 anni fa
dbgcodeview.pas 600b460ecd + added new debug output option -godwarfomflinnum for generating line number 7 anni fa
dbgdwarf.pas d093d252d5 6 anni fa
dbgstabs.pas 3ac703506c * rest of the previous accidental partial commit 6 anni fa
dbgstabx.pas aa1be3276f - removed default value of _typ parameter of TAsmData.(Weak)RefAsmSymbol(): 9 anni fa
defcmp.pas 0f4e7b65b2 # revisions: 41843,41844,42700 5 anni fa
defutil.pas 858bf743ef --- Merging r43347 into '.': 5 anni fa
dirparse.pas 2e9c6f35ae - disable -Ooregvar for the LLVM-based x86-64 code generator, as it causes 8 anni fa
elfbase.pas b34ab6b279 * The MaybeSwapXXXHeader functions moved from ogelf to the elfbase unit, so they 7 anni fa
entfile.pas 1f20cfe991 Merge of several commits related to enhancements in PPU writing 5 anni fa
export.pas b1dff29cbf * removed unused units 8 anni fa
expunix.pas b1dff29cbf * removed unused units 8 anni fa
finput.pas 3e2248f41a + implemented exporting of functions for the win16 target 9 anni fa
fmodule.pas cbe9654b04 Merged revision(s) 44072-44074 from trunk: 5 anni fa
fpccrc.pas 793fd8fc09 * Add -Xg to help pages 17 anni fa
fpcdefs.inc 5fa93e2a1e ------------------------------------------------------------------------ 6 anni fa
fpcp.pas b1dff29cbf * removed unused units 8 anni fa
fpkg.pas e8ede4c3e2 Merged revision(s) 32508-32510, 32512 from branches/svenbarth/packages: 9 anni fa
fppu.pas cbe9654b04 Merged revision(s) 44072-44074 from trunk: 5 anni fa
gendef.pas f281ee339e Add obsolete prefix to cpu_ia64, system_ia64_win64 and system_ia64_embedded, ia64 specfic code has been removed in rev 30836 dated 2015-05-09 8 anni fa
globals.pas abccef11e0 # revisions: 41710,41711,41733,41734,41735,41736,41737,41738,41739,41740,41741,41743,41744,41745,41746,41750,41751,41752,41753,41754,41755,41757,41758,41759 6 anni fa
globstat.pas 9c8a2d29e1 # revisions: 40702,40703,40704,40747,40750,40765,41277,41535,41536,41537,41548,41549,41770 5 anni fa
globtype.pas 875af11d02 Merge of commits 39916, 39925 and 39963 6 anni fa
hlcg2ll.pas 3ac703506c * rest of the previous accidental partial commit 6 anni fa
hlcgobj.pas 3ac703506c * rest of the previous accidental partial commit 6 anni fa
htypechk.pas 3129605195 --- Merging r40180 into '.': 5 anni fa
impdef.pas 4431ba2c08 merged/updated AROS/i386 target to trunk from AROS branch, to support Marcus Sackrow's work on AROS support which will hopefully benefit all Amiga-like targets (classic, MorphOS) on the long run. Compiler only, RTL comes in the next run. 11 anni fa
import.pas b1dff29cbf * removed unused units 8 anni fa
ldscript.pas d79511f96e + Basic ld script parsing capabilities (barely enough to parse glibc2.1 'libc.so' files, lacks any error handling). 13 anni fa
link.pas 783273cf01 * merged the OpenBSD 6.5 fixes 6 anni fa
macho.pas 1f20cfe991 Merge of several commits related to enhancements in PPU writing 5 anni fa
machoutils.pas 1f20cfe991 Merge of several commits related to enhancements in PPU writing 5 anni fa
msgidx.inc eeb8c747d5 --- Merging r42499 into '.': 5 anni fa
msgtxt.inc eeb8c747d5 --- Merging r42499 into '.': 5 anni fa
nadd.pas 06ef4e6ca8 Merge of commits 43634 and 43635 for currency problems 5 anni fa
nbas.pas 338873d7a7 --- Merging r39785 into '.': 6 anni fa
ncal.pas 532410ef1f -- Zusammenführen von r43553 in ».«: 5 anni fa
ncgadd.pas b1dff29cbf * removed unused units 8 anni fa
ncgbas.pas 4686f61002 * keep track of the temp position separately from the offset in references, 7 anni fa
ncgcal.pas c4bcb45fea --- Merging r43650 into '.': 5 anni fa
ncgcnv.pas 3ac703506c * rest of the previous accidental partial commit 6 anni fa
ncgcon.pas b1dff29cbf * removed unused units 8 anni fa
ncgflw.pas 23b9dde397 Merge of commits 40142, 40189 and 40347 6 anni fa
ncghlmat.pas 0fc1fd6ac1 * replaced current_procinfo.currtrue/falselabel with storing the true/false 10 anni fa
ncginl.pas bbbaa39d79 ncginl: another approach to fix the same issue #39184 supposed to address. keep left.resultdef, but try to make the target def always ordinal of an equal size, so it ends up in a data register on m68k 7 anni fa
ncgld.pas 3ac703506c * rest of the previous accidental partial commit 6 anni fa
ncgmat.pas 8c5606b41d + support mmx shifting 7 anni fa
ncgmem.pas 3ac703506c * rest of the previous accidental partial commit 6 anni fa
ncgnstfl.pas 48ef33a8b3 * fixed interprocedural gotos for llvm 8 anni fa
ncgnstld.pas 3ac703506c * rest of the previous accidental partial commit 6 anni fa
ncgnstmm.pas 3ac703506c * rest of the previous accidental partial commit 6 anni fa
ncgobjc.pas b1dff29cbf * removed unused units 8 anni fa
ncgopt.pas b1dff29cbf * removed unused units 8 anni fa
ncgrtti.pas 9c8a2d29e1 # revisions: 40702,40703,40704,40747,40750,40765,41277,41535,41536,41537,41548,41549,41770 5 anni fa
ncgset.pas 92cd9502ef Merge of revisions 40277 6 anni fa
ncgutil.pas c4bcb45fea --- Merging r43650 into '.': 5 anni fa
ncgvmt.pas edf32cd5dc The Important Ones: 6 anni fa
ncnv.pas 8172b79be1 --- Merging r44055 into '.': 5 anni fa
ncon.pas aadd93847f -- Zusammenführen von r43620 in ».«: 5 anni fa
nflw.pas 3ac703506c * rest of the previous accidental partial commit 6 anni fa
ngenutil.pas 3ac703506c * rest of the previous accidental partial commit 6 anni fa
ngtcon.pas 858bf743ef --- Merging r43347 into '.': 5 anni fa
ninl.pas 3129605195 --- Merging r40180 into '.': 5 anni fa
nld.pas f42dffb36d --- Merging r39877 into '.': 6 anni fa
nmat.pas 94e6363b34 --- Merging r43560 into '.': 5 anni fa
nmem.pas 3ac703506c * rest of the previous accidental partial commit 6 anni fa
nobj.pas 3ac703506c * rest of the previous accidental partial commit 6 anni fa
nobjc.pas 68eb921d46 * broken compilation after r39347 fixed 7 anni fa
node.pas aadd93847f -- Zusammenführen von r43620 in ».«: 5 anni fa
nopt.pas 3318703ece * moved nf_typedaddr to addrnodeflags (anf_typedaddr) 7 anni fa
nset.pas 3ac703506c * rest of the previous accidental partial commit 6 anni fa
nutils.pas 858bf743ef --- Merging r43347 into '.': 5 anni fa
objcasm.pas 51209eac9c * fixed bootstrap for Darwin/ppc with FPC 3.0 (workaround for 9 anni fa
objcdef.pas b1dff29cbf * removed unused units 8 anni fa
objcgutl.pas 68eb921d46 * broken compilation after r39347 fixed 7 anni fa
objcutil.pas b1dff29cbf * removed unused units 8 anni fa
ogbase.pas 5782acc32d * patch by J. Gareth Moreton to fix 33909 7 anni fa
ogcoff.pas 2af5c9d508 * changed type used for section alignment from byte/shortint to longint, so the 7 anni fa
ogelf.pas b34ab6b279 * The MaybeSwapXXXHeader functions moved from ogelf to the elfbase unit, so they 7 anni fa
oglx.pas d4a4b9a57b * refactored the internal linker ar object reader object creation to allow using 10 anni fa
ogmacho.pas 2af5c9d508 * changed type used for section alignment from byte/shortint to longint, so the 7 anni fa
ogmap.pas b1dff29cbf * removed unused units 8 anni fa
ognlm.pas 2af5c9d508 * changed type used for section alignment from byte/shortint to longint, so the 7 anni fa
ogomf.pas 27c618b4c4 * Merged r40720 6 anni fa
omfbase.pas 6205e530aa Merge commits 39912, 39914, 40001, 40115, 40132 and 40163 6 anni fa
optbase.pas d8b0ded10c Marge of more trunk fixes into fixes branch. 6 anni fa
optconstprop.pas 3ac703506c * rest of the previous accidental partial commit 6 anni fa
optcse.pas 3ac703506c * rest of the previous accidental partial commit 6 anni fa
optdead.pas b1dff29cbf * removed unused units 8 anni fa
optdeadstore.pas b1dff29cbf * removed unused units 8 anni fa
optdfa.pas 0ad0cefeb3 --- Merging r40202 into '.': 6 anni fa
options.pas e70c001dad --- Merging r42115 into '.': 5 anni fa
optloadmodifystore.pas 9853c4a2a3 + enabled the load-modify-store optimization for the double argument version 8 anni fa
optloop.pas 21d785e41b * do not unroll loops if the counter variable is accessed outside the current scope 7 anni fa
opttail.pas b57c95043f + support overriding tdef/tsym methods with target-specific functionality: 11 anni fa
optutils.pas 3ac703506c * rest of the previous accidental partial commit 6 anni fa
optvirt.pas b1dff29cbf * removed unused units 8 anni fa
owar.pas d4a4b9a57b * refactored the internal linker ar object reader object creation to allow using 10 anni fa
owbase.pas 368ba47d6e * support writing more than 1024 zeros in tobjectwriter.writezeros 10 anni fa
owomflib.pas 6205e530aa Merge commits 39912, 39914, 40001, 40115, 40132 and 40163 6 anni fa
parabase.pas d69ad8fa41 * removed temppos field again from parameter locations: they're not allocated 7 anni fa
paramgr.pas 68eb921d46 * broken compilation after r39347 fixed 7 anni fa
parser.pas f2f4a29dbb * Merge r43604 to fix i8086-embedded utils compilation 5 anni fa
pass_1.pas b1dff29cbf * removed unused units 8 anni fa
pass_2.pas 3ac703506c * rest of the previous accidental partial commit 6 anni fa
pbase.pas 8bc0b604db * a symbol might be specified using a partial namespace path as long as the missing part is a namespace symbol, 7 anni fa
pcp.pas 1f20cfe991 Merge of several commits related to enhancements in PPU writing 5 anni fa
pdecl.pas 7062177e1b Merge of commit r44056 5 anni fa
pdecobj.pas c4b9529d6b # revisions: 42328,42329 5 anni fa
pdecsub.pas eeb8c747d5 --- Merging r42499 into '.': 5 anni fa
pdecvar.pas d24f4b0926 --- Merging r42998 into '.': 5 anni fa
pexports.pas 3b71841a84 Merged revision(s) 28691, 31914 from branches/svenbarth/packages: 9 anni fa
pexpr.pas a1f78b242a Merged revision(s) 44082 from trunk: 5 anni fa
pgentype.pas c81eda7a42 Fully enable generic functions, procedures and methods by allowing inline specializations in procedure bodies as well. 9 anni fa
pgenutil.pas cbe9654b04 Merged revision(s) 44072-44074 from trunk: 5 anni fa
pinline.pas f6a867ef04 * move handling of Concat to tinlinenode so that it can be easily extended for dynamic arrays 7 anni fa
pkgutil.pas 9eb5f07538 * check that the PPU version of a unit loaded for package adjustment matches exactly (we don't accept different versions when loading PPUs normally, so why should we with packages?) 7 anni fa
pmodules.pas d24f4b0926 --- Merging r42998 into '.': 5 anni fa
pp.lpi ed984e0c76 - removed missing file from project 8 anni fa
pp.pas 7cdb39b3f9 -- Aufzeichnung der Informationen für Zusammenführung von r43005 in ».«: 5 anni fa
pparautl.pas d24f4b0926 --- Merging r42998 into '.': 5 anni fa
ppc68k.lpi 9ebf2aa984 * project file updates 13 anni fa
ppc8086.lpi efc5e339d0 * use an enum instead of integer constants to represent inline numbers 8 anni fa
ppcaarch64.lpi 6e56f5c191 * fixed exe output path 9 anni fa
ppcarm.lpi 2e3a12c69d * version update 7 anni fa
ppcavr.lpi b9d4240a8d + version update 7 anni fa
ppcjvm.lpi ac819b0b97 * jvm lazarus project file properly named 12 anni fa
ppcmips.lpi 9ebf2aa984 * project file updates 13 anni fa
ppcmipsel.lpi 9ebf2aa984 * project file updates 13 anni fa
ppcppc.lpi 9ebf2aa984 * project file updates 13 anni fa
ppcppc64.lpi 9ebf2aa984 * project file updates 13 anni fa
ppcsparc.lpi 188ec0f0c7 + basics for sparc64 support, we continue to use the name "sparc" for sparc32, both sparc are identified by sparcgen (dirs, defines etc.) 8 anni fa
ppcsparc64.lpi 188ec0f0c7 + basics for sparc64 support, we continue to use the name "sparc" for sparc32, both sparc are identified by sparcgen (dirs, defines etc.) 8 anni fa
ppcx64.lpi cd9e18fab4 * made lazarus project names more systematic 7 anni fa
ppcx64llvm.lpi cd9e18fab4 * made lazarus project names more systematic 7 anni fa
ppheap.pas eefdf135a5 Always write filename, truncate directory part if needed 9 anni fa
ppu.pas 1f20cfe991 Merge of several commits related to enhancements in PPU writing 5 anni fa
procdefutil.pas 9c8a2d29e1 # revisions: 40702,40703,40704,40747,40750,40765,41277,41535,41536,41537,41548,41549,41770 5 anni fa
procinfo.pas 3ac703506c * rest of the previous accidental partial commit 6 anni fa
pstatmnt.pas 858bf743ef --- Merging r43347 into '.': 5 anni fa
psub.pas d24f4b0926 --- Merging r42998 into '.': 5 anni fa
psystem.pas ab533f43aa # revisions: 43409,43473,43474,43482 5 anni fa
ptconst.pas b1dff29cbf * removed unused units 8 anni fa
ptype.pas d24f4b0926 --- Merging r42998 into '.': 5 anni fa
raatt.pas 22f48c207e 6 anni fa
rabase.pas b7fe6797bf Merged revisions 2921-2922,2925 via svnmerge from 19 anni fa
rasm.pas 46fe2d486c * forgotten comment 7 anni fa
rautils.pas d1fc31de94 + add support for '[' and ']' parenthesis in addition to '(' and ')' in 7 anni fa
rescmn.pas 09e742f243 * add a -dfpc define to the resource compiler commandlines, which allows to make FPC specific exceptions in resource scripts. Mantis #24044 12 anni fa
rgbase.pas c8487c4150 + added individual bits of the x86 flags register as subregisters 8 anni fa
rgobj.pas ea32ddd5b2 * avoid overflows of execution weight 7 anni fa
scandir.pas 153ddaffc9 --- Merging r43279 into '.': 5 anni fa
scanner.pas 7062177e1b Merge of commit r44056 5 anni fa
switches.pas be0d51d64c * allow $MinEnumSize, $PackSet and $PackRecords to be used with $Push and $Pop 7 anni fa
symbase.pas fdb477df1e # revisions: 43566,43567,43568,43586,43629,43823 5 anni fa
symconst.pas f29598384b * Objective-Pascal inferred result type and improved category method searching 5 anni fa
symcreat.pas d24f4b0926 --- Merging r42998 into '.': 5 anni fa
symdef.pas cbe9654b04 Merged revision(s) 44072-44074 from trunk: 5 anni fa
symsym.pas d24f4b0926 --- Merging r42998 into '.': 5 anni fa
symtable.pas fdb477df1e # revisions: 43566,43567,43568,43586,43629,43823 5 anni fa
symtype.pas 1f20cfe991 Merge of several commits related to enhancements in PPU writing 5 anni fa
symutil.pas d24f4b0926 --- Merging r42998 into '.': 5 anni fa
syscinfo.pas d0f8ea7969 Add arm-palmos target to list supporting po_syscall 7 anni fa
systems.inc c4bcb45fea --- Merging r43650 into '.': 5 anni fa
systems.pas 7cdb39b3f9 -- Aufzeichnung der Informationen für Zusammenführung von r43005 in ».«: 5 anni fa
tgobj.pas 875af11d02 Merge of commits 39916, 39925 and 39963 6 anni fa
tokens.pas eeb8c747d5 --- Merging r42499 into '.': 5 anni fa
verbose.pas a34f531661 + implemented support for codepage aware compiler messages. It can be enabled 8 anni fa
version.pas f1c5e0c8f9 *version update to 3.2.0rc1 5 anni fa
widestr.pas c8839d487b * fixed accidentally committed (harmless) typo in r32202 9 anni fa
wpo.pas 060d81b8fa Merged revisions 11878,11881-11882,11889,11891-11893,11895,11899-11902,11935,11938,12212,12304,12308-12310,12316,12330-12332,12334,12339-12340 via svnmerge from 16 anni fa
wpobase.pas 5df9b994d1 * fix warnings which were caused by last changes to for node generation 8 anni fa
wpoinfo.pas b1dff29cbf * removed unused units 8 anni fa

README.txt

This directory contains the sources of the Free Pascal Compiler

If you want to compile/modify the compiler, please read first the
programmers manual.

To recompile the compiler, you can use the batch files :
+ mppc386.bat if you want to build a cross compiler from i386 to m68k
+ mppcsparc if you want to build a cross compiler from i386 to SPARC

or
Use the make utility as following

make OS_TARGET="compiler OS target" \
CPU_TARGET="compiler CPU target" \
FPCCPUOPT="Optimization level" \
PP="compiler used to compile FPC" \
COMPILER_OPTIONS="Options passed to compiler" \


If an option is omitted, then target CPU/OS will be same as current CPU/OS

Possibles targets are : linux go32v2 win32 os2 freebsd beos netbsd amiga haiku
atari sunos qnx netware openbsd wdosx palmos macos macosx emx

Possible compiler switches (* marks a currently required switch):
-----------------------------------------------------------------
GDB* support of the GNU Debugger
I386 generate a compiler for the Intel i386+
x86_64 generate a compiler for the AMD x86-64 architecture
M68K generate a compiler for the M68000
SPARC generate a compiler for SPARC
POWERPC generate a compiler for the PowerPC
VIS generate a compile for the VIS
DEBUG version with debug code is generated
EXTDEBUG some extra debug code is executed
SUPPORT_MMX only i386: releases the compiler switch
MMX which allows the compiler to generate
MMX instructions
EXTERN_MSG Don't compile the msgfiles in the compiler, always
use external messagefiles, default for TP
NOAG386INT no Intel Assembler output
NOAG386NSM no NASM output
NOAG386BIN leaves out the binary writer, default for TP
NORA386DIR No direct i386 assembler reader
TEST_GENERIC Test Generic version of code generator
(uses generic RTL calls)
-----------------------------------------------------------------
cpuflags The target processor has status flags (on by default)
cpufpemu The target compiler will also support emitting software
floating point operations
cpu64bitaddr The targets use a 64-bit address space (pointers and
the default integer type are 64 bit)
cpu64bitalu The target cpu has 64-bit registers available (unless
cpu64bitaddr is also defined, pointers and default
integer type remain 32 bit, but the cpu can perform
64 bit calculations directly without needing helpers)
-----------------------------------------------------------------

Required switches for a i386 compiler be compiled by Free Pascal Compiler:
GDB;I386

to build a compiler to SPARC target using a Win32/i386 you just use :
make CPU_TARGET=SPARC