-
Notifications
You must be signed in to change notification settings - Fork 141
Assignment 3
Yulei Sui edited this page Apr 13, 2021
·
31 revisions
$tree Assignment-3
|-- Assignment-3.cpp
|-- Assignment-3.h
|-- CMakeLists.txt
|-- Test3.cpp
`-- testcase
|-- bc
| |-- CI-global.ll
| `-- CI-local.ll
`-- src
|-- CI-global.c
`-- CI-local.c
* Before coding, please type cd $HOME/SVF-Teaching and git pull in your terminal to make sure you always have the latest version of the code template before each assignment.
If git pull fails due to the conflict with your local changes, type git stash to store your current code in a temporal branch and type git pull again. If you want to retrieve your code back, type git stash pop.

- Implement the
SolveWorklistmethod of classAndersenPTAinAssignment-3.cpp - Pass the test without any assertion by
Test3.cpp - Submit
Assignment-3.cppto canvas
*You will be working on Assignment-3.cpp only and there is NO need to modify other files under the Assignment-3 folder
Please follow SVF APIs to manipulate points-to sets (e.g., union/add operations) in your Andersen's analysis implementation. Retrieving the attributes of classes ConstraintGraph, ConstraintNode and ConstraintEdge in SVF.
We provided two test cases with their corresponding LLVM bc files.
You are encouraged to write more test cases by writing your own C programs. Similar to our test cases, a C program you write will need to use MAYALIAS or NOALIAS methods to indicate the ground truth or oracle of a correct analysis (see here). Once after executing Andersen's analysis, SVF will automatically check the points-to results from Andersen against the ground truth you provided (via MAYALIAS or NOALIAS).