Open source binary analysis tools.
Go to file
2019-01-16 10:36:44 -08:00
base symbolic: Translate the InstructionStart metadata statement into Crucible 2019-01-10 22:23:39 -08:00
deps Update to the latest crucible version 2019-01-11 23:01:07 -08:00
refinement Add run-refinement --unrefined flag to show pre- and post- refinement. 2019-01-10 17:25:12 -08:00
scripts Fix graphmod script 2018-11-12 09:42:06 -05:00
symbolic [symbolic] add imports for mappend operator for GHC 8.2.2. 2019-01-12 18:10:16 -08:00
x86 symbolic: Translate the InstructionStart metadata statement into Crucible 2019-01-10 22:23:39 -08:00
x86_symbolic Clean up and document the macaw-symbolic API 2019-01-10 18:20:54 -08:00
.gitignore Remove script for building just these dependencies 2017-05-05 00:13:54 -07:00
.gitmodules Fix repo urls 2018-04-25 00:32:43 -07:00
.travis.yml Fix travis builds. 2018-11-12 09:58:10 -05:00
LICENSE Add x86 specific code. 2017-09-27 15:54:43 -07:00
README.md Delete top-level stack.yaml symlink 2018-10-30 16:12:16 -07:00
stack.ghc-8.2.2.yaml Add test case for object jump table. 2018-07-20 18:16:52 -07:00

This is the main repository for the Macaw binary analysis framework. This framework is implemented to offer extensible support for architectures.

The main algorithm implemented so far is a code discovery procedure which will discover reachable code in the binary given one or more entry points such as _start or the current symbols.

The core libraries are:

  • macaw-base -- The core architecture-independent operations and algorithms.
  • macaw-symbolic -- Library that provides symbolic simulation of Macaw programs via Crucible.
  • macaw-x86 -- Provides definitions enabling Macaw to be used on X86_64 programs.
  • macaw-x86-symbolic -- Adds Macaw-symbolic extensions needed to support x86.

The libraries that make up Macaw are released under the BSD license.

To build with Stack, first create a top-level stack.yaml file by symlinking to one of the provided stack-ghc-<version>.yaml files. E.g.

ln -s stack-ghc-8.2.yaml stack.yaml
stack build