svf-tools 1.0.675 → 1.0.677
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md
CHANGED
|
@@ -42,7 +42,7 @@
|
|
|
42
42
|
|
|
43
43
|
<br />
|
|
44
44
|
|
|
45
|
-
#### We are looking for self-motivated PhD students and we welcome industry collaboration/sponsorship to improve SVF (Please contact
|
|
45
|
+
#### We are looking for self-motivated PhD students and we welcome industry collaboration/sponsorship to improve SVF (Please contact y.sui@unsw.edu.au if you are interested)
|
|
46
46
|
|
|
47
47
|
<br />
|
|
48
48
|
<p>We release SVF source code in the hope of benefiting others. You are kindly asked to acknowledge usage of the tool by citing some of our publications listed http://svf-tools.github.io/SVF, especially the following two: </p>
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "svf-tools",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.677",
|
|
4
4
|
"description": "* <b>[TypeClone](https://github.com/SVF-tools/SVF/wiki/TypeClone) published in our [ECOOP paper](https://yuleisui.github.io/publications/ecoop20.pdf) is now available in SVF </b> * <b>SVF now uses a single script for its build. Just type [`source ./build.sh`](https://github.com/SVF-tools/SVF/blob/master/build.sh) in your terminal, that's it!</b> * <b>SVF now supports LLVM-10.0.0! </b> * <b>We thank [bsauce](https://github.com/bsauce) for writing a user manual of SVF ([link1](https://www.jianshu.com/p/068a08ec749c) and [link2](https://www.jianshu.com/p/777c30d4240e)) in Chinese </b> * <b>SVF now supports LLVM-9.0.0 (Thank [Byoungyoung Lee](https://github.com/SVF-tools/SVF/issues/142) for his help!). </b> * <b>SVF now supports a set of [field-sensitive pointer analyses](https://yuleisui.github.io/publications/sas2019a.pdf). </b> * <b>[Use SVF as an external lib](https://github.com/SVF-tools/SVF/wiki/Using-SVF-as-a-lib-in-your-own-tool) for your own project (Contributed by [Hongxu Chen](https://github.com/HongxuChen)). </b> * <b>SVF now supports LLVM-7.0.0. </b> * <b>SVF now supports Docker. [Try SVF in Docker](https://github.com/SVF-tools/SVF/wiki/Try-SVF-in-Docker)! </b> * <b>SVF now supports [LLVM-6.0.0](https://github.com/svf-tools/SVF/pull/38) (Contributed by [Jack Anthony](https://github.com/jackanth)). </b> * <b>SVF now supports [LLVM-4.0.0](https://github.com/svf-tools/SVF/pull/23) (Contributed by Jared Carlson. Thank [Jared](https://github.com/jcarlson23) and [Will](https://github.com/dtzWill) for their in-depth [discussions](https://github.com/svf-tools/SVF/pull/18) about updating SVF!) </b> * <b>SVF now supports analysis for C++ programs.</b> <br />",
|
|
5
5
|
"main": "index.js",
|
|
6
6
|
"scripts": {
|
|
@@ -261,27 +261,23 @@ void SaberSVFGBuilder::rmIncomingEdgeForSUStore(BVDataPTAImpl* pta)
|
|
|
261
261
|
|
|
262
262
|
if(const StoreSVFGNode* stmtNode = SVFUtil::dyn_cast<StoreSVFGNode>(node))
|
|
263
263
|
{
|
|
264
|
-
|
|
264
|
+
if(SVFUtil::isa<StoreStmt>(stmtNode->getPAGEdge()))
|
|
265
265
|
{
|
|
266
|
-
|
|
266
|
+
NodeID singleton;
|
|
267
|
+
if(isStrongUpdate(node, singleton, pta))
|
|
267
268
|
{
|
|
268
|
-
|
|
269
|
-
|
|
269
|
+
Set<SVFGEdge*> toRemove;
|
|
270
|
+
for (SVFGNode::const_iterator it2 = node->InEdgeBegin(), eit2 = node->InEdgeEnd(); it2 != eit2; ++it2)
|
|
270
271
|
{
|
|
271
|
-
|
|
272
|
-
for (SVFGNode::const_iterator it2 = node->InEdgeBegin(), eit2 = node->InEdgeEnd(); it2 != eit2; ++it2)
|
|
272
|
+
if ((*it2)->isIndirectVFGEdge())
|
|
273
273
|
{
|
|
274
|
-
|
|
275
|
-
{
|
|
276
|
-
toRemove.insert(*it2);
|
|
277
|
-
}
|
|
278
|
-
}
|
|
279
|
-
for (SVFGEdge* edge: toRemove)
|
|
280
|
-
{
|
|
281
|
-
svfg->removeSVFGEdge(edge);
|
|
274
|
+
toRemove.insert(*it2);
|
|
282
275
|
}
|
|
283
276
|
}
|
|
284
|
-
|
|
277
|
+
for (SVFGEdge* edge: toRemove)
|
|
278
|
+
{
|
|
279
|
+
svfg->removeSVFGEdge(edge);
|
|
280
|
+
}
|
|
285
281
|
}
|
|
286
282
|
}
|
|
287
283
|
}
|
|
@@ -47,8 +47,7 @@ public:
|
|
|
47
47
|
virtual ~LLVMLoopAnalysis() = default;
|
|
48
48
|
|
|
49
49
|
/// Build llvm loops based on LoopInfo analysis
|
|
50
|
-
virtual void buildLLVMLoops(SVFModule *mod,
|
|
51
|
-
llvm::LoopInfoBase<llvm::BasicBlock, llvm::Loop> * loopInfo);
|
|
50
|
+
virtual void buildLLVMLoops(SVFModule *mod, ICFG* icfg);
|
|
52
51
|
|
|
53
52
|
/// Start from here
|
|
54
53
|
virtual void build(ICFG *icfg);
|
|
@@ -44,7 +44,7 @@ using namespace SVFUtil;
|
|
|
44
44
|
* @param mod SVF module
|
|
45
45
|
* @param llvmLoops output llvm loops
|
|
46
46
|
*/
|
|
47
|
-
void LLVMLoopAnalysis::buildLLVMLoops(SVFModule *mod,
|
|
47
|
+
void LLVMLoopAnalysis::buildLLVMLoops(SVFModule *mod, ICFG* icfg)
|
|
48
48
|
{
|
|
49
49
|
llvm::DominatorTree DT = llvm::DominatorTree();
|
|
50
50
|
std::vector<const Loop *> loop_stack;
|
|
@@ -57,8 +57,10 @@ void LLVMLoopAnalysis::buildLLVMLoops(SVFModule *mod, std::vector<const Loop *>
|
|
|
57
57
|
// do not analyze external call
|
|
58
58
|
if (SVFUtil::isExtCall(svffun)) continue;
|
|
59
59
|
DT.recalculate(const_cast<Function&>(*func));
|
|
60
|
-
loopInfo
|
|
61
|
-
|
|
60
|
+
llvm::LoopInfoBase<llvm::BasicBlock, llvm::Loop> loopInfo;
|
|
61
|
+
std::vector<const Loop*> llvmLoops;
|
|
62
|
+
loopInfo.analyze(DT);
|
|
63
|
+
for (const auto &loop: loopInfo)
|
|
62
64
|
{
|
|
63
65
|
loop_stack.push_back(loop);
|
|
64
66
|
}
|
|
@@ -73,6 +75,7 @@ void LLVMLoopAnalysis::buildLLVMLoops(SVFModule *mod, std::vector<const Loop *>
|
|
|
73
75
|
loop_stack.push_back(subloop);
|
|
74
76
|
}
|
|
75
77
|
}
|
|
78
|
+
buildSVFLoops(icfg, llvmLoops);
|
|
76
79
|
}
|
|
77
80
|
}
|
|
78
81
|
}
|
|
@@ -84,9 +87,7 @@ void LLVMLoopAnalysis::buildLLVMLoops(SVFModule *mod, std::vector<const Loop *>
|
|
|
84
87
|
void LLVMLoopAnalysis::build(ICFG *icfg)
|
|
85
88
|
{
|
|
86
89
|
std::vector<const Loop *> llvmLoops;
|
|
87
|
-
|
|
88
|
-
buildLLVMLoops(PAG::getPAG()->getModule(), llvmLoops, &loopInfo);
|
|
89
|
-
buildSVFLoops(icfg, llvmLoops);
|
|
90
|
+
buildLLVMLoops(PAG::getPAG()->getModule(), icfg);
|
|
90
91
|
}
|
|
91
92
|
|
|
92
93
|
/*!
|