fpc/compiler/new
2000-01-28 12:17:02 +00:00
..
alpha * updated copyright to 2000 2000-01-07 01:14:18 +00:00
i386 * updated copyright to 2000 2000-01-07 01:14:18 +00:00
powerpc * updated copyright to 2000 2000-01-07 01:14:18 +00:00
symtable * updated copyright to 2000 2000-01-07 01:14:18 +00:00
agatt.pas * updated copyright to 2000 2000-01-07 01:14:18 +00:00
aopt.pas * updated copyright to 2000 2000-01-07 01:14:18 +00:00
aoptbase.pas * updated copyright to 2000 2000-01-07 01:14:18 +00:00
aoptcs.pas * updated copyright to 2000 2000-01-07 01:14:18 +00:00
aoptda.pas * updated copyright to 2000 2000-01-07 01:14:18 +00:00
aoptobj.pas * updated copyright to 2000 2000-01-07 01:14:18 +00:00
cgbase.pas * updated copyright to 2000 2000-01-07 01:14:18 +00:00
cgflw.pas * updated copyright to 2000 2000-01-07 01:14:18 +00:00
cgobj.pas * updated copyright to 2000 2000-01-07 01:14:18 +00:00
convtree.pas * updated copyright to 2000 2000-01-07 01:14:18 +00:00
Makefile * regenerated 2000-01-28 12:17:02 +00:00
Makefile.fpc * Makefile updates again 2000-01-04 00:00:14 +00:00
ncon.pas * updated copyright to 2000 2000-01-07 01:14:18 +00:00
nmem.pas * updated copyright to 2000 2000-01-07 01:14:18 +00:00
nstatmnt.pas * updated copyright to 2000 2000-01-07 01:14:18 +00:00
pass_1.pas * updated copyright to 2000 2000-01-07 01:14:18 +00:00
pass_2.pas * updated copyright to 2000 2000-01-07 01:14:18 +00:00
pp.pas * updated copyright to 2000 2000-01-07 01:14:18 +00:00
README - removed the hcodegen use in the new cg, use cgbase instead 1999-10-14 14:57:51 +00:00
tainst.pas * updated copyright to 2000 2000-01-07 01:14:18 +00:00
temp_gen.pas * updated copyright to 2000 2000-01-07 01:14:18 +00:00
tempgen.inc * updated copyright to 2000 2000-01-07 01:14:18 +00:00
tgeni386.pas * updated copyright to 2000 2000-01-07 01:14:18 +00:00
tgobj.pas * updated copyright to 2000 2000-01-07 01:14:18 +00:00
TODO * well, more changes, especially parts of secondload ported 1999-01-24 22:32:33 +00:00
transn.pas * updated copyright to 2000 2000-01-07 01:14:18 +00:00
tree.pas * updated copyright to 2000 2000-01-07 01:14:18 +00:00

$Id$

History
-------

13th oct 1999              remark about alignment added (FK)

CVS Log see at the end of that file

frame_pointer              contains the register used as frame pointer
stack_pointer              contains the register used as stack pointer
self_pointer               contains the register used as self pointer


unusedregsint              set of Currently available integer registers
unusedregsfpu              set of Currently available fpu registers
unusedregsmm               set of Currently available mm registers

availabletempregsint       set of maximally available integer registers
availabletempregsfpu       set of maximally available fpu registers
availabletempregsmm        set of maximally available mm registers

countusableregsint         count of currently available integer registers
countusableregsfpu         count of currently available fpu registers
countusableregsmm          count of currently available mm registers

c_countusableregsint       count of max. available int registers (in the current procedure)
c_countusableregsfpu       count of max. available fpu registers (in the current procedure)
c_countusableregsmm        count of max. available mm registers (in the current procedure)

intregs                    all!! available integer register
fpuregs                    all!! available fpu register
mmregs                     all!! available multimedia register

Intel specific
--------------
unusedregssse
availabletempregssse
countusableregssse

Jonas Maebe schrieb:
> 
> Hello,
> 
> Is there any difference between the localsize parameter of
> g_stackframe_entry and the parasize parameter of g_return_from_proc, or
> are they both the same value?

They are different, I think the value of g_return_from_proc doesn't matter
for the PowerPC. It's the size of parameters passed on the stack
and only important for the i386/m68k probably.

> 
> And for the PowerPC, what will they contain? Just the size of the local
> variables and parameters, or also the maximum needed size for parameters
> of any procedure called by the current one (the caller must reserve space
> for the callee's parameters on it's own stack because you can't push
> values on the stack in the middle of a procedure (no frame pointer))
>
> Jonas

the parameter passed to g_stackframe_entry contains the size of the all local space which is
needed
except
that one for saving registers: the set procinfo.registerstosave (not yet implemented,
I'll commit it soon) will contain
all registers which must be saved by the entry and restored by the exit code of a procedure
and you have to add extra space to do that.



Alignment
---------

The alignment is handled very easily: treference contains a field
alignment which describes the ensured alignment for the node, possible
values: 1,2,4,8,16 (1 means unligned). The code generator must update
that field at the appropriate places and take care of it when
generating the code


CVS Log
-------

$Log$
Revision 1.4  1999-10-14 14:57:54  florian
  - removed the hcodegen use in the new cg, use cgbase instead