This is a fork of the BAP version 0.8 release that appeared at:
https://github.com/0day1day/bap/
I am trying to keep this fork updated with patches, fixes, etc. Feel free to fork and submit pull requests.
For more information see the official project webpage at:
For the original README of BAP see the README.orig file.
Obviously, I don't claim any credit for BAP; see the AUTHORS file for a list of the developers.
I have tested this fork only with the following configurations:
-
Ubuntu 14.04.1 (i686)
- gcc (Ubuntu 4.8.2-19ubuntu1) 4.8.2
- pin-2.14-67254-gcc.4.4.7-linux
- OPAM 1.1.1
- OCaml 4.01.0
- All BAP's OCaml package dependencies from OPAM
-
OS X 10.9.4 (no Pintool yet)
- Apple LLVM version 5.1 (clang-503.0.40) (based on LLVM 3.4svn)
- OPAM 1.1.1
- OCaml 4.01.0
- All BAP's OCaml package dependencies from OPAM
- MacPorts 2.3.1 (see the INSTALL file)
- libiberty from binutils 2.24 needs to be manually installed
Install all dependencies of BAP with OPAM (also see the INSTALL file). Then download Pin version 2.14-67254-gcc.4.4.7-linux and place it at ./bap/pin. Finally do:
./autogen.sh
./configure --with-z3=`pwd`/solvers/z3
make
Add the ./bap/utils directory to your path. The Pintool is at ./bap/pintraces/obj-ia32/gentrace.so.
Follow the instructions from the INSTALL file. Before the "./autogen.sh" step you need to manually install libiberty from binutils, with something like:
wget http://ftp.gnu.org/gnu/binutils/binutils-2.24.tar.bz2
tar jxvf binutils-2.24.tar.bz2
cd binutils-2.24/libiberty
./configure --prefix=/opt/local --enable-install-libiberty
make
sudo make install
The Pintool needs to be ported to OS X.
For an example standalone utility that uses BAP see the example-util directory. The example-util directory doesn't need to be in the bap directory; place it wherever and edit example-util/Makefile to specify the location of where you compiled BAP.