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.
Go to file
Rot127 104f693c11 Architecture updater (auto-sync) - Updating ARM (#1949)
* Add auto-sync updater.

* Update Capstone core with auto-sync changes.

* Update ARM via auto-sync.

* Make changes to arch modules which are introduced by auto-sync.

* Update tests for ARM.

* Fix build warnings for make

* Remove meson.build

* Print shift amount in decimal

* Patch non LLVM register alias.

* Change type of immediate operand to unsiged (due to: #771)

* Replace all occurances of a register with its alias.

* Fix printing of signed imms

* Print rotate amount in decimal

* CHange imm type to int64_t to match LLVM imm type.

* Fix search for register names, by completing string first.

* Print ModImm operands always in decimal

* Use number format of previous capstone version.

* Correct implicit writes and update_flags according to SBit.

* Add missing test for RegImmShift

* Reverse incorrect comparision.

* Set shift information for move instructions.

* Set mem access for all memory operands

* Set subtracted flag if offset is negative.

* Add flag for post-index memory operands.

* Add detail op for BX_RET and MOVPCLR

* Use instruction post_index operand.

* Add VPOP and VPUSH as unique CS IDs.

* Add shifting info for MOVsr.

* Add TODOs.

* Add in LLVM hardcoded operands to detail.

* Move detail editing from InstPrinter to Mapping

* Formatting

* Add removed check.

* Add writeback register and constraints to RFEI instructions.

* Translate shift immediate

* Print negative immediates

* Remove duplicate invalid entry

* Add CS groups to instructions

* Fix write attriutes of stores.

* Add missing names of added instructions

* Fix LLVM bug

* Add more post_index flags

* http -> https

* Make generated functions static

* Remove tab prefix for alias instructions.

* Set ValidateMCOperand to NULL.

* Fix AddrMode3Operand operands

* Allow getting system and banked register name via API

* Add writeback to STC/LDC instructions.

* Fix (hopefully) last case where disp is negative and subtracted = true

* Remove accidentially introduced regressions
2023-07-19 17:56:27 +08:00
.github/workflows [workflows] Adjust matrix version 2023-06-23 09:44:42 +08:00
arch Architecture updater (auto-sync) - Updating ARM (#1949) 2023-07-19 17:56:27 +08:00
bindings python: update binding README 2023-07-06 00:03:39 +08:00
contrib Constify backends (#1549) 2019-12-23 20:30:57 +08:00
cstool Architecture updater (auto-sync) - Updating ARM (#1949) 2023-07-19 17:56:27 +08:00
docs Architecture updater (auto-sync) - Updating ARM (#1949) 2023-07-19 17:56:27 +08:00
include Architecture updater (auto-sync) - Updating ARM (#1949) 2023-07-19 17:56:27 +08:00
msvc fix msvc dll to compile with has_tricore, plus added CRT_SECURE_NO_WARNINGS 2023-06-24 10:00:39 +02:00
packages merge next to master 2018-07-20 12:36:50 +08:00
suite Architecture updater (auto-sync) - Updating ARM (#1949) 2023-07-19 17:56:27 +08:00
tests Architecture updater (auto-sync) - Updating ARM (#1949) 2023-07-19 17:56:27 +08:00
windows Fix user data alignment in MEMBLOCK (#1471) 2019-05-09 10:24:47 +08:00
windowsce Added documentation for building for Windows CE. 2016-04-12 09:26:47 +02:00
xcode merge next to master 2018-07-20 12:36:50 +08:00
.appveyor.yml rename appveyor.yml to .appveyor.yml 2016-03-15 00:01:10 +08:00
.clang-format Add .clang-format and format 2023-05-30 11:09:37 +08:00
.editorconfig Add OCaml to EditorConfig 2022-07-23 10:46:03 +02:00
.gitattributes Fix language statistics by considering *.inc files to be C files. (#1078) 2018-01-14 20:42:20 +08:00
.gitignore Fix all compiler errors 2023-04-14 00:34:16 +08:00
.gitmodules Architecture updater (auto-sync) - Updating ARM (#1949) 2023-07-19 17:56:27 +08:00
.travis.yml Fuzzit integration (#1520) 2019-07-25 09:06:52 +08:00
capstone-config.cmake.in Add cmake config and export targets. (#1637) 2020-06-02 20:58:33 +08:00
capstone.pc.in capstone.pc.in: use https in the URL. 2023-06-16 10:02:51 -04:00
ChangeLog Update ChangeLog v5.0 Final 2023-07-05 22:58:24 +08:00
cmake_uninstall.cmake.in add cmake uninstall option 2022-01-27 14:22:43 +08:00
cmake.sh Fix pkgcfg generation for the archs variable (#1830) 2022-01-26 11:28:04 +08:00
CMakeLists.txt Architecture updater (auto-sync) - Updating ARM (#1949) 2023-07-19 17:56:27 +08:00
CMakePresets.json Merge cmake.yml into CITest.yml 2022-04-11 09:35:10 +02:00
COMPILE_CMAKE.TXT Modify Makefiles for TriCore architecture 2023-04-14 00:34:08 +08:00
COMPILE_MSVC.TXT Modify Makefiles for TriCore architecture 2023-04-14 00:34:08 +08:00
COMPILE.TXT Modify Makefiles for TriCore architecture 2023-04-14 00:34:08 +08:00
config.mk Merge branch 'next' into tricore 2023-04-27 13:23:35 +08:00
CREDITS.TXT Fix tricore python binding 2023-04-24 22:18:07 +08:00
cs_operand.h Architecture updater (auto-sync) - Updating ARM (#1949) 2023-07-19 17:56:27 +08:00
cs_priv.h Architecture updater (auto-sync) - Updating ARM (#1949) 2023-07-19 17:56:27 +08:00
cs_simple_types.h Add operands access support for TriCore 2023-05-30 12:27:38 +08:00
cs.c Architecture updater (auto-sync) - Updating ARM (#1949) 2023-07-19 17:56:27 +08:00
functions.mk Fix if indent 2023-05-19 19:50:46 +01:00
HACK.TXT Architecture updater (auto-sync) - Updating ARM (#1949) 2023-07-19 17:56:27 +08:00
LEB128.h sync with LLVM 7.0.1. X86 is first 2019-02-26 15:19:51 +08:00
LICENSE_LLVM.TXT initial import 2013-11-27 12:11:31 +08:00
LICENSE.TXT a a newline to LICENSE.TXT 2014-02-20 17:08:28 +08:00
make.sh build: add xlc and AIX support (#1559) 2019-10-31 04:02:31 +08:00
Makefile Architecture updater (auto-sync) - Updating ARM (#1949) 2023-07-19 17:56:27 +08:00
Mapping.c Architecture updater (auto-sync) - Updating ARM (#1949) 2023-07-19 17:56:27 +08:00
Mapping.h Architecture updater (auto-sync) - Updating ARM (#1949) 2023-07-19 17:56:27 +08:00
MathExtras.h Architecture updater (auto-sync) - Updating ARM (#1949) 2023-07-19 17:56:27 +08:00
MCDisassembler.h sync with LLVM 7.0.1. X86 is first 2019-02-26 15:19:51 +08:00
MCFixedLenDisassembler.h RISCV support ISRV32/ISRV64 (#1401) 2019-03-09 08:41:12 +08:00
MCInst.c Architecture updater (auto-sync) - Updating ARM (#1949) 2023-07-19 17:56:27 +08:00
MCInst.h Architecture updater (auto-sync) - Updating ARM (#1949) 2023-07-19 17:56:27 +08:00
MCInstPrinter.c Architecture updater (auto-sync) - Updating ARM (#1949) 2023-07-19 17:56:27 +08:00
MCInstPrinter.h Architecture updater (auto-sync) - Updating ARM (#1949) 2023-07-19 17:56:27 +08:00
MCInstrDesc.c Add .clang-format and format 2023-05-30 11:09:37 +08:00
MCInstrDesc.h Architecture updater (auto-sync) - Updating ARM (#1949) 2023-07-19 17:56:27 +08:00
MCRegisterInfo.c In x86: Fixed backward compatibility with C90 (#1969) 2023-03-10 08:37:47 +08:00
MCRegisterInfo.h arm64: sync with LLVM 7.0.1 2019-04-10 14:17:08 +08:00
nmake.bat Add cmake option to tell whether architectures should be included by default (#1463) (#1466) 2019-04-29 19:20:01 +07:00
pkgconfig.mk 5.0-post1 2023-07-05 23:30:22 +08:00
README.md README: use https 2023-06-18 21:15:09 +08:00
RELEASE_NOTES empty RELEASE_NOTES for v4.1 2018-12-19 07:50:18 +07:00
SPONSORS.TXT Add webassembly arch (#1359) 2019-02-01 23:03:47 +08:00
SStream.c Architecture updater (auto-sync) - Updating ARM (#1949) 2023-07-19 17:56:27 +08:00
SStream.h Architecture updater (auto-sync) - Updating ARM (#1949) 2023-07-19 17:56:27 +08:00
utils.c Architecture updater (auto-sync) - Updating ARM (#1949) 2023-07-19 17:56:27 +08:00
utils.h Architecture updater (auto-sync) - Updating ARM (#1949) 2023-07-19 17:56:27 +08:00

Capstone Engine

Build status pypi package pypi downloads 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, M68K, M680X, Mips, MOS65XX, PPC, RISC-V(rv32G/rv64G), SH, Sparc, SystemZ, TMS320C64X, TriCore, Webassembly, XCore and X86 (16, 32, 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 https://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.