systems.pas 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789
  1. {
  2. $Id$
  3. Copyright (c) 1998-2002 by Florian Klaempfl
  4. This unit contains information about the target systems supported
  5. (these are not processor specific)
  6. This program is free software; you can redistribute it and/or modify
  7. iu under the terms of the GNU General Public License as published by
  8. the Free Software Foundation; either version 3 of the License, or
  9. (at your option) any later version.
  10. This program is distributed in the hope that it will be useful,
  11. but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. GNU General Public License for more details.
  14. You should have received a copy of the GNU General Public License
  15. along with this program; if not, write to the Free Software
  16. Foundation, Inc., 675 Mass Ave, Cambridge- MA 02139, USA.
  17. ****************************************************************************
  18. }
  19. unit systems;
  20. {$i fpcdefs.inc}
  21. interface
  22. type
  23. tendian = (endian_little,endian_big);
  24. (*
  25. IMPORTANT NOTE:
  26. The value of this enumeration is stored in PPU files.
  27. Therefore adding new CPU targets should not change the
  28. values of the pre-existing targets. (CEC)
  29. FURTHERMORE : Make sure that this branch values, are
  30. consistant with the main branch version always.
  31. *)
  32. tsystemcpu=
  33. (
  34. cpu_no, { 0 }
  35. cpu_i386, { 1 }
  36. cpu_m68k, { 2 }
  37. cpu_alpha, { 3 }
  38. cpu_powerpc, { 4 }
  39. cpu_sparc, { 5 }
  40. cpu_vm, { 6 }
  41. cpu_iA64, { 7 }
  42. cpu_x86_64, { 8 }
  43. cpu_mips, { 9 }
  44. cpu_arm { 10 }
  45. );
  46. TSection=(sec_none,
  47. sec_code,sec_data,sec_bss,
  48. sec_idata2,sec_idata4,sec_idata5,sec_idata6,sec_idata7,sec_edata,
  49. sec_stab,sec_stabstr,sec_common
  50. );
  51. tasmmode= (asmmode_none
  52. { direct output with minimal parsing }
  53. ,asmmode_direct
  54. { standard assembler (cpu dependant) with full parsing }
  55. ,asmmode_standard
  56. ,asmmode_i386_att
  57. ,asmmode_i386_intel
  58. ,asmmode_ppc_gas
  59. ,asmmode_ppc_motorola
  60. ,asmmode_arm_gas
  61. ,asmmode_sparc_gas
  62. ,asmmode_x8664_gas
  63. );
  64. (* IMPORTANT NOTE:
  65. the integer value of this enum is stored in PPU
  66. files to recognize the target, so if you add new targets
  67. allways add them at end PM
  68. FURTHERMORE : Make sure that this branch values are
  69. consistant with the main branch version always. (CEC)
  70. *)
  71. type
  72. tsystem =
  73. (
  74. system_none, { 0 }
  75. obsolete_system_i386_GO32V1,{ 1 }
  76. system_i386_GO32V2, { 2 }
  77. system_i386_linux, { 3 }
  78. system_i386_OS2, { 4 }
  79. system_i386_Win32, { 5 }
  80. system_i386_freebsd, { 6 }
  81. system_m68k_Amiga, { 7 }
  82. system_m68k_Atari, { 8 }
  83. system_m68k_Mac, { 9 }
  84. system_m68k_linux, { 10 }
  85. system_m68k_PalmOS, { 11 }
  86. system_alpha_linux, { 12 }
  87. system_powerpc_linux, { 13 }
  88. system_powerpc_macos, { 14 }
  89. system_i386_sunos, { 15 }
  90. system_i386_beos, { 16 }
  91. system_i386_netbsd, { 17 }
  92. system_m68k_netbsd, { 18 }
  93. system_i386_Netware, { 19 }
  94. system_i386_qnx, { 20 }
  95. system_i386_wdosx, { 21 }
  96. system_sparc_sunos, { 22 }
  97. system_sparc_linux, { 23 }
  98. target_i386_openbsd, { 24 }
  99. target_m68k_openbsd, { 25 }
  100. system_x86_64_linux, { 26 }
  101. system_powerpc_darwin, { 27 }
  102. system_i386_EMX, { 28 }
  103. system_powerpc_netbsd, { 29 }
  104. system_powerpc_openbsd, { 30 }
  105. system_arm_linux, { 31 }
  106. system_i386_watcom { 32 }
  107. );
  108. tasm = (as_none
  109. ,as_gas { standard gnu assembler }
  110. ,as_i386_as_aout
  111. ,as_i386_nasmcoff
  112. ,as_i386_nasmwin32
  113. ,as_i386_nasmwdosx
  114. ,as_i386_nasmelf
  115. ,as_i386_nasmobj
  116. ,as_i386_nasmbeos
  117. ,as_i386_tasm
  118. ,as_i386_masm
  119. ,as_i386_wasm
  120. ,as_i386_coff
  121. ,as_i386_pecoff
  122. ,as_i386_elf32
  123. ,as_i386_pecoffwdosx
  124. ,as_m68k_mit
  125. ,as_powerpc_mpw
  126. );
  127. tar = (ar_none
  128. ,ar_gnu_ar,ar_mpw_ar
  129. );
  130. tres = (res_none
  131. ,res_gnu_windres,res_emxbind
  132. ,res_m68k_palmos,res_m68k_mpw
  133. ,res_powerpc_mpw
  134. );
  135. tscripttype = (script_none
  136. ,script_dos,script_unix,script_amiga
  137. );
  138. tabi = (abi_default
  139. ,abi_powerpc_sysv,abi_powerpc_aix
  140. );
  141. {*****************************************************************************
  142. Structures
  143. *****************************************************************************}
  144. type
  145. { Abstract linker class which is implemented in link module }
  146. TAbstractLinker = class
  147. end;
  148. TAbstractLinkerClass = class of TABstractLinker;
  149. { Abstract assembler class which is implemented in assemble module }
  150. TAbstractAssembler = class
  151. end;
  152. TAbstractAssemblerClass = class of TAbstractAssembler;
  153. palignmentinfo = ^talignmentinfo;
  154. talignmentinfo = packed record
  155. procalign,
  156. loopalign,
  157. jumpalign,
  158. constalignmin,
  159. constalignmax,
  160. varalignmin,
  161. varalignmax,
  162. localalignmin,
  163. localalignmax,
  164. recordalignmin,
  165. recordalignmax,
  166. maxCrecordalign : longint;
  167. end;
  168. pasminfo = ^tasminfo;
  169. tasminfo = packed record
  170. id : tasm;
  171. idtxt : string[9];
  172. asmbin : string[8];
  173. asmcmd : string[50];
  174. supported_target : tsystem;
  175. outputbinary,
  176. allowdirect,
  177. needar,
  178. labelprefix_only_inside_procedure : boolean;
  179. labelprefix : string[3];
  180. comment : string[2];
  181. secnames : array[TSection] of string[20];
  182. end;
  183. parinfo = ^tarinfo;
  184. tarinfo = packed record
  185. id : tar;
  186. arcmd : string[50];
  187. end;
  188. presinfo = ^tresinfo;
  189. tresinfo = packed record
  190. id : tres;
  191. resbin : string[8];
  192. rescmd : string[50];
  193. end;
  194. tsystemflags = (tf_none,
  195. tf_under_development,
  196. tf_need_export,tf_needs_isconsole
  197. ,tf_code_small,tf_static_reg_based
  198. );
  199. psysteminfo = ^tsysteminfo;
  200. tsysteminfo = packed record
  201. system : tsystem;
  202. name : string[34];
  203. shortname : string[9];
  204. flags : set of tsystemflags;
  205. cpu : tsystemcpu;
  206. unit_env : string[12];
  207. extradefines : string[40];
  208. sourceext,
  209. pasext,
  210. exeext,
  211. defext,
  212. scriptext,
  213. smartext,
  214. unitext,
  215. unitlibext,
  216. asmext,
  217. objext,
  218. resext,
  219. resobjext : string[4];
  220. sharedlibext : string[10];
  221. staticlibext,
  222. staticlibprefix : string[4];
  223. sharedlibprefix : string[4];
  224. sharedClibext : string[10];
  225. staticClibext,
  226. staticClibprefix : string[4];
  227. sharedClibprefix : string[4];
  228. Cprefix : string[2];
  229. newline : string[2];
  230. dirsep : char;
  231. files_case_relevent : boolean;
  232. assem : tasm;
  233. assemextern : tasm; { external assembler, used by -a }
  234. link : tabstractlinkerclass;
  235. linkextern : tabstractlinkerclass; { external linker, used by -s }
  236. ar : tar;
  237. res : tres;
  238. script : tscripttype;
  239. endian : tendian;
  240. alignment : talignmentinfo;
  241. {
  242. Offset from the argument pointer register to the first
  243. argument's address. On some machines it may depend on
  244. the data type of the function.
  245. (see also FIRST_PARM_OFFSET in GCC source)
  246. }
  247. first_parm_offset : longint;
  248. heapsize,
  249. stacksize : longint;
  250. DllScanSupported : boolean;
  251. use_function_relative_addresses : boolean;
  252. abi : tabi;
  253. end;
  254. const
  255. { alias for supported_target field in tasminfo }
  256. system_any = system_none;
  257. var
  258. targetinfos : array[tsystem] of psysteminfo;
  259. arinfos : array[tar] of parinfo;
  260. resinfos : array[tres] of presinfo;
  261. asminfos : array[tasm] of pasminfo;
  262. source_info : tsysteminfo;
  263. target_cpu : tsystemcpu;
  264. target_info : tsysteminfo;
  265. target_asm : tasminfo;
  266. target_ar : tarinfo;
  267. target_res : tresinfo;
  268. target_path : string[12]; { for rtl/<X>/,fcl/<X>/, etc. }
  269. function set_target(t:tsystem):boolean;
  270. function set_target_asm(t:tasm):boolean;
  271. function set_target_ar(t:tar):boolean;
  272. function set_target_res(t:tres):boolean;
  273. function set_target_by_string(const s : string) : boolean;
  274. function set_target_asm_by_string(const s : string) : boolean;
  275. procedure set_source_info(const ti : tsysteminfo);
  276. procedure UpdateAlignment(var d:talignmentinfo;const s:talignmentinfo);
  277. procedure RegisterTarget(const r:tsysteminfo);
  278. procedure RegisterRes(const r:tresinfo);
  279. procedure RegisterAr(const r:tarinfo);
  280. { Register the external linker. This routine is called to setup the
  281. class to use for the linker. It returns the tsysteminfo structure
  282. updated with the correct linker class for external linking.
  283. }
  284. procedure RegisterExternalLinker(var system_info: tsysteminfo; c:TAbstractLinkerClass);
  285. { Register the internal linker. This routine is called to setup the
  286. class to use for the linker. It returns the tsysteminfo structure
  287. updated with the correct linker class for internal linking.
  288. If internal linking is not supported, this class can be set
  289. to nil.
  290. }
  291. procedure RegisterInternalLinker(var system_info : tsysteminfo; c:TAbstractLinkerClass);
  292. procedure InitSystems;
  293. implementation
  294. uses
  295. cutils;
  296. {****************************************************************************
  297. Target setting
  298. ****************************************************************************}
  299. function set_target(t:tsystem):boolean;
  300. begin
  301. set_target:=false;
  302. if assigned(targetinfos[t]) then
  303. begin
  304. target_info:=targetinfos[t]^;
  305. set_target_asm(target_info.assem);
  306. set_target_ar(target_info.ar);
  307. set_target_res(target_info.res);
  308. target_path:=lower(target_info.shortname);
  309. target_cpu:=target_info.cpu;
  310. set_target:=true;
  311. exit;
  312. end;
  313. end;
  314. function set_target_asm(t:tasm):boolean;
  315. begin
  316. set_target_asm:=false;
  317. if assigned(asminfos[t]) then
  318. begin
  319. target_asm:=asminfos[t]^;
  320. set_target_asm:=true;
  321. exit;
  322. end;
  323. end;
  324. function set_target_ar(t:tar):boolean;
  325. begin
  326. set_target_ar:=false;
  327. if assigned(arinfos[t]) then
  328. begin
  329. target_ar:=arinfos[t]^;
  330. set_target_ar:=true;
  331. exit;
  332. end;
  333. end;
  334. function set_target_res(t:tres):boolean;
  335. begin
  336. set_target_res:=false;
  337. if assigned(resinfos[t]) then
  338. begin
  339. target_res:=resinfos[t]^;
  340. set_target_res:=true;
  341. exit;
  342. end;
  343. end;
  344. function set_target_by_string(const s : string) : boolean;
  345. var
  346. hs : string;
  347. t : tsystem;
  348. begin
  349. set_target_by_string:=false;
  350. { this should be case insensitive !! PM }
  351. hs:=upper(s);
  352. for t:=low(tsystem) to high(tsystem) do
  353. if assigned(targetinfos[t]) and
  354. (upper(targetinfos[t]^.shortname)=hs) then
  355. begin
  356. set_target_by_string:=set_target(t);
  357. exit;
  358. end;
  359. end;
  360. function set_target_asm_by_string(const s : string) : boolean;
  361. var
  362. hs : string;
  363. t : tasm;
  364. begin
  365. set_target_asm_by_string:=false;
  366. { this should be case insensitive !! PM }
  367. hs:=upper(s);
  368. for t:=low(tasm) to high(tasm) do
  369. if assigned(asminfos[t]) and
  370. (asminfos[t]^.idtxt=hs) then
  371. begin
  372. set_target_asm_by_string:=set_target_asm(t);
  373. exit;
  374. end;
  375. end;
  376. procedure UpdateAlignment(var d:talignmentinfo;const s:talignmentinfo);
  377. begin
  378. with d do
  379. begin
  380. { general update rules:
  381. minimum: if higher then update
  382. maximum: if lower then update or if undefined then update }
  383. if s.procalign>procalign then
  384. procalign:=s.procalign;
  385. if s.loopalign>loopalign then
  386. loopalign:=s.loopalign;
  387. if s.jumpalign>jumpalign then
  388. jumpalign:=s.jumpalign;
  389. if s.constalignmin>constalignmin then
  390. constalignmin:=s.constalignmin;
  391. if (constalignmax=0) or
  392. ((s.constalignmax>0) and (s.constalignmax<constalignmax)) then
  393. constalignmax:=s.constalignmax;
  394. if s.varalignmin>varalignmin then
  395. varalignmin:=s.varalignmin;
  396. if (varalignmax=0) or
  397. ((s.varalignmax>0) and (s.varalignmax<varalignmax)) then
  398. varalignmax:=s.varalignmax;
  399. if s.localalignmin>localalignmin then
  400. localalignmin:=s.localalignmin;
  401. if (localalignmax=0) or
  402. ((s.localalignmax>0) and (s.localalignmax<localalignmax)) then
  403. localalignmax:=s.localalignmax;
  404. if s.recordalignmin>recordalignmin then
  405. recordalignmin:=s.recordalignmin;
  406. if (recordalignmax=0) or
  407. ((s.recordalignmax>0) and (s.recordalignmax<recordalignmax)) then
  408. recordalignmax:=s.recordalignmax;
  409. if (maxCrecordalign=0) or
  410. ((s.maxCrecordalign>0) and (s.maxCrecordalign<maxCrecordalign)) then
  411. maxCrecordalign:=s.maxCrecordalign;
  412. end;
  413. end;
  414. {****************************************************************************
  415. Target registration
  416. ****************************************************************************}
  417. procedure RegisterTarget(const r:tsysteminfo);
  418. var
  419. t : tsystem;
  420. begin
  421. t:=r.system;
  422. if assigned(targetinfos[t]) then
  423. writeln('Warning: Target is already registered!')
  424. else
  425. Getmem(targetinfos[t],sizeof(tsysteminfo));
  426. targetinfos[t]^:=r;
  427. end;
  428. procedure RegisterRes(const r:tresinfo);
  429. var
  430. t : tres;
  431. begin
  432. t:=r.id;
  433. if assigned(resinfos[t]) then
  434. writeln('Warning: resourcecompiler is already registered!')
  435. else
  436. Getmem(resinfos[t],sizeof(tresinfo));
  437. resinfos[t]^:=r;
  438. end;
  439. procedure RegisterAr(const r:tarinfo);
  440. var
  441. t : tar;
  442. begin
  443. t:=r.id;
  444. if assigned(arinfos[t]) then
  445. writeln('Warning: ar is already registered!')
  446. else
  447. Getmem(arinfos[t],sizeof(tarinfo));
  448. arinfos[t]^:=r;
  449. end;
  450. procedure RegisterExternalLinker(var system_info: tsysteminfo; c:TAbstractLinkerClass);
  451. begin
  452. system_info.linkextern := c;
  453. end;
  454. procedure RegisterInternalLinker(var system_info : tsysteminfo; c:TAbstractLinkerClass);
  455. begin
  456. system_info.link := c;
  457. end;
  458. procedure DeregisterInfos;
  459. var
  460. assem : tasm;
  461. target : tsystem;
  462. ar : tar;
  463. res : tres;
  464. begin
  465. for target:=low(tsystem) to high(tsystem) do
  466. if assigned(targetinfos[target]) then
  467. begin
  468. freemem(targetinfos[target],sizeof(tsysteminfo));
  469. targetinfos[target]:=nil;
  470. end;
  471. for assem:=low(tasm) to high(tasm) do
  472. if assigned(asminfos[assem]) then
  473. begin
  474. freemem(asminfos[assem],sizeof(tasminfo));
  475. asminfos[assem]:=nil;
  476. end;
  477. for ar:=low(tar) to high(tar) do
  478. if assigned(arinfos[ar]) then
  479. begin
  480. freemem(arinfos[ar],sizeof(tarinfo));
  481. arinfos[ar]:=nil;
  482. end;
  483. for res:=low(tres) to high(tres) do
  484. if assigned(resinfos[res]) then
  485. begin
  486. freemem(resinfos[res],sizeof(tresinfo));
  487. resinfos[res]:=nil;
  488. end;
  489. end;
  490. {****************************************************************************
  491. Initialization of default target
  492. ****************************************************************************}
  493. procedure default_target(t:tsystem);
  494. begin
  495. set_target(t);
  496. if source_info.name='' then
  497. source_info:=target_info;
  498. end;
  499. procedure set_source_info(const ti : tsysteminfo);
  500. begin
  501. { can't use message() here (PFV) }
  502. if source_info.name<>'' then
  503. Writeln('Warning: Source OS Redefined!');
  504. source_info:=ti;
  505. end;
  506. procedure InitSystems;
  507. begin
  508. { Now default target, this is dependent on the target cpu define,
  509. when the define is the same as the source cpu then we use the source
  510. os, else we pick a default }
  511. {$ifdef i386}
  512. {$ifdef cpu86}
  513. default_target(source_info.system);
  514. {$else cpu86}
  515. default_target(system_i386_linux);
  516. {$endif cpu86}
  517. {$endif i386}
  518. {$ifdef x86_64}
  519. {$ifdef cpu86_64}
  520. default_target(source_info.system);
  521. {$else cpu86_64}
  522. default_target(system_x86_64_linux);
  523. {$endif cpu86_64}
  524. {$endif x86_64}
  525. {$ifdef m68k}
  526. {$ifdef cpu68}
  527. default_target(source_info.target);
  528. {$else cpu68}
  529. default_target(system_m68k_linux);
  530. {$endif cpu68}
  531. {$endif m68k}
  532. {$ifdef alpha}
  533. {$ifdef cpualpha}
  534. default_target(source_info.system);
  535. {$else cpualpha}
  536. default_target(system_alpha_linux);
  537. {$endif cpualpha}
  538. {$endif alpha}
  539. {$ifdef powerpc}
  540. {$ifdef cpupowerpc}
  541. default_target(source_info.system);
  542. {$else cpupowerpc}
  543. default_target(system_powerpc_linux);
  544. {$endif cpupowerpc}
  545. {$endif powerpc}
  546. {$ifdef sparc}
  547. {$ifdef cpusparc}
  548. default_target(source_info.system);
  549. {$else cpusparc}
  550. default_target(system_sparc_linux);
  551. {$endif cpusparc}
  552. {$endif sparc}
  553. {$ifdef arm}
  554. {$ifdef cpuarm}
  555. default_target(source_info.system);
  556. {$else cpuarm}
  557. default_target(system_arm_linux);
  558. {$endif cpuarm}
  559. {$endif arm}
  560. end;
  561. initialization
  562. source_info.name:='';
  563. finalization
  564. DeregisterInfos;
  565. end.
  566. {
  567. $Log$
  568. Revision 1.75 2003-12-20 12:38:51 florian
  569. * some x86-64 compilation fixe
  570. Revision 1.74 2003/11/29 15:53:06 florian
  571. + nasmelf mode for BeOS
  572. + DQWORD directive in intel assembler mode
  573. Revision 1.73 2003/11/17 23:23:47 florian
  574. + first part of arm assembler reader
  575. Revision 1.72 2003/11/12 16:05:39 florian
  576. * assembler readers OOPed
  577. + typed currency constants
  578. + typed 128 bit float constants if the CPU supports it
  579. Revision 1.71 2003/10/18 09:04:11 hajny
  580. * Watcom target name didn't fit in name field length
  581. Revision 1.70 2003/10/03 22:00:33 peter
  582. * parameter alignment fixes
  583. Revision 1.69 2003/10/02 21:17:08 peter
  584. * use as,ld,ar instead of asw,ldw,arw for win32
  585. Revision 1.68 2003/09/05 17:41:13 florian
  586. * merged Wiktor's Watcom patches in 1.1
  587. Revision 1.67 2003/08/08 15:49:24 olle
  588. * merged macos entry/exit code generation into the general one.
  589. Revision 1.66 2003/07/21 11:52:57 florian
  590. * very basic stuff for the arm
  591. Revision 1.65 2003/05/31 16:17:27 marco
  592. * cpuppc -> cpupowerpc. Target compiler was always linux for ppc
  593. Revision 1.64 2003/05/28 23:18:31 florian
  594. * started to fix and clean up the sparc port
  595. Revision 1.63 2003/05/25 23:15:04 marco
  596. * NetBSD target support. OpenBSD reserved in the enum, for future use.
  597. Revision 1.62 2003/05/20 23:54:00 florian
  598. + basic darwin support added
  599. Revision 1.61 2003/05/18 15:15:59 florian
  600. + added abi field to tsysteminfo
  601. Revision 1.60 2003/03/23 23:21:42 hajny
  602. + emx target added
  603. Revision 1.59 2003/01/12 15:42:23 peter
  604. * m68k pathexist update from 1.0.x
  605. * palmos res update from 1.0.x
  606. Revision 1.58 2003/01/05 13:36:53 florian
  607. * x86-64 compiles
  608. + very basic support for float128 type (x86-64 only)
  609. Revision 1.57 2002/10/05 12:43:29 carl
  610. * fixes for Delphi 6 compilation
  611. (warning : Some features do not work under Delphi)
  612. Revision 1.56 2002/10/03 21:18:29 carl
  613. * correct tsystem enumeration
  614. Revision 1.55 2002/09/07 18:05:51 florian
  615. * first part of PowerPC fixes
  616. Revision 1.54 2002/08/20 21:40:44 florian
  617. + target macos for ppc added
  618. + frame work for mpw assembler output
  619. Revision 1.53 2002/08/18 09:13:02 florian
  620. * small fixes to the alpha stuff
  621. Revision 1.52 2002/08/13 21:40:57 florian
  622. * more fixes for ppc calling conventions
  623. Revision 1.51 2002/08/12 15:08:40 carl
  624. + stab register indexes for powerpc (moved from gdb to cpubase)
  625. + tprocessor enumeration moved to cpuinfo
  626. + linker in target_info is now a class
  627. * many many updates for m68k (will soon start to compile)
  628. - removed some ifdef or correct them for correct cpu
  629. Revision 1.50 2002/08/10 14:46:31 carl
  630. + moved target_cpu_string to cpuinfo
  631. * renamed asmmode enum.
  632. * assembler reader has now less ifdef's
  633. * move from nppcmem.pas -> ncgmem.pas vec. node.
  634. Revision 1.49 2002/07/28 20:45:22 florian
  635. + added direct assembler reader for PowerPC
  636. Revision 1.48 2002/07/26 21:15:42 florian
  637. * rewrote the system handling
  638. Revision 1.47 2002/07/04 20:43:02 florian
  639. * first x86-64 patches
  640. Revision 1.46 2002/07/01 18:46:29 peter
  641. * internal linker
  642. * reorganized aasm layer
  643. Revision 1.45 2002/05/18 13:34:21 peter
  644. * readded missing revisions
  645. Revision 1.44 2002/05/16 19:46:45 carl
  646. + defines.inc -> fpcdefs.inc to avoid conflicts if compiling by hand
  647. + try to fix temp allocation (still in ifdef)
  648. + generic constructor calls
  649. + start of tassembler / tmodulebase class cleanup
  650. Revision 1.42 2002/05/06 19:52:04 carl
  651. + added more patches from Mazen for SPARC port
  652. Revision 1.41 2002/04/24 16:08:30 carl
  653. * fix compilation problem
  654. Revision 1.40 2002/04/20 21:32:26 carl
  655. + generic FPC_CHECKPOINTER
  656. + first parameter offset in stack now portable
  657. * rename some constants
  658. + move some cpu stuff to other units
  659. - remove unused constents
  660. * fix stacksize for some targets
  661. * fix generic size problems which depend now on EXTEND_SIZE constant
  662. Revision 1.39 2002/04/15 19:08:22 carl
  663. + target_info.size_of_pointer -> pointer_size
  664. + some cleanup of unused types/variables
  665. Revision 1.38 2002/04/14 16:56:30 carl
  666. - remove duplicate comment
  667. }