Go to file
Nguyen Anh Quynh 81a6df4d00 x86: temporarily revert a part of commit 2be9b8791a due to some broken output 2014-04-01 07:24:33 +08:00
arch x86: temporarily revert a part of commit 2be9b8791a due to some broken output 2014-04-01 07:24:33 +08:00
bindings x86: rename X86_COMPACT to X86_REDUCE. suggested by Pancake 2014-03-27 10:54:44 +08:00
docs docs: indentation 2014-03-27 16:05:38 +08:00
include remove the useless diet.h 2014-03-27 17:15:18 +08:00
packages packages: updated MASTER_SITES 2014-03-31 11:19:31 +02:00
suite suite: add SystemZ support to benchmark.py & fuzz.py 2014-03-23 22:56:38 +08:00
tests systemz: support length for Mem op 2014-03-24 17:26:57 +08:00
.gitignore revert pkgconfig.mk 2014-03-31 20:47:35 +08:00
COMPILE.TXT Revert "no more diet.h" 2014-03-27 21:04:10 +08:00
CREDITS.TXT CREDITS.TXT 2013-12-05 10:08:03 +08:00
ChangeLog Changelog for 2.1.2 2014-03-30 22:39:22 +08:00
HACK.TXT update README & HACK with SystemZ information 2014-03-23 22:24:28 +08:00
LEB128.h 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
LICENSE_LLVM.TXT initial import 2013-11-27 12:11:31 +08:00
MCDisassembler.h rename some C header guards to be without _ as prefix to follow naming convention of C language. suggested by Markus Elfring 2014-01-02 13:15:07 +08:00
MCFixedLenDisassembler.h initial import 2013-11-27 12:11:31 +08:00
MCInst.c rename memory function pointer types to have cs_ prefix. also rename internal function pointers my_* to have cs_mem_ prefix - suggested by Pancake 2014-01-11 12:55:31 +08:00
MCInst.h x86: do not print negative immediate. request of Le Dinh Long 2014-03-29 21:39:31 +08:00
MCInstrDesc.c initial import 2013-11-27 12:11:31 +08:00
MCInstrDesc.h initial import 2013-11-27 12:11:31 +08:00
MCRegisterInfo.c fix C coding style 2014-01-23 22:22:45 +08:00
MCRegisterInfo.h ARM: Fix bunch of issues 2013-12-11 17:35:27 +08:00
Makefile revert pkgconfig.mk 2014-03-31 20:47:35 +08:00
MathExtras.h core: fix warning bugs on unused vars introduced by the last commit 2014-03-07 13:50:13 +08:00
README update README & HACK with SystemZ information 2014-03-23 22:24:28 +08:00
RELEASE_NOTES RELEASE_NOTES: update for 2.1.2 2014-03-30 22:37:58 +08:00
SStream.c add diet compile option (CAPSTONE_DIET option in config.mk). This reduces binary size by around 40% 2014-02-22 23:26:27 +08:00
SStream.h initial import 2013-11-27 12:11:31 +08:00
SubtargetFeature.h initial import 2013-11-27 12:11:31 +08:00
TODO TODO: remove C# related info 2014-01-07 23:54:31 +08:00
config.mk correct config.mk since X86-reduce now supports VMX/SVM 2014-03-27 15:38:23 +08:00
cs.c x86: rename X86_COMPACT to X86_REDUCE. suggested by Pancake 2014-03-27 10:54:44 +08:00
cs_priv.h arm: support asm syntax CS_OPT_SYNTAX_NOREGNAME to print out registers with numbers (ex: 'r11' rather than 'fp') 2014-03-11 00:18:50 +08:00
make.sh make.sh: support building for iOS 2014-03-31 21:16:47 +08:00
pkgconfig.mk revert pkgconfig.mk 2014-03-31 20:47:35 +08:00
utils.c remove now redundant insn_reverse_id() after alias handling simplifications 2014-02-18 17:58:47 +08:00
utils.h add diet compile option (CAPSTONE_DIET option in config.mk). This reduces binary size by around 40% 2014-02-22 23:26:27 +08:00

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 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, Ocaml, Python, Ruby & Vala ready (either available in main code,
  or provided externally by community).

- Native support for Windows & *nix platforms (with OSX, Linux, *BSD & Solaris
  have been confirmed).

- 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


[Status]

- Capstone can only compile to Windows via Cygwin, or cross-compile using
MingW. Visual Studio support will be done in the future.

- X86 engine cannot handle many malware tricks yet. Please report all the raw
binary code that Capstone cannot disassemble, or does that wrongly, so we can
fix that in the next version

- This package only contains Java & Python bindings. For C#, Go, Ocaml & Ruby,
refer to the corresponding git repositories.


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