Static Value-Flow Analysis
Loading...
Searching...
No Matches
svf-ex.cpp
Go to the documentation of this file.
1//===- svf-ex.cpp -- A driver example of SVF-------------------------------------//
2//
3// SVF: Static Value-Flow Analysis
4//
5// Copyright (C) <2013-> <Yulei Sui>
6//
7
8// This program is free software: you can redistribute it and/or modify
9// it under the terms of the GNU General Public License as published by
10// the Free Software Foundation, either version 3 of the License, or
11// (at your option) any later version.
12
13// This program is distributed in the hope that it will be useful,
14// but WITHOUT ANY WARRANTY; without even the implied warranty of
15// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16// GNU General Public License for more details.
17
18// You should have received a copy of the GNU General Public License
19// along with this program. If not, see <http://www.gnu.org/licenses/>.
20//
21//===-----------------------------------------------------------------------===//
22
23/*
24 // A driver program of SVF including usages of SVF APIs
25 //
26 // Author: Yulei Sui,
27 */
28
30#include "Graphs/SVFG.h"
31#include "SVF-LLVM/LLVMUtil.h"
33#include "Util/CommandLine.h"
34#include "Util/Options.h"
35#include "WPA/Andersen.h"
36
37using namespace llvm;
38using namespace std;
39using namespace SVF;
40
45{
46 return pta->alias(v1->getId(), v2->getId());
47}
48
52std::string printPts(PointerAnalysis* pta, const SVFVar* svfval)
53{
54
55 std::string str;
57
58 NodeID pNodeId = svfval->getId();
59 const PointsTo& pts = pta->getPts(pNodeId);
60 for (PointsTo::iterator ii = pts.begin(), ie = pts.end();
61 ii != ie; ii++)
62 {
63 rawstr << " " << *ii << " ";
64 PAGNode* targetObj = pta->getPAG()->getGNode(*ii);
65 rawstr << "(" << targetObj->toString() << ")\t ";
66 }
67
68 return rawstr.str();
69
70}
74void traverseOnICFG(ICFG* icfg, const ICFGNode* iNode)
75{
78 worklist.push(iNode);
79
81 while (!worklist.empty())
82 {
83 const ICFGNode* vNode = worklist.pop();
84 for (ICFGNode::const_iterator it = vNode->OutEdgeBegin(), eit =
85 vNode->OutEdgeEnd(); it != eit; ++it)
86 {
87 ICFGEdge* edge = *it;
88 ICFGNode* succNode = edge->getDstNode();
89 if (visited.find(succNode) == visited.end())
90 {
91 visited.insert(succNode);
92 worklist.push(succNode);
93 }
94 }
95 }
96}
97
98void dummyVisit(const VFGNode* node)
99{
100
101}
105void traverseOnVFG(const SVFG* vfg, const SVFVar* svfval)
106{
107 if (!vfg->hasDefSVFGNode(svfval))
108 return;
109 const VFGNode* vNode = vfg->getDefSVFGNode(svfval);
111 Set<const VFGNode*> visited;
112 worklist.push(vNode);
113
115 while (!worklist.empty())
116 {
117 const VFGNode* vNode = worklist.pop();
118 for (VFGNode::const_iterator it = vNode->OutEdgeBegin(), eit =
119 vNode->OutEdgeEnd(); it != eit; ++it)
120 {
121 VFGEdge* edge = *it;
122 VFGNode* succNode = edge->getDstNode();
123 if (visited.find(succNode) == visited.end())
124 {
125 visited.insert(succNode);
126 worklist.push(succNode);
127 }
128 }
129 }
130
132 for(Set<const VFGNode*>::const_iterator it = visited.begin(), eit = visited.end(); it!=eit; ++it)
133 {
134 const VFGNode* node = *it;
135 dummyVisit(node);
139 }
140}
141
142int main(int argc, char ** argv)
143{
144
145 std::vector<std::string> moduleNameVec;
147 argc, argv, "Whole Program Points-to Analysis", "[options] <input-bitcode...>"
148 );
149
150 if (Options::WriteAnder() == "ir_annotator")
151 {
153 }
154
156
159 SVFIR* pag = builder.build();
160
163
164
166 CallGraph* callgraph = ander->getCallGraph();
167
169 ICFG* icfg = pag->getICFG();
170
172 VFG* vfg = new VFG(callgraph);
173
176 SVFG* svfg = svfBuilder.buildFullSVFG(ander);
177
179 if (Options::PTSPrint())
180 {
181 for (const auto& it : *svfg)
182 {
183 const SVFGNode* node = it.second;
184 if (node->getValue())
185 {
186 traverseOnVFG(svfg, node->getValue());
188 printPts(ander, node->getValue());
189 for (const SVFGEdge* edge : node->getOutEdges())
190 {
191 const SVFGNode* node2 = edge->getDstNode();
192 if (node2->getValue())
193 aliasQuery(ander, node->getValue(), node2->getValue());
194 }
195 }
196 }
197 }
198
200 if (Options::PTSPrint())
201 {
202 for (const auto& it : *icfg)
203 {
204 const ICFGNode* node = it.second;
205 traverseOnICFG(icfg, node);
206 }
207 }
208
209 // clean up memory
210 delete vfg;
213
216 llvm::llvm_shutdown();
217 return 0;
218}
219
static std::vector< std::string > parseOptions(int argc, char *argv[], std::string description, std::string callFormat)
Definition CommandLine.h:75
static AndersenWaveDiff * createAndersenWaveDiff(SVFIR *_pag)
Create an singleton instance directly instead of invoking llvm pass manager.
Definition Andersen.h:407
static void releaseAndersenWaveDiff()
Definition Andersen.h:417
bool push(const Data &data)
Definition WorkList.h:165
bool empty() const
Definition WorkList.h:146
NodeType * getGNode(NodeID id) const
Get a node.
const GEdgeSetTy & getOutEdges() const
ICFGEdge::ICFGEdgeSetTy::const_iterator const_iterator
Definition ICFGNode.h:62
static LLVMModuleSet * getLLVMModuleSet()
Definition LLVMModule.h:129
static void releaseLLVMModuleSet()
Definition LLVMModule.h:136
static void preProcessBCs(std::vector< std::string > &moduleNameVec)
static void buildSVFModule(Module &mod)
void dumpModulesToFile(const std::string &suffix)
static const Option< bool > PTSPrint
Definition Options.h:116
static const Option< std::string > WriteAnder
Definition Options.h:212
virtual const PointsTo & getPts(NodeID ptr)=0
Get points-to targets of a pointer. It needs to be implemented in child class.
SVFIR * getPAG() const
CallGraph * getCallGraph() const
Return call graph.
virtual AliasResult alias(const SVFVar *V1, const SVFVar *V2)=0
Interface exposed to users of our pointer analysis, given Value infos.
static void releaseSVFIR()
Definition SVFIR.h:124
ICFG * getICFG() const
Definition SVFIR.h:163
virtual const std::string toString() const
Get string representation.
virtual const SVFVar * getValue() const
Return the corresponding LLVM value, if possible, nullptr otherwise.
Definition VFGNode.h:85
VFGEdge::VFGEdgeSetTy::const_iterator const_iterator
Definition VFGNode.h:55
Definition VFG.h:51
for isBitcode
Definition BasicTypes.h:68
u32_t NodeID
Definition GeneralType.h:56
AliasResult
Definition SVFType.h:541
llvm::IRBuilder IRBuilder
Definition BasicTypes.h:74
std::unordered_set< Key, Hash, KeyEqual, Allocator > Set
Definition GeneralType.h:96
void traverseOnICFG(ICFG *icfg, const ICFGNode *iNode)
Definition svf-ex.cpp:74
int main(int argc, char **argv)
Definition svf-ex.cpp:142
std::string printPts(PointerAnalysis *pta, const SVFVar *svfval)
Definition svf-ex.cpp:52
SVF::AliasResult aliasQuery(PointerAnalysis *pta, const SVFVar *v1, const SVFVar *v2)
Definition svf-ex.cpp:44
void dummyVisit(const VFGNode *node)
Definition svf-ex.cpp:98
void traverseOnVFG(const SVFG *vfg, const SVFVar *svfval)
Definition svf-ex.cpp:105