svf-tools 1.0.990 → 1.0.992

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "svf-tools",
3
- "version": "1.0.990",
3
+ "version": "1.0.992",
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": {
@@ -192,6 +192,12 @@ public:
192
192
  {
193
193
  callPEs.push_back(callPE);
194
194
  }
195
+ /// Return call ICFGNode at the callsite
196
+ inline const CallICFGNode* getCallSite() const
197
+ {
198
+ assert(SVFUtil::isa<CallICFGNode>(getSrcNode()) && "not a CallICFGNode?");
199
+ return SVFUtil::cast<CallICFGNode>(getSrcNode());
200
+ }
195
201
  /// Add get parameter edge to this CallCFGEdge
196
202
  inline const std::vector<const CallPE*>& getCallPEs() const
197
203
  {
@@ -243,6 +249,9 @@ public:
243
249
  {
244
250
  return retPE;
245
251
  }
252
+ /// Return call ICFGNode at the callsite
253
+ const CallICFGNode* getCallSite() const;
254
+
246
255
  /// Methods for support type inquiry through isa, cast, and dyn_cast:
247
256
  //@{
248
257
  static inline bool classof(const RetCFGEdge*)
@@ -149,6 +149,15 @@ void ConstraintGraph::buildCG()
149
149
  */
150
150
  void ConstraintGraph::clearSolitaries()
151
151
  {
152
+ /// We don't remove return SVFVar from an indirect callsite
153
+ NodeSet retFromIndCalls;
154
+ for(auto cs_pair : pag->getIndirectCallsites())
155
+ {
156
+ const RetICFGNode* retBlockNode = cs_pair.first->getRetICFGNode();
157
+ if(pag->callsiteHasRet(retBlockNode))
158
+ retFromIndCalls.insert(pag->getCallSiteRet(retBlockNode)->getId());
159
+ }
160
+
152
161
  Set<ConstraintNode*> nodesToRemove;
153
162
  for (auto it = this->begin(); it != this->end(); ++it)
154
163
  {
@@ -156,6 +165,8 @@ void ConstraintGraph::clearSolitaries()
156
165
  continue;
157
166
  if (pag->getGNode(it->first)->isPointer())
158
167
  continue;
168
+ if (retFromIndCalls.find(it->first)!=retFromIndCalls.end())
169
+ continue;
159
170
  nodesToRemove.insert(it->second);
160
171
  }
161
172
 
@@ -192,6 +192,13 @@ const std::string RetCFGEdge::toString() const
192
192
  return rawstr.str();
193
193
  }
194
194
 
195
+ /// Return call ICFGNode at the callsite
196
+ const CallICFGNode* RetCFGEdge::getCallSite() const
197
+ {
198
+ assert(SVFUtil::isa<RetICFGNode>(getDstNode()) && "not a RetICFGNode?");
199
+ return SVFUtil::cast<RetICFGNode>(getDstNode())->getCallICFGNode();
200
+ }
201
+
195
202
  /*!
196
203
  * Constructor
197
204
  * * Build ICFG