cpupi.pas 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. {
  2. $Id$
  3. Copyright (c) 2002 by Florian Klaempfl
  4. This unit contains the CPU specific part of tprocinfo
  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. { This unit contains the CPU specific part of tprocinfo. }
  19. unit cpupi;
  20. {$i fpcdefs.inc}
  21. interface
  22. uses
  23. psub;
  24. type
  25. ti386procinfo = class(tcgprocinfo)
  26. procedure allocate_interrupt_parameter;override;
  27. procedure allocate_framepointer_reg;override;
  28. procedure handle_body_start;override;
  29. end;
  30. implementation
  31. uses
  32. cgbase, cpubase, rgobj;
  33. procedure ti386procinfo.allocate_interrupt_parameter;
  34. begin
  35. { we push Flags and CS as long
  36. to cope with the IRETD
  37. and we save 6 register + 4 selectors }
  38. inc(procdef.parast.address_fixup,8+6*4+4*2);
  39. end;
  40. procedure ti386procinfo.allocate_framepointer_reg;
  41. begin
  42. if framepointer=NR_EBP then
  43. begin
  44. { Make sure the register allocator won't allocate registers
  45. into ebp }
  46. include(rg.used_in_proc_int,RS_EBP);
  47. exclude(rg.unusedregsint,RS_EBP);
  48. end;
  49. end;
  50. procedure ti386procinfo.handle_body_start;
  51. begin
  52. inherited handle_body_start;
  53. end;
  54. begin
  55. cprocinfo:=ti386procinfo;
  56. end.
  57. {
  58. $Log$
  59. Revision 1.11 2003-09-09 21:03:17 peter
  60. * basics for x86 register calling
  61. Revision 1.10 2003/09/03 15:55:01 peter
  62. * NEWRA branch merged
  63. Revision 1.9.2.1 2003/08/31 15:46:26 peter
  64. * more updates for tregister
  65. Revision 1.9 2003/07/06 17:58:22 peter
  66. * framepointer fixes for sparc
  67. * parent framepointer code more generic
  68. Revision 1.8 2003/06/13 21:19:31 peter
  69. * current_procdef removed, use current_procinfo.procdef instead
  70. Revision 1.7 2003/06/12 18:12:49 jonas
  71. * fixed compilation problems
  72. Revision 1.6 2003/06/12 16:43:07 peter
  73. * newra compiles for sparc
  74. Revision 1.5 2003/05/25 10:26:15 peter
  75. * fix interrupt stack allocation
  76. Revision 1.4 2003/05/22 21:32:29 peter
  77. * removed some unit dependencies
  78. Revision 1.3 2003/04/27 11:21:35 peter
  79. * aktprocdef renamed to current_procinfo.procdef
  80. * procinfo renamed to current_procinfo
  81. * procinfo will now be stored in current_module so it can be
  82. cleaned up properly
  83. * gen_main_procsym changed to create_main_proc and release_main_proc
  84. to also generate a tprocinfo structure
  85. * fixed unit implicit initfinal
  86. Revision 1.2 2003/04/27 07:48:05 peter
  87. * updated for removed lexlevel
  88. Revision 1.1 2002/08/17 09:23:44 florian
  89. * first part of procinfo rewrite
  90. }