aasmcpu.pas 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287
  1. {
  2. Copyright (c) 2000-2006 by Florian Klaempfl
  3. Contains the assembler object for the ia64
  4. This program is free software; you can redistribute it and/or modify
  5. it under the terms of the GNU General Public License as published by
  6. the Free Software Foundation; either version 2 of the License, or
  7. (at your option) any later version.
  8. This program is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. GNU General Public License for more details.
  12. You should have received a copy of the GNU General Public License
  13. along with this program; if not, write to the Free Software
  14. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  15. ****************************************************************************
  16. }
  17. unit aasmcpu;
  18. {$i fpcdefs.inc}
  19. interface
  20. uses
  21. globals,verbose,
  22. aasmbase,aasmtai,
  23. cpubase,
  24. cgutils;
  25. type
  26. pairegalloc = ^tairegalloc;
  27. tairegalloc = class(tai)
  28. allocation : boolean;
  29. reg : tregister;
  30. constructor alloc(r : tregister);
  31. constructor dealloc(r : tregister);
  32. end;
  33. { Types of operand }
  34. toptype=(top_none,top_reg,top_ref,top_const,top_symbol,top_qp);
  35. paicpu = ^taicpu;
  36. taicpu = class(tai)
  37. is_jmp : boolean; { is this instruction a jump? (needed for optimizer) }
  38. opcode : tasmop;
  39. ops : array[0..4] of longint;
  40. oper : longint;
  41. qp : tqp;
  42. ldsttype : tldsttype;
  43. hint : thint;
  44. { ALU instructions }
  45. { A1,A9: integer ALU }
  46. constructor op_reg_reg_reg(op : tasmop;const r1,r2,r3 : tregister);
  47. { A2,A10: shift left and add }
  48. constructor op_reg_reg_const_reg(_qp : tqp;op : tasmop;
  49. const r1,r2 : tregister;i : byte;const r3 : tregister);
  50. { A3,A4,A5: integer ALU - imm.,register }
  51. constructor op_reg_const_reg(_qp : tqp;op : tasmop;
  52. const r1 : tregister;i : longint;const r3 : tregister);
  53. { A6,A7: integer compare - register,register }
  54. constructor op_preg_preg_reg_reg(_qp : tqp;op : tasmop;
  55. cond : tasmcond;p1,p2 : tqp;const r2,r3 : tregister);
  56. { A8: integer compare - imm.,register }
  57. constructor op_preg_preg_const_reg(_qp : tqp;op : tasmop;
  58. cond : tasmcond;p1,p2 : tqp;i : longint;const r3 : tregister);
  59. {!!!!!!!
  60. { multimedia shift and multiply }
  61. constructor op_reg_reg_reg_const(_qp : tqp;
  62. { multimedia mux }
  63. constructor op_reg_reg_mbtype(_qp : tqp;
  64. { multimedia shift fixed }
  65. constructor op_reg_reg_const(_qp : tqp;
  66. { div. }
  67. constructor op_reg_reg(_qp : tqp;
  68. { mm extract }
  69. constructor op_reg_reg_const_const(_qp : tqp;
  70. { zero and deposit imm }
  71. constructor op_reg_const_const_const(_qp : tqp;
  72. { deposit imm }
  73. constructor op_reg_const_reg_const_const(_qp : tqp;
  74. { deposit }
  75. constructor op_reg_reg_reg_const_const(_qp : tqp;
  76. { test bit }
  77. { !!!! here we need also to take care of the postfix }
  78. constructor op_preg_preg_reg_const(_qp : tqp;
  79. { test NaT }
  80. { !!!! here we need also to take care of the postfix }
  81. constructor op_preg_preg_reg(_qp : tqp;
  82. { -------- here are some missed ----------- }
  83. }
  84. { M1: integer load }
  85. { M4: integer store }
  86. { M6: floating-point load }
  87. { M9: floating-point store }
  88. constructor op_reg_ref(_qp : tqp;op : tasmop;postfix : tldsttype;
  89. _hint : thint;const r1 : tregister;ref : treference);
  90. { M2: integer load incremented by register }
  91. { M7: floating-point load incremented by register }
  92. constructor op_reg_ref_reg(_qp : tqp;op : tasmop;postfix : tldsttype;
  93. _hint : thint;const r1 : tregister;const ref : treference;
  94. const r2 : tregister);
  95. { M3: integer load increment by imm. }
  96. { M5: integer store increment by imm. }
  97. { M8: floating-point load increment by imm. }
  98. { M10: floating-point store increment by imm. }
  99. constructor op_reg_ref_const(_qp : tqp;op : tasmop;postfix : tldsttype;
  100. _hint : thint;const r1 : tregister;ref : treference;i : longint);
  101. { M11: floating-point load pair}
  102. constructor op_reg_ref(_qp : tqp;op : tasmop;postfix : tldsttype;
  103. _hint : thint;const r1,r2 : tregister;ref : treference);
  104. { M12: floating-point load pair increment by imm. }
  105. constructor op_reg_ref(_qp : tqp;op : tasmop;postfix : tldsttype;
  106. _hint : thint;const r1,r2 : tregister;ref : treference;i : longint);
  107. { X1: break/nop }
  108. constructor op_const62(_qp : tqp;op : tasmop;i : int64);
  109. { X2: move imm64 }
  110. constructor op_reg_const64(_qp : tqp;op : tasmop;const r1 : tregister;
  111. i : int64);
  112. end;
  113. { the following objects are special for the ia64 }
  114. { they decribe a stop and the bundles }
  115. paistop = ^taistop;
  116. taistop = class(tai)
  117. constructor init;
  118. end;
  119. { a second underscro indicates a stop }
  120. tbundletemplate = (but_none,but_mii,but_mii_,
  121. but_mi_i,but_mi_i_,but_mlx,but_mlx_,
  122. but_mmi,but_mmi_,but_m_mi,but_m_mi_,
  123. but_mfi,but_mfi_,but_mmf,but_mmf_,
  124. but_mif,but_mib_,but_mbb,but_mbb_,
  125. but_bbb,but_bbb_,but_mmb,but_mmb_,
  126. but_mfb,but_mfb_);
  127. paibundle = ^taibundle;
  128. taibundle = class(tai)
  129. template : tbundletemplate;
  130. instructions : array[0..1] of paicpu;
  131. end;
  132. implementation
  133. {*****************************************************************************
  134. TaiStop
  135. *****************************************************************************}
  136. constructor taistop.init;
  137. begin
  138. inherited create;
  139. typ:=ait_stop;
  140. end;
  141. {*****************************************************************************
  142. TaiRegAlloc
  143. *****************************************************************************}
  144. constructor tairegalloc.alloc(r : tregister);
  145. begin
  146. inherited create;
  147. typ:=ait_regalloc;
  148. allocation:=true;
  149. reg:=r;
  150. end;
  151. constructor tairegalloc.dealloc(r : tregister);
  152. begin
  153. inherited create;
  154. typ:=ait_regalloc;
  155. allocation:=false;
  156. reg:=r;
  157. end;
  158. {*****************************************************************************
  159. Taicpu
  160. *****************************************************************************}
  161. { ALU instructions }
  162. { A1,A9: integer ALU }
  163. constructor taicpu.op_reg_reg_reg(op : tasmop;const r1,r2,r3 : tregister);
  164. begin
  165. end;
  166. { A2,A10: shift left and add }
  167. constructor taicpu.op_reg_reg_const_reg(_qp : tqp;op : tasmop;
  168. const r1,r2 : tregister;i : byte;const r3 : tregister);
  169. begin
  170. end;
  171. { A3,A4,A5: integer ALU - imm.,register }
  172. constructor taicpu.op_reg_const_reg(_qp : tqp;op : tasmop;
  173. const r1 : tregister;i : longint;const r3 : tregister);
  174. begin
  175. end;
  176. { A6,A7: integer compare - register,register }
  177. constructor taicpu.op_preg_preg_reg_reg(_qp : tqp;op : tasmop;
  178. cond : tasmcond;p1,p2 : tqp;const r2,r3 : tregister);
  179. begin
  180. end;
  181. { A8: integer compare - imm.,register }
  182. constructor taicpu.op_preg_preg_const_reg(_qp : tqp;op : tasmop;
  183. cond : tasmcond;p1,p2 : tqp;i : longint;const r3 : tregister);
  184. begin
  185. end;
  186. { M1: integer load }
  187. { M4: integer store }
  188. { M6: floating-point load }
  189. { M9: floating-point store }
  190. constructor taicpu.op_reg_ref(_qp : tqp;op : tasmop;postfix : tldsttype;
  191. _hint : thint;const r1 : tregister;ref : treference);
  192. begin
  193. end;
  194. { M2: integer load incremented by register }
  195. { M7: floating-point load incremented by register }
  196. constructor taicpu.op_reg_ref_reg(_qp : tqp;op : tasmop;postfix : tldsttype;
  197. _hint : thint;const r1 : tregister;const ref : treference;
  198. const r2 : tregister);
  199. begin
  200. end;
  201. { M3: integer load increment by imm. }
  202. { M5: integer store increment by imm. }
  203. { M8: floating-point load increment by imm. }
  204. { M10: floating-point store increment by imm. }
  205. constructor taicpu.op_reg_ref_const(_qp : tqp;op : tasmop;postfix : tldsttype;
  206. _hint : thint;const r1 : tregister;ref : treference;i : longint);
  207. begin
  208. end;
  209. { M11: floating-point load pair}
  210. constructor taicpu.op_reg_ref(_qp : tqp;op : tasmop;postfix : tldsttype;
  211. _hint : thint;const r1,r2 : tregister;ref : treference);
  212. begin
  213. end;
  214. { M12: floating-point load pair increment by imm. }
  215. constructor taicpu.op_reg_ref(_qp : tqp;op : tasmop;postfix : tldsttype;
  216. _hint : thint;const r1,r2 : tregister;ref : treference;i : longint);
  217. begin
  218. end;
  219. { X1: break/nop }
  220. constructor taicpu.op_const62(_qp : tqp;op : tasmop;i : int64);
  221. { X2: move imm64 }
  222. begin
  223. end;
  224. constructor taicpu.op_reg_const64(_qp : tqp;op : tasmop;const r1 : tregister;
  225. i : int64);
  226. begin
  227. end;
  228. end.