Don fce62a84a8 Remove "r" from FPC revision. 4 éve
..
aarch64 ea640967ee --- Merging r49312 into '.': 4 éve
arm a3db71325e Merge of commit #47207 4 éve
avr 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
generic 1f20cfe991 Merge of several commits related to enhancements in PPU writing 6 éve
html fa0d3d79e0 no message 23 éve
i386 6847e7bfa8 * CMOV does not read the second operand 4 éve
i8086 6847e7bfa8 * CMOV does not read the second operand 4 éve
jvm 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
llvm 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
m68k ab4f34e3ff * Merging recent m68k FPU fixes from trunk: r42829, r48413, r48414, r48522, r48523, r48524 4 éve
mips 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
msg 397629dd39 ------------------------------------------------------------------------ 4 éve
powerpc 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
powerpc64 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
ppcgen 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
sparc 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
sparc64 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
sparcgen 9cd5a5b916 ------------------------------------------------------------------------ 4 éve
systems 6f11225621 --- Merging r49136 into '.': 4 éve
utils 0830edbde5 Regenerate all Makefile's after ios introduction and macos->macosclassic changes inside utils/fpcm/fpcmake.ini 5 éve
x86 8d6a8e5492 + support SHLX and SHRX in TX86AsmOptimizer.RegLoadedWithNewValue, resolves #39178 4 éve
x86_64 6847e7bfa8 * CMOV does not read the second operand 4 éve
COPYING.txt e5a1231931 * updated FSF address (mantis #30198, patch by Paul Gevers) 9 éve
MPWMake 05d6f0e94d macos: added a fake sysutils for use by compiler, and fixed some tests 19 éve
Makefile 74aff88586 --- Merging r49045 into '.': 4 éve
Makefile.fpc 74aff88586 --- Merging r49045 into '.': 4 éve
README.txt 4bf254bc32 * added .txt extensions to all README, TODO and COPYING files 16 éve
aasmbase.pas 29558a74cd + support exporting labels from asm blocks in intel syntax asm blocks via the 8 éve
aasmcfi.pas 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
aasmcnst.pas 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
aasmdata.pas edf32cd5dc The Important Ones: 7 éve
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 éve
aasmsym.pas a25ebbba3e + added volatility information to all memory references 8 éve
aasmtai.pas 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
aggas.pas 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
aopt.pas b1dff29cbf * removed unused units 8 éve
aoptbase.pas 7f286eb54e + define cpudelayslot: set during compiler compilation for CPUs having branch instructions with delay slot (MIPS, SPARC) 8 éve
aoptda.pas b1dff29cbf * removed unused units 8 éve
aoptobj.pas 1d3acf10c7 r48111 | pierre | 2021-01-08 12:05:29 +0100 (Fri, 08 Jan 2021) | 1 line 4 éve
aoptutils.pas 4a43d992f5 * unified usage of MatchOpType 8 éve
assemble.pas 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
blockutl.pas d24f4b0926 --- Merging r42998 into '.': 6 éve
browcol.pas 2370669f86 Avoid infinite recursion on generic classes for IDE browser 12 éve
catch.pas fd070544db - disabled installation of SIGINT signal handler for Darwin, because 16 éve
ccharset.pas 1f20cfe991 Merge of several commits related to enhancements in PPU writing 6 éve
cclasses.pas 68eb921d46 * broken compilation after r39347 fixed 7 éve
cfidwarf.pas 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
cfileutl.pas 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
cg64f32.pas 256dc546ac + implemented the in_neg_assign_x and in_not_assign_x inline nodes, which will 8 éve
cgbase.pas b6e7ebdd3c -- Zusammenführen von r42272 in ».«: 6 éve
cghlcpu.pas 67b8aceaee * synchronized with privatetrunk till r30095 10 éve
cgobj.pas 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
cgutils.pas 4686f61002 * keep track of the temp position separately from the offset in references, 7 éve
cmsgs.pas a34f531661 + implemented support for codepage aware compiler messages. It can be enabled 8 éve
comphook.pas 643d7c4d02 --- Merging r40738 into '.': 4 éve
compiler.pas ff7f5ee423 --- Merging r44456 into '.': 5 éve
compinnr.pas ab533f43aa # revisions: 43409,43473,43474,43482 5 éve
comprsrc.pas 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
constexp.pas 2ade09bdf8 Merge commit #45733 to fixes branch: 4 éve
cpid.pas 091627883f merge r14347 from cpstrnew branch by florian: 14 éve
crefs.pas 4d5119bf1c * fixes several issues which cause warnings by the dfa code when using it to detect uninitialized variables 12 éve
cresstr.pas b1dff29cbf * removed unused units 8 éve
cscript.pas 3dda26b3b5 * quote assembly filenames in Unix script, fixes sh errors with smartlinked small filenames like unitname(1), etc 7 éve
cstreams.pas 68eb921d46 * broken compilation after r39347 fixed 7 éve
cutils.pas ea32ddd5b2 * avoid overflows of execution weight 7 éve
cwindirs.pp 0bdd15e0da + added cwindirs for the time being to the compiler dir till a release with windirs in the rtl is released 14 éve
dbgbase.pas ecda183153 * revert r37968: it does more harm than good 7 éve
dbgcodeview.pas 600b460ecd + added new debug output option -godwarfomflinnum for generating line number 7 éve
dbgdwarf.pas 06a0e48958 -- Zusammenführen von r43183 in ».«: 4 éve
dbgstabs.pas a092e59200 ------------------------------------------------------------------------ 4 éve
dbgstabx.pas 2930a975fa ------------------------------------------------------------------------ 4 éve
defcmp.pas 036c9f7ff2 --- Merging r45365 into '.': 4 éve
defutil.pas c60ce2af07 --- Merging r43264 into '.': 4 éve
dirparse.pas 2e9c6f35ae - disable -Ooregvar for the LLVM-based x86-64 code generator, as it causes 8 éve
elfbase.pas b34ab6b279 * The MaybeSwapXXXHeader functions moved from ogelf to the elfbase unit, so they 7 éve
entfile.pas 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
export.pas b1dff29cbf * removed unused units 8 éve
expunix.pas b1dff29cbf * removed unused units 8 éve
finput.pas 3e2248f41a + implemented exporting of functions for the win16 target 10 éve
fmodule.pas 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
fpccrc.pas 793fd8fc09 * Add -Xg to help pages 17 éve
fpcdefs.inc 1d3acf10c7 r48111 | pierre | 2021-01-08 12:05:29 +0100 (Fri, 08 Jan 2021) | 1 line 4 éve
fpcp.pas b1dff29cbf * removed unused units 8 éve
fpkg.pas e8ede4c3e2 Merged revision(s) 32508-32510, 32512 from branches/svenbarth/packages: 9 éve
fppu.pas 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
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 éve
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 éve
globstat.pas 9c8a2d29e1 # revisions: 40702,40703,40704,40747,40750,40765,41277,41535,41536,41537,41548,41549,41770 6 éve
globtype.pas 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
hlcg2ll.pas 3ac703506c * rest of the previous accidental partial commit 6 éve
hlcgobj.pas 52235af80c -- Zusammenführen von r44119 in ».«: 5 éve
htypechk.pas 66fa732720 Merged revision(s) 47634, 47655 from trunk: 4 éve
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 éve
import.pas b1dff29cbf * removed unused units 8 éve
ldscript.pas d79511f96e + Basic ld script parsing capabilities (barely enough to parse glibc2.1 'libc.so' files, lacks any error handling). 13 éve
link.pas 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
macho.pas 1f20cfe991 Merge of several commits related to enhancements in PPU writing 6 éve
machoutils.pas 1f20cfe991 Merge of several commits related to enhancements in PPU writing 6 éve
msgidx.inc 397629dd39 ------------------------------------------------------------------------ 4 éve
msgtxt.inc 397629dd39 ------------------------------------------------------------------------ 4 éve
nadd.pas 06ef4e6ca8 Merge of commits 43634 and 43635 for currency problems 5 éve
nbas.pas 8ed055e4bf --- Merging r44096 into '.': 4 éve
ncal.pas 7eeaf5d5a0 -- Zusammenführen von r46973 in ».«: 4 éve
ncgadd.pas b1dff29cbf * removed unused units 8 éve
ncgbas.pas b9fe6b9612 Merged revision(s) 47683, 47749 from trunk: 4 éve
ncgcal.pas ec4954111e Remove multiple calls to cg.g_check_for_fpu_exception, only keep call to cg.maybe_check_for_fpu_exception (merging error) 5 éve
ncgcnv.pas 3ac703506c * rest of the previous accidental partial commit 6 éve
ncgcon.pas b1dff29cbf * removed unused units 8 éve
ncgflw.pas b9fe6b9612 Merged revision(s) 47683, 47749 from trunk: 4 éve
ncghlmat.pas 0fc1fd6ac1 * replaced current_procinfo.currtrue/falselabel with storing the true/false 10 éve
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 éve
ncgld.pas c27981c5f4 Merge commits 46484 and 46487 to fix linux-powerpc64le snapshot generation. 5 éve
ncgmat.pas 8c5606b41d + support mmx shifting 7 éve
ncgmem.pas 3ac703506c * rest of the previous accidental partial commit 6 éve
ncgnstfl.pas 48ef33a8b3 * fixed interprocedural gotos for llvm 9 éve
ncgnstld.pas 3ac703506c * rest of the previous accidental partial commit 6 éve
ncgnstmm.pas 3ac703506c * rest of the previous accidental partial commit 6 éve
ncgobjc.pas b1dff29cbf * removed unused units 8 éve
ncgopt.pas b1dff29cbf * removed unused units 8 éve
ncgrtti.pas 9c8a2d29e1 # revisions: 40702,40703,40704,40747,40750,40765,41277,41535,41536,41537,41548,41549,41770 6 éve
ncgset.pas 92cd9502ef Merge of revisions 40277 6 éve
ncgutil.pas c4bcb45fea --- Merging r43650 into '.': 5 éve
ncgvmt.pas edf32cd5dc The Important Ones: 7 éve
ncnv.pas bd4f2057e5 --- Merging r43186 into '.': 5 éve
ncon.pas aadd93847f -- Zusammenführen von r43620 in ».«: 5 éve
nflw.pas e232588635 -- Zusammenführen von r46974 in ».«: 4 éve
ngenutil.pas 2b9ddf3bee # revisions: 45519,46865,46918 5 éve
ngtcon.pas bd4f2057e5 --- Merging r43186 into '.': 5 éve
ninl.pas e6ad8a0dfa Merged revision(s) 44172, 44188, 45457 - 45458, 45645, 46218, 46953 from trunk: 4 éve
nld.pas f42dffb36d --- Merging r39877 into '.': 7 éve
nmat.pas c60ce2af07 --- Merging r43264 into '.': 4 éve
nmem.pas 3ac703506c * rest of the previous accidental partial commit 6 éve
nobj.pas 3ac703506c * rest of the previous accidental partial commit 6 éve
nobjc.pas 68eb921d46 * broken compilation after r39347 fixed 7 éve
node.pas f8e55c4350 -- Zusammenführen von r39934 in ».«: 4 éve
nopt.pas 3318703ece * moved nf_typedaddr to addrnodeflags (anf_typedaddr) 7 éve
nset.pas 3ac703506c * rest of the previous accidental partial commit 6 éve
nutils.pas 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
objcasm.pas 51209eac9c * fixed bootstrap for Darwin/ppc with FPC 3.0 (workaround for 9 éve
objcdef.pas b1dff29cbf * removed unused units 8 éve
objcgutl.pas 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
objcutil.pas b1dff29cbf * removed unused units 8 éve
ogbase.pas 5782acc32d * patch by J. Gareth Moreton to fix 33909 7 éve
ogcoff.pas 846775f4b6 Merged revision(s) 46875-46876 from trunk: 4 éve
ogelf.pas b34ab6b279 * The MaybeSwapXXXHeader functions moved from ogelf to the elfbase unit, so they 7 éve
oglx.pas d4a4b9a57b * refactored the internal linker ar object reader object creation to allow using 10 éve
ogmacho.pas 2af5c9d508 * changed type used for section alignment from byte/shortint to longint, so the 8 éve
ogmap.pas b1dff29cbf * removed unused units 8 éve
ognlm.pas 2af5c9d508 * changed type used for section alignment from byte/shortint to longint, so the 8 éve
ogomf.pas 1ed2a3e055 ------------------------------------------------------------------------ 4 éve
omfbase.pas 6205e530aa Merge commits 39912, 39914, 40001, 40115, 40132 and 40163 6 éve
optbase.pas d8b0ded10c Marge of more trunk fixes into fixes branch. 6 éve
optconstprop.pas 3ac703506c * rest of the previous accidental partial commit 6 éve
optcse.pas 3ac703506c * rest of the previous accidental partial commit 6 éve
optdead.pas b1dff29cbf * removed unused units 8 éve
optdeadstore.pas b1dff29cbf * removed unused units 8 éve
optdfa.pas 0ad0cefeb3 --- Merging r40202 into '.': 6 éve
options.pas adfe9581ba Merged revision(s) 47390 from trunk: 4 éve
optloadmodifystore.pas 9853c4a2a3 + enabled the load-modify-store optimization for the double argument version 8 éve
optloop.pas 21d785e41b * do not unroll loops if the counter variable is accessed outside the current scope 7 éve
opttail.pas 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
optutils.pas 3ac703506c * rest of the previous accidental partial commit 6 éve
optvirt.pas b1dff29cbf * removed unused units 8 éve
owar.pas d4a4b9a57b * refactored the internal linker ar object reader object creation to allow using 10 éve
owbase.pas 368ba47d6e * support writing more than 1024 zeros in tobjectwriter.writezeros 10 éve
owomflib.pas 6205e530aa Merge commits 39912, 39914, 40001, 40115, 40132 and 40163 6 éve
parabase.pas d69ad8fa41 * removed temppos field again from parameter locations: they're not allocated 7 éve
paramgr.pas a29ee477e3 Merged revision(s) 49339 from trunk: 4 éve
parser.pas f2f4a29dbb * Merge r43604 to fix i8086-embedded utils compilation 5 éve
pass_1.pas b1dff29cbf * removed unused units 8 éve
pass_2.pas b9fe6b9612 Merged revision(s) 47683, 47749 from trunk: 4 éve
pbase.pas 8bc0b604db * a symbol might be specified using a partial namespace path as long as the missing part is a namespace symbol, 7 éve
pcp.pas 1f20cfe991 Merge of several commits related to enhancements in PPU writing 6 éve
pdecl.pas 775567e8f7 # revisions: 44598,45635,45757,45764,45772 5 éve
pdecobj.pas c4b9529d6b # revisions: 42328,42329 6 éve
pdecsub.pas 946d9ec715 Merged revision(s) 39838 from trunk: 4 éve
pdecvar.pas 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
pexports.pas 3b71841a84 Merged revision(s) 28691, 31914 from branches/svenbarth/packages: 9 éve
pexpr.pas 036c9f7ff2 --- Merging r45365 into '.': 4 éve
pgentype.pas c81eda7a42 Fully enable generic functions, procedures and methods by allowing inline specializations in procedure bodies as well. 10 éve
pgenutil.pas e6ad8a0dfa Merged revision(s) 44172, 44188, 45457 - 45458, 45645, 46218, 46953 from trunk: 4 éve
pinline.pas 7988446f1a Merged revision(s) 39802, 39816-39817 from trunk: 4 éve
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 éve
pmodules.pas adfe9581ba Merged revision(s) 47390 from trunk: 4 éve
pp.lpi ed984e0c76 - removed missing file from project 8 éve
pp.pas 7cdb39b3f9 -- Aufzeichnung der Informationen für Zusammenführung von r43005 in ».«: 6 éve
pparautl.pas d24f4b0926 --- Merging r42998 into '.': 6 éve
ppc68k.lpi 9ebf2aa984 * project file updates 13 éve
ppc8086.lpi efc5e339d0 * use an enum instead of integer constants to represent inline numbers 8 éve
ppcaarch64.lpi 6e56f5c191 * fixed exe output path 9 éve
ppcarm.lpi 2e3a12c69d * version update 7 éve
ppcavr.lpi b9d4240a8d + version update 7 éve
ppcjvm.lpi ac819b0b97 * jvm lazarus project file properly named 12 éve
ppcmips.lpi 9ebf2aa984 * project file updates 13 éve
ppcmipsel.lpi 9ebf2aa984 * project file updates 13 éve
ppcppc.lpi 9ebf2aa984 * project file updates 13 éve
ppcppc64.lpi 9ebf2aa984 * project file updates 13 éve
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 éve
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 éve
ppcx64.lpi 66fa732720 Merged revision(s) 47634, 47655 from trunk: 4 éve
ppcx64llvm.lpi cd9e18fab4 * made lazarus project names more systematic 7 éve
ppheap.pas eefdf135a5 Always write filename, truncate directory part if needed 9 éve
ppu.pas 1f20cfe991 Merge of several commits related to enhancements in PPU writing 6 éve
procdefutil.pas e6ad8a0dfa Merged revision(s) 44172, 44188, 45457 - 45458, 45645, 46218, 46953 from trunk: 4 éve
procinfo.pas d1f31fab15 Merge commits 42525 and 45891 that add 5 éve
pstatmnt.pas 858bf743ef --- Merging r43347 into '.': 5 éve
psub.pas b9fe6b9612 Merged revision(s) 47683, 47749 from trunk: 4 éve
psystem.pas ab533f43aa # revisions: 43409,43473,43474,43482 5 éve
ptconst.pas b1dff29cbf * removed unused units 8 éve
ptype.pas f455d66a75 Merged revision(s) 47794-47795, 47826 from trunk: 4 éve
raatt.pas 22f48c207e 6 éve
rabase.pas b7fe6797bf Merged revisions 2921-2922,2925 via svnmerge from 19 éve
rasm.pas 46fe2d486c * forgotten comment 7 éve
rautils.pas c9c1c1686c --- Merging r46880 into '.': 4 éve
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 éve
rgbase.pas c8487c4150 + added individual bits of the x86 flags register as subregisters 8 éve
rgobj.pas ea32ddd5b2 * avoid overflows of execution weight 7 éve
scandir.pas c60ce2af07 --- Merging r43264 into '.': 4 éve
scanner.pas c60ce2af07 --- Merging r43264 into '.': 4 éve
switches.pas be0d51d64c * allow $MinEnumSize, $PackSet and $PackRecords to be used with $Push and $Pop 7 éve
symbase.pas fdb477df1e # revisions: 43566,43567,43568,43586,43629,43823 5 éve
symconst.pas f29598384b * Objective-Pascal inferred result type and improved category method searching 6 éve
symcreat.pas d24f4b0926 --- Merging r42998 into '.': 6 éve
symdef.pas f455d66a75 Merged revision(s) 47794-47795, 47826 from trunk: 4 éve
symsym.pas 66fa732720 Merged revision(s) 47634, 47655 from trunk: 4 éve
symtable.pas 66fa732720 Merged revision(s) 47634, 47655 from trunk: 4 éve
symtype.pas 1f20cfe991 Merge of several commits related to enhancements in PPU writing 6 éve
symutil.pas d24f4b0926 --- Merging r42998 into '.': 6 éve
syscinfo.pas d0f8ea7969 Add arm-palmos target to list supporting po_syscall 8 éve
systems.inc b1249dcc32 * Merge commit #45720 5 éve
systems.pas b1249dcc32 * Merge commit #45720 5 éve
tgobj.pas 875af11d02 Merge of commits 39916, 39925 and 39963 6 éve
tokens.pas 4dca62b568 Merged revision(s) 43114-43115, 46943 from trunk: 4 éve
triplet.pas 76045bfc04 * merged macOS/AArch64 support + revisions these changes depended on 5 éve
verbose.pas a34f531661 + implemented support for codepage aware compiler messages. It can be enabled 8 éve
version.pas fce62a84a8 Remove "r" from FPC revision. 4 éve
widestr.pas c8839d487b * fixed accidentally committed (harmless) typo in r32202 10 éve
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 17 éve
wpobase.pas 5df9b994d1 * fix warnings which were caused by last changes to for node generation 9 éve
wpoinfo.pas b1dff29cbf * removed unused units 8 éve

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