cpuinfo.pas 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. {
  2. $Id$
  3. Copyright (c) 1998-2002 by the Free Pascal development team
  4. Basic Processor information for the PowerPC
  5. See the file COPYING.FPC, included in this distribution,
  6. for details about the copyright.
  7. This program is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  10. **********************************************************************}
  11. Unit CPUInfo;
  12. Interface
  13. uses
  14. globtype;
  15. Type
  16. { Architecture word - Native unsigned type }
  17. AWord = Longword;
  18. AInt = Longint;
  19. PAWord = ^AWord;
  20. { this must be an ordinal type with the same size as a pointer }
  21. { to allow some dirty type casts for example when using }
  22. { tconstsym.value }
  23. { Note: must be unsigned!! Otherwise, ugly code like }
  24. { pointer(-1) will result in a pointer with the value }
  25. { $fffffffffffffff on a 32bit machine if the compiler uses }
  26. { int64 constants internally (JM) }
  27. TConstPtrUInt = Longword;
  28. bestreal = double;
  29. ts32real = single;
  30. ts64real = double;
  31. ts80real = extended;
  32. ts128real = extended;
  33. ts64comp = comp;
  34. pbestreal=^bestreal;
  35. { possible supported processors for this target }
  36. tprocessors =
  37. (no_processor,
  38. ppc601,
  39. ppc604
  40. );
  41. tfputype =
  42. (no_fpuprocessor,
  43. fpu_soft,
  44. fpu_standard
  45. );
  46. Const
  47. {# Size of native extended floating point type }
  48. extended_size = 8;
  49. {# Size of a pointer }
  50. pointer_size = 4;
  51. {# Size of a multimedia register }
  52. mmreg_size = 16;
  53. { target cpu string (used by compiler options) }
  54. target_cpu_string = 'powerpc';
  55. { size of the buffer used for setjump/longjmp
  56. the size of this buffer is deduced from the
  57. jmp_buf structure in setjumph.inc file
  58. }
  59. { for linux: }
  60. jmp_buf_size = 232;
  61. { calling conventions supported by the code generator }
  62. supported_calling_conventions : tproccalloptions = [
  63. pocall_internproc,
  64. pocall_compilerproc,
  65. pocall_inline,
  66. pocall_stdcall,
  67. { the difference to stdcall is only the name mangling }
  68. pocall_cdecl,
  69. { the difference to stdcall is only the name mangling }
  70. pocall_cppdecl
  71. ];
  72. processorsstr : array[tprocessors] of string[10] = ('',
  73. '603',
  74. '604'
  75. );
  76. fputypestr : array[tfputype] of string[6] = ('',
  77. 'SOFT',
  78. 'STANDARD'
  79. );
  80. Implementation
  81. end.
  82. {
  83. $Log$
  84. Revision 1.18 2004-04-28 15:19:03 florian
  85. + syscall directive support for MorphOS added
  86. Revision 1.17 2004/02/27 10:21:05 florian
  87. * top_symbol killed
  88. + refaddr to treference added
  89. + refsymbol to treference added
  90. * top_local stuff moved to an extra record to save memory
  91. + aint introduced
  92. * tppufile.get/putint64/aint implemented
  93. Revision 1.16 2003/11/12 16:05:40 florian
  94. * assembler readers OOPed
  95. + typed currency constants
  96. + typed 128 bit float constants if the CPU supports it
  97. Revision 1.15 2003/11/07 15:58:33 florian
  98. * Florian's culmutative nr. 1; contains:
  99. - invalid calling conventions for a certain cpu are rejected
  100. - arm softfloat calling conventions
  101. - -Sp for cpu dependend code generation
  102. - several arm fixes
  103. - remaining code for value open array paras on heap
  104. Revision 1.14 2003/09/03 11:18:37 florian
  105. * fixed arm concatcopy
  106. + arm support in the common compiler sources added
  107. * moved some generic cg code around
  108. + tfputype added
  109. * ...
  110. Revision 1.13 2003/04/26 20:15:22 florian
  111. * fixed setjmp record size
  112. Revision 1.12 2002/09/07 20:57:08 carl
  113. * cardinal -> longword
  114. Revision 1.11 2002/09/07 15:25:14 peter
  115. * old logs removed and tabs fixed
  116. Revision 1.10 2002/08/15 15:15:55 carl
  117. * jmpbuf size allocation for exceptions is now cpu specific (as it should)
  118. * more generic nodes for maths
  119. * several fixes for better m68k support
  120. Revision 1.9 2002/08/12 15:08:44 carl
  121. + stab register indexes for powerpc (moved from gdb to cpubase)
  122. + tprocessor enumeration moved to cpuinfo
  123. + linker in target_info is now a class
  124. * many many updates for m68k (will soon start to compile)
  125. - removed some ifdef or correct them for correct cpu
  126. Revision 1.8 2002/08/10 14:52:52 carl
  127. + moved target_cpu_string to cpuinfo
  128. * renamed asmmode enum.
  129. * assembler reader has now less ifdef's
  130. * move from nppcmem.pas -> ncgmem.pas vec. node.
  131. Revision 1.7 2002/05/18 13:34:26 peter
  132. * readded missing revisions
  133. Revision 1.6 2002/05/16 19:46:53 carl
  134. + defines.inc -> fpcdefs.inc to avoid conflicts if compiling by hand
  135. + try to fix temp allocation (still in ifdef)
  136. + generic constructor calls
  137. + start of tassembler / tmodulebase class cleanup
  138. Revision 1.4 2002/05/13 19:52:46 peter
  139. * a ppcppc can be build again
  140. Revision 1.3 2002/04/07 13:43:11 carl
  141. - moved type constant
  142. }