Finn Wilkinson 6d5a3b1a44 Updated AArch64 Instruction Printer to support new Armv9.2 instructions.
Implemented new functions present in LLVM 14.0.5 for any new instruction
type in Armv9.2; mainly SME / Matrix printing functions.

New set_sme_index function added (called from AArch64GenAsmWriter.inc)
to correctly add operands to new sme_index operand type. Doing_SME_Index
bool added to cs_struct to indicate when operands should be added to
sme_index type.

Functionality added to support SMSTART/SMSTOP aliases.
2022-09-30 16:34:09 +01:00
2019-12-23 20:30:57 +08:00
2019-08-30 23:39:52 +08:00
2018-07-20 12:36:50 +08:00
2018-07-20 12:36:50 +08:00
2019-07-25 09:06:52 +08:00
2022-04-30 13:06:30 +02:00
2022-02-28 22:13:21 +08:00
2019-03-09 08:41:12 +08:00
2022-01-09 11:22:01 +08:00
2019-02-26 15:19:51 +08:00
2013-11-27 12:11:31 +08:00
2014-02-20 17:08:28 +08:00
2019-10-31 04:02:31 +08:00
2022-01-05 15:49:11 +08:00
2019-04-10 14:17:08 +08:00
2022-02-28 23:28:58 +08:00
2021-11-10 00:23:13 +08:00
2018-12-19 07:50:18 +07:00
2019-02-01 23:03:47 +08:00
2019-04-30 13:50:42 +08:00
2019-04-30 13:50:42 +08:00
2015-03-11 11:33:00 +08:00
2019-04-10 14:17:08 +08:00
2019-04-10 14:17:08 +08:00

Capstone Engine

Build Status Build status pypi package pypi downloads Fuzzit Status
oss-fuzz Status

Capstone is a disassembly framework with the target of becoming the ultimate disasm engine for binary analysis and reversing in the security community.

Created by Nguyen Anh Quynh, then developed and maintained by a small community, Capstone offers some unparalleled features:

  • Support multiple hardware architectures: ARM, ARM64 (ARMv8), BPF, Ethereum VM, Webassembly, M68K, Mips, MOS65XX, PPC, Sparc, SystemZ, TMS320C64X, M680X, XCore, RISC-V(rv32G/rv64G) and X86 (including X86_64).

  • Having clean/simple/lightweight/intuitive architecture-neutral API.

  • Provide details on disassembled instruction (called “decomposer” by others).

  • Provide semantics of the disassembled instruction, such as list of implicit registers read & written.

  • Implemented in pure C language, with lightweight bindings for Swift, D, Clojure, F#, Common Lisp, Visual Basic, PHP, PowerShell, Emacs, Haskell, Perl, Python, Ruby, C#, NodeJS, Java, GO, C++, OCaml, Lua, Rust, Delphi, Free Pascal & Vala ready either in main code, or provided externally by the community).

  • Native support for all popular platforms: Windows, Mac OSX, iOS, Android, Linux, *BSD, Solaris, etc.

  • Thread-safe by design.

  • Special support for embedding into firmware or OS kernel.

  • High performance & suitable for malware analysis (capable of handling various X86 malware tricks).

  • Distributed under the open source BSD license.

Further information is available at http://www.capstone-engine.org

Compile

See COMPILE.TXT file for how to compile and install Capstone.

Documentation

See docs/README for how to customize & program your own tools with Capstone.

Hack

See HACK.TXT file for the structure of the source code.

Fuzz

See suite/fuzz/README.md for more information.

License

This project is released under the BSD license. If you redistribute the binary or source code of Capstone, please attach file LICENSE.TXT with your products.

Description
Capstone disassembly/disassembler framework for ARM, ARM64 (ARMv8), Alpha, BPF, Ethereum VM, HPPA, LoongArch, M68K, M680X, Mips, MOS65XX, PPC, RISC-V(rv32G/rv64G), SH, Sparc, SystemZ, TMS320C64X, TriCore, Webassembly, XCore and X86.
Readme 114 MiB
Languages
C 82%
C++ 8.9%
C# 4.1%
Python 2.1%
Java 1.5%
Other 1.1%