Skip to content

TalbenXu/POCR

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

66 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Intro

POCR is a light-weight CFL-reachability tool developed upon the open-source tool SVF and run on Ubuntu (20.04 or higher) or MacOS. It includes a general CFL-reachability solver and to specific solvers for field-sensitive alias analysis and context-sensitive value-flow analysis, where our fast CFL-reachability algorithm POCR is implemented.

Setup POCR

1. Install dependencies

sudo apt install cmake gcc g++ libtinfo-dev libz-dev zip wget npm

2. Clone repository

git clone https://github.com/kisslune/POCR.git

3. Build POCR

cd POCR
source ./build.sh

4. Setup environment

. ./setup.sh

Usage

General CFL-reachability solver

POCR provides a general standard CFL-reachability solver as the baseline, which accepts an input GRAMMAR_FILE and an input <GRAPH_FILE>. You can invoke the general solver using the following command:

cfl -std <GRAMMAR_FILE> <GRAPH_FILE>

The <GRAMMAR_FILE> should be normalized with the following format:

A   B   C

where A denotes the symbol on the left-hand side of a production rule and B, C denotes the symbols on the right-hand side of the production rule. Note: B and C are optional, and the symbols should be separated by a tab character, i.e., "\t".

<GRAPH_FILE> should be with the following format:

EDGE_SOURCE    EDGE_DESTINATION    EDGE_LABEL    LABEL_INDEX

Note: the symbols should also be separated by a tab character, i.e., "\t" and any EDGE_LABEL having a subscript should end with "_i". For example, an edge $1 \xrightarrow{X_3} 2$ is denoted by 1 2 X_i 3 in <GRAPH_FILE>.

Field-Sensitive Alias Analyzer

You can invoke the alias analyzer by either of the following two commands:

aa -std <GRAPH_FILE>
aa -pocr <GRAPH_FILE>

where the format of the input <GRAPH_FILE> is the same as what for the general solver.

The difference between the above two commands is that the first one solves CFL-reachability using the classical algorithm whereas the second one uses our POCR algorithm.

Note: the EDGE_LABEL of the input grammar file may contain the following six terminals of the context-free grammar:

  • a: assigment
  • d: dereference
  • f_i: address of field with an index i

and their reverses aber, dbar and fbar_i.

Grammar (normalized and already embeded in the solver).

Context-Sensitive Value-Flow Analyzer

Like alias analyzer, you can use

vf -std <GRAPH_FILE>

or

vf -pocr <GRAPH_FILE>

to run value-flow analysis on the input <GRAPH_FILE> with the classical CFL-reachability algorithm or our POCR algorithm. The format of the input <GRAPH_FILE> is also the same as what for the general solver.

Note: the EDGE_LABEL of the input grammar file may contain the following six terminals of the context-free grammar:

  • a: assignment
  • call_i: call with a callsite index i
  • ret_i: return with a callsite index i

Grammar (normalized and already embeded in the solver).

Test Cases

We provide some program expression graphs (PEGs) and value-flow graphs (VFGs) in tests/ as the test cases of POCR. You can enter the directory and try POCR with the following commands:

aa -pocr art.peg
vf -pocr art.vfg
cfl -std aa.cfg art.peg
cfl -std vf.cfg art.vfg

Plan

  • Merge our work to the upstream SVF.

  • Implement the POCR algorithm for more clients.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 96.8%
  • CMake 2.6%
  • Shell 0.6%