rgcpu.pas 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. {
  2. Copyright (c) 1998-2002 by Florian Klaempfl
  3. This unit implements the powerpc specific class for the register
  4. allocator
  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. unit rgcpu;
  19. {$i fpcdefs.inc}
  20. interface
  21. uses
  22. aasmbase,aasmtai,aasmdata,
  23. cpubase,
  24. rgobj;
  25. type
  26. trgcpu = class(trgobj)
  27. {
  28. function getcpuregisterint(list: TAsmList; reg: Tnewregister): tregister; override;
  29. procedure ungetregisterint(list: TAsmList; reg: tregister); override;
  30. function getcpuregisterfpu(list : TAsmList; r : Toldregister) : tregister;override;
  31. procedure ungetregisterfpu(list: TAsmList; r : tregister; size:TCGsize);override;
  32. procedure cleartempgen; override;
  33. private
  34. usedpararegs: Tsupregset;
  35. usedparafpuregs: tregisterset;
  36. }
  37. end;
  38. implementation
  39. uses
  40. cgobj, verbose, cutils;
  41. (*
  42. function trgcpu.getcpuregisterint(list: TAsmList; reg: Tnewregister): tregister;
  43. begin
  44. if ((reg shr 8) in [RS_R0]) and
  45. not((reg shr 8) in is_reg_var_int) then
  46. begin
  47. if (reg shr 8) in usedpararegs then
  48. internalerror(2003060701);
  49. { comment(v_warning,'Double allocation of register '+tostr((reg shr 8)-1));}
  50. include(usedpararegs,reg shr 8);
  51. result.enum:=R_INTREGISTER;
  52. result.number:=reg;
  53. cg.a_reg_alloc(list,result);
  54. end
  55. else result := inherited getcpuregisterint(list,reg);
  56. end;
  57. procedure trgcpu.ungetregisterint(list: TAsmList; reg: tregister);
  58. begin
  59. if ((reg.number shr 8) in [RS_R0]) and
  60. not((reg.number shr 8) in is_reg_var_int) then
  61. begin
  62. if not((reg.number shr 8) in usedpararegs) then
  63. internalerror(2003060702);
  64. { comment(v_warning,'Double free of register '+tostr((reg.number shr 8)-1));}
  65. exclude(usedpararegs,reg.number shr 8);
  66. cg.a_reg_dealloc(list,reg);
  67. end
  68. else
  69. inherited ungetregisterint(list,reg);
  70. end;
  71. function trgcpu.getcpuregisterfpu(list : TAsmList; r : Toldregister) : tregister;
  72. begin
  73. if (r in [R_F1..R_F13]) and
  74. not is_reg_var_other[r] then
  75. begin
  76. if r in usedparafpuregs then
  77. internalerror(2003060902);
  78. include(usedparafpuregs,r);
  79. result.enum := r;
  80. cg.a_reg_alloc(list,result);
  81. end
  82. else
  83. result := inherited getcpuregisterfpu(list,r);
  84. end;
  85. procedure trgcpu.ungetregisterfpu(list: TAsmList; r : tregister; size:TCGsize);
  86. begin
  87. if (r.enum in [R_F1..R_F13]) and
  88. not is_reg_var_other[r.enum] then
  89. begin
  90. if not(r.enum in usedparafpuregs) then
  91. internalerror(2003060903);
  92. exclude(usedparafpuregs,r.enum);
  93. cg.a_reg_dealloc(list,r);
  94. end
  95. else
  96. inherited ungetregisterfpu(list,r,size);
  97. end;
  98. procedure trgcpu.cleartempgen;
  99. begin
  100. inherited cleartempgen;
  101. usedpararegs := [];
  102. usedparafpuregs := [];
  103. end;
  104. *)
  105. end.