disas.c 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249
  1. /*
  2. * OpenRISC disassembler
  3. *
  4. * Copyright (c) 2018 Richard Henderson <rth@twiddle.net>
  5. *
  6. * This program is free software: you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License as published by
  8. * the Free Software Foundation, either version 2 of the License, or
  9. * (at your option) any later version.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. * GNU General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU General Public License
  17. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  18. */
  19. #include "qemu/osdep.h"
  20. #include "disas/dis-asm.h"
  21. #include "qemu/bitops.h"
  22. #include "cpu.h"
  23. typedef disassemble_info DisasContext;
  24. /* Include the auto-generated decoder. */
  25. #include "decode.c.inc"
  26. #define output(mnemonic, format, ...) \
  27. (info->fprintf_func(info->stream, "%-9s " format, \
  28. mnemonic, ##__VA_ARGS__))
  29. int print_insn_or1k(bfd_vma addr, disassemble_info *info)
  30. {
  31. bfd_byte buffer[4];
  32. uint32_t insn;
  33. int status;
  34. status = info->read_memory_func(addr, buffer, 4, info);
  35. if (status != 0) {
  36. info->memory_error_func(status, addr, info);
  37. return -1;
  38. }
  39. insn = bfd_getb32(buffer);
  40. if (!decode(info, insn)) {
  41. output(".long", "%#08x", insn);
  42. }
  43. return 4;
  44. }
  45. #define INSN(opcode, format, ...) \
  46. static bool trans_l_##opcode(disassemble_info *info, arg_l_##opcode *a) \
  47. { \
  48. output("l." #opcode, format, ##__VA_ARGS__); \
  49. return true; \
  50. }
  51. INSN(add, "r%d, r%d, r%d", a->d, a->a, a->b)
  52. INSN(addc, "r%d, r%d, r%d", a->d, a->a, a->b)
  53. INSN(sub, "r%d, r%d, r%d", a->d, a->a, a->b)
  54. INSN(and, "r%d, r%d, r%d", a->d, a->a, a->b)
  55. INSN(or, "r%d, r%d, r%d", a->d, a->a, a->b)
  56. INSN(xor, "r%d, r%d, r%d", a->d, a->a, a->b)
  57. INSN(sll, "r%d, r%d, r%d", a->d, a->a, a->b)
  58. INSN(srl, "r%d, r%d, r%d", a->d, a->a, a->b)
  59. INSN(sra, "r%d, r%d, r%d", a->d, a->a, a->b)
  60. INSN(ror, "r%d, r%d, r%d", a->d, a->a, a->b)
  61. INSN(exths, "r%d, r%d", a->d, a->a)
  62. INSN(extbs, "r%d, r%d", a->d, a->a)
  63. INSN(exthz, "r%d, r%d", a->d, a->a)
  64. INSN(extbz, "r%d, r%d", a->d, a->a)
  65. INSN(cmov, "r%d, r%d, r%d", a->d, a->a, a->b)
  66. INSN(ff1, "r%d, r%d", a->d, a->a)
  67. INSN(fl1, "r%d, r%d", a->d, a->a)
  68. INSN(mul, "r%d, r%d, r%d", a->d, a->a, a->b)
  69. INSN(mulu, "r%d, r%d, r%d", a->d, a->a, a->b)
  70. INSN(div, "r%d, r%d, r%d", a->d, a->a, a->b)
  71. INSN(divu, "r%d, r%d, r%d", a->d, a->a, a->b)
  72. INSN(muld, "r%d, r%d", a->a, a->b)
  73. INSN(muldu, "r%d, r%d", a->a, a->b)
  74. INSN(j, "%d", a->n)
  75. INSN(jal, "%d", a->n)
  76. INSN(bf, "%d", a->n)
  77. INSN(bnf, "%d", a->n)
  78. INSN(jr, "r%d", a->b)
  79. INSN(jalr, "r%d", a->b)
  80. INSN(lwa, "r%d, %d(r%d)", a->d, a->i, a->a)
  81. INSN(lwz, "r%d, %d(r%d)", a->d, a->i, a->a)
  82. INSN(lws, "r%d, %d(r%d)", a->d, a->i, a->a)
  83. INSN(lbz, "r%d, %d(r%d)", a->d, a->i, a->a)
  84. INSN(lbs, "r%d, %d(r%d)", a->d, a->i, a->a)
  85. INSN(lhz, "r%d, %d(r%d)", a->d, a->i, a->a)
  86. INSN(lhs, "r%d, %d(r%d)", a->d, a->i, a->a)
  87. INSN(swa, "%d(r%d), r%d", a->i, a->a, a->b)
  88. INSN(sw, "%d(r%d), r%d", a->i, a->a, a->b)
  89. INSN(sb, "%d(r%d), r%d", a->i, a->a, a->b)
  90. INSN(sh, "%d(r%d), r%d", a->i, a->a, a->b)
  91. INSN(nop, "")
  92. INSN(adrp, "r%d, %d", a->d, a->i)
  93. INSN(addi, "r%d, r%d, %d", a->d, a->a, a->i)
  94. INSN(addic, "r%d, r%d, %d", a->d, a->a, a->i)
  95. INSN(muli, "r%d, r%d, %d", a->d, a->a, a->i)
  96. INSN(maci, "r%d, %d", a->a, a->i)
  97. INSN(andi, "r%d, r%d, %d", a->d, a->a, a->k)
  98. INSN(ori, "r%d, r%d, %d", a->d, a->a, a->k)
  99. INSN(xori, "r%d, r%d, %d", a->d, a->a, a->i)
  100. INSN(mfspr, "r%d, r%d, %d", a->d, a->a, a->k)
  101. INSN(mtspr, "r%d, r%d, %d", a->a, a->b, a->k)
  102. INSN(mac, "r%d, r%d", a->a, a->b)
  103. INSN(msb, "r%d, r%d", a->a, a->b)
  104. INSN(macu, "r%d, r%d", a->a, a->b)
  105. INSN(msbu, "r%d, r%d", a->a, a->b)
  106. INSN(slli, "r%d, r%d, %d", a->d, a->a, a->l)
  107. INSN(srli, "r%d, r%d, %d", a->d, a->a, a->l)
  108. INSN(srai, "r%d, r%d, %d", a->d, a->a, a->l)
  109. INSN(rori, "r%d, r%d, %d", a->d, a->a, a->l)
  110. INSN(movhi, "r%d, %d", a->d, a->k)
  111. INSN(macrc, "r%d", a->d)
  112. INSN(sfeq, "r%d, r%d", a->a, a->b)
  113. INSN(sfne, "r%d, r%d", a->a, a->b)
  114. INSN(sfgtu, "r%d, r%d", a->a, a->b)
  115. INSN(sfgeu, "r%d, r%d", a->a, a->b)
  116. INSN(sfltu, "r%d, r%d", a->a, a->b)
  117. INSN(sfleu, "r%d, r%d", a->a, a->b)
  118. INSN(sfgts, "r%d, r%d", a->a, a->b)
  119. INSN(sfges, "r%d, r%d", a->a, a->b)
  120. INSN(sflts, "r%d, r%d", a->a, a->b)
  121. INSN(sfles, "r%d, r%d", a->a, a->b)
  122. INSN(sfeqi, "r%d, %d", a->a, a->i)
  123. INSN(sfnei, "r%d, %d", a->a, a->i)
  124. INSN(sfgtui, "r%d, %d", a->a, a->i)
  125. INSN(sfgeui, "r%d, %d", a->a, a->i)
  126. INSN(sfltui, "r%d, %d", a->a, a->i)
  127. INSN(sfleui, "r%d, %d", a->a, a->i)
  128. INSN(sfgtsi, "r%d, %d", a->a, a->i)
  129. INSN(sfgesi, "r%d, %d", a->a, a->i)
  130. INSN(sfltsi, "r%d, %d", a->a, a->i)
  131. INSN(sflesi, "r%d, %d", a->a, a->i)
  132. INSN(sys, "%d", a->k)
  133. INSN(trap, "%d", a->k)
  134. INSN(msync, "")
  135. INSN(psync, "")
  136. INSN(csync, "")
  137. INSN(rfe, "")
  138. #define FP_INSN(opcode, suffix, format, ...) \
  139. static bool trans_lf_##opcode##_##suffix(disassemble_info *info, \
  140. arg_lf_##opcode##_##suffix *a) \
  141. { \
  142. output("lf." #opcode "." #suffix, format, ##__VA_ARGS__); \
  143. return true; \
  144. }
  145. FP_INSN(add, s, "r%d, r%d, r%d", a->d, a->a, a->b)
  146. FP_INSN(sub, s, "r%d, r%d, r%d", a->d, a->a, a->b)
  147. FP_INSN(mul, s, "r%d, r%d, r%d", a->d, a->a, a->b)
  148. FP_INSN(div, s, "r%d, r%d, r%d", a->d, a->a, a->b)
  149. FP_INSN(rem, s, "r%d, r%d, r%d", a->d, a->a, a->b)
  150. FP_INSN(itof, s, "r%d, r%d", a->d, a->a)
  151. FP_INSN(ftoi, s, "r%d, r%d", a->d, a->a)
  152. FP_INSN(madd, s, "r%d, r%d, r%d", a->d, a->a, a->b)
  153. FP_INSN(sfeq, s, "r%d, r%d", a->a, a->b)
  154. FP_INSN(sfne, s, "r%d, r%d", a->a, a->b)
  155. FP_INSN(sfgt, s, "r%d, r%d", a->a, a->b)
  156. FP_INSN(sfge, s, "r%d, r%d", a->a, a->b)
  157. FP_INSN(sflt, s, "r%d, r%d", a->a, a->b)
  158. FP_INSN(sfle, s, "r%d, r%d", a->a, a->b)
  159. FP_INSN(sfun, s, "r%d, r%d", a->a, a->b)
  160. FP_INSN(sfueq, s, "r%d, r%d", a->a, a->b)
  161. FP_INSN(sfuge, s, "r%d, r%d", a->a, a->b)
  162. FP_INSN(sfugt, s, "r%d, r%d", a->a, a->b)
  163. FP_INSN(sfule, s, "r%d, r%d", a->a, a->b)
  164. FP_INSN(sfult, s, "r%d, r%d", a->a, a->b)
  165. FP_INSN(add, d, "r%d,r%d, r%d,r%d, r%d,r%d",
  166. a->d, a->d + a->dp + 1,
  167. a->a, a->a + a->ap + 1,
  168. a->b, a->b + a->bp + 1)
  169. FP_INSN(sub, d, "r%d,r%d, r%d,r%d, r%d,r%d",
  170. a->d, a->d + a->dp + 1,
  171. a->a, a->a + a->ap + 1,
  172. a->b, a->b + a->bp + 1)
  173. FP_INSN(mul, d, "r%d,r%d, r%d,r%d, r%d,r%d",
  174. a->d, a->d + a->dp + 1,
  175. a->a, a->a + a->ap + 1,
  176. a->b, a->b + a->bp + 1)
  177. FP_INSN(div, d, "r%d,r%d, r%d,r%d, r%d,r%d",
  178. a->d, a->d + a->dp + 1,
  179. a->a, a->a + a->ap + 1,
  180. a->b, a->b + a->bp + 1)
  181. FP_INSN(rem, d, "r%d,r%d, r%d,r%d, r%d,r%d",
  182. a->d, a->d + a->dp + 1,
  183. a->a, a->a + a->ap + 1,
  184. a->b, a->b + a->bp + 1)
  185. FP_INSN(madd, d, "r%d,r%d, r%d,r%d, r%d,r%d",
  186. a->d, a->d + a->dp + 1,
  187. a->a, a->a + a->ap + 1,
  188. a->b, a->b + a->bp + 1)
  189. FP_INSN(itof, d, "r%d,r%d, r%d,r%d",
  190. a->d, a->d + a->dp + 1,
  191. a->a, a->a + a->ap + 1)
  192. FP_INSN(ftoi, d, "r%d,r%d, r%d,r%d",
  193. a->d, a->d + a->dp + 1,
  194. a->a, a->a + a->ap + 1)
  195. FP_INSN(stod, d, "r%d,r%d, r%d",
  196. a->d, a->d + a->dp + 1, a->a)
  197. FP_INSN(dtos, d, "r%d r%d,r%d",
  198. a->d, a->a, a->a + a->ap + 1)
  199. FP_INSN(sfeq, d, "r%d,r%d, r%d,r%d",
  200. a->a, a->a + a->ap + 1,
  201. a->b, a->b + a->bp + 1)
  202. FP_INSN(sfne, d, "r%d,r%d, r%d,r%d",
  203. a->a, a->a + a->ap + 1,
  204. a->b, a->b + a->bp + 1)
  205. FP_INSN(sfgt, d, "r%d,r%d, r%d,r%d",
  206. a->a, a->a + a->ap + 1,
  207. a->b, a->b + a->bp + 1)
  208. FP_INSN(sfge, d, "r%d,r%d, r%d,r%d",
  209. a->a, a->a + a->ap + 1,
  210. a->b, a->b + a->bp + 1)
  211. FP_INSN(sflt, d, "r%d,r%d, r%d,r%d",
  212. a->a, a->a + a->ap + 1,
  213. a->b, a->b + a->bp + 1)
  214. FP_INSN(sfle, d, "r%d,r%d, r%d,r%d",
  215. a->a, a->a + a->ap + 1,
  216. a->b, a->b + a->bp + 1)
  217. FP_INSN(sfun, d, "r%d,r%d, r%d,r%d",
  218. a->a, a->a + a->ap + 1,
  219. a->b, a->b + a->bp + 1)
  220. FP_INSN(sfueq, d, "r%d,r%d, r%d,r%d",
  221. a->a, a->a + a->ap + 1,
  222. a->b, a->b + a->bp + 1)
  223. FP_INSN(sfuge, d, "r%d,r%d, r%d,r%d",
  224. a->a, a->a + a->ap + 1,
  225. a->b, a->b + a->bp + 1)
  226. FP_INSN(sfugt, d, "r%d,r%d, r%d,r%d",
  227. a->a, a->a + a->ap + 1,
  228. a->b, a->b + a->bp + 1)
  229. FP_INSN(sfule, d, "r%d,r%d, r%d,r%d",
  230. a->a, a->a + a->ap + 1,
  231. a->b, a->b + a->bp + 1)
  232. FP_INSN(sfult, d, "r%d,r%d, r%d,r%d",
  233. a->a, a->a + a->ap + 1,
  234. a->b, a->b + a->bp + 1)