codelion / pathgrind

Path based Dynamic Analysis

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

pathgrind Build Status

DOI

Path based Dynamic Analysis (Works for 32-bit programs only)

Requirements

  • bzip2
  • autoconf
  • make
  • gcc
  • python
  • gawk
  • 32 bit libraries for ubuntu (sudo apt-get install ia32-libs)
  • 32 bit c library for building c programs for testing with pathgrind (sudo apt-get install libc6-dev-i386)

On ubuntu you can install the dependencies using apt-get, e.g. sudo apt-get install autoconf

Installation

$ ./install.sh

Configuration

Configuration file: fuzz/settings.cfg

Execution

CLI: $ ./fuzz/fuzz.py

GUI: $ ./fuzz/gui.py

Example

$ ./fuzz/fuzz.py test6

New input are created in testcase/input/

Crash files are be saved in testcase/crash/

You can also read a fairly detailed tutorial on Pathgrind at the SRC:CLR blog

Publications

Exploiting Undefined Behaviors for Efficient Symbolic Execution, ICSE 2014

An Empirical Study of Path Feasibility Queries, CoRR 2013

A Critical Review of Dynamic Taint Analysis and Forward Symbolic Execution, Technical Report NUS 2012

About

Path based Dynamic Analysis

License:GNU General Public License v3.0


Languages

Language:C 92.6%Language:C++ 3.5%Language:Assembly 1.3%Language:Makefile 0.8%Language:Perl 0.7%Language:Python 0.5%Language:Shell 0.4%Language:GDB 0.1%Language:Haskell 0.1%Language:Ruby 0.0%Language:Roff 0.0%Language:Lex 0.0%Language:JavaScript 0.0%Language:PHP 0.0%