svf-tools 1.0.989 → 1.0.991
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.991",
|
|
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": {
|
|
@@ -55,7 +55,7 @@ public:
|
|
|
55
55
|
* @brief Constructor for AbsExtAPI.
|
|
56
56
|
* @param abstractTrace Reference to a map of ICFG nodes to abstract states.
|
|
57
57
|
*/
|
|
58
|
-
AbsExtAPI(Map<const ICFGNode*, AbstractState>&
|
|
58
|
+
AbsExtAPI(Map<const ICFGNode*, AbstractState>& traces);
|
|
59
59
|
|
|
60
60
|
/**
|
|
61
61
|
* @brief Initializes the external function map.
|
|
@@ -298,7 +298,53 @@ private:
|
|
|
298
298
|
std::vector<std::unique_ptr<AEDetector>> detectors;
|
|
299
299
|
AbsExtAPI* utils;
|
|
300
300
|
|
|
301
|
-
|
|
301
|
+
// according to varieties of cmp insts,
|
|
302
|
+
// maybe var X var, var X const, const X var, const X const
|
|
303
|
+
// we accept 'var X const' 'var X var' 'const X const'
|
|
304
|
+
// if 'const X var', we need to reverse op0 op1 and its predicate 'var X' const'
|
|
305
|
+
// X' is reverse predicate of X
|
|
306
|
+
// == -> !=, != -> ==, > -> <=, >= -> <, < -> >=, <= -> >
|
|
307
|
+
|
|
308
|
+
Map<s32_t, s32_t> _reverse_predicate =
|
|
309
|
+
{
|
|
310
|
+
{CmpStmt::Predicate::FCMP_OEQ, CmpStmt::Predicate::FCMP_ONE}, // == -> !=
|
|
311
|
+
{CmpStmt::Predicate::FCMP_UEQ, CmpStmt::Predicate::FCMP_UNE}, // == -> !=
|
|
312
|
+
{CmpStmt::Predicate::FCMP_OGT, CmpStmt::Predicate::FCMP_OLE}, // > -> <=
|
|
313
|
+
{CmpStmt::Predicate::FCMP_OGE, CmpStmt::Predicate::FCMP_OLT}, // >= -> <
|
|
314
|
+
{CmpStmt::Predicate::FCMP_OLT, CmpStmt::Predicate::FCMP_OGE}, // < -> >=
|
|
315
|
+
{CmpStmt::Predicate::FCMP_OLE, CmpStmt::Predicate::FCMP_OGT}, // <= -> >
|
|
316
|
+
{CmpStmt::Predicate::FCMP_ONE, CmpStmt::Predicate::FCMP_OEQ}, // != -> ==
|
|
317
|
+
{CmpStmt::Predicate::FCMP_UNE, CmpStmt::Predicate::FCMP_UEQ}, // != -> ==
|
|
318
|
+
{CmpStmt::Predicate::ICMP_EQ, CmpStmt::Predicate::ICMP_NE}, // == -> !=
|
|
319
|
+
{CmpStmt::Predicate::ICMP_NE, CmpStmt::Predicate::ICMP_EQ}, // != -> ==
|
|
320
|
+
{CmpStmt::Predicate::ICMP_UGT, CmpStmt::Predicate::ICMP_ULE}, // > -> <=
|
|
321
|
+
{CmpStmt::Predicate::ICMP_ULT, CmpStmt::Predicate::ICMP_UGE}, // < -> >=
|
|
322
|
+
{CmpStmt::Predicate::ICMP_UGE, CmpStmt::Predicate::ICMP_ULT}, // >= -> <
|
|
323
|
+
{CmpStmt::Predicate::ICMP_SGT, CmpStmt::Predicate::ICMP_SLE}, // > -> <=
|
|
324
|
+
{CmpStmt::Predicate::ICMP_SLT, CmpStmt::Predicate::ICMP_SGE}, // < -> >=
|
|
325
|
+
{CmpStmt::Predicate::ICMP_SGE, CmpStmt::Predicate::ICMP_SLT}, // >= -> <
|
|
326
|
+
};
|
|
327
|
+
|
|
328
|
+
|
|
329
|
+
Map<s32_t, s32_t> _switch_lhsrhs_predicate =
|
|
330
|
+
{
|
|
331
|
+
{CmpStmt::Predicate::FCMP_OEQ, CmpStmt::Predicate::FCMP_OEQ}, // == -> ==
|
|
332
|
+
{CmpStmt::Predicate::FCMP_UEQ, CmpStmt::Predicate::FCMP_UEQ}, // == -> ==
|
|
333
|
+
{CmpStmt::Predicate::FCMP_OGT, CmpStmt::Predicate::FCMP_OLT}, // > -> <
|
|
334
|
+
{CmpStmt::Predicate::FCMP_OGE, CmpStmt::Predicate::FCMP_OLE}, // >= -> <=
|
|
335
|
+
{CmpStmt::Predicate::FCMP_OLT, CmpStmt::Predicate::FCMP_OGT}, // < -> >
|
|
336
|
+
{CmpStmt::Predicate::FCMP_OLE, CmpStmt::Predicate::FCMP_OGE}, // <= -> >=
|
|
337
|
+
{CmpStmt::Predicate::FCMP_ONE, CmpStmt::Predicate::FCMP_ONE}, // != -> !=
|
|
338
|
+
{CmpStmt::Predicate::FCMP_UNE, CmpStmt::Predicate::FCMP_UNE}, // != -> !=
|
|
339
|
+
{CmpStmt::Predicate::ICMP_EQ, CmpStmt::Predicate::ICMP_EQ}, // == -> ==
|
|
340
|
+
{CmpStmt::Predicate::ICMP_NE, CmpStmt::Predicate::ICMP_NE}, // != -> !=
|
|
341
|
+
{CmpStmt::Predicate::ICMP_UGT, CmpStmt::Predicate::ICMP_ULT}, // > -> <
|
|
342
|
+
{CmpStmt::Predicate::ICMP_ULT, CmpStmt::Predicate::ICMP_UGT}, // < -> >
|
|
343
|
+
{CmpStmt::Predicate::ICMP_UGE, CmpStmt::Predicate::ICMP_ULE}, // >= -> <=
|
|
344
|
+
{CmpStmt::Predicate::ICMP_SGT, CmpStmt::Predicate::ICMP_SLT}, // > -> <
|
|
345
|
+
{CmpStmt::Predicate::ICMP_SLT, CmpStmt::Predicate::ICMP_SGT}, // < -> >
|
|
346
|
+
{CmpStmt::Predicate::ICMP_SGE, CmpStmt::Predicate::ICMP_SLE}, // >= -> <=
|
|
347
|
+
};
|
|
302
348
|
|
|
303
349
|
};
|
|
304
350
|
}
|
|
@@ -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*)
|
|
@@ -36,54 +36,6 @@ using namespace SVF;
|
|
|
36
36
|
using namespace SVFUtil;
|
|
37
37
|
using namespace z3;
|
|
38
38
|
|
|
39
|
-
// according to varieties of cmp insts,
|
|
40
|
-
// maybe var X var, var X const, const X var, const X const
|
|
41
|
-
// we accept 'var X const' 'var X var' 'const X const'
|
|
42
|
-
// if 'const X var', we need to reverse op0 op1 and its predicate 'var X' const'
|
|
43
|
-
// X' is reverse predicate of X
|
|
44
|
-
// == -> !=, != -> ==, > -> <=, >= -> <, < -> >=, <= -> >
|
|
45
|
-
|
|
46
|
-
Map<s32_t, s32_t> _reverse_predicate =
|
|
47
|
-
{
|
|
48
|
-
{CmpStmt::Predicate::FCMP_OEQ, CmpStmt::Predicate::FCMP_ONE}, // == -> !=
|
|
49
|
-
{CmpStmt::Predicate::FCMP_UEQ, CmpStmt::Predicate::FCMP_UNE}, // == -> !=
|
|
50
|
-
{CmpStmt::Predicate::FCMP_OGT, CmpStmt::Predicate::FCMP_OLE}, // > -> <=
|
|
51
|
-
{CmpStmt::Predicate::FCMP_OGE, CmpStmt::Predicate::FCMP_OLT}, // >= -> <
|
|
52
|
-
{CmpStmt::Predicate::FCMP_OLT, CmpStmt::Predicate::FCMP_OGE}, // < -> >=
|
|
53
|
-
{CmpStmt::Predicate::FCMP_OLE, CmpStmt::Predicate::FCMP_OGT}, // <= -> >
|
|
54
|
-
{CmpStmt::Predicate::FCMP_ONE, CmpStmt::Predicate::FCMP_OEQ}, // != -> ==
|
|
55
|
-
{CmpStmt::Predicate::FCMP_UNE, CmpStmt::Predicate::FCMP_UEQ}, // != -> ==
|
|
56
|
-
{CmpStmt::Predicate::ICMP_EQ, CmpStmt::Predicate::ICMP_NE}, // == -> !=
|
|
57
|
-
{CmpStmt::Predicate::ICMP_NE, CmpStmt::Predicate::ICMP_EQ}, // != -> ==
|
|
58
|
-
{CmpStmt::Predicate::ICMP_UGT, CmpStmt::Predicate::ICMP_ULE}, // > -> <=
|
|
59
|
-
{CmpStmt::Predicate::ICMP_ULT, CmpStmt::Predicate::ICMP_UGE}, // < -> >=
|
|
60
|
-
{CmpStmt::Predicate::ICMP_UGE, CmpStmt::Predicate::ICMP_ULT}, // >= -> <
|
|
61
|
-
{CmpStmt::Predicate::ICMP_SGT, CmpStmt::Predicate::ICMP_SLE}, // > -> <=
|
|
62
|
-
{CmpStmt::Predicate::ICMP_SLT, CmpStmt::Predicate::ICMP_SGE}, // < -> >=
|
|
63
|
-
{CmpStmt::Predicate::ICMP_SGE, CmpStmt::Predicate::ICMP_SLT}, // >= -> <
|
|
64
|
-
};
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
Map<s32_t, s32_t> _switch_lhsrhs_predicate =
|
|
68
|
-
{
|
|
69
|
-
{CmpStmt::Predicate::FCMP_OEQ, CmpStmt::Predicate::FCMP_OEQ}, // == -> ==
|
|
70
|
-
{CmpStmt::Predicate::FCMP_UEQ, CmpStmt::Predicate::FCMP_UEQ}, // == -> ==
|
|
71
|
-
{CmpStmt::Predicate::FCMP_OGT, CmpStmt::Predicate::FCMP_OLT}, // > -> <
|
|
72
|
-
{CmpStmt::Predicate::FCMP_OGE, CmpStmt::Predicate::FCMP_OLE}, // >= -> <=
|
|
73
|
-
{CmpStmt::Predicate::FCMP_OLT, CmpStmt::Predicate::FCMP_OGT}, // < -> >
|
|
74
|
-
{CmpStmt::Predicate::FCMP_OLE, CmpStmt::Predicate::FCMP_OGE}, // <= -> >=
|
|
75
|
-
{CmpStmt::Predicate::FCMP_ONE, CmpStmt::Predicate::FCMP_ONE}, // != -> !=
|
|
76
|
-
{CmpStmt::Predicate::FCMP_UNE, CmpStmt::Predicate::FCMP_UNE}, // != -> !=
|
|
77
|
-
{CmpStmt::Predicate::ICMP_EQ, CmpStmt::Predicate::ICMP_EQ}, // == -> ==
|
|
78
|
-
{CmpStmt::Predicate::ICMP_NE, CmpStmt::Predicate::ICMP_NE}, // != -> !=
|
|
79
|
-
{CmpStmt::Predicate::ICMP_UGT, CmpStmt::Predicate::ICMP_ULT}, // > -> <
|
|
80
|
-
{CmpStmt::Predicate::ICMP_ULT, CmpStmt::Predicate::ICMP_UGT}, // < -> >
|
|
81
|
-
{CmpStmt::Predicate::ICMP_UGE, CmpStmt::Predicate::ICMP_ULE}, // >= -> <=
|
|
82
|
-
{CmpStmt::Predicate::ICMP_SGT, CmpStmt::Predicate::ICMP_SLT}, // > -> <
|
|
83
|
-
{CmpStmt::Predicate::ICMP_SLT, CmpStmt::Predicate::ICMP_SGT}, // < -> >
|
|
84
|
-
{CmpStmt::Predicate::ICMP_SGE, CmpStmt::Predicate::ICMP_SLE}, // >= -> <=
|
|
85
|
-
};
|
|
86
|
-
|
|
87
39
|
|
|
88
40
|
void AbstractInterpretation::runOnModule(ICFG *_icfg)
|
|
89
41
|
{
|
package/svf/lib/Graphs/ICFG.cpp
CHANGED
|
@@ -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
|