Capstone disassembly/disassembler framework: Core (Arm, Arm64, BPF, EVM, M68K, M680X, MOS65xx, Mips, PPC, RISCV, Sparc, SystemZ, TMS320C64x, Web Assembly, X86, X86_64, XCore) + bindings. (bloaty 依赖)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Nguyen Anh Quynh 42c11bc98c python & java: update constant symbols for SystemZ's groups & PPC_BC_INVALID 10 years ago
arch sparc: initialize detail->sparc in Sparc_getInstruction. bug reported by Ben Nagy 10 years ago
bindings python & java: update constant symbols for SystemZ's groups & PPC_BC_INVALID 10 years ago
contrib vsnprintf fix 10 years ago
docs
include ppc: add PPC_BC_INVALID 10 years ago
msvc msvc: remove unused CAPSTONE_STATIC macro in capstone_static project 10 years ago
packages
suite suite: support XCore in fuzz.py 10 years ago
tests Merge branch 'next' into opsize 10 years ago
.gitignore update .gitignore for Ocaml binding 10 years ago
CMakeLists.txt Modified CMakeLists.txt to re-enable support for building both static and shared versions of the library. 10 years ago
COMPILE.TXT add COMPILE_CMAKE.TXT & update COMPILE.TXT 10 years ago
COMPILE_CMAKE.TXT Update COMPILE_CMAKE.TXT 10 years ago
COMPILE_MSVC.TXT add COMPILE_CMAKE.TXT & update COMPILE.TXT 10 years ago
CREDITS.TXT update CREDITS.TXT 10 years ago
ChangeLog
HACK.TXT update HACK.TXT 10 years ago
LEB128.h
LICENSE.TXT
LICENSE_LLVM.TXT
MCDisassembler.h
MCFixedLenDisassembler.h
MCInst.c x86: provide size for X86_OP_IMM operand. thank Gabriel Quadros for some suggestions 10 years ago
MCInst.h x86: provide size for X86_OP_IMM operand. thank Gabriel Quadros for some suggestions 10 years ago
MCInstrDesc.c
MCInstrDesc.h
MCRegisterInfo.c
MCRegisterInfo.h
Makefile Simplify universal builds by relying on the linker to do the right thing 10 years ago
MathExtras.h
README update README 10 years ago
RELEASE_NOTES
SStream.c msvc: disable warning on strcpy() 10 years ago
SStream.h avoid using vsnprintf when possible for SStream_concat() to improve performance. based on the idea of Dang Hoang Vu. 10 years ago
TODO update TODO 10 years ago
config.mk enable disabled archs 10 years ago
cs.c add new API cs_group_name() to return group name in string, given the group id 10 years ago
cs_priv.h add new API cs_group_name() to return group name in string, given the group id 10 years ago
functions.mk
make.sh OSX: install into /usr/local rather than /usr 10 years ago
pkgconfig.mk
utils.c no need to zeroout insn_cache in make_id2insn() 10 years ago
utils.h replace offset_of with offsetof from stddef.h 10 years ago

README

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), Mips, PPC, Sparc,
SystemZ, XCore and X86.

- 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 wrappers for C++, C#, Go,
Java, NodeJS, Ocaml, Python, Ruby & Vala ready (available 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.

- 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.


[Hack]

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


[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.