cga.pas 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. {
  2. $Id$
  3. Copyright (c) 1998-2002 by Florian Klaempfl
  4. Helper routines for the i386 code generator
  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 cga;
  19. {$i fpcdefs.inc}
  20. interface
  21. uses
  22. globtype,
  23. cpuinfo,cpubase,cgbase,
  24. symconst,symtype,symdef,aasmbase,aasmtai,aasmcpu;
  25. procedure emit_none(i : tasmop;s : topsize);
  26. procedure emit_reg(i : tasmop;s : topsize;reg : tregister);
  27. procedure emit_ref(i : tasmop;s : topsize;const ref : treference);
  28. procedure emit_const_reg(i : tasmop;s : topsize;c : aint;reg : tregister);
  29. procedure emit_const_ref(i : tasmop;s : topsize;c : aint;const ref : treference);
  30. procedure emit_ref_reg(i : tasmop;s : topsize;const ref : treference;reg : tregister);
  31. procedure emit_reg_ref(i : tasmop;s : topsize;reg : tregister;const ref : treference);
  32. procedure emit_reg_reg(i : tasmop;s : topsize;reg1,reg2 : tregister);
  33. procedure emit_const_reg_reg(i : tasmop;s : topsize;c : longint;reg1,reg2 : tregister);
  34. procedure emit_reg_reg_reg(i : tasmop;s : topsize;reg1,reg2,reg3 : tregister);
  35. procedure emit_sym(i : tasmop;s : topsize;op : tasmsymbol);
  36. implementation
  37. uses
  38. cutils,
  39. systems,verbose,
  40. cgobj;
  41. {*****************************************************************************
  42. Emit Assembler
  43. *****************************************************************************}
  44. procedure emit_none(i : tasmop;s : topsize);
  45. begin
  46. exprasmList.concat(Taicpu.Op_none(i,s));
  47. end;
  48. procedure emit_reg(i : tasmop;s : topsize;reg : tregister);
  49. begin
  50. exprasmList.concat(Taicpu.Op_reg(i,s,reg));
  51. end;
  52. procedure emit_ref(i : tasmop;s : topsize;const ref : treference);
  53. begin
  54. exprasmList.concat(Taicpu.Op_ref(i,s,ref));
  55. end;
  56. procedure emit_const_reg(i : tasmop;s : topsize;c : aint;reg : tregister);
  57. begin
  58. exprasmList.concat(Taicpu.Op_const_reg(i,s,c,reg));
  59. end;
  60. procedure emit_const_ref(i : tasmop;s : topsize;c : aint;const ref : treference);
  61. begin
  62. exprasmList.concat(Taicpu.Op_const_ref(i,s,c,ref));
  63. end;
  64. procedure emit_ref_reg(i : tasmop;s : topsize;const ref : treference;reg : tregister);
  65. begin
  66. exprasmList.concat(Taicpu.Op_ref_reg(i,s,ref,reg));
  67. end;
  68. procedure emit_reg_ref(i : tasmop;s : topsize;reg : tregister;const ref : treference);
  69. begin
  70. exprasmList.concat(Taicpu.Op_reg_ref(i,s,reg,ref));
  71. end;
  72. procedure emit_reg_reg(i : tasmop;s : topsize;reg1,reg2 : tregister);
  73. var instr:Taicpu;
  74. begin
  75. if not ((reg1=reg2) and (i=A_MOV)) then
  76. begin
  77. instr:=Taicpu.op_reg_reg(i,s,reg1,reg2);
  78. exprasmlist.concat(instr);
  79. if i=A_MOV then
  80. cg.add_move_instruction(instr);
  81. end;
  82. end;
  83. procedure emit_const_reg_reg(i : tasmop;s : topsize;c : longint;reg1,reg2 : tregister);
  84. begin
  85. exprasmList.concat(Taicpu.Op_const_reg_reg(i,s,c,reg1,reg2));
  86. end;
  87. procedure emit_reg_reg_reg(i : tasmop;s : topsize;reg1,reg2,reg3 : tregister);
  88. begin
  89. exprasmList.concat(Taicpu.Op_reg_reg_reg(i,s,reg1,reg2,reg3));
  90. end;
  91. procedure emit_sym(i : tasmop;s : topsize;op : tasmsymbol);
  92. begin
  93. exprasmList.concat(Taicpu.Op_sym(i,s,op));
  94. end;
  95. end.
  96. {
  97. $Log$
  98. Revision 1.9 2004-06-20 08:55:32 florian
  99. * logs truncated
  100. Revision 1.8 2004/06/16 20:07:11 florian
  101. * dwarf branch merged
  102. Revision 1.7.2.3 2004/05/01 16:02:10 peter
  103. * POINTER_SIZE replaced with sizeof(aint)
  104. * aint,aword,tconst*int moved to globtype
  105. Revision 1.7.2.2 2004/04/29 23:30:28 peter
  106. * fix i386 compiler
  107. Revision 1.7.2.1 2004/04/27 18:18:26 peter
  108. * aword -> aint
  109. }