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 yulei.sui@uts.edu.au if you are interested)
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.675",
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
- for(const SVFStmt* svfstmt : pta->getPAG()->getSVFStmtList(stmtNode->getICFGNode()))
264
+ if(SVFUtil::isa<StoreStmt>(stmtNode->getPAGEdge()))
265
265
  {
266
- if(SVFUtil::isa<StoreStmt>(svfstmt))
266
+ NodeID singleton;
267
+ if(isStrongUpdate(node, singleton, pta))
267
268
  {
268
- NodeID singleton;
269
- if(isStrongUpdate(node, singleton, pta))
269
+ Set<SVFGEdge*> toRemove;
270
+ for (SVFGNode::const_iterator it2 = node->InEdgeBegin(), eit2 = node->InEdgeEnd(); it2 != eit2; ++it2)
270
271
  {
271
- Set<SVFGEdge*> toRemove;
272
- for (SVFGNode::const_iterator it2 = node->InEdgeBegin(), eit2 = node->InEdgeEnd(); it2 != eit2; ++it2)
272
+ if ((*it2)->isIndirectVFGEdge())
273
273
  {
274
- if ((*it2)->isIndirectVFGEdge())
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, std::vector<const Loop *> &llvmLoops,
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, std::vector<const Loop *> &llvmLoops, llvm::LoopInfoBase<llvm::BasicBlock, llvm::Loop> * loopInfo)
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->analyze(DT);
61
- for (const auto &loop: *loopInfo)
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
- llvm::LoopInfoBase<llvm::BasicBlock, llvm::Loop> loopInfo;
88
- buildLLVMLoops(PAG::getPAG()->getModule(), llvmLoops, &loopInfo);
89
- buildSVFLoops(icfg, llvmLoops);
90
+ buildLLVMLoops(PAG::getPAG()->getModule(), icfg);
90
91
  }
91
92
 
92
93
  /*!