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,335 @@
1
+ {1, 1, X86_AAD8i8},
2
+ {1, 1, X86_AAM8i8},
3
+ {2, 2, X86_ADC16i16},
4
+ {2, 2, X86_ADC16mi},
5
+ {1, 2, X86_ADC16mi8},
6
+ {2, 2, X86_ADC16ri},
7
+ {1, 2, X86_ADC16ri8},
8
+ {4, 4, X86_ADC32i32},
9
+ {4, 4, X86_ADC32mi},
10
+ {1, 4, X86_ADC32mi8},
11
+ {4, 4, X86_ADC32ri},
12
+ {1, 4, X86_ADC32ri8},
13
+ {4, 8, X86_ADC64i32},
14
+ {4, 8, X86_ADC64mi32},
15
+ {1, 8, X86_ADC64mi8},
16
+ {4, 8, X86_ADC64ri32},
17
+ {1, 8, X86_ADC64ri8},
18
+ {1, 1, X86_ADC8i8},
19
+ {1, 1, X86_ADC8mi},
20
+ {1, 1, X86_ADC8mi8},
21
+ {1, 1, X86_ADC8ri},
22
+ {1, 1, X86_ADC8ri8},
23
+ {2, 2, X86_ADD16i16},
24
+ {2, 2, X86_ADD16mi},
25
+ {1, 2, X86_ADD16mi8},
26
+ {2, 2, X86_ADD16ri},
27
+ {1, 2, X86_ADD16ri8},
28
+ {4, 4, X86_ADD32i32},
29
+ {4, 4, X86_ADD32mi},
30
+ {1, 4, X86_ADD32mi8},
31
+ {4, 4, X86_ADD32ri},
32
+ {1, 4, X86_ADD32ri8},
33
+ {4, 8, X86_ADD64i32},
34
+ {4, 8, X86_ADD64mi32},
35
+ {1, 8, X86_ADD64mi8},
36
+ {4, 8, X86_ADD64ri32},
37
+ {1, 8, X86_ADD64ri8},
38
+ {1, 1, X86_ADD8i8},
39
+ {1, 1, X86_ADD8mi},
40
+ {1, 1, X86_ADD8mi8},
41
+ {1, 1, X86_ADD8ri},
42
+ {1, 1, X86_ADD8ri8},
43
+ {2, 2, X86_AND16i16},
44
+ {2, 2, X86_AND16mi},
45
+ {1, 2, X86_AND16mi8},
46
+ {2, 2, X86_AND16ri},
47
+ {1, 2, X86_AND16ri8},
48
+ {4, 4, X86_AND32i32},
49
+ {4, 4, X86_AND32mi},
50
+ {1, 4, X86_AND32mi8},
51
+ {4, 4, X86_AND32ri},
52
+ {1, 4, X86_AND32ri8},
53
+ {4, 8, X86_AND64i32},
54
+ {4, 8, X86_AND64mi32},
55
+ {1, 8, X86_AND64mi8},
56
+ {4, 8, X86_AND64ri32},
57
+ {1, 8, X86_AND64ri8},
58
+ {1, 1, X86_AND8i8},
59
+ {1, 1, X86_AND8mi},
60
+ {1, 1, X86_AND8mi8},
61
+ {1, 1, X86_AND8ri},
62
+ {1, 1, X86_AND8ri8},
63
+ {1, 1, X86_BT16mi8},
64
+ {1, 1, X86_BT16ri8},
65
+ {1, 1, X86_BT32mi8},
66
+ {1, 1, X86_BT32ri8},
67
+ {1, 1, X86_BT64mi8},
68
+ {1, 1, X86_BT64ri8},
69
+ {1, 1, X86_BTC16mi8},
70
+ {1, 1, X86_BTC16ri8},
71
+ {1, 1, X86_BTC32mi8},
72
+ {1, 1, X86_BTC32ri8},
73
+ {1, 1, X86_BTC64mi8},
74
+ {1, 1, X86_BTC64ri8},
75
+ {1, 1, X86_BTR16mi8},
76
+ {1, 1, X86_BTR16ri8},
77
+ {1, 1, X86_BTR32mi8},
78
+ {1, 1, X86_BTR32ri8},
79
+ {1, 1, X86_BTR64mi8},
80
+ {1, 1, X86_BTR64ri8},
81
+ {1, 1, X86_BTS16mi8},
82
+ {1, 1, X86_BTS16ri8},
83
+ {1, 1, X86_BTS32mi8},
84
+ {1, 1, X86_BTS32ri8},
85
+ {1, 1, X86_BTS64mi8},
86
+ {1, 1, X86_BTS64ri8},
87
+ {2, 2, X86_CALLpcrel16},
88
+ {2, 4, X86_CALLpcrel32},
89
+ {2, 2, X86_CMP16i16},
90
+ {2, 2, X86_CMP16mi},
91
+ {1, 2, X86_CMP16mi8},
92
+ {2, 2, X86_CMP16ri},
93
+ {1, 2, X86_CMP16ri8},
94
+ {4, 4, X86_CMP32i32},
95
+ {4, 4, X86_CMP32mi},
96
+ {1, 4, X86_CMP32mi8},
97
+ {4, 4, X86_CMP32ri},
98
+ {1, 4, X86_CMP32ri8},
99
+ {4, 8, X86_CMP64i32},
100
+ {4, 8, X86_CMP64mi32},
101
+ {1, 8, X86_CMP64mi8},
102
+ {4, 8, X86_CMP64ri32},
103
+ {1, 8, X86_CMP64ri8},
104
+ {1, 1, X86_CMP8i8},
105
+ {1, 1, X86_CMP8mi},
106
+ {1, 1, X86_CMP8mi8},
107
+ {1, 1, X86_CMP8ri},
108
+ {1, 1, X86_CMP8ri8},
109
+ {1, 2, X86_IMUL16rmi8},
110
+ {1, 2, X86_IMUL16rri8},
111
+ {1, 4, X86_IMUL32rmi8},
112
+ {1, 4, X86_IMUL32rri8},
113
+ {4, 8, X86_IMUL64rmi32},
114
+ {1, 8, X86_IMUL64rmi8},
115
+ {4, 8, X86_IMUL64rri32},
116
+ {1, 8, X86_IMUL64rri8},
117
+ {2, 2, X86_IN16ri},
118
+ {4, 4, X86_IN32ri},
119
+ {1, 1, X86_IN8ri},
120
+ {2, 2, X86_JMP_2},
121
+ {2, 2, X86_MOV16mi},
122
+ {2, 2, X86_MOV16ri},
123
+ {2, 2, X86_MOV16ri_alt},
124
+ {4, 4, X86_MOV32mi},
125
+ {4, 4, X86_MOV32ri},
126
+ {4, 4, X86_MOV32ri_alt},
127
+ {4, 8, X86_MOV64mi32},
128
+ {8, 8, X86_MOV64ri},
129
+ {4, 8, X86_MOV64ri32},
130
+ {1, 1, X86_MOV8mi},
131
+ {1, 1, X86_MOV8ri},
132
+ {1, 1, X86_MOV8ri_alt},
133
+ {2, 2, X86_OR16i16},
134
+ {2, 2, X86_OR16mi},
135
+ {1, 2, X86_OR16mi8},
136
+ {2, 2, X86_OR16ri},
137
+ {1, 2, X86_OR16ri8},
138
+ {4, 4, X86_OR32i32},
139
+ {4, 4, X86_OR32mi},
140
+ {1, 4, X86_OR32mi8},
141
+ {4, 4, X86_OR32ri},
142
+ {1, 4, X86_OR32ri8},
143
+ {4, 8, X86_OR64i32},
144
+ {4, 8, X86_OR64mi32},
145
+ {1, 8, X86_OR64mi8},
146
+ {4, 8, X86_OR64ri32},
147
+ {1, 8, X86_OR64ri8},
148
+ {1, 1, X86_OR8i8},
149
+ {1, 1, X86_OR8mi},
150
+ {1, 1, X86_OR8mi8},
151
+ {1, 1, X86_OR8ri},
152
+ {1, 1, X86_OR8ri8},
153
+ {1, 2, X86_PUSH16i8},
154
+ {1, 4, X86_PUSH32i8},
155
+ {4, 8, X86_PUSH64i32},
156
+ {1, 8, X86_PUSH64i8},
157
+ {2, 2, X86_PUSHi16},
158
+ {4, 4, X86_PUSHi32},
159
+ {1, 1, X86_RCL16mi},
160
+ {1, 1, X86_RCL16ri},
161
+ {1, 1, X86_RCL32mi},
162
+ {1, 1, X86_RCL32ri},
163
+ {1, 1, X86_RCL64mi},
164
+ {1, 1, X86_RCL64ri},
165
+ {1, 1, X86_RCL8mi},
166
+ {1, 1, X86_RCL8ri},
167
+ {1, 1, X86_RCR16mi},
168
+ {1, 1, X86_RCR16ri},
169
+ {1, 1, X86_RCR32mi},
170
+ {1, 1, X86_RCR32ri},
171
+ {1, 1, X86_RCR64mi},
172
+ {1, 1, X86_RCR64ri},
173
+ {1, 1, X86_RCR8mi},
174
+ {1, 1, X86_RCR8ri},
175
+ //{4, 4, X86_RELEASE_ADD32mi},
176
+ //{4, 8, X86_RELEASE_ADD64mi32},
177
+ //{1, 1, X86_RELEASE_ADD8mi},
178
+ //{4, 4, X86_RELEASE_AND32mi},
179
+ //{4, 8, X86_RELEASE_AND64mi32},
180
+ //{1, 1, X86_RELEASE_AND8mi},
181
+ //{2, 2, X86_RELEASE_MOV16mi},
182
+ //{4, 4, X86_RELEASE_MOV32mi},
183
+ //{4, 8, X86_RELEASE_MOV64mi32},
184
+ //{1, 1, X86_RELEASE_MOV8mi},
185
+ //{4, 4, X86_RELEASE_OR32mi},
186
+ //{4, 8, X86_RELEASE_OR64mi32},
187
+ //{1, 1, X86_RELEASE_OR8mi},
188
+ //{4, 4, X86_RELEASE_XOR32mi},
189
+ //{4, 8, X86_RELEASE_XOR64mi32},
190
+ //{1, 1, X86_RELEASE_XOR8mi},
191
+ {1, 1, X86_ROL16mi},
192
+ {1, 1, X86_ROL16ri},
193
+ {1, 1, X86_ROL32mi},
194
+ {1, 1, X86_ROL32ri},
195
+ {1, 1, X86_ROL64mi},
196
+ {1, 1, X86_ROL64ri},
197
+ {1, 1, X86_ROL8mi},
198
+ {1, 1, X86_ROL8ri},
199
+ {1, 1, X86_ROR16mi},
200
+ {1, 1, X86_ROR16ri},
201
+ {1, 1, X86_ROR32mi},
202
+ {1, 1, X86_ROR32ri},
203
+ {1, 1, X86_ROR64mi},
204
+ {1, 1, X86_ROR64ri},
205
+ {1, 1, X86_ROR8mi},
206
+ {1, 1, X86_ROR8ri},
207
+ {4, 4, X86_RORX32mi},
208
+ {4, 4, X86_RORX32ri},
209
+ {8, 8, X86_RORX64mi},
210
+ {8, 8, X86_RORX64ri},
211
+ {1, 1, X86_SAL16mi},
212
+ {1, 1, X86_SAL16ri},
213
+ {1, 1, X86_SAL32mi},
214
+ {1, 1, X86_SAL32ri},
215
+ {1, 1, X86_SAL64mi},
216
+ {1, 1, X86_SAL64ri},
217
+ {1, 1, X86_SAL8mi},
218
+ {1, 1, X86_SAL8ri},
219
+ {1, 1, X86_SAR16mi},
220
+ {1, 1, X86_SAR16ri},
221
+ {1, 1, X86_SAR32mi},
222
+ {1, 1, X86_SAR32ri},
223
+ {1, 1, X86_SAR64mi},
224
+ {1, 1, X86_SAR64ri},
225
+ {1, 1, X86_SAR8mi},
226
+ {1, 1, X86_SAR8ri},
227
+ {2, 2, X86_SBB16i16},
228
+ {2, 2, X86_SBB16mi},
229
+ {1, 2, X86_SBB16mi8},
230
+ {2, 2, X86_SBB16ri},
231
+ {1, 2, X86_SBB16ri8},
232
+ {4, 4, X86_SBB32i32},
233
+ {4, 4, X86_SBB32mi},
234
+ {1, 4, X86_SBB32mi8},
235
+ {4, 4, X86_SBB32ri},
236
+ {1, 4, X86_SBB32ri8},
237
+ {4, 8, X86_SBB64i32},
238
+ {4, 8, X86_SBB64mi32},
239
+ {1, 8, X86_SBB64mi8},
240
+ {4, 8, X86_SBB64ri32},
241
+ {1, 8, X86_SBB64ri8},
242
+ {1, 1, X86_SBB8i8},
243
+ {1, 1, X86_SBB8mi},
244
+ {1, 1, X86_SBB8mi8},
245
+ {1, 1, X86_SBB8ri},
246
+ {1, 1, X86_SBB8ri8},
247
+ {1, 1, X86_SHL16mi},
248
+ {1, 1, X86_SHL16ri},
249
+ {1, 1, X86_SHL32mi},
250
+ {1, 1, X86_SHL32ri},
251
+ {1, 1, X86_SHL64mi},
252
+ {1, 1, X86_SHL64ri},
253
+ {1, 1, X86_SHL8mi},
254
+ {1, 1, X86_SHL8ri},
255
+ {1, 1, X86_SHLD16mri8},
256
+ {1, 1, X86_SHLD16rri8},
257
+ {1, 1, X86_SHLD32mri8},
258
+ {1, 1, X86_SHLD32rri8},
259
+ {1, 1, X86_SHLD64mri8},
260
+ {1, 1, X86_SHLD64rri8},
261
+ {1, 1, X86_SHR16mi},
262
+ {1, 1, X86_SHR16ri},
263
+ {1, 1, X86_SHR32mi},
264
+ {1, 1, X86_SHR32ri},
265
+ {1, 1, X86_SHR64mi},
266
+ {1, 1, X86_SHR64ri},
267
+ {1, 1, X86_SHR8mi},
268
+ {1, 1, X86_SHR8ri},
269
+ {1, 1, X86_SHRD16mri8},
270
+ {1, 1, X86_SHRD16rri8},
271
+ {1, 1, X86_SHRD32mri8},
272
+ {1, 1, X86_SHRD32rri8},
273
+ {1, 1, X86_SHRD64mri8},
274
+ {1, 1, X86_SHRD64rri8},
275
+ {2, 2, X86_SUB16i16},
276
+ {2, 2, X86_SUB16mi},
277
+ {1, 2, X86_SUB16mi8},
278
+ {2, 2, X86_SUB16ri},
279
+ {1, 2, X86_SUB16ri8},
280
+ {4, 4, X86_SUB32i32},
281
+ {4, 4, X86_SUB32mi},
282
+ {1, 4, X86_SUB32mi8},
283
+ {4, 4, X86_SUB32ri},
284
+ {1, 4, X86_SUB32ri8},
285
+ {4, 8, X86_SUB64i32},
286
+ {4, 8, X86_SUB64mi32},
287
+ {1, 8, X86_SUB64mi8},
288
+ {4, 8, X86_SUB64ri32},
289
+ {1, 8, X86_SUB64ri8},
290
+ {1, 1, X86_SUB8i8},
291
+ {1, 1, X86_SUB8mi},
292
+ {1, 1, X86_SUB8mi8},
293
+ {1, 1, X86_SUB8ri},
294
+ {1, 1, X86_SUB8ri8},
295
+ {2, 2, X86_TEST16i16},
296
+ {2, 2, X86_TEST16mi},
297
+ // {2, 2, X86_TEST16mi_alt},
298
+ {2, 2, X86_TEST16ri},
299
+ //{2, 2, X86_TEST16ri_alt},
300
+ {4, 4, X86_TEST32i32},
301
+ {4, 4, X86_TEST32mi},
302
+ //{4, 4, X86_TEST32mi_alt},
303
+ {4, 4, X86_TEST32ri},
304
+ //{4, 4, X86_TEST32ri_alt},
305
+ {4, 8, X86_TEST64i32},
306
+ {4, 8, X86_TEST64mi32},
307
+ //{4, 4, X86_TEST64mi32_alt},
308
+ {4, 8, X86_TEST64ri32},
309
+ //{4, 4, X86_TEST64ri32_alt},
310
+ {1, 1, X86_TEST8i8},
311
+ {1, 1, X86_TEST8mi},
312
+ //{1, 1, X86_TEST8mi_alt},
313
+ {1, 1, X86_TEST8ri},
314
+ //{1, 1, X86_TEST8ri_NOREX},
315
+ //{1, 1, X86_TEST8ri_alt},
316
+ {2, 2, X86_XOR16i16},
317
+ {2, 2, X86_XOR16mi},
318
+ {1, 2, X86_XOR16mi8},
319
+ {2, 2, X86_XOR16ri},
320
+ {1, 2, X86_XOR16ri8},
321
+ {4, 4, X86_XOR32i32},
322
+ {4, 4, X86_XOR32mi},
323
+ {1, 4, X86_XOR32mi8},
324
+ {4, 4, X86_XOR32ri},
325
+ {1, 4, X86_XOR32ri8},
326
+ {4, 8, X86_XOR64i32},
327
+ {4, 8, X86_XOR64mi32},
328
+ {1, 8, X86_XOR64mi8},
329
+ {4, 8, X86_XOR64ri32},
330
+ {1, 8, X86_XOR64ri8},
331
+ {1, 1, X86_XOR8i8},
332
+ {1, 1, X86_XOR8mi},
333
+ {1, 1, X86_XOR8mi8},
334
+ {1, 1, X86_XOR8ri},
335
+ {1, 1, X86_XOR8ri8},
@@ -0,0 +1,26 @@
1
+ //= X86IntelInstPrinter.h - Convert X86 MCInst to assembly syntax -*- C++ -*-=//
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 X86 MCInst to Intel style .s file syntax.
11
+ //
12
+ //===----------------------------------------------------------------------===//
13
+
14
+ /* Capstone Disassembly Engine */
15
+ /* By Nguyen Anh Quynh <aquynh@gmail.com>, 2013-2019 */
16
+
17
+ #ifndef CS_X86_INSTPRINTER_H
18
+ #define CS_X86_INSTPRINTER_H
19
+
20
+ #include "../../MCInst.h"
21
+ #include "../../SStream.h"
22
+
23
+ void X86_Intel_printInst(MCInst *MI, SStream *OS, void *Info);
24
+ void X86_ATT_printInst(MCInst *MI, SStream *OS, void *Info);
25
+
26
+ #endif
@@ -0,0 +1,116 @@
1
+ //===--- X86InstPrinterCommon.cpp - X86 assembly instruction printing -----===//
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 file includes common code for rendering MCInst instances as Intel-style
11
+ // and Intel-style assembly.
12
+ //
13
+ //===----------------------------------------------------------------------===//
14
+
15
+ /* Capstone Disassembly Engine */
16
+ /* By Nguyen Anh Quynh <aquynh@gmail.com>, 2013-2019 */
17
+
18
+ #if defined (WIN32) || defined (WIN64) || defined (_WIN32) || defined (_WIN64)
19
+ #pragma warning(disable:4996) // disable MSVC's warning on strncpy()
20
+ #pragma warning(disable:28719) // disable MSVC's warning on strncpy()
21
+ #endif
22
+
23
+ #if !defined(CAPSTONE_HAS_OSXKERNEL)
24
+ #include <ctype.h>
25
+ #endif
26
+ #include <capstone/platform.h>
27
+
28
+ #if defined(CAPSTONE_HAS_OSXKERNEL)
29
+ #include <Availability.h>
30
+ #include <libkern/libkern.h>
31
+ #else
32
+ #include <stdio.h>
33
+ #include <stdlib.h>
34
+ #endif
35
+
36
+ #include <string.h>
37
+
38
+ #include "../../utils.h"
39
+ #include "../../MCInst.h"
40
+ #include "../../SStream.h"
41
+
42
+ #include "X86InstPrinterCommon.h"
43
+ #include "X86Mapping.h"
44
+
45
+ #ifndef CAPSTONE_X86_REDUCE
46
+ void printSSEAVXCC(MCInst *MI, unsigned Op, SStream *O)
47
+ {
48
+ uint8_t Imm = (uint8_t)(MCOperand_getImm(MCInst_getOperand(MI, Op)) & 0x1f);
49
+ switch (Imm) {
50
+ default: break;//printf("Invalid avxcc argument!\n"); break;
51
+ case 0: SStream_concat0(O, "eq"); op_addAvxCC(MI, X86_AVX_CC_EQ); break;
52
+ case 1: SStream_concat0(O, "lt"); op_addAvxCC(MI, X86_AVX_CC_LT); break;
53
+ case 2: SStream_concat0(O, "le"); op_addAvxCC(MI, X86_AVX_CC_LE); break;
54
+ case 3: SStream_concat0(O, "unord"); op_addAvxCC(MI, X86_AVX_CC_UNORD); break;
55
+ case 4: SStream_concat0(O, "neq"); op_addAvxCC(MI, X86_AVX_CC_NEQ); break;
56
+ case 5: SStream_concat0(O, "nlt"); op_addAvxCC(MI, X86_AVX_CC_NLT); break;
57
+ case 6: SStream_concat0(O, "nle"); op_addAvxCC(MI, X86_AVX_CC_NLE); break;
58
+ case 7: SStream_concat0(O, "ord"); op_addAvxCC(MI, X86_AVX_CC_ORD); break;
59
+ case 8: SStream_concat0(O, "eq_uq"); op_addAvxCC(MI, X86_AVX_CC_EQ_UQ); break;
60
+ case 9: SStream_concat0(O, "nge"); op_addAvxCC(MI, X86_AVX_CC_NGE); break;
61
+ case 0xa: SStream_concat0(O, "ngt"); op_addAvxCC(MI, X86_AVX_CC_NGT); break;
62
+ case 0xb: SStream_concat0(O, "false"); op_addAvxCC(MI, X86_AVX_CC_FALSE); break;
63
+ case 0xc: SStream_concat0(O, "neq_oq"); op_addAvxCC(MI, X86_AVX_CC_NEQ_OQ); break;
64
+ case 0xd: SStream_concat0(O, "ge"); op_addAvxCC(MI, X86_AVX_CC_GE); break;
65
+ case 0xe: SStream_concat0(O, "gt"); op_addAvxCC(MI, X86_AVX_CC_GT); break;
66
+ case 0xf: SStream_concat0(O, "true"); op_addAvxCC(MI, X86_AVX_CC_TRUE); break;
67
+ case 0x10: SStream_concat0(O, "eq_os"); op_addAvxCC(MI, X86_AVX_CC_EQ_OS); break;
68
+ case 0x11: SStream_concat0(O, "lt_oq"); op_addAvxCC(MI, X86_AVX_CC_LT_OQ); break;
69
+ case 0x12: SStream_concat0(O, "le_oq"); op_addAvxCC(MI, X86_AVX_CC_LE_OQ); break;
70
+ case 0x13: SStream_concat0(O, "unord_s"); op_addAvxCC(MI, X86_AVX_CC_UNORD_S); break;
71
+ case 0x14: SStream_concat0(O, "neq_us"); op_addAvxCC(MI, X86_AVX_CC_NEQ_US); break;
72
+ case 0x15: SStream_concat0(O, "nlt_uq"); op_addAvxCC(MI, X86_AVX_CC_NLT_UQ); break;
73
+ case 0x16: SStream_concat0(O, "nle_uq"); op_addAvxCC(MI, X86_AVX_CC_NLE_UQ); break;
74
+ case 0x17: SStream_concat0(O, "ord_s"); op_addAvxCC(MI, X86_AVX_CC_ORD_S); break;
75
+ case 0x18: SStream_concat0(O, "eq_us"); op_addAvxCC(MI, X86_AVX_CC_EQ_US); break;
76
+ case 0x19: SStream_concat0(O, "nge_uq"); op_addAvxCC(MI, X86_AVX_CC_NGE_UQ); break;
77
+ case 0x1a: SStream_concat0(O, "ngt_uq"); op_addAvxCC(MI, X86_AVX_CC_NGT_UQ); break;
78
+ case 0x1b: SStream_concat0(O, "false_os"); op_addAvxCC(MI, X86_AVX_CC_FALSE_OS); break;
79
+ case 0x1c: SStream_concat0(O, "neq_os"); op_addAvxCC(MI, X86_AVX_CC_NEQ_OS); break;
80
+ case 0x1d: SStream_concat0(O, "ge_oq"); op_addAvxCC(MI, X86_AVX_CC_GE_OQ); break;
81
+ case 0x1e: SStream_concat0(O, "gt_oq"); op_addAvxCC(MI, X86_AVX_CC_GT_OQ); break;
82
+ case 0x1f: SStream_concat0(O, "true_us"); op_addAvxCC(MI, X86_AVX_CC_TRUE_US); break;
83
+ }
84
+
85
+ MI->popcode_adjust = Imm + 1;
86
+ }
87
+
88
+ void printXOPCC(MCInst *MI, unsigned Op, SStream *O)
89
+ {
90
+ int64_t Imm = MCOperand_getImm(MCInst_getOperand(MI, Op));
91
+
92
+ switch (Imm) {
93
+ default: // llvm_unreachable("Invalid xopcc argument!");
94
+ case 0: SStream_concat0(O, "lt"); op_addXopCC(MI, X86_XOP_CC_LT); break;
95
+ case 1: SStream_concat0(O, "le"); op_addXopCC(MI, X86_XOP_CC_LE); break;
96
+ case 2: SStream_concat0(O, "gt"); op_addXopCC(MI, X86_XOP_CC_GT); break;
97
+ case 3: SStream_concat0(O, "ge"); op_addXopCC(MI, X86_XOP_CC_GE); break;
98
+ case 4: SStream_concat0(O, "eq"); op_addXopCC(MI, X86_XOP_CC_EQ); break;
99
+ case 5: SStream_concat0(O, "neq"); op_addXopCC(MI, X86_XOP_CC_NEQ); break;
100
+ case 6: SStream_concat0(O, "false"); op_addXopCC(MI, X86_XOP_CC_FALSE); break;
101
+ case 7: SStream_concat0(O, "true"); op_addXopCC(MI, X86_XOP_CC_TRUE); break;
102
+ }
103
+ }
104
+
105
+ void printRoundingControl(MCInst *MI, unsigned Op, SStream *O)
106
+ {
107
+ int64_t Imm = MCOperand_getImm(MCInst_getOperand(MI, Op)) & 0x3;
108
+ switch (Imm) {
109
+ case 0: SStream_concat0(O, "{rn-sae}"); op_addAvxSae(MI); op_addAvxRoundingMode(MI, X86_AVX_RM_RN); break;
110
+ case 1: SStream_concat0(O, "{rd-sae}"); op_addAvxSae(MI); op_addAvxRoundingMode(MI, X86_AVX_RM_RD); break;
111
+ case 2: SStream_concat0(O, "{ru-sae}"); op_addAvxSae(MI); op_addAvxRoundingMode(MI, X86_AVX_RM_RU); break;
112
+ case 3: SStream_concat0(O, "{rz-sae}"); op_addAvxSae(MI); op_addAvxRoundingMode(MI, X86_AVX_RM_RZ); break;
113
+ default: break; // never reach
114
+ }
115
+ }
116
+ #endif
@@ -0,0 +1,16 @@
1
+ /* Capstone Disassembly Engine */
2
+ /* By Nguyen Anh Quynh <aquynh@gmail.com>, 2013-2019 */
3
+
4
+ #ifndef CS_X86_INSTPRINTERCOMMON_H
5
+ #define CS_X86_INSTPRINTERCOMMON_H
6
+
7
+ #include "../../MCInst.h"
8
+ #include "../../SStream.h"
9
+
10
+
11
+ void printSSEAVXCC(MCInst *MI, unsigned Op, SStream *O);
12
+ void printXOPCC(MCInst *MI, unsigned Op, SStream *O);
13
+ void printRoundingControl(MCInst *MI, unsigned Op, SStream *O);
14
+
15
+ #endif
16
+