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,366 @@
1
+
2
+ #ifdef CAPSTONE_HAS_RISCV
3
+
4
+ #include <stdio.h> // debug
5
+ #include <string.h>
6
+
7
+ #include "../../utils.h"
8
+
9
+ #include "RISCVMapping.h"
10
+ #include "RISCVInstPrinter.h"
11
+
12
+ #define GET_INSTRINFO_ENUM
13
+ #include "RISCVGenInstrInfo.inc"
14
+
15
+ #ifndef CAPSTONE_DIET
16
+ static const name_map reg_name_maps[] = {
17
+ { RISCV_REG_INVALID, NULL },
18
+
19
+ { RISCV_REG_X0, "zero" },
20
+ { RISCV_REG_X1, "ra" },
21
+ { RISCV_REG_X2, "sp" },
22
+ { RISCV_REG_X3, "gp" },
23
+ { RISCV_REG_X4, "tp" },
24
+ { RISCV_REG_X5, "t0" },
25
+ { RISCV_REG_X6, "t1" },
26
+ { RISCV_REG_X7, "t2" },
27
+ { RISCV_REG_X8, "s0" },
28
+ { RISCV_REG_X9, "s1" },
29
+ { RISCV_REG_X10, "a0" },
30
+ { RISCV_REG_X11, "a1" },
31
+ { RISCV_REG_X12, "a2" },
32
+ { RISCV_REG_X13, "a3" },
33
+ { RISCV_REG_X14, "a4" },
34
+ { RISCV_REG_X15, "a5" },
35
+ { RISCV_REG_X16, "a6" },
36
+ { RISCV_REG_X17, "a7" },
37
+ { RISCV_REG_X18, "s2" },
38
+ { RISCV_REG_X19, "s3" },
39
+ { RISCV_REG_X20, "s4" },
40
+ { RISCV_REG_X21, "s5" },
41
+ { RISCV_REG_X22, "s6" },
42
+ { RISCV_REG_X23, "s7" },
43
+ { RISCV_REG_X24, "s8" },
44
+ { RISCV_REG_X25, "s9" },
45
+ { RISCV_REG_X26, "s10" },
46
+ { RISCV_REG_X27, "s11" },
47
+ { RISCV_REG_X28, "t3" },
48
+ { RISCV_REG_X29, "t4" },
49
+ { RISCV_REG_X30, "t5" },
50
+ { RISCV_REG_X31, "t6" },
51
+
52
+ { RISCV_REG_F0_32, "ft0" },
53
+ { RISCV_REG_F0_64, "ft0" },
54
+ { RISCV_REG_F1_32, "ft1" },
55
+ { RISCV_REG_F1_64, "ft1" },
56
+ { RISCV_REG_F2_32, "ft2" },
57
+ { RISCV_REG_F2_64, "ft2" },
58
+ { RISCV_REG_F3_32, "ft3" },
59
+ { RISCV_REG_F3_64, "ft3" },
60
+ { RISCV_REG_F4_32, "ft4" },
61
+ { RISCV_REG_F4_64, "ft4" },
62
+ { RISCV_REG_F5_32, "ft5" },
63
+ { RISCV_REG_F5_64, "ft5" },
64
+ { RISCV_REG_F6_32, "ft6" },
65
+ { RISCV_REG_F6_64, "ft6" },
66
+ { RISCV_REG_F7_32, "ft7" },
67
+ { RISCV_REG_F7_64, "ft7" },
68
+ { RISCV_REG_F8_32, "fs0" },
69
+ { RISCV_REG_F8_64, "fs0" },
70
+ { RISCV_REG_F9_32, "fs1" },
71
+ { RISCV_REG_F9_64, "fs1" },
72
+ { RISCV_REG_F10_32, "fa0" },
73
+ { RISCV_REG_F10_64, "fa0" },
74
+ { RISCV_REG_F11_32, "fa1" },
75
+ { RISCV_REG_F11_64, "fa1" },
76
+ { RISCV_REG_F12_32, "fa2" },
77
+ { RISCV_REG_F12_64, "fa2" },
78
+ { RISCV_REG_F13_32, "fa3" },
79
+ { RISCV_REG_F13_64, "fa3" },
80
+ { RISCV_REG_F14_32, "fa4" },
81
+ { RISCV_REG_F14_64, "fa4" },
82
+ { RISCV_REG_F15_32, "fa5" },
83
+ { RISCV_REG_F15_64, "fa5" },
84
+ { RISCV_REG_F16_32, "fa6" },
85
+ { RISCV_REG_F16_64, "fa6" },
86
+ { RISCV_REG_F17_32, "fa7" },
87
+ { RISCV_REG_F17_64, "fa7" },
88
+ { RISCV_REG_F18_32, "fs2" },
89
+ { RISCV_REG_F18_64, "fs2" },
90
+ { RISCV_REG_F19_32, "fs3" },
91
+ { RISCV_REG_F19_64, "fs3" },
92
+ { RISCV_REG_F20_32, "fs4" },
93
+ { RISCV_REG_F20_64, "fs4" },
94
+ { RISCV_REG_F21_32, "fs5" },
95
+ { RISCV_REG_F21_64, "fs5" },
96
+ { RISCV_REG_F22_32, "fs6" },
97
+ { RISCV_REG_F22_64, "fs6" },
98
+ { RISCV_REG_F23_32, "fs7" },
99
+ { RISCV_REG_F23_64, "fs7" },
100
+ { RISCV_REG_F24_32, "fs8" },
101
+ { RISCV_REG_F24_64, "fs8" },
102
+ { RISCV_REG_F25_32, "fs9" },
103
+ { RISCV_REG_F25_64, "fs9" },
104
+ { RISCV_REG_F26_32, "fs10" },
105
+ { RISCV_REG_F26_64, "fs10" },
106
+ { RISCV_REG_F27_32, "fs11" },
107
+ { RISCV_REG_F27_64, "fs11" },
108
+ { RISCV_REG_F28_32, "ft8" },
109
+ { RISCV_REG_F28_64, "ft8" },
110
+ { RISCV_REG_F29_32, "ft9" },
111
+ { RISCV_REG_F29_64, "ft9" },
112
+ { RISCV_REG_F30_32, "ft10" },
113
+ { RISCV_REG_F30_64, "ft10" },
114
+ { RISCV_REG_F31_32, "ft11" },
115
+ { RISCV_REG_F31_64, "ft11" },
116
+ };
117
+ #endif
118
+
119
+ const char *RISCV_reg_name(csh handle, unsigned int reg)
120
+ {
121
+ #ifndef CAPSTONE_DIET
122
+ if (reg >= RISCV_REG_ENDING)
123
+ return NULL;
124
+ return reg_name_maps[reg].name;
125
+ #else
126
+ return NULL;
127
+ #endif
128
+ }
129
+
130
+ static const insn_map insns[] = {
131
+ // dummy item
132
+ {
133
+ 0, 0,
134
+ #ifndef CAPSTONE_DIET
135
+ {0}, {0}, {0}, 0, 0
136
+ #endif
137
+ },
138
+
139
+ #include "RISCVMappingInsn.inc"
140
+ };
141
+
142
+ // given internal insn id, return public instruction info
143
+ void RISCV_get_insn_id(cs_struct * h, cs_insn * insn, unsigned int id)
144
+ {
145
+ unsigned int i;
146
+
147
+ i = insn_find(insns, ARR_SIZE(insns), id, &h->insn_cache);
148
+ if (i != 0) {
149
+ insn->id = insns[i].mapid;
150
+
151
+ if (h->detail) {
152
+ #ifndef CAPSTONE_DIET
153
+ memcpy(insn->detail->regs_read,
154
+ insns[i].regs_use, sizeof(insns[i].regs_use));
155
+ insn->detail->regs_read_count = (uint8_t)count_positive(insns[i].regs_use);
156
+
157
+ memcpy(insn->detail->regs_write, insns[i].regs_mod, sizeof(insns[i].regs_mod));
158
+ insn->detail->regs_write_count = (uint8_t)count_positive(insns[i].regs_mod);
159
+
160
+ memcpy(insn->detail->groups, insns[i].groups, sizeof(insns[i].groups));
161
+ insn->detail->groups_count = (uint8_t)count_positive8(insns[i].groups);
162
+
163
+ if (insns[i].branch || insns[i].indirect_branch) {
164
+ // this insn also belongs to JUMP group. add JUMP group
165
+ insn->detail->groups[insn->detail->groups_count] = RISCV_GRP_JUMP;
166
+ insn->detail->groups_count++;
167
+ }
168
+ #endif
169
+ }
170
+ }
171
+ }
172
+
173
+ static const name_map insn_name_maps[] = {
174
+ {RISCV_INS_INVALID, NULL},
175
+
176
+ #include "RISCVGenInsnNameMaps.inc"
177
+ };
178
+
179
+ const char *RISCV_insn_name(csh handle, unsigned int id)
180
+ {
181
+ #ifndef CAPSTONE_DIET
182
+ if (id >= RISCV_INS_ENDING)
183
+ return NULL;
184
+
185
+ return insn_name_maps[id].name;
186
+ #else
187
+ return NULL;
188
+ #endif
189
+ }
190
+
191
+ #ifndef CAPSTONE_DIET
192
+ static const name_map group_name_maps[] = {
193
+ // generic groups
194
+ { RISCV_GRP_INVALID, NULL },
195
+ { RISCV_GRP_JUMP, "jump" },
196
+ { RISCV_GRP_CALL, "call" },
197
+ { RISCV_GRP_RET, "ret" },
198
+ { RISCV_GRP_INT, "int" },
199
+ { RISCV_GRP_IRET, "iret" },
200
+ { RISCV_GRP_PRIVILEGE, "privileged" },
201
+ { RISCV_GRP_BRANCH_RELATIVE, "branch_relative" },
202
+
203
+ // architecture specific
204
+ { RISCV_GRP_ISRV32, "isrv32" },
205
+ { RISCV_GRP_ISRV64, "isrv64" },
206
+ { RISCV_GRP_HASSTDEXTA, "hasStdExtA" },
207
+ { RISCV_GRP_HASSTDEXTC, "hasStdExtC" },
208
+ { RISCV_GRP_HASSTDEXTD, "hasStdExtD" },
209
+ { RISCV_GRP_HASSTDEXTF, "hasStdExtF" },
210
+ { RISCV_GRP_HASSTDEXTM, "hasStdExtM" },
211
+
212
+ /*
213
+ { RISCV_GRP_ISRVA, "isrva" },
214
+ { RISCV_GRP_ISRVC, "isrvc" },
215
+ { RISCV_GRP_ISRVD, "isrvd" },
216
+ { RISCV_GRP_ISRVCD, "isrvcd" },
217
+ { RISCV_GRP_ISRVF, "isrvf" },
218
+ { RISCV_GRP_ISRV32C, "isrv32c" },
219
+ { RISCV_GRP_ISRV32CF, "isrv32cf" },
220
+ { RISCV_GRP_ISRVM, "isrvm" },
221
+ { RISCV_GRP_ISRV64A, "isrv64a" },
222
+ { RISCV_GRP_ISRV64C, "isrv64c" },
223
+ { RISCV_GRP_ISRV64D, "isrv64d" },
224
+ { RISCV_GRP_ISRV64F, "isrv64f" },
225
+ { RISCV_GRP_ISRV64M, "isrv64m" }
226
+ */
227
+ { RISCV_GRP_ENDING, NULL }
228
+ };
229
+ #endif
230
+
231
+ const char *RISCV_group_name(csh handle, unsigned int id)
232
+ {
233
+ #ifndef CAPSTONE_DIET
234
+ // verify group id
235
+ if (id >= RISCV_GRP_ENDING ||
236
+ (id > RISCV_GRP_BRANCH_RELATIVE && id < RISCV_GRP_ISRV32))
237
+ return NULL;
238
+ return id2name(group_name_maps, ARR_SIZE(group_name_maps), id);
239
+ #else
240
+ return NULL;
241
+ #endif
242
+ }
243
+
244
+ // map instruction name to public instruction ID
245
+ riscv_reg RISCV_map_insn(const char *name)
246
+ {
247
+ // handle special alias first
248
+ unsigned int i;
249
+
250
+ // NOTE: skip first NULL name in insn_name_maps
251
+ i = name2id(&insn_name_maps[1], ARR_SIZE(insn_name_maps) - 1, name);
252
+
253
+ return (i != -1) ? i : RISCV_REG_INVALID;
254
+ }
255
+
256
+ // map internal raw register to 'public' register
257
+ riscv_reg RISCV_map_register(unsigned int r)
258
+ {
259
+ static const unsigned int map[] = { 0,
260
+ RISCV_REG_X0,
261
+ RISCV_REG_X1,
262
+ RISCV_REG_X2,
263
+ RISCV_REG_X3,
264
+ RISCV_REG_X4,
265
+ RISCV_REG_X5,
266
+ RISCV_REG_X6,
267
+ RISCV_REG_X7,
268
+ RISCV_REG_X8,
269
+ RISCV_REG_X9,
270
+ RISCV_REG_X10,
271
+ RISCV_REG_X11,
272
+ RISCV_REG_X12,
273
+ RISCV_REG_X13,
274
+ RISCV_REG_X14,
275
+ RISCV_REG_X15,
276
+ RISCV_REG_X16,
277
+ RISCV_REG_X17,
278
+ RISCV_REG_X18,
279
+ RISCV_REG_X19,
280
+ RISCV_REG_X20,
281
+ RISCV_REG_X21,
282
+ RISCV_REG_X22,
283
+ RISCV_REG_X23,
284
+ RISCV_REG_X24,
285
+ RISCV_REG_X25,
286
+ RISCV_REG_X26,
287
+ RISCV_REG_X27,
288
+ RISCV_REG_X28,
289
+ RISCV_REG_X29,
290
+ RISCV_REG_X30,
291
+ RISCV_REG_X31,
292
+
293
+ RISCV_REG_F0_32,
294
+ RISCV_REG_F0_64,
295
+ RISCV_REG_F1_32,
296
+ RISCV_REG_F1_64,
297
+ RISCV_REG_F2_32,
298
+ RISCV_REG_F2_64,
299
+ RISCV_REG_F3_32,
300
+ RISCV_REG_F3_64,
301
+ RISCV_REG_F4_32,
302
+ RISCV_REG_F4_64,
303
+ RISCV_REG_F5_32,
304
+ RISCV_REG_F5_64,
305
+ RISCV_REG_F6_32,
306
+ RISCV_REG_F6_64,
307
+ RISCV_REG_F7_32,
308
+ RISCV_REG_F7_64,
309
+ RISCV_REG_F8_32,
310
+ RISCV_REG_F8_64,
311
+ RISCV_REG_F9_32,
312
+ RISCV_REG_F9_64,
313
+ RISCV_REG_F10_32,
314
+ RISCV_REG_F10_64,
315
+ RISCV_REG_F11_32,
316
+ RISCV_REG_F11_64,
317
+ RISCV_REG_F12_32,
318
+ RISCV_REG_F12_64,
319
+ RISCV_REG_F13_32,
320
+ RISCV_REG_F13_64,
321
+ RISCV_REG_F14_32,
322
+ RISCV_REG_F14_64,
323
+ RISCV_REG_F15_32,
324
+ RISCV_REG_F15_64,
325
+ RISCV_REG_F16_32,
326
+ RISCV_REG_F16_64,
327
+ RISCV_REG_F17_32,
328
+ RISCV_REG_F17_64,
329
+ RISCV_REG_F18_32,
330
+ RISCV_REG_F18_64,
331
+ RISCV_REG_F19_32,
332
+ RISCV_REG_F19_64,
333
+ RISCV_REG_F20_32,
334
+ RISCV_REG_F20_64,
335
+ RISCV_REG_F21_32,
336
+ RISCV_REG_F21_64,
337
+ RISCV_REG_F22_32,
338
+ RISCV_REG_F22_64,
339
+ RISCV_REG_F23_32,
340
+ RISCV_REG_F23_64,
341
+ RISCV_REG_F24_32,
342
+ RISCV_REG_F24_64,
343
+ RISCV_REG_F25_32,
344
+ RISCV_REG_F25_64,
345
+ RISCV_REG_F26_32,
346
+ RISCV_REG_F26_64,
347
+ RISCV_REG_F27_32,
348
+ RISCV_REG_F27_64,
349
+ RISCV_REG_F28_32,
350
+ RISCV_REG_F28_64,
351
+ RISCV_REG_F29_32,
352
+ RISCV_REG_F29_64,
353
+ RISCV_REG_F30_32,
354
+ RISCV_REG_F30_64,
355
+ RISCV_REG_F31_32,
356
+ RISCV_REG_F31_64,
357
+ };
358
+
359
+ if (r < ARR_SIZE(map))
360
+ return map[r];
361
+
362
+ // cannot find this register
363
+ return 0;
364
+ }
365
+
366
+ #endif
@@ -0,0 +1,22 @@
1
+
2
+ #ifndef CS_RISCV_MAP_H
3
+ #define CS_RISCV_MAP_H
4
+
5
+ #include "../../include/capstone/capstone.h"
6
+
7
+ // given internal insn id, return public instruction info
8
+ void RISCV_get_insn_id(cs_struct * h, cs_insn * insn, unsigned int id);
9
+
10
+ const char *RISCV_insn_name(csh handle, unsigned int id);
11
+
12
+ const char *RISCV_group_name(csh handle, unsigned int id);
13
+
14
+ const char *RISCV_reg_name(csh handle, unsigned int reg);
15
+
16
+ // map instruction name to instruction ID
17
+ riscv_reg RISCV_map_insn(const char *name);
18
+
19
+ // map internal raw register to 'public' register
20
+ riscv_reg RISCV_map_register(unsigned int r);
21
+
22
+ #endif