hexcore-capstone 1.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (332) hide show
  1. package/LICENSE +26 -0
  2. package/README.md +191 -0
  3. package/binding.gyp +168 -0
  4. package/deps/capstone/LEB128.h +38 -0
  5. package/deps/capstone/MCDisassembler.h +14 -0
  6. package/deps/capstone/MCFixedLenDisassembler.h +32 -0
  7. package/deps/capstone/MCInst.c +270 -0
  8. package/deps/capstone/MCInst.h +165 -0
  9. package/deps/capstone/MCInstrDesc.c +41 -0
  10. package/deps/capstone/MCInstrDesc.h +167 -0
  11. package/deps/capstone/MCRegisterInfo.c +151 -0
  12. package/deps/capstone/MCRegisterInfo.h +116 -0
  13. package/deps/capstone/Mapping.c +254 -0
  14. package/deps/capstone/Mapping.h +174 -0
  15. package/deps/capstone/MathExtras.h +442 -0
  16. package/deps/capstone/SStream.c +181 -0
  17. package/deps/capstone/SStream.h +40 -0
  18. package/deps/capstone/arch/AArch64/AArch64AddressingModes.h +945 -0
  19. package/deps/capstone/arch/AArch64/AArch64BaseInfo.c +77 -0
  20. package/deps/capstone/arch/AArch64/AArch64BaseInfo.h +585 -0
  21. package/deps/capstone/arch/AArch64/AArch64Disassembler.c +2280 -0
  22. package/deps/capstone/arch/AArch64/AArch64Disassembler.h +18 -0
  23. package/deps/capstone/arch/AArch64/AArch64GenAsmWriter.inc +26589 -0
  24. package/deps/capstone/arch/AArch64/AArch64GenDisassemblerTables.inc +27322 -0
  25. package/deps/capstone/arch/AArch64/AArch64GenInstrInfo.inc +13194 -0
  26. package/deps/capstone/arch/AArch64/AArch64GenRegisterInfo.inc +3814 -0
  27. package/deps/capstone/arch/AArch64/AArch64GenRegisterName.inc +714 -0
  28. package/deps/capstone/arch/AArch64/AArch64GenRegisterV.inc +673 -0
  29. package/deps/capstone/arch/AArch64/AArch64GenSubtargetInfo.inc +229 -0
  30. package/deps/capstone/arch/AArch64/AArch64GenSystemOperands.inc +2863 -0
  31. package/deps/capstone/arch/AArch64/AArch64GenSystemOperands_enum.inc +21 -0
  32. package/deps/capstone/arch/AArch64/AArch64InstPrinter.c +3029 -0
  33. package/deps/capstone/arch/AArch64/AArch64InstPrinter.h +28 -0
  34. package/deps/capstone/arch/AArch64/AArch64Mapping.c +883 -0
  35. package/deps/capstone/arch/AArch64/AArch64Mapping.h +43 -0
  36. package/deps/capstone/arch/AArch64/AArch64MappingInsn.inc +37790 -0
  37. package/deps/capstone/arch/AArch64/AArch64MappingInsnName.inc +1282 -0
  38. package/deps/capstone/arch/AArch64/AArch64MappingInsnOp.inc +26994 -0
  39. package/deps/capstone/arch/AArch64/AArch64Module.c +44 -0
  40. package/deps/capstone/arch/AArch64/AArch64Module.h +12 -0
  41. package/deps/capstone/arch/ARM/ARMAddressingModes.h +698 -0
  42. package/deps/capstone/arch/ARM/ARMBaseInfo.h +486 -0
  43. package/deps/capstone/arch/ARM/ARMDisassembler.c +5763 -0
  44. package/deps/capstone/arch/ARM/ARMDisassembler.h +18 -0
  45. package/deps/capstone/arch/ARM/ARMGenAsmWriter.inc +9545 -0
  46. package/deps/capstone/arch/ARM/ARMGenDisassemblerTables.inc +15185 -0
  47. package/deps/capstone/arch/ARM/ARMGenInstrInfo.inc +6632 -0
  48. package/deps/capstone/arch/ARM/ARMGenRegisterInfo.inc +2102 -0
  49. package/deps/capstone/arch/ARM/ARMGenRegisterName.inc +231 -0
  50. package/deps/capstone/arch/ARM/ARMGenRegisterName_digit.inc +231 -0
  51. package/deps/capstone/arch/ARM/ARMGenSubtargetInfo.inc +162 -0
  52. package/deps/capstone/arch/ARM/ARMGenSystemRegister.inc +270 -0
  53. package/deps/capstone/arch/ARM/ARMInstPrinter.c +3364 -0
  54. package/deps/capstone/arch/ARM/ARMInstPrinter.h +43 -0
  55. package/deps/capstone/arch/ARM/ARMMapping.c +551 -0
  56. package/deps/capstone/arch/ARM/ARMMapping.h +40 -0
  57. package/deps/capstone/arch/ARM/ARMMappingInsn.inc +18772 -0
  58. package/deps/capstone/arch/ARM/ARMMappingInsnName.inc +475 -0
  59. package/deps/capstone/arch/ARM/ARMMappingInsnOp.inc +10729 -0
  60. package/deps/capstone/arch/ARM/ARMModule.c +63 -0
  61. package/deps/capstone/arch/ARM/ARMModule.h +12 -0
  62. package/deps/capstone/arch/BPF/BPFConstants.h +88 -0
  63. package/deps/capstone/arch/BPF/BPFDisassembler.c +464 -0
  64. package/deps/capstone/arch/BPF/BPFDisassembler.h +27 -0
  65. package/deps/capstone/arch/BPF/BPFInstPrinter.c +285 -0
  66. package/deps/capstone/arch/BPF/BPFInstPrinter.h +16 -0
  67. package/deps/capstone/arch/BPF/BPFMapping.c +513 -0
  68. package/deps/capstone/arch/BPF/BPFMapping.h +21 -0
  69. package/deps/capstone/arch/BPF/BPFModule.c +34 -0
  70. package/deps/capstone/arch/BPF/BPFModule.h +12 -0
  71. package/deps/capstone/arch/EVM/EVMDisassembler.c +379 -0
  72. package/deps/capstone/arch/EVM/EVMDisassembler.h +12 -0
  73. package/deps/capstone/arch/EVM/EVMInstPrinter.c +20 -0
  74. package/deps/capstone/arch/EVM/EVMInstPrinter.h +17 -0
  75. package/deps/capstone/arch/EVM/EVMMapping.c +344 -0
  76. package/deps/capstone/arch/EVM/EVMMapping.h +8 -0
  77. package/deps/capstone/arch/EVM/EVMMappingInsn.inc +259 -0
  78. package/deps/capstone/arch/EVM/EVMModule.c +33 -0
  79. package/deps/capstone/arch/EVM/EVMModule.h +12 -0
  80. package/deps/capstone/arch/M680X/M680XDisassembler.c +2307 -0
  81. package/deps/capstone/arch/M680X/M680XDisassembler.h +17 -0
  82. package/deps/capstone/arch/M680X/M680XDisassemblerInternals.h +57 -0
  83. package/deps/capstone/arch/M680X/M680XInstPrinter.c +360 -0
  84. package/deps/capstone/arch/M680X/M680XInstPrinter.h +25 -0
  85. package/deps/capstone/arch/M680X/M680XModule.c +77 -0
  86. package/deps/capstone/arch/M680X/M680XModule.h +12 -0
  87. package/deps/capstone/arch/M680X/cpu12.inc +335 -0
  88. package/deps/capstone/arch/M680X/hcs08.inc +60 -0
  89. package/deps/capstone/arch/M680X/hd6301.inc +15 -0
  90. package/deps/capstone/arch/M680X/hd6309.inc +259 -0
  91. package/deps/capstone/arch/M680X/insn_props.inc +367 -0
  92. package/deps/capstone/arch/M680X/m6800.inc +277 -0
  93. package/deps/capstone/arch/M680X/m6801.inc +39 -0
  94. package/deps/capstone/arch/M680X/m6805.inc +277 -0
  95. package/deps/capstone/arch/M680X/m6808.inc +91 -0
  96. package/deps/capstone/arch/M680X/m6809.inc +352 -0
  97. package/deps/capstone/arch/M680X/m6811.inc +105 -0
  98. package/deps/capstone/arch/M68K/M68KDisassembler.c +3668 -0
  99. package/deps/capstone/arch/M68K/M68KDisassembler.h +30 -0
  100. package/deps/capstone/arch/M68K/M68KInstPrinter.c +387 -0
  101. package/deps/capstone/arch/M68K/M68KInstPrinter.h +21 -0
  102. package/deps/capstone/arch/M68K/M68KInstructionTable.inc +65540 -0
  103. package/deps/capstone/arch/M68K/M68KModule.c +42 -0
  104. package/deps/capstone/arch/M68K/M68KModule.h +12 -0
  105. package/deps/capstone/arch/MOS65XX/MOS65XXDisassembler.c +544 -0
  106. package/deps/capstone/arch/MOS65XX/MOS65XXDisassembler.h +22 -0
  107. package/deps/capstone/arch/MOS65XX/MOS65XXDisassemblerInternals.h +23 -0
  108. package/deps/capstone/arch/MOS65XX/MOS65XXModule.c +79 -0
  109. package/deps/capstone/arch/MOS65XX/MOS65XXModule.h +12 -0
  110. package/deps/capstone/arch/MOS65XX/instruction_info.inc +106 -0
  111. package/deps/capstone/arch/MOS65XX/m6502.inc +256 -0
  112. package/deps/capstone/arch/MOS65XX/m65816.inc +256 -0
  113. package/deps/capstone/arch/MOS65XX/m65c02.inc +256 -0
  114. package/deps/capstone/arch/MOS65XX/mw65c02.inc +256 -0
  115. package/deps/capstone/arch/Mips/MipsDisassembler.c +1794 -0
  116. package/deps/capstone/arch/Mips/MipsDisassembler.h +16 -0
  117. package/deps/capstone/arch/Mips/MipsGenAsmWriter.inc +5725 -0
  118. package/deps/capstone/arch/Mips/MipsGenDisassemblerTables.inc +6942 -0
  119. package/deps/capstone/arch/Mips/MipsGenInstrInfo.inc +1805 -0
  120. package/deps/capstone/arch/Mips/MipsGenRegisterInfo.inc +1679 -0
  121. package/deps/capstone/arch/Mips/MipsGenSubtargetInfo.inc +52 -0
  122. package/deps/capstone/arch/Mips/MipsInstPrinter.c +424 -0
  123. package/deps/capstone/arch/Mips/MipsInstPrinter.h +25 -0
  124. package/deps/capstone/arch/Mips/MipsMapping.c +1070 -0
  125. package/deps/capstone/arch/Mips/MipsMapping.h +25 -0
  126. package/deps/capstone/arch/Mips/MipsMappingInsn.inc +9315 -0
  127. package/deps/capstone/arch/Mips/MipsModule.c +52 -0
  128. package/deps/capstone/arch/Mips/MipsModule.h +12 -0
  129. package/deps/capstone/arch/PowerPC/PPCDisassembler.c +627 -0
  130. package/deps/capstone/arch/PowerPC/PPCDisassembler.h +17 -0
  131. package/deps/capstone/arch/PowerPC/PPCGenAsmWriter.inc +11451 -0
  132. package/deps/capstone/arch/PowerPC/PPCGenDisassemblerTables.inc +6886 -0
  133. package/deps/capstone/arch/PowerPC/PPCGenInstrInfo.inc +4772 -0
  134. package/deps/capstone/arch/PowerPC/PPCGenRegisterInfo.inc +1122 -0
  135. package/deps/capstone/arch/PowerPC/PPCGenRegisterName.inc +278 -0
  136. package/deps/capstone/arch/PowerPC/PPCGenSubtargetInfo.inc +90 -0
  137. package/deps/capstone/arch/PowerPC/PPCInstPrinter.c +1238 -0
  138. package/deps/capstone/arch/PowerPC/PPCInstPrinter.h +15 -0
  139. package/deps/capstone/arch/PowerPC/PPCMapping.c +570 -0
  140. package/deps/capstone/arch/PowerPC/PPCMapping.h +40 -0
  141. package/deps/capstone/arch/PowerPC/PPCMappingInsn.inc +13220 -0
  142. package/deps/capstone/arch/PowerPC/PPCMappingInsnName.inc +1731 -0
  143. package/deps/capstone/arch/PowerPC/PPCModule.c +45 -0
  144. package/deps/capstone/arch/PowerPC/PPCModule.h +12 -0
  145. package/deps/capstone/arch/PowerPC/PPCPredicates.h +62 -0
  146. package/deps/capstone/arch/RISCV/RISCVBaseInfo.h +106 -0
  147. package/deps/capstone/arch/RISCV/RISCVDisassembler.c +433 -0
  148. package/deps/capstone/arch/RISCV/RISCVDisassembler.h +18 -0
  149. package/deps/capstone/arch/RISCV/RISCVGenAsmWriter.inc +2651 -0
  150. package/deps/capstone/arch/RISCV/RISCVGenDisassemblerTables.inc +1776 -0
  151. package/deps/capstone/arch/RISCV/RISCVGenInsnNameMaps.inc +275 -0
  152. package/deps/capstone/arch/RISCV/RISCVGenInstrInfo.inc +470 -0
  153. package/deps/capstone/arch/RISCV/RISCVGenRegisterInfo.inc +426 -0
  154. package/deps/capstone/arch/RISCV/RISCVGenSubtargetInfo.inc +33 -0
  155. package/deps/capstone/arch/RISCV/RISCVInstPrinter.c +447 -0
  156. package/deps/capstone/arch/RISCV/RISCVInstPrinter.h +24 -0
  157. package/deps/capstone/arch/RISCV/RISCVMapping.c +366 -0
  158. package/deps/capstone/arch/RISCV/RISCVMapping.h +22 -0
  159. package/deps/capstone/arch/RISCV/RISCVMappingInsn.inc +1635 -0
  160. package/deps/capstone/arch/RISCV/RISCVModule.c +42 -0
  161. package/deps/capstone/arch/RISCV/RISCVModule.h +12 -0
  162. package/deps/capstone/arch/SH/SHDisassembler.c +2221 -0
  163. package/deps/capstone/arch/SH/SHDisassembler.h +19 -0
  164. package/deps/capstone/arch/SH/SHInsnTable.inc +66 -0
  165. package/deps/capstone/arch/SH/SHInstPrinter.c +438 -0
  166. package/deps/capstone/arch/SH/SHInstPrinter.h +23 -0
  167. package/deps/capstone/arch/SH/SHModule.c +39 -0
  168. package/deps/capstone/arch/SH/SHModule.h +12 -0
  169. package/deps/capstone/arch/SH/mktable.rb +390 -0
  170. package/deps/capstone/arch/Sparc/Sparc.h +63 -0
  171. package/deps/capstone/arch/Sparc/SparcDisassembler.c +500 -0
  172. package/deps/capstone/arch/Sparc/SparcDisassembler.h +17 -0
  173. package/deps/capstone/arch/Sparc/SparcGenAsmWriter.inc +5709 -0
  174. package/deps/capstone/arch/Sparc/SparcGenDisassemblerTables.inc +2028 -0
  175. package/deps/capstone/arch/Sparc/SparcGenInstrInfo.inc +514 -0
  176. package/deps/capstone/arch/Sparc/SparcGenRegisterInfo.inc +451 -0
  177. package/deps/capstone/arch/Sparc/SparcGenSubtargetInfo.inc +27 -0
  178. package/deps/capstone/arch/Sparc/SparcInstPrinter.c +446 -0
  179. package/deps/capstone/arch/Sparc/SparcInstPrinter.h +17 -0
  180. package/deps/capstone/arch/Sparc/SparcMapping.c +665 -0
  181. package/deps/capstone/arch/Sparc/SparcMapping.h +34 -0
  182. package/deps/capstone/arch/Sparc/SparcMappingInsn.inc +2643 -0
  183. package/deps/capstone/arch/Sparc/SparcModule.c +45 -0
  184. package/deps/capstone/arch/Sparc/SparcModule.h +12 -0
  185. package/deps/capstone/arch/SystemZ/SystemZDisassembler.c +484 -0
  186. package/deps/capstone/arch/SystemZ/SystemZDisassembler.h +17 -0
  187. package/deps/capstone/arch/SystemZ/SystemZGenAsmWriter.inc +11575 -0
  188. package/deps/capstone/arch/SystemZ/SystemZGenDisassemblerTables.inc +10262 -0
  189. package/deps/capstone/arch/SystemZ/SystemZGenInsnNameMaps.inc +2348 -0
  190. package/deps/capstone/arch/SystemZ/SystemZGenInstrInfo.inc +2820 -0
  191. package/deps/capstone/arch/SystemZ/SystemZGenRegisterInfo.inc +741 -0
  192. package/deps/capstone/arch/SystemZ/SystemZGenSubtargetInfo.inc +49 -0
  193. package/deps/capstone/arch/SystemZ/SystemZInstPrinter.c +433 -0
  194. package/deps/capstone/arch/SystemZ/SystemZInstPrinter.h +15 -0
  195. package/deps/capstone/arch/SystemZ/SystemZMCTargetDesc.c +195 -0
  196. package/deps/capstone/arch/SystemZ/SystemZMCTargetDesc.h +51 -0
  197. package/deps/capstone/arch/SystemZ/SystemZMapping.c +479 -0
  198. package/deps/capstone/arch/SystemZ/SystemZMapping.h +23 -0
  199. package/deps/capstone/arch/SystemZ/SystemZMappingInsn.inc +14175 -0
  200. package/deps/capstone/arch/SystemZ/SystemZModule.c +44 -0
  201. package/deps/capstone/arch/SystemZ/SystemZModule.h +12 -0
  202. package/deps/capstone/arch/TMS320C64x/TMS320C64xDisassembler.c +628 -0
  203. package/deps/capstone/arch/TMS320C64x/TMS320C64xDisassembler.h +19 -0
  204. package/deps/capstone/arch/TMS320C64x/TMS320C64xGenAsmWriter.inc +684 -0
  205. package/deps/capstone/arch/TMS320C64x/TMS320C64xGenDisassemblerTables.inc +1352 -0
  206. package/deps/capstone/arch/TMS320C64x/TMS320C64xGenInstrInfo.inc +298 -0
  207. package/deps/capstone/arch/TMS320C64x/TMS320C64xGenRegisterInfo.inc +277 -0
  208. package/deps/capstone/arch/TMS320C64x/TMS320C64xInstPrinter.c +572 -0
  209. package/deps/capstone/arch/TMS320C64x/TMS320C64xInstPrinter.h +15 -0
  210. package/deps/capstone/arch/TMS320C64x/TMS320C64xMapping.c +1926 -0
  211. package/deps/capstone/arch/TMS320C64x/TMS320C64xMapping.h +26 -0
  212. package/deps/capstone/arch/TMS320C64x/TMS320C64xModule.c +39 -0
  213. package/deps/capstone/arch/TMS320C64x/TMS320C64xModule.h +12 -0
  214. package/deps/capstone/arch/TriCore/TriCore.td +134 -0
  215. package/deps/capstone/arch/TriCore/TriCoreCallingConv.td +61 -0
  216. package/deps/capstone/arch/TriCore/TriCoreDisassembler.c +1655 -0
  217. package/deps/capstone/arch/TriCore/TriCoreDisassembler.h +18 -0
  218. package/deps/capstone/arch/TriCore/TriCoreGenAsmWriter.inc +3691 -0
  219. package/deps/capstone/arch/TriCore/TriCoreGenCSFeatureName.inc +22 -0
  220. package/deps/capstone/arch/TriCore/TriCoreGenCSMappingInsn.inc +8938 -0
  221. package/deps/capstone/arch/TriCore/TriCoreGenCSMappingInsnName.inc +404 -0
  222. package/deps/capstone/arch/TriCore/TriCoreGenCSMappingInsnOp.inc +7994 -0
  223. package/deps/capstone/arch/TriCore/TriCoreGenCSOpGroup.inc +32 -0
  224. package/deps/capstone/arch/TriCore/TriCoreGenDisassemblerTables.inc +4044 -0
  225. package/deps/capstone/arch/TriCore/TriCoreGenInstrInfo.inc +2693 -0
  226. package/deps/capstone/arch/TriCore/TriCoreGenRegisterInfo.inc +295 -0
  227. package/deps/capstone/arch/TriCore/TriCoreGenSubtargetInfo.inc +40 -0
  228. package/deps/capstone/arch/TriCore/TriCoreInstPrinter.c +488 -0
  229. package/deps/capstone/arch/TriCore/TriCoreInstrFormats.td +773 -0
  230. package/deps/capstone/arch/TriCore/TriCoreInstrInfo.td +1873 -0
  231. package/deps/capstone/arch/TriCore/TriCoreLinkage.h +21 -0
  232. package/deps/capstone/arch/TriCore/TriCoreMapping.c +241 -0
  233. package/deps/capstone/arch/TriCore/TriCoreMapping.h +32 -0
  234. package/deps/capstone/arch/TriCore/TriCoreModule.c +44 -0
  235. package/deps/capstone/arch/TriCore/TriCoreModule.h +11 -0
  236. package/deps/capstone/arch/TriCore/TriCoreRegisterInfo.td +153 -0
  237. package/deps/capstone/arch/WASM/WASMDisassembler.c +1009 -0
  238. package/deps/capstone/arch/WASM/WASMDisassembler.h +12 -0
  239. package/deps/capstone/arch/WASM/WASMInstPrinter.c +47 -0
  240. package/deps/capstone/arch/WASM/WASMInstPrinter.h +18 -0
  241. package/deps/capstone/arch/WASM/WASMMapping.c +333 -0
  242. package/deps/capstone/arch/WASM/WASMMapping.h +9 -0
  243. package/deps/capstone/arch/WASM/WASMModule.c +33 -0
  244. package/deps/capstone/arch/WASM/WASMModule.h +12 -0
  245. package/deps/capstone/arch/X86/X86ATTInstPrinter.c +997 -0
  246. package/deps/capstone/arch/X86/X86BaseInfo.h +50 -0
  247. package/deps/capstone/arch/X86/X86Disassembler.c +1033 -0
  248. package/deps/capstone/arch/X86/X86Disassembler.h +28 -0
  249. package/deps/capstone/arch/X86/X86DisassemblerDecoder.c +2358 -0
  250. package/deps/capstone/arch/X86/X86DisassemblerDecoder.h +725 -0
  251. package/deps/capstone/arch/X86/X86DisassemblerDecoderCommon.h +483 -0
  252. package/deps/capstone/arch/X86/X86GenAsmWriter.inc +49199 -0
  253. package/deps/capstone/arch/X86/X86GenAsmWriter1.inc +33196 -0
  254. package/deps/capstone/arch/X86/X86GenAsmWriter1_reduce.inc +2531 -0
  255. package/deps/capstone/arch/X86/X86GenAsmWriter_reduce.inc +2855 -0
  256. package/deps/capstone/arch/X86/X86GenDisassemblerTables.inc +112961 -0
  257. package/deps/capstone/arch/X86/X86GenDisassemblerTables2.inc +102151 -0
  258. package/deps/capstone/arch/X86/X86GenDisassemblerTables_reduce.inc +28047 -0
  259. package/deps/capstone/arch/X86/X86GenDisassemblerTables_reduce2.inc +18827 -0
  260. package/deps/capstone/arch/X86/X86GenInstrInfo.inc +15158 -0
  261. package/deps/capstone/arch/X86/X86GenInstrInfo_reduce.inc +1564 -0
  262. package/deps/capstone/arch/X86/X86GenRegisterInfo.inc +1549 -0
  263. package/deps/capstone/arch/X86/X86GenRegisterName.inc +292 -0
  264. package/deps/capstone/arch/X86/X86GenRegisterName1.inc +291 -0
  265. package/deps/capstone/arch/X86/X86ImmSize.inc +335 -0
  266. package/deps/capstone/arch/X86/X86InstPrinter.h +26 -0
  267. package/deps/capstone/arch/X86/X86InstPrinterCommon.c +116 -0
  268. package/deps/capstone/arch/X86/X86InstPrinterCommon.h +16 -0
  269. package/deps/capstone/arch/X86/X86IntelInstPrinter.c +1061 -0
  270. package/deps/capstone/arch/X86/X86Lookup16.inc +16874 -0
  271. package/deps/capstone/arch/X86/X86Lookup16_reduce.inc +2308 -0
  272. package/deps/capstone/arch/X86/X86Mapping.c +2266 -0
  273. package/deps/capstone/arch/X86/X86Mapping.h +96 -0
  274. package/deps/capstone/arch/X86/X86MappingInsn.inc +105977 -0
  275. package/deps/capstone/arch/X86/X86MappingInsnName.inc +1527 -0
  276. package/deps/capstone/arch/X86/X86MappingInsnName_reduce.inc +348 -0
  277. package/deps/capstone/arch/X86/X86MappingInsnOp.inc +75700 -0
  278. package/deps/capstone/arch/X86/X86MappingInsnOp_reduce.inc +7729 -0
  279. package/deps/capstone/arch/X86/X86MappingInsn_reduce.inc +10819 -0
  280. package/deps/capstone/arch/X86/X86MappingReg.inc +280 -0
  281. package/deps/capstone/arch/X86/X86Module.c +94 -0
  282. package/deps/capstone/arch/X86/X86Module.h +12 -0
  283. package/deps/capstone/arch/XCore/XCoreDisassembler.c +794 -0
  284. package/deps/capstone/arch/XCore/XCoreDisassembler.h +17 -0
  285. package/deps/capstone/arch/XCore/XCoreGenAsmWriter.inc +772 -0
  286. package/deps/capstone/arch/XCore/XCoreGenDisassemblerTables.inc +853 -0
  287. package/deps/capstone/arch/XCore/XCoreGenInstrInfo.inc +267 -0
  288. package/deps/capstone/arch/XCore/XCoreGenRegisterInfo.inc +110 -0
  289. package/deps/capstone/arch/XCore/XCoreInstPrinter.c +250 -0
  290. package/deps/capstone/arch/XCore/XCoreInstPrinter.h +18 -0
  291. package/deps/capstone/arch/XCore/XCoreMapping.c +297 -0
  292. package/deps/capstone/arch/XCore/XCoreMapping.h +26 -0
  293. package/deps/capstone/arch/XCore/XCoreMappingInsn.inc +1287 -0
  294. package/deps/capstone/arch/XCore/XCoreModule.c +41 -0
  295. package/deps/capstone/arch/XCore/XCoreModule.h +12 -0
  296. package/deps/capstone/cs.c +1664 -0
  297. package/deps/capstone/cs_priv.h +101 -0
  298. package/deps/capstone/cs_simple_types.h +886 -0
  299. package/deps/capstone/include/capstone/arm.h +991 -0
  300. package/deps/capstone/include/capstone/arm64.h +3159 -0
  301. package/deps/capstone/include/capstone/bpf.h +209 -0
  302. package/deps/capstone/include/capstone/capstone.h +875 -0
  303. package/deps/capstone/include/capstone/evm.h +188 -0
  304. package/deps/capstone/include/capstone/m680x.h +537 -0
  305. package/deps/capstone/include/capstone/m68k.h +613 -0
  306. package/deps/capstone/include/capstone/mips.h +956 -0
  307. package/deps/capstone/include/capstone/mos65xx.h +204 -0
  308. package/deps/capstone/include/capstone/platform.h +122 -0
  309. package/deps/capstone/include/capstone/ppc.h +2108 -0
  310. package/deps/capstone/include/capstone/riscv.h +531 -0
  311. package/deps/capstone/include/capstone/sh.h +465 -0
  312. package/deps/capstone/include/capstone/sparc.h +520 -0
  313. package/deps/capstone/include/capstone/systemz.h +2601 -0
  314. package/deps/capstone/include/capstone/tms320c64x.h +359 -0
  315. package/deps/capstone/include/capstone/tricore.h +567 -0
  316. package/deps/capstone/include/capstone/wasm.h +250 -0
  317. package/deps/capstone/include/capstone/x86.h +1986 -0
  318. package/deps/capstone/include/capstone/xcore.h +235 -0
  319. package/deps/capstone/include/platform.h +110 -0
  320. package/deps/capstone/include/windowsce/intrin.h +12 -0
  321. package/deps/capstone/include/windowsce/stdint.h +133 -0
  322. package/deps/capstone/utils.c +140 -0
  323. package/deps/capstone/utils.h +54 -0
  324. package/index.d.ts +448 -0
  325. package/index.js +64 -0
  326. package/index.mjs +25 -0
  327. package/package.json +82 -0
  328. package/prebuilds/win32-x64/hexcore-capstone.node +0 -0
  329. package/src/capstone_wrapper.cpp +910 -0
  330. package/src/capstone_wrapper.h +147 -0
  331. package/src/disasm_async_worker.h +215 -0
  332. package/src/main.cpp +145 -0
