optab.c 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. #include "l.h"
  2. #define X 99
  3. Optab optab[] =
  4. {
  5. { ATEXT, C_LEXT, C_NONE, C_LCON, 0, 0, 0 },
  6. { ATEXT, C_LEXT, C_REG, C_LCON, 0, 0, 0 },
  7. { AMOVQ, C_REG, C_NONE, C_REG, 1, 4, 0 },
  8. { AMOVQ, C_SCON, C_NONE, C_REG, 6, 4, REGZERO },
  9. { AMOVQ, C_SECON,C_NONE, C_REG, 6, 4, REGSB },
  10. { AMOVQ, C_SACON,C_NONE, C_REG, 6, 4, REGSP },
  11. { AMOVQ, C_LCON, C_NONE, C_REG, 15, 8, REGZERO },
  12. { AMOVQ, C_LECON,C_NONE, C_REG, 15, 8, REGSB },
  13. { AMOVQ, C_LACON,C_NONE, C_REG, 15, 8, REGSP },
  14. { AMOVQ, C_QCON, C_NONE, C_REG, 16,20, REGZERO },
  15. { AMOVQ, C_REG, C_NONE, C_SOREG, 8, 4, REGZERO },
  16. { AMOVQ, C_REG, C_NONE, C_SEXT, 8, 4, REGSB },
  17. { AMOVQ, C_REG, C_NONE, C_SAUTO, 8, 4, REGSP },
  18. { AMOVQ, C_SOREG,C_NONE, C_REG, 9, 4, REGZERO },
  19. { AMOVQ, C_SEXT, C_NONE, C_REG, 9, 4, REGSB },
  20. { AMOVQ, C_SAUTO,C_NONE, C_REG, 9, 4, REGSP },
  21. { AMOVQ, C_REG, C_NONE, C_LOREG, 19, 8, REGZERO },
  22. { AMOVQ, C_REG, C_NONE, C_LEXT, 19, 8, REGSB },
  23. { AMOVQ, C_REG, C_NONE, C_LAUTO, 19, 8, REGSP },
  24. { AMOVQ, C_LOREG,C_NONE, C_REG, 20, 8, REGZERO },
  25. { AMOVQ, C_LEXT, C_NONE, C_REG, 20, 8, REGSB },
  26. { AMOVQ, C_LAUTO,C_NONE, C_REG, 20, 8, REGSP },
  27. /*
  28. { AMOVBU, C_REG, C_NONE, C_REG, 7, 4, 0 },
  29. { AMOVB, C_REG, C_NONE, C_REG, 10, 8, 0 },
  30. */
  31. { AMOVT, C_FREG, C_NONE, C_FREG, 17, 4, 0 },
  32. { AMOVT, C_FREG, C_NONE, C_SOREG, 8, 4, REGZERO },
  33. { AMOVT, C_FREG, C_NONE, C_SEXT, 8, 4, REGSB },
  34. { AMOVT, C_FREG, C_NONE, C_SAUTO, 8, 4, REGSP },
  35. { AMOVT, C_SOREG,C_NONE, C_FREG, 9, 4, REGZERO },
  36. { AMOVT, C_SEXT, C_NONE, C_FREG, 9, 4, REGSB },
  37. { AMOVT, C_SAUTO,C_NONE, C_FREG, 9, 4, REGSP },
  38. { AMOVT, C_FREG, C_NONE, C_LOREG, 19, 8, REGZERO },
  39. { AMOVT, C_FREG, C_NONE, C_LEXT, 19, 8, REGSB },
  40. { AMOVT, C_FREG, C_NONE, C_LAUTO, 19, 8, REGSP },
  41. { AMOVT, C_LOREG,C_NONE, C_FREG, 20, 8, REGZERO },
  42. { AMOVT, C_LEXT, C_NONE, C_FREG, 20, 8, REGSB },
  43. { AMOVT, C_LAUTO,C_NONE, C_FREG, 20, 8, REGSP },
  44. { AADDQ, C_REG, C_REG, C_REG, 2, 4, 0 },
  45. { AADDL, C_REG, C_REG, C_REG, 2, 4, 0 },
  46. { AAND, C_REG, C_REG, C_REG, 2, 4, 0 },
  47. { AMULQ, C_REG, C_REG, C_REG, 2, 4, 0 },
  48. { AADDQ, C_REG, C_NONE, C_REG, 2, 4, 0 },
  49. { AADDL, C_REG, C_NONE, C_REG, 2, 4, 0 },
  50. { AAND, C_REG, C_NONE, C_REG, 2, 4, 0 },
  51. { AMULQ, C_REG, C_NONE, C_REG, 2, 4, 0 },
  52. { AADDQ, C_SCON, C_REG, C_REG, 12, 4, 0 },
  53. { AADDQ, C_SCON, C_NONE, C_REG, 12, 4, 0 },
  54. { AADDL, C_BCON, C_REG, C_REG, 3, 4, 0 },
  55. { AAND, C_BCON, C_REG, C_REG, 3, 4, 0 },
  56. { AMULQ, C_BCON, C_REG, C_REG, 3, 4, 0 },
  57. { AADDL, C_BCON, C_NONE, C_REG, 3, 4, 0 },
  58. { AAND, C_BCON, C_NONE, C_REG, 3, 4, 0 },
  59. { AMULQ, C_BCON, C_NONE, C_REG, 3, 4, 0 },
  60. /* { AADDL, C_NCON, C_REG, C_REG, 34, 4, 0 }, */
  61. { AAND, C_NCON, C_REG, C_REG, 34, 4, 0 },
  62. /* { AADDL, C_NCON, C_NONE, C_REG, 34, 4, 0 }, */
  63. { AAND, C_NCON, C_NONE, C_REG, 34, 4, 0 },
  64. { AADDL, C_SCON, C_REG, C_REG, 13, 8, 0 },
  65. { AAND, C_SCON, C_REG, C_REG, 13, 8, 0 },
  66. { AMULQ, C_SCON, C_REG, C_REG, 13, 8, 0 },
  67. { AADDL, C_SCON, C_NONE, C_REG, 13, 8, 0 },
  68. { AAND, C_SCON, C_NONE, C_REG, 13, 8, 0 },
  69. { AMULQ, C_SCON, C_NONE, C_REG, 13, 8, 0 },
  70. { AADDQ, C_LCON, C_REG, C_REG, 14,12, 0 },
  71. { AADDQ, C_LCON, C_NONE, C_REG, 14,12, 0 },
  72. { AADDL, C_LCON, C_REG, C_REG, 14,12, 0 },
  73. { AAND, C_LCON, C_REG, C_REG, 14,12, 0 },
  74. { AMULQ, C_LCON, C_REG, C_REG, 14,12, 0 },
  75. { AADDL, C_LCON, C_NONE, C_REG, 14,12, 0 },
  76. { AAND, C_LCON, C_NONE, C_REG, 14,12, 0 },
  77. { AMULQ, C_LCON, C_NONE, C_REG, 14,12, 0 },
  78. { AADDQ, C_QCON, C_REG, C_REG, 23,24, 0 },
  79. { AADDQ, C_QCON, C_NONE, C_REG, 23,24, 0 },
  80. { AADDL, C_QCON, C_REG, C_REG, 23,24, 0 },
  81. { AAND, C_QCON, C_REG, C_REG, 23,24, 0 },
  82. { AMULQ, C_QCON, C_REG, C_REG, 23,24, 0 },
  83. { AADDL, C_QCON, C_NONE, C_REG, 23,24, 0 },
  84. { AAND, C_QCON, C_NONE, C_REG, 23,24, 0 },
  85. { AMULQ, C_QCON, C_NONE, C_REG, 23,24, 0 },
  86. { AADDT, C_FREG, C_REG, C_FREG, 2, 4, 0 },
  87. { AADDT, C_FREG, C_NONE, C_FREG, 2, 4, 0 },
  88. { ACVTTQ, C_FREG, C_NONE, C_FREG, 28, 4, 0 },
  89. { ABEQ, C_REG, C_NONE, C_SBRA, 4, 4, 0 },
  90. { AFBEQ, C_FREG, C_NONE, C_SBRA, 4, 4, 0 },
  91. { AJMP, C_NONE, C_NONE, C_SBRA, 11, 4, 0 },
  92. { AJSR, C_NONE, C_NONE, C_SBRA, 11, 4, 0 },
  93. { AJMP, C_NONE, C_NONE, C_ZOREG, 5, 4, REGZERO },
  94. { AJSR, C_NONE, C_NONE, C_ZOREG, 5, 4, REGLINK },
  95. { AJMP, C_NONE, C_REG, C_ZOREG, 5, 4, REGZERO },
  96. { AJSR, C_NONE, C_REG, C_ZOREG, 5, 4, REGLINK },
  97. { ACALL_PAL, C_SCON, C_NONE, C_NONE, 18, 4, 0 },
  98. { AWORD, C_NONE, C_NONE, C_LCON, 40, 4, 0 },
  99. { AMOVT, C_FREG, C_NONE, C_FCREG, 24, 4, 0 },
  100. { AMOVT, C_FCREG,C_NONE, C_FREG, 25, 4, 0 },
  101. { AMOVQ, C_REG, C_NONE, C_PREG, 26, 4, 0 },
  102. { AMOVQ, C_PREG, C_NONE, C_REG, 27, 4, 0 },
  103. { AMOVQ, C_PCC, C_NONE, C_REG, 29, 4, 0 },
  104. { AREI, C_NONE, C_NONE, C_NONE, 30, 4, 0 },
  105. { AFETCH, C_ZOREG,C_NONE, C_NONE, 31, 4, REGZERO },
  106. { AMOVQL, C_SOREG,C_NONE, C_REG, 9, 4, REGZERO },
  107. { AMOVQC, C_REG, C_NONE, C_SOREG, 8, 4, REGZERO },
  108. { AMOVQP, C_SOREG,C_NONE, C_REG, 33, 4, REGZERO },
  109. { AMOVQP, C_REG, C_NONE, C_SOREG, 32, 4, REGZERO },
  110. { AXXX, C_NONE, C_NONE, C_NONE, 0, 4, 0 },
  111. };