mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-06-03 22:58:51 +02:00
![]() and more precisely to cross reading/writing fixes. ------------------------------------------------------------------------ r41896 | pierre | 2019-04-18 14:08:03 +0000 (Thu, 18 Apr 2019) | 15 lines Integrate patch from bug report 35409. Add possibiliy to throw InternalError for unhandled case values inside tentryfile, But avoid adding dependency on verbose unit as this would break ppudump handling of ppu files. Add RaiseAssertion virtual method to tentryfile class. Call RaiseAssertion in tentryfile methods where an internal error is wanted. Override RaiseAssertion method in symtype.pas unit to call InternalError. Add new class tppudumpfile to override RaiseAssertion in utils/ppuutils/ppudump.pp unit. ------------------------------------------------------------------------ --- Merging r41896 into '.': U compiler/entfile.pas U compiler/pcp.pas U compiler/symtype.pas U compiler/utils/ppuutils/ppudump.pp --- Recording mergeinfo for merge of r41896 into '.': U . ------------------------------------------------------------------------ r42111 | pierre | 2019-05-20 22:06:57 +0000 (Mon, 20 May 2019) | 1 line List TSettings partially and improve generic output ------------------------------------------------------------------------ --- Merging r42111 into '.': G compiler/utils/ppuutils/ppudump.pp --- Recording mergeinfo for merge of r42111 into '.': G . ------------------------------------------------------------------------ r42322 | pierre | 2019-07-03 13:35:05 +0000 (Wed, 03 Jul 2019) | 1 line Systematically include fpcdefs.inc at sart of all units used by compiler ------------------------------------------------------------------------ --- Merging r42322 into '.': U compiler/aarch64/cpuinfo.pas U compiler/arm/cpuinfo.pas U compiler/avr/cpuinfo.pas U compiler/ccharset.pas U compiler/generic/cpuinfo.pas U compiler/jvm/cpuinfo.pas U compiler/m68k/cpuinfo.pas U compiler/macho.pas U compiler/machoutils.pas U compiler/mips/cpuinfo.pas G compiler/pcp.pas U compiler/powerpc/cpuinfo.pas U compiler/powerpc64/cpuinfo.pas U compiler/systems/i_wii.pas --- Recording mergeinfo for merge of r42322 into '.': G . ------------------------------------------------------------------------ r42323 | pierre | 2019-07-04 15:24:49 +0000 (Thu, 04 Jul 2019) | 7 lines * Set ControllerSupport to false for sparc/sparc64 and x86_64 CPUs. This boolean must only be set to true if TControllerType is not simply (ct_none) * ppu.pas: Increment CurrentPPULongVersion constant as the above modification changes the number of fields of the TSettings record that is saved to PPU in ST_LOADSETTINGS field. { not mereged } ------------------------------------------------------------------------ --- Merging r42323 into '.': C compiler/ppu.pas { not mereged } U compiler/sparc/cpuinfo.pas U compiler/sparc64/cpuinfo.pas U compiler/x86_64/cpuinfo.pas --- Recording mergeinfo for merge of r42323 into '.': G . ------------------------------------------------------------------------ r42324 | pierre | 2019-07-04 15:25:40 +0000 (Thu, 04 Jul 2019) | 1 line Correctly read saved tsettings ------------------------------------------------------------------------ --- Merging r42324 into '.': C compiler/utils/ppuutils/ppudump.pp --- Recording mergeinfo for merge of r42324 into '.': G . Summary of conflicts: Text conflicts: 1 ------------------------------------------------------------------------ r42325 | marcus | 2019-07-04 16:49:26 +0000 (Thu, 04 Jul 2019) | 1 line Fixed ppudump compilation on big endian platforms after r42324 ------------------------------------------------------------------------ --- Merging r42325 into '.': G compiler/utils/ppuutils/ppudump.pp --- Recording mergeinfo for merge of r42325 into '.': G . ------------------------------------------------------------------------ r42353 | svenbarth | 2019-07-12 16:25:33 +0000 (Fri, 12 Jul 2019) | 1 line * write an entry name for the property options ------------------------------------------------------------------------ --- Merging r42353 into '.': G compiler/utils/ppuutils/ppudump.pp --- Recording mergeinfo for merge of r42353 into '.': G . ------------------------------------------------------------------------ r42354 | svenbarth | 2019-07-12 16:25:36 +0000 (Fri, 12 Jul 2019) | 1 line * write a name for the none property access entry (looks nicer than a "(Nil)" at the start of the line) ------------------------------------------------------------------------ --- Merging r42354 into '.': G compiler/utils/ppuutils/ppudump.pp --- Recording mergeinfo for merge of r42354 into '.': G . ------------------------------------------------------------------------ r42527 | pierre | 2019-07-29 05:33:00 +0000 (Mon, 29 Jul 2019) | 22 lines Fix recordtoken writing into ppu files to allow correct handling in cross-configuration with different endianess. The code has been modified to use the same scheme as the writing of the other parts of the ppu, i.e. change_endian filed has been added also to tscannerfile class of scanner unit. This field is then used to swap values that required endianess conversion. * scanner.pas: change_endian filed added to tscannerfile class. The value of this field is set as the same field in tentryfile class of entfile unit. Token read and write methods converted to use change_endian field. * ppu.pas: Increase CurrentPPILongVersion * utils/ppuutils/ppudump.pp: Remove unneeded FPC_BIG_ENDIAN code which was needed because tokens were previously written using a different rule. ------------------------------------------------------------------------ --- Merging r42527 into '.': C compiler/ppu.pas U compiler/scanner.pas G compiler/utils/ppuutils/ppudump.pp --- Recording mergeinfo for merge of r42527 into '.': G . Summary of conflicts: Text conflicts: 1 ------------------------------------------------------------------------ r42528 | pierre | 2019-07-29 11:54:27 +0000 (Mon, 29 Jul 2019) | 1 line Changed paths: M /trunk/compiler/scanner.pas Try to fix bug introduced in previous commit #42527, hopefully fixing bug report 35902 ------------------------------------------------------------------------ --- Merging r42528 into '.': G compiler/scanner.pas --- Recording mergeinfo for merge of r42528 into '.': G .------------------------------------------------------------------------ r42530 | pierre | 2019-07-29 16:40:58 +0000 (Mon, 29 Jul 2019) | 8 lines Try to fix ppudump for generic/inline. * entfile.pas: Differenciate ibsymtableoptions and ibrecsymtableoptions. * ppu.pas: Increase ppu unit CurrentPPULongVersion value. * utils/ppuutils/ppudump.pp: Add current_symtable_options variable. Change readsymtableoptions from procedure to function returning the new tsymtableoptions. ------------------------------------------------------------------------ --- Merging r42530 into '.': G compiler/entfile.pas G compiler/ppu.pas G compiler/utils/ppuutils/ppudump.pp --- Recording mergeinfo for merge of r42530 into '.': G . ------------------------------------------------------------------------ r42583 | pierre | 2019-08-05 09:15:12 +0000 (Mon, 05 Aug 2019) | 1 line Reorganize token buffer output to be able to use it for generics and inlined functions ------------------------------------------------------------------------ --- Merging r42583 into '.': G compiler/utils/ppuutils/ppudump.pp --- Recording mergeinfo for merge of r42583 into '.': G . ------------------------------------------------------------------------ r42591 | pierre | 2019-08-06 06:32:52 +0000 (Tue, 06 Aug 2019) | 1 line Add mode and optimizer switches names, and check that no unknown switch is set ------------------------------------------------------------------------ --- Merging r42591 into '.': G compiler/utils/ppuutils/ppudump.pp --- Recording mergeinfo for merge of r42591 into '.': G . ------------------------------------------------------------------------ r42596 | pierre | 2019-08-06 21:32:51 +0000 (Tue, 06 Aug 2019) | 1 line Fix gettokenbufshortint, as shortint is one byte long, not two ------------------------------------------------------------------------ --- Merging r42596 into '.': G compiler/utils/ppuutils/ppudump.pp --- Recording mergeinfo for merge of r42596 into '.': G . ------------------------------------------------------------------------ r42609 | pierre | 2019-08-09 09:29:50 +0000 (Fri, 09 Aug 2019) | 1 line Correct size of asizeint, which is still 4-byte long even when CpuAddrBitSize is 16 as for avr and i8086 ------------------------------------------------------------------------ --- Merging r42609 into '.': G compiler/utils/ppuutils/ppudump.pp --- Recording mergeinfo for merge of r42609 into '.': G . ------------------------------------------------------------------------ r42670 | pierre | 2019-08-13 06:20:23 +0000 (Tue, 13 Aug 2019) | 1 line Reduce cpu-os dependency on real constant printout by using system.str ------------------------------------------------------------------------ --- Merging r42670 into '.': G compiler/utils/ppuutils/ppudump.pp --- Recording mergeinfo for merge of r42670 into '.': G . ------------------------------------------------------------------------ r42906 | pierre | 2019-09-02 16:00:15 +0000 (Mon, 02 Sep 2019) | 1 line Fix problems with big endian systems without 80-bit floating point support ------------------------------------------------------------------------ --- Merging r42906 into '.': G compiler/utils/ppuutils/ppudump.pp --- Recording mergeinfo for merge of r42906 into '.': G . git-svn-id: branches/fixes_3_2@43387 - |
||
---|---|---|
.. | ||
aarch64 | ||
arm | ||
avr | ||
generic | ||
html | ||
i386 | ||
i8086 | ||
jvm | ||
llvm | ||
m68k | ||
mips | ||
msg | ||
powerpc | ||
powerpc64 | ||
ppcgen | ||
sparc | ||
sparc64 | ||
sparcgen | ||
systems | ||
utils | ||
x86 | ||
x86_64 | ||
aasmbase.pas | ||
aasmcnst.pas | ||
aasmdata.pas | ||
aasmdef.pas | ||
aasmsym.pas | ||
aasmtai.pas | ||
aggas.pas | ||
aopt.pas | ||
aoptbase.pas | ||
aoptda.pas | ||
aoptobj.pas | ||
aoptutils.pas | ||
assemble.pas | ||
blockutl.pas | ||
browcol.pas | ||
catch.pas | ||
ccharset.pas | ||
cclasses.pas | ||
cfidwarf.pas | ||
cfileutl.pas | ||
cg64f32.pas | ||
cgbase.pas | ||
cghlcpu.pas | ||
cgobj.pas | ||
cgutils.pas | ||
cmsgs.pas | ||
comphook.pas | ||
compiler.pas | ||
compinnr.pas | ||
comprsrc.pas | ||
constexp.pas | ||
COPYING.txt | ||
cpid.pas | ||
crefs.pas | ||
cresstr.pas | ||
cscript.pas | ||
cstreams.pas | ||
cutils.pas | ||
cwindirs.pp | ||
dbgbase.pas | ||
dbgcodeview.pas | ||
dbgdwarf.pas | ||
dbgstabs.pas | ||
dbgstabx.pas | ||
defcmp.pas | ||
defutil.pas | ||
dirparse.pas | ||
elfbase.pas | ||
entfile.pas | ||
export.pas | ||
expunix.pas | ||
finput.pas | ||
fmodule.pas | ||
fpccrc.pas | ||
fpcdefs.inc | ||
fpcp.pas | ||
fpkg.pas | ||
fppu.pas | ||
gendef.pas | ||
globals.pas | ||
globstat.pas | ||
globtype.pas | ||
hlcg2ll.pas | ||
hlcgobj.pas | ||
htypechk.pas | ||
impdef.pas | ||
import.pas | ||
ldscript.pas | ||
link.pas | ||
macho.pas | ||
machoutils.pas | ||
Makefile | ||
Makefile.fpc | ||
MPWMake | ||
msgidx.inc | ||
msgtxt.inc | ||
nadd.pas | ||
nbas.pas | ||
ncal.pas | ||
ncgadd.pas | ||
ncgbas.pas | ||
ncgcal.pas | ||
ncgcnv.pas | ||
ncgcon.pas | ||
ncgflw.pas | ||
ncghlmat.pas | ||
ncginl.pas | ||
ncgld.pas | ||
ncgmat.pas | ||
ncgmem.pas | ||
ncgnstfl.pas | ||
ncgnstld.pas | ||
ncgnstmm.pas | ||
ncgobjc.pas | ||
ncgopt.pas | ||
ncgrtti.pas | ||
ncgset.pas | ||
ncgutil.pas | ||
ncgvmt.pas | ||
ncnv.pas | ||
ncon.pas | ||
nflw.pas | ||
ngenutil.pas | ||
ngtcon.pas | ||
ninl.pas | ||
nld.pas | ||
nmat.pas | ||
nmem.pas | ||
nobj.pas | ||
nobjc.pas | ||
node.pas | ||
nopt.pas | ||
nset.pas | ||
nutils.pas | ||
objcasm.pas | ||
objcdef.pas | ||
objcgutl.pas | ||
objcutil.pas | ||
ogbase.pas | ||
ogcoff.pas | ||
ogelf.pas | ||
oglx.pas | ||
ogmacho.pas | ||
ogmap.pas | ||
ognlm.pas | ||
ogomf.pas | ||
omfbase.pas | ||
optbase.pas | ||
optconstprop.pas | ||
optcse.pas | ||
optdead.pas | ||
optdeadstore.pas | ||
optdfa.pas | ||
options.pas | ||
optloadmodifystore.pas | ||
optloop.pas | ||
opttail.pas | ||
optutils.pas | ||
optvirt.pas | ||
owar.pas | ||
owbase.pas | ||
owomflib.pas | ||
parabase.pas | ||
paramgr.pas | ||
parser.pas | ||
pass_1.pas | ||
pass_2.pas | ||
pbase.pas | ||
pcp.pas | ||
pdecl.pas | ||
pdecobj.pas | ||
pdecsub.pas | ||
pdecvar.pas | ||
pexports.pas | ||
pexpr.pas | ||
pgentype.pas | ||
pgenutil.pas | ||
pinline.pas | ||
pkgutil.pas | ||
pmodules.pas | ||
pp.lpi | ||
pp.pas | ||
pparautl.pas | ||
ppc68k.lpi | ||
ppc8086.lpi | ||
ppcaarch64.lpi | ||
ppcarm.lpi | ||
ppcavr.lpi | ||
ppcjvm.lpi | ||
ppcmips.lpi | ||
ppcmipsel.lpi | ||
ppcppc64.lpi | ||
ppcppc.lpi | ||
ppcsparc64.lpi | ||
ppcsparc.lpi | ||
ppcx64.lpi | ||
ppcx64llvm.lpi | ||
ppheap.pas | ||
ppu.pas | ||
procdefutil.pas | ||
procinfo.pas | ||
pstatmnt.pas | ||
psub.pas | ||
psystem.pas | ||
ptconst.pas | ||
ptype.pas | ||
raatt.pas | ||
rabase.pas | ||
rasm.pas | ||
rautils.pas | ||
README.txt | ||
rescmn.pas | ||
rgbase.pas | ||
rgobj.pas | ||
scandir.pas | ||
scanner.pas | ||
switches.pas | ||
symbase.pas | ||
symconst.pas | ||
symcreat.pas | ||
symdef.pas | ||
symsym.pas | ||
symtable.pas | ||
symtype.pas | ||
symutil.pas | ||
syscinfo.pas | ||
systems.inc | ||
systems.pas | ||
tgobj.pas | ||
tokens.pas | ||
verbose.pas | ||
version.pas | ||
widestr.pas | ||
wpo.pas | ||
wpobase.pas | ||
wpoinfo.pas |
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