bin2llvm

A binary to LLVM translator

Github星跟蹤圖

The bin2llvm Project Build Status

This is an S2E based binary-to-LLVM
translator. It converts any binary code to LLVM code. The resulting LLVM module
contains functions. Some, control flow details are recovered.

Overview

The idea is to reuse components from S2E to achieve the translation to LLVM.
Rougly, qemu translates from binary to TCG and S2E translates from TCG to LLVM.
Plugins were added to perform the recursive disassembly of the binary. The
raw LLVM code is then fed to a set of external LLVM passes. The purpose of
these step is to add more details about the extracted code, concretely, basic
blocks are grouped in functions.
It is mainly tested on the ARM architecture.
bin2llvm is a best effort tool, it will try to translate as much as possible
and then link the LLVM code in a final file.

Running the Docker image

$ docker pull docker.io/cojocar/bin2llvm
$ # run one example binary
$ docker run --rm -t docker.io/cojocar/bin2llvm /bin/bash -c "/usr/local/bin2llvm/bin/bin2llvm.py --file /usr/local/bin2llvm/bin/ls-example"
$ # run the tests
$ docker run --rm -t docker.io/cojocar/bin2llvm /bin/bash -c "cd /usr/local/bin2llvm/tests; BIN2LLVM_INSTALL_DIR=/usr/local/bin2llvm make;"

How to build, install & run from the source tree

Dependencies

Consult the Dockerfile for the list of dependencies.

Building (outside Docker)

$ ./scripts/setup.sh # this will copy some dependencies in the third_party directory
$ ./scripts/build.sh ../bin2llvm-build
$ ./scripts/install.sh ../bin2llvm-build ../bin2llvm-install

(optionally) Building the Docker image

$ ./scripts/build_docker.sh

This will result in bin2llvm-dev and in bin2llvm-release-squashed images.

Running

$ cd ../bin2llvm-install && ./bin/bin2llvm.py --file ./bin/ls-example
Press Ctrl+C
INFO:bin2llvm:Using /tmp/bin2llvm-W4yJvU as temp_dir
INFO:bin2llvm:Use entry: 0x00009a74
INFO:bin2llvm:Use entry: 0x00009fa8
INFO:bin2llvm:Use entry: 0x0000c470
INFO:bin2llvm:Use entry: 0x0000c4d0
INFO:bin2llvm:Use entry: 0x0000c514
INFO:bin2llvm:Use entry: 0x0000c560
....
INFO:bin2llvm:Use entry: 0x00000000
WARNING:bin2llvm:(passes) crashed with entry: 0x00000000
INFO:bin2llvm:FINAL output is in /tmp/bin2llvm-W4yJvU/final.bc (370 functions)

The final bit code is ${OUT_DIR}/final.bc

Testing

$ cd ./tests && BIN2LLVM_INSTALL_DIR=$(realpath ../../bin2llvm-install) make

See the test directory for more details.


bin2llvm in practice

The following works are using bin2llvm:

主要指標

概覽
名稱與所有者cojocar/bin2llvm
主編程語言C++
編程語言Python (語言數: 10)
平台
許可證Apache License 2.0
所有者活动
創建於2017-05-13 09:17:36
推送於2018-06-05 12:46:08
最后一次提交2018-06-05 14:43:23
發布數0
用户参与
星數148
關注者數10
派生數18
提交數12
已啟用問題?
問題數5
打開的問題數2
拉請求數0
打開的拉請求數0
關閉的拉請求數0
项目设置
已啟用Wiki?
已存檔?
是復刻?
已鎖定?
是鏡像?
是私有?