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,43 @@
1
+ //===- ARMInstPrinter.h - Convert ARM 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 ARM MCInst to a .s file.
11
+ //
12
+ //===----------------------------------------------------------------------===//
13
+
14
+ /* Capstone Disassembly Engine */
15
+ /* By Nguyen Anh Quynh <aquynh@gmail.com>, 2013-2019 */
16
+
17
+ #ifndef CS_ARMINSTPRINTER_H
18
+ #define CS_ARMINSTPRINTER_H
19
+
20
+ #include "../../MCInst.h"
21
+ #include "../../MCRegisterInfo.h"
22
+ #include "../../SStream.h"
23
+
24
+ void ARM_printInst(MCInst *MI, SStream *O, void *Info);
25
+ void ARM_post_printer(csh handle, cs_insn *pub_insn, char *mnem, MCInst *mci);
26
+
27
+ // setup handle->get_regname
28
+ void ARM_getRegName(cs_struct *handle, int value);
29
+
30
+ // specify vector data type for vector instructions
31
+ void ARM_addVectorDataType(MCInst *MI, arm_vectordata_type vd);
32
+
33
+ void ARM_addVectorDataSize(MCInst *MI, int size);
34
+
35
+ void ARM_addReg(MCInst *MI, int reg);
36
+
37
+ // load usermode registers (LDM, STM)
38
+ void ARM_addUserMode(MCInst *MI);
39
+
40
+ // sysreg for MRS/MSR
41
+ void ARM_addSysReg(MCInst *MI, arm_sysreg reg);
42
+
43
+ #endif
@@ -0,0 +1,551 @@
1
+ /* Capstone Disassembly Engine */
2
+ /* By Nguyen Anh Quynh <aquynh@gmail.com>, 2013-2019 */
3
+
4
+ #ifdef CAPSTONE_HAS_ARM
5
+
6
+ #include <stdio.h> // debug
7
+ #include <string.h>
8
+
9
+ #include "../../cs_priv.h"
10
+
11
+ #include "ARMMapping.h"
12
+
13
+ #define GET_INSTRINFO_ENUM
14
+ #include "ARMGenInstrInfo.inc"
15
+
16
+ #ifndef CAPSTONE_DIET
17
+ static const name_map reg_name_maps[] = {
18
+ { ARM_REG_INVALID, NULL },
19
+ { ARM_REG_APSR, "apsr"},
20
+ { ARM_REG_APSR_NZCV, "apsr_nzcv"},
21
+ { ARM_REG_CPSR, "cpsr"},
22
+ { ARM_REG_FPEXC, "fpexc"},
23
+ { ARM_REG_FPINST, "fpinst"},
24
+ { ARM_REG_FPSCR, "fpscr"},
25
+ { ARM_REG_FPSCR_NZCV, "fpscr_nzcv"},
26
+ { ARM_REG_FPSID, "fpsid"},
27
+ { ARM_REG_ITSTATE, "itstate"},
28
+ { ARM_REG_LR, "lr"},
29
+ { ARM_REG_PC, "pc"},
30
+ { ARM_REG_SP, "sp"},
31
+ { ARM_REG_SPSR, "spsr"},
32
+ { ARM_REG_D0, "d0"},
33
+ { ARM_REG_D1, "d1"},
34
+ { ARM_REG_D2, "d2"},
35
+ { ARM_REG_D3, "d3"},
36
+ { ARM_REG_D4, "d4"},
37
+ { ARM_REG_D5, "d5"},
38
+ { ARM_REG_D6, "d6"},
39
+ { ARM_REG_D7, "d7"},
40
+ { ARM_REG_D8, "d8"},
41
+ { ARM_REG_D9, "d9"},
42
+ { ARM_REG_D10, "d10"},
43
+ { ARM_REG_D11, "d11"},
44
+ { ARM_REG_D12, "d12"},
45
+ { ARM_REG_D13, "d13"},
46
+ { ARM_REG_D14, "d14"},
47
+ { ARM_REG_D15, "d15"},
48
+ { ARM_REG_D16, "d16"},
49
+ { ARM_REG_D17, "d17"},
50
+ { ARM_REG_D18, "d18"},
51
+ { ARM_REG_D19, "d19"},
52
+ { ARM_REG_D20, "d20"},
53
+ { ARM_REG_D21, "d21"},
54
+ { ARM_REG_D22, "d22"},
55
+ { ARM_REG_D23, "d23"},
56
+ { ARM_REG_D24, "d24"},
57
+ { ARM_REG_D25, "d25"},
58
+ { ARM_REG_D26, "d26"},
59
+ { ARM_REG_D27, "d27"},
60
+ { ARM_REG_D28, "d28"},
61
+ { ARM_REG_D29, "d29"},
62
+ { ARM_REG_D30, "d30"},
63
+ { ARM_REG_D31, "d31"},
64
+ { ARM_REG_FPINST2, "fpinst2"},
65
+ { ARM_REG_MVFR0, "mvfr0"},
66
+ { ARM_REG_MVFR1, "mvfr1"},
67
+ { ARM_REG_MVFR2, "mvfr2"},
68
+ { ARM_REG_Q0, "q0"},
69
+ { ARM_REG_Q1, "q1"},
70
+ { ARM_REG_Q2, "q2"},
71
+ { ARM_REG_Q3, "q3"},
72
+ { ARM_REG_Q4, "q4"},
73
+ { ARM_REG_Q5, "q5"},
74
+ { ARM_REG_Q6, "q6"},
75
+ { ARM_REG_Q7, "q7"},
76
+ { ARM_REG_Q8, "q8"},
77
+ { ARM_REG_Q9, "q9"},
78
+ { ARM_REG_Q10, "q10"},
79
+ { ARM_REG_Q11, "q11"},
80
+ { ARM_REG_Q12, "q12"},
81
+ { ARM_REG_Q13, "q13"},
82
+ { ARM_REG_Q14, "q14"},
83
+ { ARM_REG_Q15, "q15"},
84
+ { ARM_REG_R0, "r0"},
85
+ { ARM_REG_R1, "r1"},
86
+ { ARM_REG_R2, "r2"},
87
+ { ARM_REG_R3, "r3"},
88
+ { ARM_REG_R4, "r4"},
89
+ { ARM_REG_R5, "r5"},
90
+ { ARM_REG_R6, "r6"},
91
+ { ARM_REG_R7, "r7"},
92
+ { ARM_REG_R8, "r8"},
93
+ { ARM_REG_R9, "sb"},
94
+ { ARM_REG_R10, "sl"},
95
+ { ARM_REG_R11, "fp"},
96
+ { ARM_REG_R12, "ip"},
97
+ { ARM_REG_S0, "s0"},
98
+ { ARM_REG_S1, "s1"},
99
+ { ARM_REG_S2, "s2"},
100
+ { ARM_REG_S3, "s3"},
101
+ { ARM_REG_S4, "s4"},
102
+ { ARM_REG_S5, "s5"},
103
+ { ARM_REG_S6, "s6"},
104
+ { ARM_REG_S7, "s7"},
105
+ { ARM_REG_S8, "s8"},
106
+ { ARM_REG_S9, "s9"},
107
+ { ARM_REG_S10, "s10"},
108
+ { ARM_REG_S11, "s11"},
109
+ { ARM_REG_S12, "s12"},
110
+ { ARM_REG_S13, "s13"},
111
+ { ARM_REG_S14, "s14"},
112
+ { ARM_REG_S15, "s15"},
113
+ { ARM_REG_S16, "s16"},
114
+ { ARM_REG_S17, "s17"},
115
+ { ARM_REG_S18, "s18"},
116
+ { ARM_REG_S19, "s19"},
117
+ { ARM_REG_S20, "s20"},
118
+ { ARM_REG_S21, "s21"},
119
+ { ARM_REG_S22, "s22"},
120
+ { ARM_REG_S23, "s23"},
121
+ { ARM_REG_S24, "s24"},
122
+ { ARM_REG_S25, "s25"},
123
+ { ARM_REG_S26, "s26"},
124
+ { ARM_REG_S27, "s27"},
125
+ { ARM_REG_S28, "s28"},
126
+ { ARM_REG_S29, "s29"},
127
+ { ARM_REG_S30, "s30"},
128
+ { ARM_REG_S31, "s31"},
129
+ };
130
+ static const name_map reg_name_maps2[] = {
131
+ { ARM_REG_INVALID, NULL },
132
+ { ARM_REG_APSR, "apsr"},
133
+ { ARM_REG_APSR_NZCV, "apsr_nzcv"},
134
+ { ARM_REG_CPSR, "cpsr"},
135
+ { ARM_REG_FPEXC, "fpexc"},
136
+ { ARM_REG_FPINST, "fpinst"},
137
+ { ARM_REG_FPSCR, "fpscr"},
138
+ { ARM_REG_FPSCR_NZCV, "fpscr_nzcv"},
139
+ { ARM_REG_FPSID, "fpsid"},
140
+ { ARM_REG_ITSTATE, "itstate"},
141
+ { ARM_REG_LR, "lr"},
142
+ { ARM_REG_PC, "pc"},
143
+ { ARM_REG_SP, "sp"},
144
+ { ARM_REG_SPSR, "spsr"},
145
+ { ARM_REG_D0, "d0"},
146
+ { ARM_REG_D1, "d1"},
147
+ { ARM_REG_D2, "d2"},
148
+ { ARM_REG_D3, "d3"},
149
+ { ARM_REG_D4, "d4"},
150
+ { ARM_REG_D5, "d5"},
151
+ { ARM_REG_D6, "d6"},
152
+ { ARM_REG_D7, "d7"},
153
+ { ARM_REG_D8, "d8"},
154
+ { ARM_REG_D9, "d9"},
155
+ { ARM_REG_D10, "d10"},
156
+ { ARM_REG_D11, "d11"},
157
+ { ARM_REG_D12, "d12"},
158
+ { ARM_REG_D13, "d13"},
159
+ { ARM_REG_D14, "d14"},
160
+ { ARM_REG_D15, "d15"},
161
+ { ARM_REG_D16, "d16"},
162
+ { ARM_REG_D17, "d17"},
163
+ { ARM_REG_D18, "d18"},
164
+ { ARM_REG_D19, "d19"},
165
+ { ARM_REG_D20, "d20"},
166
+ { ARM_REG_D21, "d21"},
167
+ { ARM_REG_D22, "d22"},
168
+ { ARM_REG_D23, "d23"},
169
+ { ARM_REG_D24, "d24"},
170
+ { ARM_REG_D25, "d25"},
171
+ { ARM_REG_D26, "d26"},
172
+ { ARM_REG_D27, "d27"},
173
+ { ARM_REG_D28, "d28"},
174
+ { ARM_REG_D29, "d29"},
175
+ { ARM_REG_D30, "d30"},
176
+ { ARM_REG_D31, "d31"},
177
+ { ARM_REG_FPINST2, "fpinst2"},
178
+ { ARM_REG_MVFR0, "mvfr0"},
179
+ { ARM_REG_MVFR1, "mvfr1"},
180
+ { ARM_REG_MVFR2, "mvfr2"},
181
+ { ARM_REG_Q0, "q0"},
182
+ { ARM_REG_Q1, "q1"},
183
+ { ARM_REG_Q2, "q2"},
184
+ { ARM_REG_Q3, "q3"},
185
+ { ARM_REG_Q4, "q4"},
186
+ { ARM_REG_Q5, "q5"},
187
+ { ARM_REG_Q6, "q6"},
188
+ { ARM_REG_Q7, "q7"},
189
+ { ARM_REG_Q8, "q8"},
190
+ { ARM_REG_Q9, "q9"},
191
+ { ARM_REG_Q10, "q10"},
192
+ { ARM_REG_Q11, "q11"},
193
+ { ARM_REG_Q12, "q12"},
194
+ { ARM_REG_Q13, "q13"},
195
+ { ARM_REG_Q14, "q14"},
196
+ { ARM_REG_Q15, "q15"},
197
+ { ARM_REG_R0, "r0"},
198
+ { ARM_REG_R1, "r1"},
199
+ { ARM_REG_R2, "r2"},
200
+ { ARM_REG_R3, "r3"},
201
+ { ARM_REG_R4, "r4"},
202
+ { ARM_REG_R5, "r5"},
203
+ { ARM_REG_R6, "r6"},
204
+ { ARM_REG_R7, "r7"},
205
+ { ARM_REG_R8, "r8"},
206
+ { ARM_REG_R9, "r9"},
207
+ { ARM_REG_R10, "r10"},
208
+ { ARM_REG_R11, "r11"},
209
+ { ARM_REG_R12, "r12"},
210
+ { ARM_REG_S0, "s0"},
211
+ { ARM_REG_S1, "s1"},
212
+ { ARM_REG_S2, "s2"},
213
+ { ARM_REG_S3, "s3"},
214
+ { ARM_REG_S4, "s4"},
215
+ { ARM_REG_S5, "s5"},
216
+ { ARM_REG_S6, "s6"},
217
+ { ARM_REG_S7, "s7"},
218
+ { ARM_REG_S8, "s8"},
219
+ { ARM_REG_S9, "s9"},
220
+ { ARM_REG_S10, "s10"},
221
+ { ARM_REG_S11, "s11"},
222
+ { ARM_REG_S12, "s12"},
223
+ { ARM_REG_S13, "s13"},
224
+ { ARM_REG_S14, "s14"},
225
+ { ARM_REG_S15, "s15"},
226
+ { ARM_REG_S16, "s16"},
227
+ { ARM_REG_S17, "s17"},
228
+ { ARM_REG_S18, "s18"},
229
+ { ARM_REG_S19, "s19"},
230
+ { ARM_REG_S20, "s20"},
231
+ { ARM_REG_S21, "s21"},
232
+ { ARM_REG_S22, "s22"},
233
+ { ARM_REG_S23, "s23"},
234
+ { ARM_REG_S24, "s24"},
235
+ { ARM_REG_S25, "s25"},
236
+ { ARM_REG_S26, "s26"},
237
+ { ARM_REG_S27, "s27"},
238
+ { ARM_REG_S28, "s28"},
239
+ { ARM_REG_S29, "s29"},
240
+ { ARM_REG_S30, "s30"},
241
+ { ARM_REG_S31, "s31"},
242
+ };
243
+ #endif
244
+
245
+ const char *ARM_reg_name(csh handle, unsigned int reg)
246
+ {
247
+ #ifndef CAPSTONE_DIET
248
+ if (reg >= ARR_SIZE(reg_name_maps))
249
+ return NULL;
250
+
251
+ return reg_name_maps[reg].name;
252
+ #else
253
+ return NULL;
254
+ #endif
255
+ }
256
+
257
+ const char *ARM_reg_name2(csh handle, unsigned int reg)
258
+ {
259
+ #ifndef CAPSTONE_DIET
260
+ if (reg >= ARR_SIZE(reg_name_maps2))
261
+ return NULL;
262
+
263
+ return reg_name_maps2[reg].name;
264
+ #else
265
+ return NULL;
266
+ #endif
267
+ }
268
+
269
+ static const insn_map insns[] = {
270
+ // dummy item
271
+ {
272
+ 0, 0,
273
+ #ifndef CAPSTONE_DIET
274
+ { 0 }, { 0 }, { 0 }, 0, 0
275
+ #endif
276
+ },
277
+ #include "ARMMappingInsn.inc"
278
+ };
279
+
280
+ // look for @id in @insns
281
+ // return -1 if not found
282
+ static unsigned int find_insn(unsigned int id)
283
+ {
284
+ // binary searching since the IDs are sorted in order
285
+ unsigned int left, right, m;
286
+ unsigned int max = ARR_SIZE(insns);
287
+
288
+ right = max - 1;
289
+
290
+ if (id < insns[0].id || id > insns[right].id)
291
+ // not found
292
+ return -1;
293
+
294
+ left = 0;
295
+
296
+ while(left <= right) {
297
+ m = (left + right) / 2;
298
+ if (id == insns[m].id) {
299
+ return m;
300
+ }
301
+
302
+ if (id < insns[m].id)
303
+ right = m - 1;
304
+ else
305
+ left = m + 1;
306
+ }
307
+
308
+ // not found
309
+ // printf("NOT FOUNDDDDDDDDDDDDDDD id = %u\n", id);
310
+ return -1;
311
+ }
312
+
313
+ void ARM_get_insn_id(cs_struct *h, cs_insn *insn, unsigned int id)
314
+ {
315
+ unsigned int i = find_insn(id);
316
+ if (i != -1) {
317
+ insn->id = insns[i].mapid;
318
+
319
+ // printf("id = %u, mapid = %u\n", id, insn->id);
320
+
321
+ if (h->detail) {
322
+ #ifndef CAPSTONE_DIET
323
+ cs_struct handle;
324
+ handle.detail = h->detail;
325
+
326
+ memcpy(insn->detail->regs_read, insns[i].regs_use, sizeof(insns[i].regs_use));
327
+ insn->detail->regs_read_count = (uint8_t)count_positive(insns[i].regs_use);
328
+
329
+ memcpy(insn->detail->regs_write, insns[i].regs_mod, sizeof(insns[i].regs_mod));
330
+ insn->detail->regs_write_count = (uint8_t)count_positive(insns[i].regs_mod);
331
+
332
+ memcpy(insn->detail->groups, insns[i].groups, sizeof(insns[i].groups));
333
+ insn->detail->groups_count = (uint8_t)count_positive8(insns[i].groups);
334
+
335
+ insn->detail->arm.update_flags = cs_reg_write((csh)&handle, insn, ARM_REG_CPSR);
336
+
337
+ if (insns[i].branch || insns[i].indirect_branch) {
338
+ // this insn also belongs to JUMP group. add JUMP group
339
+ insn->detail->groups[insn->detail->groups_count] = ARM_GRP_JUMP;
340
+ insn->detail->groups_count++;
341
+ }
342
+ #endif
343
+ }
344
+ }
345
+ }
346
+
347
+ #ifndef CAPSTONE_DIET
348
+ static const char * const insn_name_maps[] = {
349
+ NULL, // ARM_INS_INVALID
350
+ #include "ARMMappingInsnName.inc"
351
+ };
352
+ #endif
353
+
354
+ const char *ARM_insn_name(csh handle, unsigned int id)
355
+ {
356
+ #ifndef CAPSTONE_DIET
357
+ if (id >= ARM_INS_ENDING)
358
+ return NULL;
359
+
360
+ return insn_name_maps[id];
361
+ #else
362
+ return NULL;
363
+ #endif
364
+ }
365
+
366
+ #ifndef CAPSTONE_DIET
367
+ static const name_map group_name_maps[] = {
368
+ // generic groups
369
+ { ARM_GRP_INVALID, NULL },
370
+ { ARM_GRP_JUMP, "jump" },
371
+ { ARM_GRP_CALL, "call" },
372
+ { ARM_GRP_INT, "int" },
373
+ { ARM_GRP_PRIVILEGE, "privilege" },
374
+ { ARM_GRP_BRANCH_RELATIVE, "branch_relative" },
375
+
376
+ // architecture-specific groups
377
+ { ARM_GRP_CRYPTO, "crypto" },
378
+ { ARM_GRP_DATABARRIER, "databarrier" },
379
+ { ARM_GRP_DIVIDE, "divide" },
380
+ { ARM_GRP_FPARMV8, "fparmv8" },
381
+ { ARM_GRP_MULTPRO, "multpro" },
382
+ { ARM_GRP_NEON, "neon" },
383
+ { ARM_GRP_T2EXTRACTPACK, "T2EXTRACTPACK" },
384
+ { ARM_GRP_THUMB2DSP, "THUMB2DSP" },
385
+ { ARM_GRP_TRUSTZONE, "TRUSTZONE" },
386
+ { ARM_GRP_V4T, "v4t" },
387
+ { ARM_GRP_V5T, "v5t" },
388
+ { ARM_GRP_V5TE, "v5te" },
389
+ { ARM_GRP_V6, "v6" },
390
+ { ARM_GRP_V6T2, "v6t2" },
391
+ { ARM_GRP_V7, "v7" },
392
+ { ARM_GRP_V8, "v8" },
393
+ { ARM_GRP_VFP2, "vfp2" },
394
+ { ARM_GRP_VFP3, "vfp3" },
395
+ { ARM_GRP_VFP4, "vfp4" },
396
+ { ARM_GRP_ARM, "arm" },
397
+ { ARM_GRP_MCLASS, "mclass" },
398
+ { ARM_GRP_NOTMCLASS, "notmclass" },
399
+ { ARM_GRP_THUMB, "thumb" },
400
+ { ARM_GRP_THUMB1ONLY, "thumb1only" },
401
+ { ARM_GRP_THUMB2, "thumb2" },
402
+ { ARM_GRP_PREV8, "prev8" },
403
+ { ARM_GRP_FPVMLX, "fpvmlx" },
404
+ { ARM_GRP_MULOPS, "mulops" },
405
+ { ARM_GRP_CRC, "crc" },
406
+ { ARM_GRP_DPVFP, "dpvfp" },
407
+ { ARM_GRP_V6M, "v6m" },
408
+ { ARM_GRP_VIRTUALIZATION, "virtualization" },
409
+ };
410
+ #endif
411
+
412
+ const char *ARM_group_name(csh handle, unsigned int id)
413
+ {
414
+ #ifndef CAPSTONE_DIET
415
+ return id2name(group_name_maps, ARR_SIZE(group_name_maps), id);
416
+ #else
417
+ return NULL;
418
+ #endif
419
+ }
420
+
421
+ // list all relative branch instructions
422
+ // ie: insns[i].branch && !insns[i].indirect_branch
423
+ static const unsigned int insn_rel[] = {
424
+ ARM_BL,
425
+ ARM_BLX_pred,
426
+ ARM_Bcc,
427
+ ARM_t2B,
428
+ ARM_t2Bcc,
429
+ ARM_tB,
430
+ ARM_tBcc,
431
+ ARM_tCBNZ,
432
+ ARM_tCBZ,
433
+ ARM_BL_pred,
434
+ ARM_BLXi,
435
+ ARM_tBL,
436
+ ARM_tBLXi,
437
+ 0
438
+ };
439
+
440
+ static const unsigned int insn_blx_rel_to_arm[] = {
441
+ ARM_tBLXi,
442
+ 0
443
+ };
444
+
445
+ // check if this insn is relative branch
446
+ bool ARM_rel_branch(cs_struct *h, unsigned int id)
447
+ {
448
+ int i;
449
+
450
+ for (i = 0; insn_rel[i]; i++) {
451
+ if (id == insn_rel[i]) {
452
+ return true;
453
+ }
454
+ }
455
+
456
+ // not found
457
+ return false;
458
+ }
459
+
460
+ bool ARM_blx_to_arm_mode(cs_struct *h, unsigned int id) {
461
+ int i;
462
+
463
+ for (i = 0; insn_blx_rel_to_arm[i]; i++)
464
+ if (id == insn_blx_rel_to_arm[i])
465
+ return true;
466
+
467
+ // not found
468
+ return false;
469
+
470
+ }
471
+
472
+ #ifndef CAPSTONE_DIET
473
+ // map instruction to its characteristics
474
+ typedef struct insn_op {
475
+ uint8_t access[7];
476
+ } insn_op;
477
+
478
+ static const insn_op insn_ops[] = {
479
+ {
480
+ // NULL item
481
+ { 0 }
482
+ },
483
+
484
+ #include "ARMMappingInsnOp.inc"
485
+ };
486
+
487
+ // given internal insn id, return operand access info
488
+ const uint8_t *ARM_get_op_access(cs_struct *h, unsigned int id)
489
+ {
490
+ int i = insn_find(insns, ARR_SIZE(insns), id, &h->insn_cache);
491
+ if (i != 0) {
492
+ return insn_ops[i].access;
493
+ }
494
+
495
+ return NULL;
496
+ }
497
+
498
+ void ARM_reg_access(const cs_insn *insn,
499
+ cs_regs regs_read, uint8_t *regs_read_count,
500
+ cs_regs regs_write, uint8_t *regs_write_count)
501
+ {
502
+ uint8_t i;
503
+ uint8_t read_count, write_count;
504
+ cs_arm *arm = &(insn->detail->arm);
505
+
506
+ read_count = insn->detail->regs_read_count;
507
+ write_count = insn->detail->regs_write_count;
508
+
509
+ // implicit registers
510
+ memcpy(regs_read, insn->detail->regs_read, read_count * sizeof(insn->detail->regs_read[0]));
511
+ memcpy(regs_write, insn->detail->regs_write, write_count * sizeof(insn->detail->regs_write[0]));
512
+
513
+ // explicit registers
514
+ for (i = 0; i < arm->op_count; i++) {
515
+ cs_arm_op *op = &(arm->operands[i]);
516
+ switch((int)op->type) {
517
+ case ARM_OP_REG:
518
+ if ((op->access & CS_AC_READ) && !arr_exist(regs_read, read_count, op->reg)) {
519
+ regs_read[read_count] = (uint16_t)op->reg;
520
+ read_count++;
521
+ }
522
+ if ((op->access & CS_AC_WRITE) && !arr_exist(regs_write, write_count, op->reg)) {
523
+ regs_write[write_count] = (uint16_t)op->reg;
524
+ write_count++;
525
+ }
526
+ break;
527
+ case ARM_OP_MEM:
528
+ // registers appeared in memory references always being read
529
+ if ((op->mem.base != ARM_REG_INVALID) && !arr_exist(regs_read, read_count, op->mem.base)) {
530
+ regs_read[read_count] = (uint16_t)op->mem.base;
531
+ read_count++;
532
+ }
533
+ if ((op->mem.index != ARM_REG_INVALID) && !arr_exist(regs_read, read_count, op->mem.index)) {
534
+ regs_read[read_count] = (uint16_t)op->mem.index;
535
+ read_count++;
536
+ }
537
+ if ((arm->writeback) && (op->mem.base != ARM_REG_INVALID) && !arr_exist(regs_write, write_count, op->mem.base)) {
538
+ regs_write[write_count] = (uint16_t)op->mem.base;
539
+ write_count++;
540
+ }
541
+ default:
542
+ break;
543
+ }
544
+ }
545
+
546
+ *regs_read_count = read_count;
547
+ *regs_write_count = write_count;
548
+ }
549
+ #endif
550
+
551
+ #endif
@@ -0,0 +1,40 @@
1
+ /* Capstone Disassembly Engine */
2
+ /* By Nguyen Anh Quynh <aquynh@gmail.com>, 2013-2019 */
3
+
4
+ #ifndef CS_ARM_MAP_H
5
+ #define CS_ARM_MAP_H
6
+
7
+ #include "../../include/capstone/capstone.h"
8
+ #include "../../utils.h"
9
+
10
+ // return name of regiser in friendly string
11
+ const char *ARM_reg_name(csh handle, unsigned int reg);
12
+ const char *ARM_reg_name2(csh handle, unsigned int reg);
13
+
14
+ // given internal insn id, return public instruction ID
15
+ void ARM_get_insn_id(cs_struct *h, cs_insn *insn, unsigned int id);
16
+
17
+ const char *ARM_insn_name(csh handle, unsigned int id);
18
+
19
+ const char *ARM_group_name(csh handle, unsigned int id);
20
+
21
+ // check if this insn is relative branch
22
+ bool ARM_rel_branch(cs_struct *h, unsigned int insn_id);
23
+
24
+ bool ARM_blx_to_arm_mode(cs_struct *h, unsigned int insn_id);
25
+
26
+ const uint8_t *ARM_get_op_access(cs_struct *h, unsigned int id);
27
+
28
+ void ARM_reg_access(const cs_insn *insn,
29
+ cs_regs regs_read, uint8_t *regs_read_count,
30
+ cs_regs regs_write, uint8_t *regs_write_count);
31
+
32
+ typedef struct BankedReg {
33
+ const char *Name;
34
+ arm_sysreg sysreg;
35
+ uint16_t Encoding;
36
+ } BankedReg;
37
+
38
+ const BankedReg *lookupBankedRegByEncoding(uint8_t encoding);
39
+
40
+ #endif