Skip to content

ZJU-Automated-Reasoning-Group/canary

 
 

Repository files navigation

Canary

Canary is a program analysis and verification framework. It provides severl toolkits that can be used individully or in combination to perform different tasks. The current version of Canary has been tested on x86 Linux architectures using LLVM-12 and Z3-4.11.

  • Alias Analysis: a unification-based, exhuastive alias analysis (See lib/DyckAA)
  • SMT Solving (See lib/SMT)
  • Binary Decision Diagram (BDD): (See lib/cudd)

Installation

Build LLVM

# Clone LLVM repository
git clone https://github.com/llvm/llvm-project.git
cd llvm-project

# Checkout desired version
git checkout llvmorg-14.0.0  # or llvmorg-12.0.0

# Build LLVM
mkdir build && cd build
cmake -DCMAKE_BUILD_TYPE=Release ../llvm
make -j$(nproc)  # Uses all available CPU cores

Then, you can build this projet as follow

git clone https://github.com/ZJU-Automated-Reasoning-Group/canary
cd canary
mkdir build
cd build
cmake ../ -DLLVM_BUILD_PATH=/path/to/llvm/build
make -j$(nproc)

Currently, we asume that the system has the right version of Z3.

TBD: download the LLVM and Z3 obj files automatically...

Using the Alias Analysis

Build and link the lib files to your project and use DyckAliasAnalysis as a common Mod pass. You may use the following options.

  • -print-alias-set-info

This will print the evaluation of alias sets and outputs all alias sets, and their relations (dot style).

  • -count-fp

Count how many functions that a function pointer may point to.

  • -no-function-type-check

If the option is set, we do not check the function FuncTy when resolving pointer calls, otherwise, only FuncTy compatible function can be aliased with a function pointer. We say f1 and f2 are two FuncTy-compatible functions iff.

- Both or netheir of them are var arg function;

- Both or netheir of them have a non-void return value;

- Same number of parameters;

- Same FuncTy store sizes of each pair of parameters;

- There is an explicit cast operation between FuncTy(f1) and FuncTy(f2) (it works with option -with-function-cast-comb).
  • -dot-dyck-callgraph

This option is used to print a call graph based on the alias analysis. You can use it with -with-labels option, which will add lables (call insts) to the edges in call graphs.

Using the SMT Solver

./owl file.smt2

About

A unification-based alias analysis and related tools

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 60.4%
  • C 32.6%
  • Python 5.4%
  • CMake 0.6%
  • M4 0.4%
  • Shell 0.3%
  • Makefile 0.3%