systems.pas 21 KB

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