CFG explorer
Project description
cfg-explorer
CFG explorer is a simple utility which can be used to explore control flow graphs of binary programs.
It uses angr binary analysis framework, for CFG recovery, and renders the CFG to SVGs, with the help of bingraphvis.
The generated SVGs can be navigated by clicking on the function or the callsite nodes.
Besides, now it can also export multiple formats of static CFG files to your local machine, including:
- .canon
- .cmap
- .cmapx
- .cmapx_np
- .dot
- .fig
- .gd
- .gd2
- .gif
- .imap
- .imap_np
- .ismap
- .jpe
- .jpeg
- .jpg
- .mp
- .plain
- .plain-ext
- .png
- .ps
- .ps2
- .svg
- .svgz
- .vml
- .vmlz
- .vrml
- .wbmp
- .xdot
- .raw
CFGs starting from multiple start addresses or for multiple functions can also be automatically exported to multiple files at once with different suffixes in their filenames.
Note
This project is in its very early stage!
Install
$ pip install cfg-explorer
Usage
CLI
After installation, cfg_explorer
can be easily called in command lines as:
$ cfgexplorer --help
usage: cfgexplorer [-h] [-v] [-s [STARTS [STARTS ...]]] [-P PORT] [-p] [-l]
[-o OUTFILE]
binary
positional arguments:
binary the binary to explore
optional arguments:
-h, --help show this help message and exit
-v, --verbose increase output verbosity
-s [STARTS [STARTS ...]], --start [STARTS [STARTS ...]]
start addresses
-P PORT, --port PORT server port
-p, --pie is position independent
-l, --launch launch browser
-o OUTFILE, --output OUTFILE
output file path, only support for ['canon', 'cmap',
'cmapx', 'cmapx_np', 'dot', 'fig', 'gd', 'gd2', 'gif',
'imap', 'imap_np', 'ismap', 'jpe', 'jpeg', 'jpg',
'mp', 'pdf', 'plain', 'plain-ext', 'png', 'ps', 'ps2',
'svg', 'svgz', 'vml', 'vmlz', 'vrml', 'wbmp', 'xdot',
'raw']
For example:
$ cfgexplorer /your/binary -l
The command above will build the CFG, spawn a web server, and open it in your browser.
Module
You can also utilize cfg_explore
function in it as other common modules in Python:
from cfgexplorer import cfg_explore
cfg_explore(binary=r'/your/binary', launch=True)
The codes will do what the cfgexplorer
does in the previous example. If you want to shut down the app, you need to interrupt your Python interpreter as well. So the function is more often used by specifying output
to generate output files in a Python program like:
cfg_explore(binary=r'/your/binary', output='./cfg_output.svg')
The code above exports CFG as svg
format to file path ./cfg_output.svg
The function is defined as follow:
cfg_explore(binary, starts=[], port=5000, pie=False, launch=False, output='')
- binary(str): the path of the binary file to analysis
- starts(list): the start points (address) in CFGs, if none, the CFG will start with main func entry address
- port(int): server port to host the web app. make sure the port is idle now.
- pie(bool): whether the analysis position-independent
- launch(bool): Whether launch a browser to view CFG immediately
- output(str): the output file path. only support certain formats. If you leave it an empty string, no output will be generated and the interactive web app will start. Otherwise, no app will be launched and the CFGs will be exported to specified files.
Detailed usages of this function are available in examples/demo.ipynb.
Annotation Style
Edges:
Edge class | Color | Style |
---|---|---|
Conditional True | Green | |
Conditional False | Red | |
Unconditional | Blue | |
Next | Blue | Dashed |
Call | Black | |
Return | Gray | |
Fake Return | Gray | Dotted |
Unknown | Orange |
Limitations
- works on Linux only
- at the moment, the result is simply an SVG file, i plan to add a small frontend around it
Screenshots
Function graph mode (/function/0x123456
)
CFG mode (/cfg/0x123456
)
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file cfg-explorer-0.0.2.tar.gz
.
File metadata
- Download URL: cfg-explorer-0.0.2.tar.gz
- Upload date:
- Size: 24.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/53.0.0 requests-toolbelt/0.9.1 tqdm/4.57.0 CPython/3.7.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 965124ca9ed931a2ae2afea62cfbc476f9e96c8db96e6f53b837a3479437c389 |
|
MD5 | 9720f8e78dc712635980697d4a8d72fb |
|
BLAKE2b-256 | 808db2e1273729f5d7e57d5eff7ad7df42bbd92a5ce3bad1eb8e8d75172e1f1a |
File details
Details for the file cfg_explorer-0.0.2-py3-none-any.whl
.
File metadata
- Download URL: cfg_explorer-0.0.2-py3-none-any.whl
- Upload date:
- Size: 27.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/53.0.0 requests-toolbelt/0.9.1 tqdm/4.57.0 CPython/3.7.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 08ad54ce77b7412c01eb771bdab556564de99d60b5cb3cdd102534cd497c0fab |
|
MD5 | da34287595fcecc6dfe785dc382b057c |
|
BLAKE2b-256 | 5db878b905336a5289561f1572641caa439acefd7c770faabb2c3e1e1a033fcc |