cgbase.pas 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775
  1. {
  2. $Id$
  3. Copyright (c) 1998-2002 by Florian Klaempfl
  4. This unit exports some help routines for the code generation
  5. This program is free software; you can redistribute it and/or modify
  6. it under the terms of the GNU General Public License as published by
  7. the Free Software Foundation; either version 2 of the License, or
  8. (at your option) any later version.
  9. This program is distributed in the hope that it will be useful,
  10. but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. GNU General Public License for more details.
  13. You should have received a copy of the GNU General Public License
  14. along with this program; if not, write to the Free Software
  15. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  16. ****************************************************************************
  17. }
  18. {# Some helpers for the code generator.
  19. }
  20. unit cgbase;
  21. {$i fpcdefs.inc}
  22. interface
  23. uses
  24. { common }
  25. cclasses,
  26. { global }
  27. globtype,globals,verbose,
  28. { symtable }
  29. symconst,symtype,symdef,symsym,
  30. { aasm }
  31. cpubase,cpuinfo,cginfo,aasmbase,aasmtai
  32. ;
  33. type
  34. tprocinfoflag=(
  35. {# procedure uses asm }
  36. pi_uses_asm,
  37. {# procedure does a call }
  38. pi_do_call,
  39. {# procedure has a try statement = no register optimization }
  40. pi_uses_exceptions,
  41. {# procedure is declared as @var(assembler), don't optimize}
  42. pi_is_assembler,
  43. {# procedure contains data which needs to be finalized }
  44. pi_needs_implicit_finally
  45. );
  46. tprocinfoflags=set of tprocinfoflag;
  47. type
  48. {# This object gives information on the current routine being
  49. compiled.
  50. }
  51. tprocinfo = class(tlinkedlistitem)
  52. { pointer to parent in nested procedures }
  53. parent : tprocinfo;
  54. {# the definition of the routine itself }
  55. procdef : tprocdef;
  56. { file location of begin of procedure }
  57. entrypos : tfileposinfo;
  58. { file location of end of procedure }
  59. exitpos : tfileposinfo;
  60. { local switches at begin of procedure }
  61. entryswitches : tlocalswitches;
  62. { local switches at end of procedure }
  63. exitswitches : tlocalswitches;
  64. {# offset from frame pointer to get parent frame pointer reference
  65. (used in nested routines only)
  66. On the PowerPC, this is used to store the offset where the
  67. frame pointer from the outer procedure is stored.
  68. }
  69. framepointer_offset : longint;
  70. {# firsttemp position }
  71. firsttemp_offset : longint;
  72. {# some collected informations about the procedure
  73. see pi_xxxx constants above
  74. }
  75. flags : tprocinfoflags;
  76. {# register used as frame pointer }
  77. framepointer : tregister;
  78. {# Holds the reference used to store the original stackpointer
  79. after all registers are saved
  80. }
  81. save_stackptr_ref :treference;
  82. {# Holds the reference used to store alll saved registers.
  83. This is used on systems which do not have direct stack
  84. operations (such as the PowerPC), it is unused on other
  85. systems
  86. }
  87. save_regs_ref : treference;
  88. { label to leave the sub routine }
  89. aktexitlabel : tasmlabel;
  90. {# The code for the routine itself, excluding entry and
  91. exit code. This is a linked list of tai classes.
  92. }
  93. aktproccode : taasmoutput;
  94. { Data (like jump tables) that belongs to this routine }
  95. aktlocaldata : taasmoutput;
  96. constructor create(aparent:tprocinfo);virtual;
  97. destructor destroy;override;
  98. procedure allocate_interrupt_stackframe;virtual;
  99. procedure allocate_implicit_parameter;virtual;
  100. { Does the necessary stuff before a procedure body is compiled }
  101. procedure handle_body_start;virtual;
  102. { This is called by parser, after the header of a subroutine is parsed.
  103. If the local symtable offset depends on the para symtable size, the
  104. necessary stuff must be done here.
  105. }
  106. procedure after_header;virtual;
  107. { This procedure is called after the pass 1 of the subroutine body is done.
  108. Here the address fix ups to generate code for the body must be done.
  109. }
  110. procedure after_pass1;virtual;
  111. end;
  112. pregvarinfo = ^tregvarinfo;
  113. tregvarinfo = record
  114. regvars : array[1..maxvarregs] of tvarsym;
  115. regvars_para : array[1..maxvarregs] of boolean;
  116. regvars_refs : array[1..maxvarregs] of longint;
  117. fpuregvars : array[1..maxfpuvarregs] of tvarsym;
  118. fpuregvars_para : array[1..maxfpuvarregs] of boolean;
  119. fpuregvars_refs : array[1..maxfpuvarregs] of longint;
  120. end;
  121. tcprocinfo = class of tprocinfo;
  122. var
  123. cprocinfo : tcprocinfo;
  124. {# information about the current sub routine being parsed (@var(pprocinfo))}
  125. current_procinfo : tprocinfo;
  126. { labels for BREAK and CONTINUE }
  127. aktbreaklabel,aktcontinuelabel : tasmlabel;
  128. { label when the result is true or false }
  129. truelabel,falselabel : tasmlabel;
  130. {# true, if there was an error while code generation occurs }
  131. codegenerror : boolean;
  132. { save the size of pushed parameter, needed for aligning }
  133. pushedparasize : longint;
  134. { message calls with codegenerror support }
  135. procedure cgmessage(t : longint);
  136. procedure cgmessage1(t : longint;const s : string);
  137. procedure cgmessage2(t : longint;const s1,s2 : string);
  138. procedure cgmessage3(t : longint;const s1,s2,s3 : string);
  139. procedure CGMessagePos(const pos:tfileposinfo;t:longint);
  140. procedure CGMessagePos1(const pos:tfileposinfo;t:longint;const s1:string);
  141. procedure CGMessagePos2(const pos:tfileposinfo;t:longint;const s1,s2:string);
  142. procedure CGMessagePos3(const pos:tfileposinfo;t:longint;const s1,s2,s3:string);
  143. { initialize respectively terminates the code generator }
  144. { for a new module or procedure }
  145. procedure codegen_newmodule;
  146. procedure codegen_donemodule;
  147. {# From a definition return the abstract code generator size enum. It is
  148. to note that the value returned can be @var(OS_NO) }
  149. function def_cgsize(def: tdef): tcgsize;
  150. {# From a constant numeric value, return the abstract code generator
  151. size.
  152. }
  153. function int_cgsize(const a: aword): tcgsize;
  154. {# return the inverse condition of opcmp }
  155. function inverse_opcmp(opcmp: topcmp): topcmp;
  156. {# return whether op is commutative }
  157. function commutativeop(op: topcg): boolean;
  158. implementation
  159. uses
  160. systems,
  161. cresstr,
  162. tgobj,rgobj,
  163. defutil,
  164. fmodule
  165. ,symbase,paramgr
  166. ;
  167. {*****************************************************************************
  168. override the message calls to set codegenerror
  169. *****************************************************************************}
  170. procedure cgmessage(t : longint);
  171. var
  172. olderrorcount : longint;
  173. begin
  174. if not(codegenerror) then
  175. begin
  176. olderrorcount:=Errorcount;
  177. verbose.Message(t);
  178. codegenerror:=olderrorcount<>Errorcount;
  179. end;
  180. end;
  181. procedure cgmessage1(t : longint;const s : string);
  182. var
  183. olderrorcount : longint;
  184. begin
  185. if not(codegenerror) then
  186. begin
  187. olderrorcount:=Errorcount;
  188. verbose.Message1(t,s);
  189. codegenerror:=olderrorcount<>Errorcount;
  190. end;
  191. end;
  192. procedure cgmessage2(t : longint;const s1,s2 : string);
  193. var
  194. olderrorcount : longint;
  195. begin
  196. if not(codegenerror) then
  197. begin
  198. olderrorcount:=Errorcount;
  199. verbose.Message2(t,s1,s2);
  200. codegenerror:=olderrorcount<>Errorcount;
  201. end;
  202. end;
  203. procedure cgmessage3(t : longint;const s1,s2,s3 : string);
  204. var
  205. olderrorcount : longint;
  206. begin
  207. if not(codegenerror) then
  208. begin
  209. olderrorcount:=Errorcount;
  210. verbose.Message3(t,s1,s2,s3);
  211. codegenerror:=olderrorcount<>Errorcount;
  212. end;
  213. end;
  214. procedure cgmessagepos(const pos:tfileposinfo;t : longint);
  215. var
  216. olderrorcount : longint;
  217. begin
  218. if not(codegenerror) then
  219. begin
  220. olderrorcount:=Errorcount;
  221. verbose.MessagePos(pos,t);
  222. codegenerror:=olderrorcount<>Errorcount;
  223. end;
  224. end;
  225. procedure cgmessagepos1(const pos:tfileposinfo;t : longint;const s1 : string);
  226. var
  227. olderrorcount : longint;
  228. begin
  229. if not(codegenerror) then
  230. begin
  231. olderrorcount:=Errorcount;
  232. verbose.MessagePos1(pos,t,s1);
  233. codegenerror:=olderrorcount<>Errorcount;
  234. end;
  235. end;
  236. procedure cgmessagepos2(const pos:tfileposinfo;t : longint;const s1,s2 : string);
  237. var
  238. olderrorcount : longint;
  239. begin
  240. if not(codegenerror) then
  241. begin
  242. olderrorcount:=Errorcount;
  243. verbose.MessagePos2(pos,t,s1,s2);
  244. codegenerror:=olderrorcount<>Errorcount;
  245. end;
  246. end;
  247. procedure cgmessagepos3(const pos:tfileposinfo;t : longint;const s1,s2,s3 : string);
  248. var
  249. olderrorcount : longint;
  250. begin
  251. if not(codegenerror) then
  252. begin
  253. olderrorcount:=Errorcount;
  254. verbose.MessagePos3(pos,t,s1,s2,s3);
  255. codegenerror:=olderrorcount<>Errorcount;
  256. end;
  257. end;
  258. {****************************************************************************
  259. TProcInfo
  260. ****************************************************************************}
  261. constructor tprocinfo.create(aparent:tprocinfo);
  262. begin
  263. parent:=aparent;
  264. procdef:=nil;
  265. framepointer_offset:=0;
  266. firsttemp_offset:=0;
  267. flags:=[];
  268. framepointer.enum:=R_INTREGISTER;
  269. framepointer.number:=NR_FRAME_POINTER_REG;
  270. { asmlists }
  271. aktproccode:=Taasmoutput.Create;
  272. aktlocaldata:=Taasmoutput.Create;
  273. reference_reset(save_stackptr_ref);
  274. { labels }
  275. objectlibrary.getlabel(aktexitlabel);
  276. end;
  277. destructor tprocinfo.destroy;
  278. begin
  279. aktproccode.free;
  280. aktlocaldata.free;
  281. end;
  282. procedure tprocinfo.allocate_interrupt_stackframe;
  283. begin
  284. end;
  285. procedure tprocinfo.handle_body_start;
  286. begin
  287. { temporary space is set, while the BEGIN of the procedure }
  288. if (symtablestack.symtabletype=localsymtable) then
  289. current_procinfo.firsttemp_offset := tg.direction*symtablestack.datasize
  290. else
  291. current_procinfo.firsttemp_offset := 0;
  292. { space for the return value }
  293. { !!!!! this means that we can not set the return value
  294. in a subfunction !!!!! }
  295. { because we don't know yet where the address is }
  296. if not is_void(procdef.rettype.def) then
  297. begin
  298. if not paramanager.ret_in_param(procdef.rettype.def,procdef.proccalloption) then
  299. begin
  300. rg.usedinproc := rg.usedinproc +
  301. getfuncretusedregisters(procdef.rettype.def,procdef.proccalloption);
  302. end;
  303. end;
  304. end;
  305. procedure tprocinfo.allocate_implicit_parameter;
  306. begin
  307. { Insert implicit parameters, will be removed in the future }
  308. if (procdef.parast.symtablelevel>normal_function_level) then
  309. begin
  310. framepointer_offset:=procdef.parast.address_fixup;
  311. inc(procdef.parast.address_fixup,POINTER_SIZE);
  312. end;
  313. end;
  314. procedure tprocinfo.after_header;
  315. begin
  316. end;
  317. procedure tprocinfo.after_pass1;
  318. begin
  319. end;
  320. {*****************************************************************************
  321. initialize/terminate the codegen for procedure and modules
  322. *****************************************************************************}
  323. procedure codegen_newmodule;
  324. begin
  325. exprasmlist:=taasmoutput.create;
  326. datasegment:=taasmoutput.create;
  327. codesegment:=taasmoutput.create;
  328. bsssegment:=taasmoutput.create;
  329. debuglist:=taasmoutput.create;
  330. withdebuglist:=taasmoutput.create;
  331. consts:=taasmoutput.create;
  332. rttilist:=taasmoutput.create;
  333. ResourceStringList:=Nil;
  334. importssection:=nil;
  335. exportssection:=nil;
  336. resourcesection:=nil;
  337. { resourcestrings }
  338. ResourceStrings:=TResourceStrings.Create;
  339. { use the librarydata from current_module }
  340. objectlibrary:=current_module.librarydata;
  341. end;
  342. procedure codegen_donemodule;
  343. {$ifdef MEMDEBUG}
  344. var
  345. d : tmemdebug;
  346. {$endif}
  347. begin
  348. {$ifdef MEMDEBUG}
  349. d:=tmemdebug.create(current_module.modulename^+' - asmlists');
  350. {$endif}
  351. exprasmlist.free;
  352. codesegment.free;
  353. bsssegment.free;
  354. datasegment.free;
  355. debuglist.free;
  356. withdebuglist.free;
  357. consts.free;
  358. rttilist.free;
  359. if assigned(ResourceStringList) then
  360. ResourceStringList.free;
  361. if assigned(importssection) then
  362. importssection.free;
  363. if assigned(exportssection) then
  364. exportssection.free;
  365. if assigned(resourcesection) then
  366. resourcesection.free;
  367. {$ifdef MEMDEBUG}
  368. d.free;
  369. {$endif}
  370. { resource strings }
  371. ResourceStrings.free;
  372. objectlibrary:=nil;
  373. end;
  374. function def_cgsize(def: tdef): tcgsize;
  375. begin
  376. case def.deftype of
  377. orddef,
  378. enumdef,
  379. setdef:
  380. begin
  381. result := int_cgsize(def.size);
  382. if is_signed(def) then
  383. result := tcgsize(ord(result)+(ord(OS_S8)-ord(OS_8)));
  384. end;
  385. classrefdef,
  386. pointerdef,
  387. procvardef:
  388. result := OS_ADDR;
  389. stringdef :
  390. begin
  391. if is_ansistring(def) or is_widestring(def) then
  392. result := OS_ADDR
  393. else
  394. result := OS_NO;
  395. end;
  396. objectdef :
  397. begin
  398. if is_class_or_interface(def) then
  399. result := OS_ADDR
  400. else
  401. result := OS_NO;
  402. end;
  403. floatdef:
  404. result := tfloat2tcgsize[tfloatdef(def).typ];
  405. recorddef :
  406. result:=int_cgsize(def.size);
  407. arraydef :
  408. begin
  409. if not is_special_array(def) then
  410. result := int_cgsize(def.size)
  411. else
  412. begin
  413. if is_dynamic_array(def) then
  414. result := OS_ADDR
  415. else
  416. result := OS_NO;
  417. end;
  418. end;
  419. else
  420. begin
  421. { undefined size }
  422. result:=OS_NO;
  423. end;
  424. end;
  425. end;
  426. function int_cgsize(const a: aword): tcgsize;
  427. begin
  428. if a > 8 then
  429. begin
  430. int_cgsize := OS_NO;
  431. exit;
  432. end;
  433. case byte(a) of
  434. 1 :
  435. result := OS_8;
  436. 2 :
  437. result := OS_16;
  438. 3,4 :
  439. result := OS_32;
  440. 5..8 :
  441. result := OS_64;
  442. end;
  443. end;
  444. function inverse_opcmp(opcmp: topcmp): topcmp;
  445. const
  446. list: array[TOpCmp] of TOpCmp =
  447. (OC_NONE,OC_NE,OC_LTE,OC_GTE,OC_LT,OC_GT,OC_EQ,OC_A,OC_AE,
  448. OC_B,OC_BE);
  449. begin
  450. inverse_opcmp := list[opcmp];
  451. end;
  452. function commutativeop(op: topcg): boolean;
  453. const
  454. list: array[topcg] of boolean =
  455. (true,true,true,false,false,true,true,false,false,
  456. true,false,false,false,false,true);
  457. begin
  458. commutativeop := list[op];
  459. end;
  460. end.
  461. {
  462. $Log$
  463. Revision 1.54 2003-06-09 12:23:29 peter
  464. * init/final of procedure data splitted from genentrycode
  465. * use asmnode getposition to insert final at the correct position
  466. als for the implicit try...finally
  467. Revision 1.53 2003/06/02 21:42:05 jonas
  468. * function results can now also be regvars
  469. - removed tprocinfo.return_offset, never use it again since it's invalid
  470. if the result is a regvar
  471. Revision 1.52 2003/05/26 21:17:17 peter
  472. * procinlinenode removed
  473. * aktexit2label removed, fast exit removed
  474. + tcallnode.inlined_pass_2 added
  475. Revision 1.51 2003/05/23 14:27:35 peter
  476. * remove some unit dependencies
  477. * current_procinfo changes to store more info
  478. Revision 1.50 2003/05/16 20:54:12 jonas
  479. - undid previous commit, it wasn't necessary
  480. Revision 1.49 2003/05/16 20:00:39 jonas
  481. * powerpc nested procedure fixes, should work completely now if all
  482. local variables of the parent procedure are declared before the
  483. nested procedures are declared
  484. Revision 1.48 2003/05/15 18:58:53 peter
  485. * removed selfpointer_offset, vmtpointer_offset
  486. * tvarsym.adjusted_address
  487. * address in localsymtable is now in the real direction
  488. * removed some obsolete globals
  489. Revision 1.47 2003/05/13 19:14:41 peter
  490. * failn removed
  491. * inherited result code check moven to pexpr
  492. Revision 1.46 2003/05/09 17:47:02 peter
  493. * self moved to hidden parameter
  494. * removed hdisposen,hnewn,selfn
  495. Revision 1.45 2003/04/27 11:21:32 peter
  496. * aktprocdef renamed to current_procdef
  497. * procinfo renamed to current_procinfo
  498. * procinfo will now be stored in current_module so it can be
  499. cleaned up properly
  500. * gen_main_procsym changed to create_main_proc and release_main_proc
  501. to also generate a tprocinfo structure
  502. * fixed unit implicit initfinal
  503. Revision 1.44 2003/04/27 07:29:50 peter
  504. * current_procdef cleanup, current_procdef is now always nil when parsing
  505. a new procdef declaration
  506. * aktprocsym removed
  507. * lexlevel removed, use symtable.symtablelevel instead
  508. * implicit init/final code uses the normal genentry/genexit
  509. * funcret state checking updated for new funcret handling
  510. Revision 1.43 2003/04/26 00:31:42 peter
  511. * set return_offset moved to after_header
  512. Revision 1.42 2003/04/25 20:59:33 peter
  513. * removed funcretn,funcretsym, function result is now in varsym
  514. and aliases for result and function name are added using absolutesym
  515. * vs_hidden parameter for funcret passed in parameter
  516. * vs_hidden fixes
  517. * writenode changed to printnode and released from extdebug
  518. * -vp option added to generate a tree.log with the nodetree
  519. * nicer printnode for statements, callnode
  520. Revision 1.41 2003/04/23 12:35:34 florian
  521. * fixed several issues with powerpc
  522. + applied a patch from Jonas for nested function calls (PowerPC only)
  523. * ...
  524. Revision 1.40 2003/04/22 13:47:08 peter
  525. * fixed C style array of const
  526. * fixed C array passing
  527. * fixed left to right with high parameters
  528. Revision 1.39 2003/04/05 21:09:31 jonas
  529. * several ppc/generic result offset related fixes. The "normal" result
  530. offset seems now to be calculated correctly and a lot of duplicate
  531. calculations have been removed. Nested functions accessing the parent's
  532. function result don't work at all though :(
  533. Revision 1.38 2003/03/28 19:16:56 peter
  534. * generic constructor working for i386
  535. * remove fixed self register
  536. * esi added as address register for i386
  537. Revision 1.37 2003/03/20 17:51:45 peter
  538. * dynamic arrays have size OS_ADDR
  539. Revision 1.36 2003/01/08 18:43:56 daniel
  540. * Tregister changed into a record
  541. Revision 1.35 2003/01/01 21:04:48 peter
  542. * removed unused method
  543. Revision 1.34 2002/11/25 17:43:16 peter
  544. * splitted defbase in defutil,symutil,defcmp
  545. * merged isconvertable and is_equal into compare_defs(_ext)
  546. * made operator search faster by walking the list only once
  547. Revision 1.33 2002/11/18 17:31:54 peter
  548. * pass proccalloption to ret_in_xxx and push_xxx functions
  549. Revision 1.32 2002/10/05 12:43:23 carl
  550. * fixes for Delphi 6 compilation
  551. (warning : Some features do not work under Delphi)
  552. Revision 1.31 2002/10/03 21:20:19 carl
  553. * range check error fix
  554. Revision 1.30 2002/09/30 07:00:44 florian
  555. * fixes to common code to get the alpha compiler compiled applied
  556. Revision 1.29 2002/09/07 19:35:45 florian
  557. + tcg.direction is used now
  558. Revision 1.28 2002/09/07 15:25:01 peter
  559. * old logs removed and tabs fixed
  560. Revision 1.27 2002/09/05 19:29:42 peter
  561. * memdebug enhancements
  562. Revision 1.26 2002/08/18 20:06:23 peter
  563. * inlining is now also allowed in interface
  564. * renamed write/load to ppuwrite/ppuload
  565. * tnode storing in ppu
  566. * nld,ncon,nbas are already updated for storing in ppu
  567. Revision 1.25 2002/08/17 09:23:33 florian
  568. * first part of procinfo rewrite
  569. Revision 1.24 2002/08/11 14:32:26 peter
  570. * renamed current_library to objectlibrary
  571. Revision 1.23 2002/08/11 13:24:11 peter
  572. * saving of asmsymbols in ppu supported
  573. * asmsymbollist global is removed and moved into a new class
  574. tasmlibrarydata that will hold the info of a .a file which
  575. corresponds with a single module. Added librarydata to tmodule
  576. to keep the library info stored for the module. In the future the
  577. objectfiles will also be stored to the tasmlibrarydata class
  578. * all getlabel/newasmsymbol and friends are moved to the new class
  579. Revision 1.22 2002/08/06 20:55:20 florian
  580. * first part of ppc calling conventions fix
  581. Revision 1.21 2002/08/05 18:27:48 carl
  582. + more more more documentation
  583. + first version include/exclude (can't test though, not enough scratch for i386 :()...
  584. Revision 1.20 2002/08/04 19:06:41 carl
  585. + added generic exception support (still does not work!)
  586. + more documentation
  587. Revision 1.19 2002/07/20 11:57:53 florian
  588. * types.pas renamed to defbase.pas because D6 contains a types
  589. unit so this would conflicts if D6 programms are compiled
  590. + Willamette/SSE2 instructions to assembler added
  591. Revision 1.18 2002/07/01 18:46:22 peter
  592. * internal linker
  593. * reorganized aasm layer
  594. Revision 1.17 2002/05/20 13:30:40 carl
  595. * bugfix of hdisponen (base must be set, not index)
  596. * more portability fixes
  597. Revision 1.16 2002/05/18 13:34:05 peter
  598. * readded missing revisions
  599. Revision 1.15 2002/05/16 19:46:35 carl
  600. + defines.inc -> fpcdefs.inc to avoid conflicts if compiling by hand
  601. + try to fix temp allocation (still in ifdef)
  602. + generic constructor calls
  603. + start of tassembler / tmodulebase class cleanup
  604. Revision 1.13 2002/04/25 20:16:38 peter
  605. * moved more routines from cga/n386util
  606. Revision 1.12 2002/04/21 15:28:06 carl
  607. - remove duplicate constants
  608. - move some constants to cginfo
  609. Revision 1.11 2002/04/20 21:32:23 carl
  610. + generic FPC_CHECKPOINTER
  611. + first parameter offset in stack now portable
  612. * rename some constants
  613. + move some cpu stuff to other units
  614. - remove unused constents
  615. * fix stacksize for some targets
  616. * fix generic size problems which depend now on EXTEND_SIZE constant
  617. Revision 1.10 2002/04/07 09:13:39 carl
  618. + documentation
  619. - remove unused variables
  620. Revision 1.9 2002/04/04 19:05:54 peter
  621. * removed unused units
  622. * use tlocation.size in cg.a_*loc*() routines
  623. Revision 1.8 2002/04/02 17:11:27 peter
  624. * tlocation,treference update
  625. * LOC_CONSTANT added for better constant handling
  626. * secondadd splitted in multiple routines
  627. * location_force_reg added for loading a location to a register
  628. of a specified size
  629. * secondassignment parses now first the right and then the left node
  630. (this is compatible with Kylix). This saves a lot of push/pop especially
  631. with string operations
  632. * adapted some routines to use the new cg methods
  633. Revision 1.7 2002/03/31 20:26:33 jonas
  634. + a_loadfpu_* and a_loadmm_* methods in tcg
  635. * register allocation is now handled by a class and is mostly processor
  636. independent (+rgobj.pas and i386/rgcpu.pas)
  637. * temp allocation is now handled by a class (+tgobj.pas, -i386\tgcpu.pas)
  638. * some small improvements and fixes to the optimizer
  639. * some register allocation fixes
  640. * some fpuvaroffset fixes in the unary minus node
  641. * push/popusedregisters is now called rg.save/restoreusedregisters and
  642. (for i386) uses temps instead of push/pop's when using -Op3 (that code is
  643. also better optimizable)
  644. * fixed and optimized register saving/restoring for new/dispose nodes
  645. * LOC_FPU locations now also require their "register" field to be set to
  646. R_ST, not R_ST0 (the latter is used for LOC_CFPUREGISTER locations only)
  647. - list field removed of the tnode class because it's not used currently
  648. and can cause hard-to-find bugs
  649. }