svf-tools 1.0.1220 → 1.0.1222
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.
|
|
3
|
+
"version": "1.0.1222",
|
|
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": {
|
|
@@ -72,6 +72,18 @@ public:
|
|
|
72
72
|
/// Given an ObjVar and its def-site ICFGNode, find all use-site ICFGNodes
|
|
73
73
|
const Set<const ICFGNode*> getUseSitesOfObjVar(const ObjVar* obj, const ICFGNode* node) const;
|
|
74
74
|
|
|
75
|
+
/// Given a ValVar, find all use-site ICFGNodes
|
|
76
|
+
/// by following outgoing direct VFGEdges from its unique definition SVFGNode
|
|
77
|
+
const Set<const ICFGNode*> getUseSitesOfValVar(const ValVar* var) const;
|
|
78
|
+
|
|
79
|
+
/// Given a ValVar and its SVFGNode, find the definition-site ICFGNode
|
|
80
|
+
/// by following incoming direct VFGEdges (asserts unique definition)
|
|
81
|
+
const ICFGNode* getDefSiteOfValVar(const ValVar* var) const;
|
|
82
|
+
|
|
83
|
+
/// Given an ObjVar and its use-site ICFGNode, find the definition-site ICFGNode
|
|
84
|
+
/// by following incoming IndirectSVFGEdges whose pts contains the ObjVar (asserts unique definition)
|
|
85
|
+
const ICFGNode* getDefSiteOfObjVar(const ObjVar* obj, const ICFGNode* node) const;
|
|
86
|
+
|
|
75
87
|
/// Build WTO for each function using call graph SCC
|
|
76
88
|
void initWTO();
|
|
77
89
|
|
|
@@ -67,6 +67,47 @@ const Set<const ICFGNode*> PreAnalysis::getUseSitesOfObjVar(const ObjVar* obj, c
|
|
|
67
67
|
return succs;
|
|
68
68
|
}
|
|
69
69
|
|
|
70
|
+
const Set<const ICFGNode*> PreAnalysis::getUseSitesOfValVar(const ValVar* var) const
|
|
71
|
+
{
|
|
72
|
+
if (Options::SparseAE())
|
|
73
|
+
{
|
|
74
|
+
assert(svfg && "SVFG is not built for sparse AE");
|
|
75
|
+
return svfg->getUseSitesOfValVar(var);
|
|
76
|
+
}
|
|
77
|
+
// Non-sparse mode: return ICFG successor nodes of the ValVar's ICFGNode
|
|
78
|
+
Set<const ICFGNode*> succs;
|
|
79
|
+
if (const ICFGNode* node = var->getICFGNode())
|
|
80
|
+
{
|
|
81
|
+
for (const auto* edge : node->getOutEdges())
|
|
82
|
+
succs.insert(edge->getDstNode());
|
|
83
|
+
}
|
|
84
|
+
return succs;
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
const ICFGNode* PreAnalysis::getDefSiteOfValVar(const ValVar* var) const
|
|
88
|
+
{
|
|
89
|
+
if (Options::SparseAE())
|
|
90
|
+
{
|
|
91
|
+
assert(svfg && "SVFG is not built for sparse AE");
|
|
92
|
+
return svfg->getDefSiteOfValVar(var);
|
|
93
|
+
}
|
|
94
|
+
// Non-sparse mode: return the ValVar's associated ICFGNode
|
|
95
|
+
return var->getICFGNode();
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
const ICFGNode* PreAnalysis::getDefSiteOfObjVar(const ObjVar* obj, const ICFGNode* node) const
|
|
99
|
+
{
|
|
100
|
+
if (Options::SparseAE())
|
|
101
|
+
{
|
|
102
|
+
assert(svfg && "SVFG is not built for sparse AE");
|
|
103
|
+
return svfg->getDefSiteOfObjVar(obj, node);
|
|
104
|
+
}
|
|
105
|
+
// Non-sparse mode: return ICFG predecessor node
|
|
106
|
+
for (const auto* edge : node->getInEdges())
|
|
107
|
+
return edge->getSrcNode();
|
|
108
|
+
return nullptr;
|
|
109
|
+
}
|
|
110
|
+
|
|
70
111
|
void PreAnalysis::initWTO()
|
|
71
112
|
{
|
|
72
113
|
callGraphSCC->find();
|