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,446 @@
1
+ //===-- SparcInstPrinter.cpp - Convert Sparc MCInst to assembly syntax --------===//
2
+ //
3
+ // The LLVM Compiler Infrastructure
4
+ //
5
+ // This file is distributed under the University of Illinois Open Source
6
+ // License. See LICENSE.TXT for details.
7
+ //
8
+ //===----------------------------------------------------------------------===//
9
+ //
10
+ // This class prints an Sparc MCInst to a .s file.
11
+ //
12
+ //===----------------------------------------------------------------------===//
13
+
14
+ /* Capstone Disassembly Engine */
15
+ /* By Nguyen Anh Quynh <aquynh@gmail.com>, 2013-2015 */
16
+
17
+ #ifdef CAPSTONE_HAS_SPARC
18
+
19
+ #ifdef _MSC_VER
20
+ #define _CRT_SECURE_NO_WARNINGS
21
+ #endif
22
+
23
+ #include <stdio.h>
24
+ #include <stdlib.h>
25
+ #include <string.h>
26
+ #include <limits.h>
27
+
28
+ #include "SparcInstPrinter.h"
29
+ #include "../../MCInst.h"
30
+ #include "../../utils.h"
31
+ #include "../../SStream.h"
32
+ #include "../../MCRegisterInfo.h"
33
+ #include "../../MathExtras.h"
34
+ #include "SparcMapping.h"
35
+
36
+ #include "Sparc.h"
37
+
38
+ static const char *getRegisterName(unsigned RegNo);
39
+ static void printInstruction(MCInst *MI, SStream *O, const MCRegisterInfo *MRI);
40
+ static void printMemOperand(MCInst *MI, int opNum, SStream *O, const char *Modifier);
41
+ static void printOperand(MCInst *MI, int opNum, SStream *O);
42
+
43
+ static void Sparc_add_hint(MCInst *MI, unsigned int hint)
44
+ {
45
+ if (MI->csh->detail) {
46
+ MI->flat_insn->detail->sparc.hint = hint;
47
+ }
48
+ }
49
+
50
+ static void Sparc_add_reg(MCInst *MI, unsigned int reg)
51
+ {
52
+ if (MI->csh->detail) {
53
+ MI->flat_insn->detail->sparc.operands[MI->flat_insn->detail->sparc.op_count].type = SPARC_OP_REG;
54
+ MI->flat_insn->detail->sparc.operands[MI->flat_insn->detail->sparc.op_count].reg = reg;
55
+ MI->flat_insn->detail->sparc.op_count++;
56
+ }
57
+ }
58
+
59
+ static void set_mem_access(MCInst *MI, bool status)
60
+ {
61
+ if (MI->csh->detail != CS_OPT_ON)
62
+ return;
63
+
64
+ MI->csh->doing_mem = status;
65
+
66
+ if (status) {
67
+ MI->flat_insn->detail->sparc.operands[MI->flat_insn->detail->sparc.op_count].type = SPARC_OP_MEM;
68
+ MI->flat_insn->detail->sparc.operands[MI->flat_insn->detail->sparc.op_count].mem.base = SPARC_REG_INVALID;
69
+ MI->flat_insn->detail->sparc.operands[MI->flat_insn->detail->sparc.op_count].mem.disp = 0;
70
+ } else {
71
+ // done, create the next operand slot
72
+ MI->flat_insn->detail->sparc.op_count++;
73
+ }
74
+ }
75
+
76
+ void Sparc_post_printer(csh ud, cs_insn *insn, char *insn_asm, MCInst *mci)
77
+ {
78
+ if (((cs_struct *)ud)->detail != CS_OPT_ON)
79
+ return;
80
+
81
+ // fix up some instructions
82
+ if (insn->id == SPARC_INS_CASX) {
83
+ // first op is actually a memop, not regop
84
+ insn->detail->sparc.operands[0].type = SPARC_OP_MEM;
85
+ insn->detail->sparc.operands[0].mem.base = (uint8_t)insn->detail->sparc.operands[0].reg;
86
+ insn->detail->sparc.operands[0].mem.disp = 0;
87
+ }
88
+ }
89
+
90
+ static void printRegName(SStream *OS, unsigned RegNo)
91
+ {
92
+ SStream_concat0(OS, "%");
93
+ SStream_concat0(OS, getRegisterName(RegNo));
94
+ }
95
+
96
+ #define GET_INSTRINFO_ENUM
97
+ #include "SparcGenInstrInfo.inc"
98
+
99
+ #define GET_REGINFO_ENUM
100
+ #include "SparcGenRegisterInfo.inc"
101
+
102
+ static bool printSparcAliasInstr(MCInst *MI, SStream *O)
103
+ {
104
+ switch (MCInst_getOpcode(MI)) {
105
+ default: return false;
106
+ case SP_JMPLrr:
107
+ case SP_JMPLri:
108
+ if (MCInst_getNumOperands(MI) != 3)
109
+ return false;
110
+ if (!MCOperand_isReg(MCInst_getOperand(MI, 0)))
111
+ return false;
112
+
113
+ switch (MCOperand_getReg(MCInst_getOperand(MI, 0))) {
114
+ default: return false;
115
+ case SP_G0: // jmp $addr | ret | retl
116
+ if (MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
117
+ MCOperand_getImm(MCInst_getOperand(MI, 2)) == 8) {
118
+ switch(MCOperand_getReg(MCInst_getOperand(MI, 1))) {
119
+ default: break;
120
+ case SP_I7: SStream_concat0(O, "ret"); MCInst_setOpcodePub(MI, SPARC_INS_RET); return true;
121
+ case SP_O7: SStream_concat0(O, "retl"); MCInst_setOpcodePub(MI, SPARC_INS_RETL); return true;
122
+ }
123
+ }
124
+
125
+ SStream_concat0(O, "jmp\t");
126
+ MCInst_setOpcodePub(MI, SPARC_INS_JMP);
127
+ printMemOperand(MI, 1, O, NULL);
128
+ return true;
129
+ case SP_O7: // call $addr
130
+ SStream_concat0(O, "call ");
131
+ MCInst_setOpcodePub(MI, SPARC_INS_CALL);
132
+ printMemOperand(MI, 1, O, NULL);
133
+ return true;
134
+ }
135
+ case SP_V9FCMPS:
136
+ case SP_V9FCMPD:
137
+ case SP_V9FCMPQ:
138
+ case SP_V9FCMPES:
139
+ case SP_V9FCMPED:
140
+ case SP_V9FCMPEQ:
141
+ if (MI->csh->mode & CS_MODE_V9 || (MCInst_getNumOperands(MI) != 3) ||
142
+ (!MCOperand_isReg(MCInst_getOperand(MI, 0))) ||
143
+ (MCOperand_getReg(MCInst_getOperand(MI, 0)) != SP_FCC0))
144
+ return false;
145
+ // if V8, skip printing %fcc0.
146
+ switch(MCInst_getOpcode(MI)) {
147
+ default:
148
+ case SP_V9FCMPS: SStream_concat0(O, "fcmps\t"); MCInst_setOpcodePub(MI, SPARC_INS_FCMPS); break;
149
+ case SP_V9FCMPD: SStream_concat0(O, "fcmpd\t"); MCInst_setOpcodePub(MI, SPARC_INS_FCMPD); break;
150
+ case SP_V9FCMPQ: SStream_concat0(O, "fcmpq\t"); MCInst_setOpcodePub(MI, SPARC_INS_FCMPQ); break;
151
+ case SP_V9FCMPES: SStream_concat0(O, "fcmpes\t"); MCInst_setOpcodePub(MI, SPARC_INS_FCMPES); break;
152
+ case SP_V9FCMPED: SStream_concat0(O, "fcmped\t"); MCInst_setOpcodePub(MI, SPARC_INS_FCMPED); break;
153
+ case SP_V9FCMPEQ: SStream_concat0(O, "fcmpeq\t"); MCInst_setOpcodePub(MI, SPARC_INS_FCMPEQ); break;
154
+ }
155
+ printOperand(MI, 1, O);
156
+ SStream_concat0(O, ", ");
157
+ printOperand(MI, 2, O);
158
+ return true;
159
+ }
160
+ }
161
+
162
+ static void printOperand(MCInst *MI, int opNum, SStream *O)
163
+ {
164
+ int64_t Imm;
165
+ unsigned reg;
166
+ MCOperand *MO = MCInst_getOperand(MI, opNum);
167
+
168
+ if (MCOperand_isReg(MO)) {
169
+ reg = MCOperand_getReg(MO);
170
+ printRegName(O, reg);
171
+ reg = Sparc_map_register(reg);
172
+
173
+ if (MI->csh->detail) {
174
+ if (MI->csh->doing_mem) {
175
+ if (MI->flat_insn->detail->sparc.operands[MI->flat_insn->detail->sparc.op_count].mem.base)
176
+ MI->flat_insn->detail->sparc.operands[MI->flat_insn->detail->sparc.op_count].mem.index = (uint8_t)reg;
177
+ else
178
+ MI->flat_insn->detail->sparc.operands[MI->flat_insn->detail->sparc.op_count].mem.base = (uint8_t)reg;
179
+ } else {
180
+ MI->flat_insn->detail->sparc.operands[MI->flat_insn->detail->sparc.op_count].type = SPARC_OP_REG;
181
+ MI->flat_insn->detail->sparc.operands[MI->flat_insn->detail->sparc.op_count].reg = reg;
182
+ MI->flat_insn->detail->sparc.op_count++;
183
+ }
184
+ }
185
+
186
+ return;
187
+ }
188
+
189
+ if (MCOperand_isImm(MO)) {
190
+ Imm = (int)MCOperand_getImm(MO);
191
+
192
+ // Conditional branches displacements needs to be signextended to be
193
+ // able to jump backwards.
194
+ //
195
+ // Displacements are measured as the number of instructions forward or
196
+ // backward, so they need to be multiplied by 4
197
+ switch (MI->Opcode) {
198
+ case SP_CALL:
199
+ // Imm = SignExtend32(Imm, 30);
200
+ Imm += MI->address;
201
+ break;
202
+
203
+ // Branch on integer condition with prediction (BPcc)
204
+ // Branch on floating point condition with prediction (FBPfcc)
205
+ case SP_BPICC:
206
+ case SP_BPICCA:
207
+ case SP_BPICCANT:
208
+ case SP_BPICCNT:
209
+ case SP_BPXCC:
210
+ case SP_BPXCCA:
211
+ case SP_BPXCCANT:
212
+ case SP_BPXCCNT:
213
+ case SP_BPFCC:
214
+ case SP_BPFCCA:
215
+ case SP_BPFCCANT:
216
+ case SP_BPFCCNT:
217
+ Imm = SignExtend32(Imm, 19);
218
+ Imm = MI->address + Imm * 4;
219
+ break;
220
+
221
+ // Branch on integer condition (Bicc)
222
+ // Branch on floating point condition (FBfcc)
223
+ case SP_BA:
224
+ case SP_BCOND:
225
+ case SP_BCONDA:
226
+ case SP_FBCOND:
227
+ case SP_FBCONDA:
228
+ Imm = SignExtend32(Imm, 22);
229
+ Imm = MI->address + Imm * 4;
230
+ break;
231
+
232
+ // Branch on integer register with prediction (BPr)
233
+ case SP_BPGEZapn:
234
+ case SP_BPGEZapt:
235
+ case SP_BPGEZnapn:
236
+ case SP_BPGEZnapt:
237
+ case SP_BPGZapn:
238
+ case SP_BPGZapt:
239
+ case SP_BPGZnapn:
240
+ case SP_BPGZnapt:
241
+ case SP_BPLEZapn:
242
+ case SP_BPLEZapt:
243
+ case SP_BPLEZnapn:
244
+ case SP_BPLEZnapt:
245
+ case SP_BPLZapn:
246
+ case SP_BPLZapt:
247
+ case SP_BPLZnapn:
248
+ case SP_BPLZnapt:
249
+ case SP_BPNZapn:
250
+ case SP_BPNZapt:
251
+ case SP_BPNZnapn:
252
+ case SP_BPNZnapt:
253
+ case SP_BPZapn:
254
+ case SP_BPZapt:
255
+ case SP_BPZnapn:
256
+ case SP_BPZnapt:
257
+ Imm = SignExtend32(Imm, 16);
258
+ Imm = MI->address + Imm * 4;
259
+ break;
260
+ }
261
+
262
+ printInt64(O, Imm);
263
+
264
+ if (MI->csh->detail) {
265
+ if (MI->csh->doing_mem) {
266
+ MI->flat_insn->detail->sparc.operands[MI->flat_insn->detail->sparc.op_count].mem.disp = Imm;
267
+ } else {
268
+ MI->flat_insn->detail->sparc.operands[MI->flat_insn->detail->sparc.op_count].type = SPARC_OP_IMM;
269
+ MI->flat_insn->detail->sparc.operands[MI->flat_insn->detail->sparc.op_count].imm = Imm;
270
+ MI->flat_insn->detail->sparc.op_count++;
271
+ }
272
+ }
273
+ }
274
+
275
+ return;
276
+ }
277
+
278
+ static void printMemOperand(MCInst *MI, int opNum, SStream *O, const char *Modifier)
279
+ {
280
+ MCOperand *MO;
281
+
282
+ set_mem_access(MI, true);
283
+ printOperand(MI, opNum, O);
284
+
285
+ // If this is an ADD operand, emit it like normal operands.
286
+ if (Modifier && !strcmp(Modifier, "arith")) {
287
+ SStream_concat0(O, ", ");
288
+ printOperand(MI, opNum + 1, O);
289
+ set_mem_access(MI, false);
290
+ return;
291
+ }
292
+
293
+ MO = MCInst_getOperand(MI, opNum + 1);
294
+
295
+ if (MCOperand_isReg(MO) && (MCOperand_getReg(MO) == SP_G0)) {
296
+ set_mem_access(MI, false);
297
+ return; // don't print "+%g0"
298
+ }
299
+
300
+ if (MCOperand_isImm(MO) && (MCOperand_getImm(MO) == 0)) {
301
+ set_mem_access(MI, false);
302
+ return; // don't print "+0"
303
+ }
304
+
305
+ SStream_concat0(O, "+"); // qq
306
+
307
+ printOperand(MI, opNum + 1, O);
308
+ set_mem_access(MI, false);
309
+ }
310
+
311
+ static void printCCOperand(MCInst *MI, int opNum, SStream *O)
312
+ {
313
+ int CC = (int)MCOperand_getImm(MCInst_getOperand(MI, opNum)) + 256;
314
+
315
+ switch (MCInst_getOpcode(MI)) {
316
+ default: break;
317
+ case SP_FBCOND:
318
+ case SP_FBCONDA:
319
+ case SP_BPFCC:
320
+ case SP_BPFCCA:
321
+ case SP_BPFCCNT:
322
+ case SP_BPFCCANT:
323
+ case SP_MOVFCCrr: case SP_V9MOVFCCrr:
324
+ case SP_MOVFCCri: case SP_V9MOVFCCri:
325
+ case SP_FMOVS_FCC: case SP_V9FMOVS_FCC:
326
+ case SP_FMOVD_FCC: case SP_V9FMOVD_FCC:
327
+ case SP_FMOVQ_FCC: case SP_V9FMOVQ_FCC:
328
+ // Make sure CC is a fp conditional flag.
329
+ CC = (CC < 16+256) ? (CC + 16) : CC;
330
+ break;
331
+ }
332
+
333
+ SStream_concat0(O, SPARCCondCodeToString((sparc_cc)CC));
334
+
335
+ if (MI->csh->detail)
336
+ MI->flat_insn->detail->sparc.cc = (sparc_cc)CC;
337
+ }
338
+
339
+
340
+ static bool printGetPCX(MCInst *MI, unsigned opNum, SStream *O)
341
+ {
342
+ return true;
343
+ }
344
+
345
+
346
+ #define PRINT_ALIAS_INSTR
347
+ #include "SparcGenAsmWriter.inc"
348
+
349
+ void Sparc_printInst(MCInst *MI, SStream *O, void *Info)
350
+ {
351
+ char *mnem, *p;
352
+ char instr[64]; // Sparc has no instruction this long
353
+
354
+ mnem = printAliasInstr(MI, O, Info);
355
+ if (mnem) {
356
+ // fixup instruction id due to the change in alias instruction
357
+ unsigned cpy_len = sizeof(instr) - 1 < strlen(mnem) ? sizeof(instr) - 1 : strlen(mnem);
358
+ memcpy(instr, mnem, cpy_len);
359
+ instr[cpy_len] = '\0';
360
+ // does this contains hint with a coma?
361
+ p = strchr(instr, ',');
362
+ if (p)
363
+ *p = '\0'; // now instr only has instruction mnemonic
364
+ MCInst_setOpcodePub(MI, Sparc_map_insn(instr));
365
+ switch(MCInst_getOpcode(MI)) {
366
+ case SP_BCOND:
367
+ case SP_BCONDA:
368
+ case SP_BPICCANT:
369
+ case SP_BPICCNT:
370
+ case SP_BPXCCANT:
371
+ case SP_BPXCCNT:
372
+ case SP_TXCCri:
373
+ case SP_TXCCrr:
374
+ if (MI->csh->detail) {
375
+ // skip 'b', 't'
376
+ MI->flat_insn->detail->sparc.cc = Sparc_map_ICC(instr + 1);
377
+ MI->flat_insn->detail->sparc.hint = Sparc_map_hint(mnem);
378
+ }
379
+ break;
380
+ case SP_BPFCCANT:
381
+ case SP_BPFCCNT:
382
+ if (MI->csh->detail) {
383
+ // skip 'fb'
384
+ MI->flat_insn->detail->sparc.cc = Sparc_map_FCC(instr + 2);
385
+ MI->flat_insn->detail->sparc.hint = Sparc_map_hint(mnem);
386
+ }
387
+ break;
388
+ case SP_FMOVD_ICC:
389
+ case SP_FMOVD_XCC:
390
+ case SP_FMOVQ_ICC:
391
+ case SP_FMOVQ_XCC:
392
+ case SP_FMOVS_ICC:
393
+ case SP_FMOVS_XCC:
394
+ if (MI->csh->detail) {
395
+ // skip 'fmovd', 'fmovq', 'fmovs'
396
+ MI->flat_insn->detail->sparc.cc = Sparc_map_ICC(instr + 5);
397
+ MI->flat_insn->detail->sparc.hint = Sparc_map_hint(mnem);
398
+ }
399
+ break;
400
+ case SP_MOVICCri:
401
+ case SP_MOVICCrr:
402
+ case SP_MOVXCCri:
403
+ case SP_MOVXCCrr:
404
+ if (MI->csh->detail) {
405
+ // skip 'mov'
406
+ MI->flat_insn->detail->sparc.cc = Sparc_map_ICC(instr + 3);
407
+ MI->flat_insn->detail->sparc.hint = Sparc_map_hint(mnem);
408
+ }
409
+ break;
410
+ case SP_V9FMOVD_FCC:
411
+ case SP_V9FMOVQ_FCC:
412
+ case SP_V9FMOVS_FCC:
413
+ if (MI->csh->detail) {
414
+ // skip 'fmovd', 'fmovq', 'fmovs'
415
+ MI->flat_insn->detail->sparc.cc = Sparc_map_FCC(instr + 5);
416
+ MI->flat_insn->detail->sparc.hint = Sparc_map_hint(mnem);
417
+ }
418
+ break;
419
+ case SP_V9MOVFCCri:
420
+ case SP_V9MOVFCCrr:
421
+ if (MI->csh->detail) {
422
+ // skip 'mov'
423
+ MI->flat_insn->detail->sparc.cc = Sparc_map_FCC(instr + 3);
424
+ MI->flat_insn->detail->sparc.hint = Sparc_map_hint(mnem);
425
+ }
426
+ break;
427
+ default:
428
+ break;
429
+ }
430
+ cs_mem_free(mnem);
431
+ } else {
432
+ if (!printSparcAliasInstr(MI, O))
433
+ printInstruction(MI, O, NULL);
434
+ }
435
+ }
436
+
437
+ void Sparc_addReg(MCInst *MI, int reg)
438
+ {
439
+ if (MI->csh->detail) {
440
+ MI->flat_insn->detail->sparc.operands[MI->flat_insn->detail->sparc.op_count].type = SPARC_OP_REG;
441
+ MI->flat_insn->detail->sparc.operands[MI->flat_insn->detail->sparc.op_count].reg = reg;
442
+ MI->flat_insn->detail->sparc.op_count++;
443
+ }
444
+ }
445
+
446
+ #endif
@@ -0,0 +1,17 @@
1
+ /* Capstone Disassembly Engine */
2
+ /* By Nguyen Anh Quynh <aquynh@gmail.com>, 2013-2015 */
3
+
4
+ #ifndef CS_SPARCINSTPRINTER_H
5
+ #define CS_SPARCINSTPRINTER_H
6
+
7
+ #include "../../MCInst.h"
8
+ #include "../../MCRegisterInfo.h"
9
+ #include "../../SStream.h"
10
+
11
+ void Sparc_printInst(MCInst *MI, SStream *O, void *Info);
12
+
13
+ void Sparc_post_printer(csh ud, cs_insn *insn, char *insn_asm, MCInst *mci);
14
+
15
+ void Sparc_addReg(MCInst *MI, int reg);
16
+
17
+ #endif