@@ -0,0 +1,684 @@
1
+ /*===- TableGen'erated file -------------------------------------*- C++ -*-===*\
2
+ |* *|
3
+ |*Assembly Writer Source Fragment *|
4
+ |* *|
5
+ |* Automatically generated file, do not edit! *|
6
+ |* *|
7
+ \*===----------------------------------------------------------------------===*/
8
+
9
+ #include <stdio.h>
10
+
11
+ /// printInstruction - This method is automatically generated by tablegen
12
+ /// from the instruction set description.
13
+ static void printInstruction(MCInst *MI, SStream *O, MCRegisterInfo *MRI) {
14
+ static const uint32_t OpInfo[] = {
15
+ 0U, // PHI
16
+ 0U, // INLINEASM
17
+ 0U, // CFI_INSTRUCTION
18
+ 0U, // EH_LABEL
19
+ 0U, // GC_LABEL
20
+ 0U, // KILL
21
+ 0U, // EXTRACT_SUBREG
22
+ 0U, // INSERT_SUBREG
23
+ 0U, // IMPLICIT_DEF
24
+ 0U, // SUBREG_TO_REG
25
+ 0U, // COPY_TO_REGCLASS
26
+ 882U, // DBG_VALUE
27
+ 0U, // REG_SEQUENCE
28
+ 0U, // COPY
29
+ 875U, // BUNDLE
30
+ 904U, // LIFETIME_START
31
+ 862U, // LIFETIME_END
32
+ 0U, // STACKMAP
33
+ 0U, // PATCHPOINT
34
+ 0U, // LOAD_STACK_GUARD
35
+ 0U, // STATEPOINT
36
+ 0U, // FRAME_ALLOC
37
+ 1126U, // ABS2_l2_rr
38
+ 10847U, // ABS_l1_pp
39
+ 1631U, // ABS_l1_rr
40
+ 85006U, // ADD2_d2_rrr
41
+ 85006U, // ADD2_l1_rrr_x2
42
+ 85006U, // ADD2_s1_rrr
43
+ 85171U, // ADD4_l1_rrr_x2
44
+ 91479U, // ADDAB_d1_rir
45
+ 91479U, // ADDAB_d1_rrr
46
+ 91541U, // ADDAD_d1_rir
47
+ 91541U, // ADDAD_d1_rrr
48
+ 91577U, // ADDAH_d1_rir
49
+ 91577U, // ADDAH_d1_rrr
50
+ 91937U, // ADDAW_d1_rir
51
+ 91937U, // ADDAW_d1_rrr
52
+ 132488U, // ADDKPC_s3_iir
53
+ 1518U, // ADDK_s2_ir
54
+ 233140U, // ADDU_l1_rpp
55
+ 216756U, // ADDU_l1_rrp_x2
56
+ 91555U, // ADD_d1_rir
57
+ 91555U, // ADD_d1_rrr
58
+ 91555U, // ADD_d2_rir
59
+ 85411U, // ADD_d2_rrr
60
+ 232867U, // ADD_l1_ipp
61
+ 85411U, // ADD_l1_irr
62
+ 232867U, // ADD_l1_rpp
63
+ 216483U, // ADD_l1_rrp_x2
64
+ 85411U, // ADD_l1_rrr_x2
65
+ 85411U, // ADD_s1_irr
66
+ 85411U, // ADD_s1_rrr
67
+ 85542U, // ANDN_d2_rrr
68
+ 85542U, // ANDN_l1_rrr_x2
69
+ 85542U, // ANDN_s4_rrr
70
+ 85416U, // AND_d2_rir
71
+ 85416U, // AND_d2_rrr
72
+ 85416U, // AND_l1_irr
73
+ 85416U, // AND_l1_rrr_x2
74
+ 85416U, // AND_s1_irr
75
+ 85416U, // AND_s1_rrr
76
+ 85019U, // AVG2_m1_rrr
77
+ 85232U, // AVGU4_m1_rrr
78
+ 1410U, // BDEC_s8_ir
79
+ 1196U, // BITC4_m2_rr
80
+ 307756U, // BNOP_s10_ri
81
+ 307756U, // BNOP_s9_ii
82
+ 1654U, // BPOS_s8_ir
83
+ 53588U, // B_s5_i
84
+ 53588U, // B_s6_r
85
+ 892U, // B_s7_irp
86
+ 898U, // B_s7_nrp
87
+ 353870U, // CLR_s15_riir
88
+ 91726U, // CLR_s1_rrr
89
+ 85080U, // CMPEQ2_s1_rrr
90
+ 85207U, // CMPEQ4_s1_rrr
91
+ 101938U, // CMPEQ_l1_ipr
92
+ 85554U, // CMPEQ_l1_irr
93
+ 101938U, // CMPEQ_l1_rpr
94
+ 85554U, // CMPEQ_l1_rrr_x2
95
+ 85109U, // CMPGT2_s1_rrr
96
+ 85298U, // CMPGTU4_s1_rrr
97
+ 102037U, // CMPGT_l1_ipr
98
+ 85653U, // CMPGT_l1_irr
99
+ 102037U, // CMPGT_l1_rpr
100
+ 85653U, // CMPGT_l1_rrr_x2
101
+ 102150U, // CMPLTU_l1_ipr
102
+ 85766U, // CMPLTU_l1_irr
103
+ 102150U, // CMPLTU_l1_rpr
104
+ 85766U, // CMPLTU_l1_rrr_x2
105
+ 102044U, // CMPLT_l1_ipr
106
+ 85660U, // CMPLT_l1_irr
107
+ 102044U, // CMPLT_l1_rpr
108
+ 85660U, // CMPLT_l1_rrr_x2
109
+ 1529U, // DEAL_m2_rr
110
+ 216145U, // DOTP2_m1_rrp
111
+ 85073U, // DOTP2_m1_rrr
112
+ 85065U, // DOTPN2_m1_rrr
113
+ 85124U, // DOTPNRSU2_m1_rrr
114
+ 85135U, // DOTPRSU2_m1_rrr
115
+ 85281U, // DOTPSU4_m1_rrr
116
+ 85273U, // DOTPU4_m1_rrr
117
+ 354062U, // EXTU_s15_riir
118
+ 91918U, // EXTU_s1_rrr
119
+ 353955U, // EXT_s15_riir
120
+ 91811U, // EXT_s1_rrr
121
+ 102142U, // GMPGTU_l1_ipr
122
+ 85758U, // GMPGTU_l1_irr
123
+ 102142U, // GMPGTU_l1_rpr
124
+ 85758U, // GMPGTU_l1_rrr_x2
125
+ 85321U, // GMPY4_m1_rrr
126
+ 5800U, // LDBU_d5_mr
127
+ 6824U, // LDBU_d6_mr
128
+ 5470U, // LDB_d5_mr
129
+ 6494U, // LDB_d6_mr
130
+ 14120U, // LDDW_d7_mp
131
+ 5818U, // LDHU_d5_mr
132
+ 6842U, // LDHU_d6_mr
133
+ 5568U, // LDH_d5_mr
134
+ 6592U, // LDH_d6_mr
135
+ 14131U, // LDNDW_d8_mp
136
+ 5959U, // LDNW_d5_mr
137
+ 5934U, // LDW_d5_mr
138
+ 6958U, // LDW_d6_mr
139
+ 85404U, // LMBD_l1_irr
140
+ 85404U, // LMBD_l1_rrr_x2
141
+ 85145U, // MAX2_l1_rrr_x2
142
+ 85307U, // MAXU4_l1_rrr_x2
143
+ 85059U, // MIN2_l1_rrr_x2
144
+ 85266U, // MINU4_l1_rrr_x2
145
+ 216224U, // MPY2_m1_rrp
146
+ 85566U, // MPYHIR_m1_rrr
147
+ 216544U, // MPYHI_m1_rrp
148
+ 85720U, // MPYHLU_m4_rrr
149
+ 85516U, // MPYHL_m4_rrr
150
+ 85728U, // MPYHSLU_m4_rrr
151
+ 85743U, // MPYHSU_m4_rrr
152
+ 85613U, // MPYHULS_m4_rrr
153
+ 85628U, // MPYHUS_m4_rrr
154
+ 85713U, // MPYHU_m4_rrr
155
+ 85466U, // MPYH_m4_rrr
156
+ 85696U, // MPYLHU_m4_rrr
157
+ 85453U, // MPYLH_m4_rrr
158
+ 85574U, // MPYLIR_m1_rrr
159
+ 216551U, // MPYLI_m1_rrp
160
+ 85704U, // MPYLSHU_m4_rrr
161
+ 85604U, // MPYLUHS_m4_rrr
162
+ 216362U, // MPYSU4_m1_rrp
163
+ 85751U, // MPYSU_m4_irr
164
+ 85751U, // MPYSU_m4_rrr
165
+ 216386U, // MPYU4_m1_rrp
166
+ 85636U, // MPYUS_m4_rrr
167
+ 85780U, // MPYU_m4_rrr
168
+ 85849U, // MPY_m4_irr
169
+ 85849U, // MPY_m4_rrr
170
+ 1424U, // MVC_s1_rr
171
+ 1424U, // MVC_s1_rr2
172
+ 1453U, // MVD_m2_rr
173
+ 1477U, // MVKLH_s12_ir
174
+ 1524U, // MVKL_s12_ir
175
+ 1524U, // MVK_d1_rr
176
+ 1524U, // MVK_l2_ir
177
+ 53249U, // NOP_n
178
+ 2592U, // NORM_l1_pr
179
+ 1568U, // NORM_l1_rr
180
+ 85588U, // OR_d2_rir
181
+ 85588U, // OR_d2_rrr
182
+ 85588U, // OR_l1_irr
183
+ 85588U, // OR_l1_rrr_x2
184
+ 85588U, // OR_s1_irr
185
+ 85588U, // OR_s1_rrr
186
+ 85043U, // PACK2_l1_rrr_x2
187
+ 85043U, // PACK2_s4_rrr
188
+ 85025U, // PACKH2_l1_rrr_x2
189
+ 85025U, // PACKH2_s1_rrr
190
+ 85184U, // PACKH4_l1_rrr_x2
191
+ 85050U, // PACKHL2_l1_rrr_x2
192
+ 85050U, // PACKHL2_s1_rrr
193
+ 85192U, // PACKL4_l1_rrr_x2
194
+ 85033U, // PACKLH2_l1_rrr_x2
195
+ 85033U, // PACKLH2_s1_rrr
196
+ 91667U, // ROTL_m1_rir
197
+ 91667U, // ROTL_m1_rrr
198
+ 85005U, // SADD2_s4_rrr
199
+ 85224U, // SADDU4_s4_rrr
200
+ 85100U, // SADDUS2_s4_rrr
201
+ 232866U, // SADD_l1_ipp
202
+ 85410U, // SADD_l1_irr
203
+ 232866U, // SADD_l1_rpp
204
+ 85410U, // SADD_l1_rrr_x2
205
+ 85410U, // SADD_s1_rrr
206
+ 2699U, // SAT_l1_pr
207
+ 353936U, // SET_s15_riir
208
+ 91792U, // SET_s1_rrr
209
+ 1535U, // SHFL_m2_rr
210
+ 85347U, // SHLMB_l1_rrr_x2
211
+ 85347U, // SHLMB_s4_rrr
212
+ 223750U, // SHL_s1_pip
213
+ 223750U, // SHL_s1_prp
214
+ 222726U, // SHL_s1_rip
215
+ 91654U, // SHL_s1_rir
216
+ 222726U, // SHL_s1_rrp
217
+ 91654U, // SHL_s1_rrr
218
+ 91232U, // SHR2_s1_rir
219
+ 91232U, // SHR2_s4_rrr
220
+ 85354U, // SHRMB_l1_rrr_x2
221
+ 85354U, // SHRMB_s4_rrr
222
+ 91261U, // SHRU2_s1_rir
223
+ 91261U, // SHRU2_s4_rrr
224
+ 223977U, // SHRU_s1_pip
225
+ 223977U, // SHRU_s1_prp
226
+ 91881U, // SHRU_s1_rir
227
+ 91881U, // SHRU_s1_rrr
228
+ 223801U, // SHR_s1_pip
229
+ 223801U, // SHR_s1_prp
230
+ 91705U, // SHR_s1_rir
231
+ 91705U, // SHR_s1_rrr
232
+ 216223U, // SMPY2_m1_rrp
233
+ 85515U, // SMPYHL_m4_rrr
234
+ 85465U, // SMPYH_m4_rrr
235
+ 85452U, // SMPYLH_m4_rrr
236
+ 85848U, // SMPY_m4_rrr
237
+ 85042U, // SPACK2_s4_rrr
238
+ 85248U, // SPACKU4_s4_rrr
239
+ 91653U, // SSHL_s1_rir
240
+ 91653U, // SSHL_s1_rrr
241
+ 85529U, // SSHVL_m1_rrr
242
+ 85592U, // SSHVR_m1_rrr
243
+ 232822U, // SSUB_l1_ipp
244
+ 85366U, // SSUB_l1_irr
245
+ 85366U, // SSUB_l1_rrr_x1
246
+ 85366U, // SSUB_l1_rrr_x2
247
+ 438641U, // STB_d5_rm
248
+ 504177U, // STB_d6_rm
249
+ 8001U, // STDW_d7_pm
250
+ 438740U, // STH_d5_rm
251
+ 504276U, // STH_d6_rm
252
+ 7994U, // STNDW_d8_pm
253
+ 439117U, // STNW_d5_rm
254
+ 439123U, // STW_d5_rm
255
+ 504659U, // STW_d6_rm
256
+ 84999U, // SUB2_d2_rrr
257
+ 84999U, // SUB2_l1_rrr_x2
258
+ 84999U, // SUB2_s1_rrr
259
+ 85158U, // SUB4_l1_rrr_x2
260
+ 85215U, // SUBABS4_l1_rrr_x2
261
+ 91472U, // SUBAB_d1_rir
262
+ 91472U, // SUBAB_d1_rrr
263
+ 91472U, // SUBAH_d1_rir
264
+ 91570U, // SUBAH_d1_rrr
265
+ 91472U, // SUBAW_d1_rir
266
+ 91930U, // SUBAW_d1_rrr
267
+ 85372U, // SUBC_l1_rrr_x2
268
+ 216750U, // SUBU_l1_rrp_x1
269
+ 216750U, // SUBU_l1_rrp_x2
270
+ 91511U, // SUB_d1_rir
271
+ 91511U, // SUB_d1_rrr
272
+ 85367U, // SUB_d2_rrr
273
+ 232823U, // SUB_l1_ipp
274
+ 85367U, // SUB_l1_irr
275
+ 216439U, // SUB_l1_rrp_x1
276
+ 216439U, // SUB_l1_rrp_x2
277
+ 85367U, // SUB_l1_rrr_x1
278
+ 85367U, // SUB_l1_rrr_x2
279
+ 85367U, // SUB_s1_irr
280
+ 85367U, // SUB_s1_rrr
281
+ 91511U, // SUB_s4_rrr
282
+ 1232U, // SWAP4_l2_rr
283
+ 1271U, // UNPKHU4_l2_rr
284
+ 1271U, // UNPKHU4_s14_rr
285
+ 1289U, // UNPKLU4_l2_rr
286
+ 1289U, // UNPKLU4_s14_rr
287
+ 85587U, // XOR_d2_rir
288
+ 85587U, // XOR_d2_rrr
289
+ 85587U, // XOR_l1_irr
290
+ 85587U, // XOR_l1_rrr_x2
291
+ 85587U, // XOR_s1_irr
292
+ 85587U, // XOR_s1_rrr
293
+ 1044U, // XPND2_m2_rr
294
+ 1209U, // XPND4_m2_rr
295
+ 0U
296
+ };
297
+
298
+ static const char AsmStrs[] = {
299
+ /* 0 */ 'n', 'o', 'p', 9, 9, 0,
300
+ /* 6 */ 's', 'u', 'b', '2', 9, 0,
301
+ /* 12 */ 's', 'a', 'd', 'd', '2', 9, 0,
302
+ /* 19 */ 'x', 'p', 'n', 'd', '2', 9, 0,
303
+ /* 26 */ 'a', 'v', 'g', '2', 9, 0,
304
+ /* 32 */ 'p', 'a', 'c', 'k', 'h', '2', 9, 0,
305
+ /* 40 */ 'p', 'a', 'c', 'k', 'l', 'h', '2', 9, 0,
306
+ /* 49 */ 's', 'p', 'a', 'c', 'k', '2', 9, 0,
307
+ /* 57 */ 'p', 'a', 'c', 'k', 'h', 'l', '2', 9, 0,
308
+ /* 66 */ 'm', 'i', 'n', '2', 9, 0,
309
+ /* 72 */ 'd', 'o', 't', 'p', 'n', '2', 9, 0,
310
+ /* 80 */ 'd', 'o', 't', 'p', '2', 9, 0,
311
+ /* 87 */ 'c', 'm', 'p', 'e', 'q', '2', 9, 0,
312
+ /* 95 */ 's', 'h', 'r', '2', 9, 0,
313
+ /* 101 */ 'a', 'b', 's', '2', 9, 0,
314
+ /* 107 */ 's', 'a', 'd', 'd', 'u', 's', '2', 9, 0,
315
+ /* 116 */ 'c', 'm', 'p', 'g', 't', '2', 9, 0,
316
+ /* 124 */ 's', 'h', 'r', 'u', '2', 9, 0,
317
+ /* 131 */ 'd', 'o', 't', 'p', 'n', 'r', 's', 'u', '2', 9, 0,
318
+ /* 142 */ 'd', 'o', 't', 'p', 'r', 's', 'u', '2', 9, 0,
319
+ /* 152 */ 'm', 'a', 'x', '2', 9, 0,
320
+ /* 158 */ 's', 'm', 'p', 'y', '2', 9, 0,
321
+ /* 165 */ 's', 'u', 'b', '4', 9, 0,
322
+ /* 171 */ 'b', 'i', 't', 'c', '4', 9, 0,
323
+ /* 178 */ 'a', 'd', 'd', '4', 9, 0,
324
+ /* 184 */ 'x', 'p', 'n', 'd', '4', 9, 0,
325
+ /* 191 */ 'p', 'a', 'c', 'k', 'h', '4', 9, 0,
326
+ /* 199 */ 'p', 'a', 'c', 'k', 'l', '4', 9, 0,
327
+ /* 207 */ 's', 'w', 'a', 'p', '4', 9, 0,
328
+ /* 214 */ 'c', 'm', 'p', 'e', 'q', '4', 9, 0,
329
+ /* 222 */ 's', 'u', 'b', 'a', 'b', 's', '4', 9, 0,
330
+ /* 231 */ 's', 'a', 'd', 'd', 'u', '4', 9, 0,
331
+ /* 239 */ 'a', 'v', 'g', 'u', '4', 9, 0,
332
+ /* 246 */ 'u', 'n', 'p', 'k', 'h', 'u', '4', 9, 0,
333
+ /* 255 */ 's', 'p', 'a', 'c', 'k', 'u', '4', 9, 0,
334
+ /* 264 */ 'u', 'n', 'p', 'k', 'l', 'u', '4', 9, 0,
335
+ /* 273 */ 'm', 'i', 'n', 'u', '4', 9, 0,
336
+ /* 280 */ 'd', 'o', 't', 'p', 'u', '4', 9, 0,
337
+ /* 288 */ 'd', 'o', 't', 'p', 's', 'u', '4', 9, 0,
338
+ /* 297 */ 'm', 'p', 'y', 's', 'u', '4', 9, 0,
339
+ /* 305 */ 'c', 'm', 'p', 'g', 't', 'u', '4', 9, 0,
340
+ /* 314 */ 'm', 'a', 'x', 'u', '4', 9, 0,
341
+ /* 321 */ 'm', 'p', 'y', 'u', '4', 9, 0,
342
+ /* 328 */ 'g', 'm', 'p', 'y', '4', 9, 0,
343
+ /* 335 */ 's', 'u', 'b', 'a', 'b', 9, 0,
344
+ /* 342 */ 'a', 'd', 'd', 'a', 'b', 9, 0,
345
+ /* 349 */ 'l', 'd', 'b', 9, 0,
346
+ /* 354 */ 's', 'h', 'l', 'm', 'b', 9, 0,
347
+ /* 361 */ 's', 'h', 'r', 'm', 'b', 9, 0,
348
+ /* 368 */ 's', 't', 'b', 9, 0,
349
+ /* 373 */ 's', 's', 'u', 'b', 9, 0,
350
+ /* 379 */ 's', 'u', 'b', 'c', 9, 0,
351
+ /* 385 */ 'b', 'd', 'e', 'c', 9, 0,
352
+ /* 391 */ 'a', 'd', 'd', 'k', 'p', 'c', 9, 0,
353
+ /* 399 */ 'm', 'v', 'c', 9, 0,
354
+ /* 404 */ 'a', 'd', 'd', 'a', 'd', 9, 0,
355
+ /* 411 */ 'l', 'm', 'b', 'd', 9, 0,
356
+ /* 417 */ 's', 'a', 'd', 'd', 9, 0,
357
+ /* 423 */ 'a', 'n', 'd', 9, 0,
358
+ /* 428 */ 'm', 'v', 'd', 9, 0,
359
+ /* 433 */ 's', 'u', 'b', 'a', 'h', 9, 0,
360
+ /* 440 */ 'a', 'd', 'd', 'a', 'h', 9, 0,
361
+ /* 447 */ 'l', 'd', 'h', 9, 0,
362
+ /* 452 */ 'm', 'v', 'k', 'l', 'h', 9, 0,
363
+ /* 459 */ 's', 'm', 'p', 'y', 'l', 'h', 9, 0,
364
+ /* 467 */ 's', 't', 'h', 9, 0,
365
+ /* 472 */ 's', 'm', 'p', 'y', 'h', 9, 0,
366
+ /* 479 */ 'm', 'p', 'y', 'h', 'i', 9, 0,
367
+ /* 486 */ 'm', 'p', 'y', 'l', 'i', 9, 0,
368
+ /* 493 */ 'a', 'd', 'd', 'k', 9, 0,
369
+ /* 499 */ 'm', 'v', 'k', 9, 0,
370
+ /* 504 */ 'd', 'e', 'a', 'l', 9, 0,
371
+ /* 510 */ 's', 'h', 'f', 'l', 9, 0,
372
+ /* 516 */ 's', 's', 'h', 'l', 9, 0,
373
+ /* 522 */ 's', 'm', 'p', 'y', 'h', 'l', 9, 0,
374
+ /* 530 */ 'r', 'o', 't', 'l', 9, 0,
375
+ /* 536 */ 's', 's', 'h', 'v', 'l', 9, 0,
376
+ /* 543 */ 'n', 'o', 'r', 'm', 9, 0,
377
+ /* 549 */ 'a', 'n', 'd', 'n', 9, 0,
378
+ /* 555 */ 'b', 'n', 'o', 'p', 9, 0,
379
+ /* 561 */ 'c', 'm', 'p', 'e', 'q', 9, 0,
380
+ /* 568 */ 's', 'h', 'r', 9, 0,
381
+ /* 573 */ 'm', 'p', 'y', 'h', 'i', 'r', 9, 0,
382
+ /* 581 */ 'm', 'p', 'y', 'l', 'i', 'r', 9, 0,
383
+ /* 589 */ 'c', 'l', 'r', 9, 0,
384
+ /* 594 */ 'x', 'o', 'r', 9, 0,
385
+ /* 599 */ 's', 's', 'h', 'v', 'r', 9, 0,
386
+ /* 606 */ 'a', 'b', 's', 9, 0,
387
+ /* 611 */ 'm', 'p', 'y', 'l', 'u', 'h', 's', 9, 0,
388
+ /* 620 */ 'm', 'p', 'y', 'h', 'u', 'l', 's', 9, 0,
389
+ /* 629 */ 'b', 'p', 'o', 's', 9, 0,
390
+ /* 635 */ 'm', 'p', 'y', 'h', 'u', 's', 9, 0,
391
+ /* 643 */ 'm', 'p', 'y', 'u', 's', 9, 0,
392
+ /* 650 */ 's', 'a', 't', 9, 0,
393
+ /* 655 */ 's', 'e', 't', 9, 0,
394
+ /* 660 */ 'c', 'm', 'p', 'g', 't', 9, 0,
395
+ /* 667 */ 'c', 'm', 'p', 'l', 't', 9, 0,
396
+ /* 674 */ 'e', 'x', 't', 9, 0,
397
+ /* 679 */ 'l', 'd', 'b', 'u', 9, 0,
398
+ /* 685 */ 's', 'u', 'b', 'u', 9, 0,
399
+ /* 691 */ 'a', 'd', 'd', 'u', 9, 0,
400
+ /* 697 */ 'l', 'd', 'h', 'u', 9, 0,
401
+ /* 703 */ 'm', 'p', 'y', 'l', 'h', 'u', 9, 0,
402
+ /* 711 */ 'm', 'p', 'y', 'l', 's', 'h', 'u', 9, 0,
403
+ /* 720 */ 'm', 'p', 'y', 'h', 'u', 9, 0,
404
+ /* 727 */ 'm', 'p', 'y', 'h', 'l', 'u', 9, 0,
405
+ /* 735 */ 'm', 'p', 'y', 'h', 's', 'l', 'u', 9, 0,
406
+ /* 744 */ 's', 'h', 'r', 'u', 9, 0,
407
+ /* 750 */ 'm', 'p', 'y', 'h', 's', 'u', 9, 0,
408
+ /* 758 */ 'm', 'p', 'y', 's', 'u', 9, 0,
409
+ /* 765 */ 'c', 'm', 'p', 'g', 't', 'u', 9, 0,
410
+ /* 773 */ 'c', 'm', 'p', 'l', 't', 'u', 9, 0,
411
+ /* 781 */ 'e', 'x', 't', 'u', 9, 0,
412
+ /* 787 */ 'm', 'p', 'y', 'u', 9, 0,
413
+ /* 793 */ 's', 'u', 'b', 'a', 'w', 9, 0,
414
+ /* 800 */ 'a', 'd', 'd', 'a', 'w', 9, 0,
415
+ /* 807 */ 'l', 'd', 'd', 'w', 9, 0,
416
+ /* 813 */ 'l', 'd', 'w', 9, 0,
417
+ /* 818 */ 'l', 'd', 'n', 'd', 'w', 9, 0,
418
+ /* 825 */ 's', 't', 'n', 'd', 'w', 9, 0,
419
+ /* 832 */ 's', 't', 'd', 'w', 9, 0,
420
+ /* 838 */ 'l', 'd', 'n', 'w', 9, 0,
421
+ /* 844 */ 's', 't', 'n', 'w', 9, 0,
422
+ /* 850 */ 's', 't', 'w', 9, 0,
423
+ /* 855 */ 's', 'm', 'p', 'y', 9, 0,
424
+ /* 861 */ 'l', 'i', 'f', 'e', 't', 'i', 'm', 'e', '_', 'e', 'n', 'd', 0,
425
+ /* 874 */ 'b', 'u', 'n', 'd', 'l', 'e', 0,
426
+ /* 881 */ 'd', 'b', 'g', '_', 'v', 'a', 'l', 'u', 'e', 0,
427
+ /* 891 */ 'b', 9, 'i', 'r', 'p', 0,
428
+ /* 897 */ 'b', 9, 'n', 'r', 'p', 0,
429
+ /* 903 */ 'l', 'i', 'f', 'e', 't', 'i', 'm', 'e', '_', 's', 't', 'a', 'r', 't', 0,
430
+ };
431
+
432
+ // Emit the opcode for the instruction.
433
+ uint32_t Bits = OpInfo[MCInst_getOpcode(MI)];
434
+ // assert(Bits != 0 && "Cannot print this instruction.");
435
+ #ifndef CAPSTONE_DIET
436
+ SStream_concat0(O, AsmStrs+(Bits & 1023)-1);
437
+ #endif
438
+
439
+
440
+ // Fragment 0 encoded into 3 bits for 8 unique commands.
441
+ switch ((Bits >> 10) & 7) {
442
+ default:
443
+ case 0:
444
+ // DBG_VALUE, BUNDLE, LIFETIME_START, LIFETIME_END, B_s7_irp, B_s7_nrp
445
+ return;
446
+ break;
447
+ case 1:
448
+ // ABS2_l2_rr, ABS_l1_rr, ADDAB_d1_rir, ADDAB_d1_rrr, ADDAD_d1_rir, ADDAD...
449
+ printOperand(MI, 1, O);
450
+ SStream_concat0(O, ", ");
451
+ break;
452
+ case 2:
453
+ // ABS_l1_pp, NORM_l1_pr, SAT_l1_pr, SHL_s1_pip, SHL_s1_prp, SHRU_s1_pip,...
454
+ printRegPair(MI, 1, O);
455
+ SStream_concat0(O, ", ");
456
+ break;
457
+ case 3:
458
+ // ADD2_d2_rrr, ADD2_l1_rrr_x2, ADD2_s1_rrr, ADD4_l1_rrr_x2, ADDU_l1_rpp,...
459
+ printOperand(MI, 2, O);
460
+ SStream_concat0(O, ", ");
461
+ break;
462
+ case 4:
463
+ // BNOP_s10_ri, BNOP_s9_ii, B_s5_i, B_s6_r, NOP_n, STB_d5_rm, STB_d6_rm, ...
464
+ printOperand(MI, 0, O);
465
+ break;
466
+ case 5:
467
+ // LDBU_d5_mr, LDB_d5_mr, LDDW_d7_mp, LDHU_d5_mr, LDH_d5_mr, LDNDW_d8_mp,...
468
+ printMemOperand(MI, 1, O);
469
+ SStream_concat0(O, ", ");
470
+ break;
471
+ case 6:
472
+ // LDBU_d6_mr, LDB_d6_mr, LDHU_d6_mr, LDH_d6_mr, LDW_d6_mr
473
+ printMemOperand2(MI, 1, O);
474
+ SStream_concat0(O, ", ");
475
+ printOperand(MI, 0, O);
476
+ return;
477
+ break;
478
+ case 7:
479
+ // STDW_d7_pm, STNDW_d8_pm
480
+ printRegPair(MI, 0, O);
481
+ SStream_concat0(O, ", ");
482
+ printMemOperand(MI, 1, O);
483
+ return;
484
+ break;
485
+ }
486
+
487
+
488
+ // Fragment 1 encoded into 3 bits for 7 unique commands.
489
+ switch ((Bits >> 13) & 7) {
490
+ default:
491
+ case 0:
492
+ // ABS2_l2_rr, ABS_l1_rr, ADDKPC_s3_iir, ADDK_s2_ir, BDEC_s8_ir, BITC4_m2...
493
+ printOperand(MI, 0, O);
494
+ break;
495
+ case 1:
496
+ // ABS_l1_pp, LDDW_d7_mp, LDNDW_d8_mp
497
+ printRegPair(MI, 0, O);
498
+ return;
499
+ break;
500
+ case 2:
501
+ // ADD2_d2_rrr, ADD2_l1_rrr_x2, ADD2_s1_rrr, ADD4_l1_rrr_x2, ADDU_l1_rrp_...
502
+ printOperand(MI, 1, O);
503
+ SStream_concat0(O, ", ");
504
+ break;
505
+ case 3:
506
+ // ADDAB_d1_rir, ADDAB_d1_rrr, ADDAD_d1_rir, ADDAD_d1_rrr, ADDAH_d1_rir, ...
507
+ printOperand(MI, 2, O);
508
+ SStream_concat0(O, ", ");
509
+ break;
510
+ case 4:
511
+ // ADDU_l1_rpp, ADD_l1_ipp, ADD_l1_rpp, CMPEQ_l1_ipr, CMPEQ_l1_rpr, CMPGT...
512
+ printRegPair(MI, 1, O);
513
+ SStream_concat0(O, ", ");
514
+ break;
515
+ case 5:
516
+ // BNOP_s10_ri, BNOP_s9_ii, STB_d5_rm, STB_d6_rm, STH_d5_rm, STH_d6_rm, S...
517
+ SStream_concat0(O, ", ");
518
+ break;
519
+ case 6:
520
+ // B_s5_i, B_s6_r, NOP_n
521
+ return;
522
+ break;
523
+ }
524
+
525
+
526
+ // Fragment 2 encoded into 3 bits for 8 unique commands.
527
+ switch ((Bits >> 16) & 7) {
528
+ default:
529
+ case 0:
530
+ // ABS2_l2_rr, ABS_l1_rr, ADDK_s2_ir, BDEC_s8_ir, BITC4_m2_rr, BPOS_s8_ir...
531
+ return;
532
+ break;
533
+ case 1:
534
+ // ADD2_d2_rrr, ADD2_l1_rrr_x2, ADD2_s1_rrr, ADD4_l1_rrr_x2, ADDAB_d1_rir...
535
+ printOperand(MI, 0, O);
536
+ return;
537
+ break;
538
+ case 2:
539
+ // ADDKPC_s3_iir
540
+ SStream_concat0(O, ", ");
541
+ printOperand(MI, 2, O);
542
+ return;
543
+ break;
544
+ case 3:
545
+ // ADDU_l1_rpp, ADDU_l1_rrp_x2, ADD_l1_ipp, ADD_l1_rpp, ADD_l1_rrp_x2, DO...
546
+ printRegPair(MI, 0, O);
547
+ return;
548
+ break;
549
+ case 4:
550
+ // BNOP_s10_ri, BNOP_s9_ii
551
+ printOperand(MI, 1, O);
552
+ return;
553
+ break;
554
+ case 5:
555
+ // CLR_s15_riir, EXTU_s15_riir, EXT_s15_riir, SET_s15_riir
556
+ printOperand(MI, 3, O);
557
+ SStream_concat0(O, ", ");
558
+ printOperand(MI, 0, O);
559
+ return;
560
+ break;
561
+ case 6:
562
+ // STB_d5_rm, STH_d5_rm, STNW_d5_rm, STW_d5_rm
563
+ printMemOperand(MI, 1, O);
564
+ return;
565
+ break;
566
+ case 7:
567
+ // STB_d6_rm, STH_d6_rm, STW_d6_rm
568
+ printMemOperand2(MI, 1, O);
569
+ return;
570
+ break;
571
+ }
572
+
573
+ }
574
+
575
+
576
+ /// getRegisterName - This method is automatically generated by tblgen
577
+ /// from the register set description. This returns the assembler name
578
+ /// for the specified register.
579
+ static const char *getRegisterName(unsigned RegNo) {
580
+ #ifndef CAPSTONE_DIET
581
+ static const char AsmStrs[] = {
582
+ /* 0 */ 'a', '1', '0', 0,
583
+ /* 4 */ 'b', '1', '0', 0,
584
+ /* 8 */ 'a', '2', '0', 0,
585
+ /* 12 */ 'b', '2', '0', 0,
586
+ /* 16 */ 'a', '3', '0', 0,
587
+ /* 20 */ 'b', '3', '0', 0,
588
+ /* 24 */ 'a', '0', 0,
589
+ /* 27 */ 'b', '0', 0,
590
+ /* 30 */ 'a', '1', '1', 0,
591
+ /* 34 */ 'b', '1', '1', 0,
592
+ /* 38 */ 'a', '2', '1', 0,
593
+ /* 42 */ 'b', '2', '1', 0,
594
+ /* 46 */ 'a', '3', '1', 0,
595
+ /* 50 */ 'b', '3', '1', 0,
596
+ /* 54 */ 'a', '1', 0,
597
+ /* 57 */ 'b', '1', 0,
598
+ /* 60 */ 'p', 'c', 'e', '1', 0,
599
+ /* 65 */ 'a', '1', '2', 0,
600
+ /* 69 */ 'b', '1', '2', 0,
601
+ /* 73 */ 'a', '2', '2', 0,
602
+ /* 77 */ 'b', '2', '2', 0,
603
+ /* 81 */ 'a', '2', 0,
604
+ /* 84 */ 'b', '2', 0,
605
+ /* 87 */ 'a', '1', '3', 0,
606
+ /* 91 */ 'b', '1', '3', 0,
607
+ /* 95 */ 'a', '2', '3', 0,
608
+ /* 99 */ 'b', '2', '3', 0,
609
+ /* 103 */ 'a', '3', 0,
610
+ /* 106 */ 'b', '3', 0,
611
+ /* 109 */ 'a', '1', '4', 0,
612
+ /* 113 */ 'b', '1', '4', 0,
613
+ /* 117 */ 'a', '2', '4', 0,
614
+ /* 121 */ 'b', '2', '4', 0,
615
+ /* 125 */ 'a', '4', 0,
616
+ /* 128 */ 'b', '4', 0,
617
+ /* 131 */ 'a', '1', '5', 0,
618
+ /* 135 */ 'b', '1', '5', 0,
619
+ /* 139 */ 'a', '2', '5', 0,
620
+ /* 143 */ 'b', '2', '5', 0,
621
+ /* 147 */ 'a', '5', 0,
622
+ /* 150 */ 'b', '5', 0,
623
+ /* 153 */ 'a', '1', '6', 0,
624
+ /* 157 */ 'b', '1', '6', 0,
625
+ /* 161 */ 'a', '2', '6', 0,
626
+ /* 165 */ 'b', '2', '6', 0,
627
+ /* 169 */ 'a', '6', 0,
628
+ /* 172 */ 'b', '6', 0,
629
+ /* 175 */ 'a', '1', '7', 0,
630
+ /* 179 */ 'b', '1', '7', 0,
631
+ /* 183 */ 'a', '2', '7', 0,
632
+ /* 187 */ 'b', '2', '7', 0,
633
+ /* 191 */ 'a', '7', 0,
634
+ /* 194 */ 'b', '7', 0,
635
+ /* 197 */ 'a', '1', '8', 0,
636
+ /* 201 */ 'b', '1', '8', 0,
637
+ /* 205 */ 'a', '2', '8', 0,
638
+ /* 209 */ 'b', '2', '8', 0,
639
+ /* 213 */ 'a', '8', 0,
640
+ /* 216 */ 'b', '8', 0,
641
+ /* 219 */ 'a', '1', '9', 0,
642
+ /* 223 */ 'b', '1', '9', 0,
643
+ /* 227 */ 'a', '2', '9', 0,
644
+ /* 231 */ 'b', '2', '9', 0,
645
+ /* 235 */ 'a', '9', 0,
646
+ /* 238 */ 'b', '9', 0,
647
+ /* 241 */ 'g', 'p', 'l', 'y', 'a', 0,
648
+ /* 247 */ 'g', 'p', 'l', 'y', 'b', 0,
649
+ /* 253 */ 'r', 'i', 'l', 'c', 0,
650
+ /* 258 */ 't', 's', 'c', 'h', 0,
651
+ /* 263 */ 't', 's', 'c', 'l', 0,
652
+ /* 268 */ 'd', 'n', 'u', 'm', 0,
653
+ /* 273 */ 'r', 'e', 'p', 0,
654
+ /* 277 */ 'i', 'r', 'p', 0,
655
+ /* 281 */ 'n', 'r', 'p', 0,
656
+ /* 285 */ 'i', 's', 't', 'p', 0,
657
+ /* 290 */ 'e', 'c', 'r', 0,
658
+ /* 294 */ 'i', 'c', 'r', 0,
659
+ /* 298 */ 'd', 'i', 'e', 'r', 0,
660
+ /* 303 */ 'g', 'f', 'p', 'g', 'f', 'r', 0,
661
+ /* 310 */ 'a', 'm', 'r', 0,
662
+ /* 314 */ 'i', 'e', 'r', 'r', 0,
663
+ /* 319 */ 'c', 's', 'r', 0,
664
+ /* 323 */ 'i', 's', 'r', 0,
665
+ /* 327 */ 's', 's', 'r', 0,
666
+ /* 331 */ 'i', 't', 's', 'r', 0,
667
+ /* 336 */ 'n', 't', 's', 'r', 0,
668
+ };
669
+
670
+ static const uint16_t RegAsmOffset[] = {
671
+ 310, 319, 298, 268, 290, 303, 241, 247, 294, 299, 314, 254, 277, 323,
672
+ 285, 331, 281, 336, 273, 253, 327, 258, 263, 332, 24, 54, 81, 103,
673
+ 125, 147, 169, 191, 213, 235, 0, 30, 65, 87, 109, 131, 153, 175,
674
+ 197, 219, 8, 38, 73, 95, 117, 139, 161, 183, 205, 227, 16, 46,
675
+ 27, 57, 84, 106, 128, 150, 172, 194, 216, 238, 4, 34, 69, 91,
676
+ 113, 135, 157, 179, 201, 223, 12, 42, 77, 99, 121, 143, 165, 187,
677
+ 209, 231, 20, 50, 60,
678
+ };
679
+
680
+ return AsmStrs+RegAsmOffset[RegNo-1];
681
+ #else
682
+ return NULL;
683
+ #endif
684
+ }