svf-lib 1.0.1925 → 1.0.1927

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.
Files changed (29) hide show
  1. package/SVF-linux/Release-build/bin/ae +0 -0
  2. package/SVF-linux/Release-build/bin/svf-ex +0 -0
  3. package/SVF-linux/Release-build/include/AE/Core/AbstractState.h +750 -0
  4. package/SVF-linux/Release-build/include/AE/Core/AbstractValue.h +514 -39
  5. package/SVF-linux/Release-build/include/AE/Core/AddressValue.h +32 -25
  6. package/SVF-linux/Release-build/include/AE/Core/ExeState.h +2 -2
  7. package/SVF-linux/Release-build/include/AE/Core/IntervalValue.h +9 -24
  8. package/SVF-linux/Release-build/include/AE/Core/RelationSolver.h +9 -9
  9. package/SVF-linux/Release-build/include/AE/Svfexe/{AbstractExecution.h → AbstractInterpretation.h} +24 -22
  10. package/SVF-linux/Release-build/include/AE/Svfexe/BufOverflowChecker.h +5 -5
  11. package/SVF-linux/Release-build/include/AE/Svfexe/SVFIR2ItvExeState.h +23 -25
  12. package/SVF-linux/Release-build/lib/libSvfCore.a +0 -0
  13. package/SVF-osx/Release-build/bin/ae +0 -0
  14. package/SVF-osx/Release-build/bin/svf-ex +0 -0
  15. package/SVF-osx/Release-build/include/AE/Core/AbstractState.h +2 -3
  16. package/SVF-osx/Release-build/include/AE/Core/IntervalValue.h +1 -0
  17. package/SVF-osx/Release-build/include/AE/Core/RelExeState.h +1 -1
  18. package/SVF-osx/Release-build/include/AE/Svfexe/AbstractInterpretation.h +3 -4
  19. package/SVF-osx/Release-build/include/AE/Svfexe/ICFGSimplification.h +1 -2
  20. package/SVF-osx/Release-build/include/AE/Svfexe/{SVFIR2ItvExeState.h → SVFIR2AbsState.h} +8 -9
  21. package/SVF-osx/Release-build/lib/libSvfCore.a +0 -0
  22. package/SVF-osx/Release-build/lib/libSvfLLVM.a +0 -0
  23. package/package.json +1 -1
  24. package/SVF-linux/Release-build/include/AE/Core/IntervalExeState.h +0 -650
  25. package/SVF-osx/Release-build/include/AE/Core/ConsExeState.h +0 -453
  26. package/SVF-osx/Release-build/include/AE/Core/ExeState.h +0 -304
  27. package/SVF-osx/Release-build/include/AE/Core/SingleAbsValue.h +0 -477
  28. package/SVF-osx/Release-build/include/AE/Core/SymState.h +0 -221
  29. package/SVF-osx/Release-build/include/AE/Svfexe/SVFIR2ConsExeState.h +0 -148
@@ -1,453 +0,0 @@
1
- //===- ConsExeState.h ----Constant Execution State-------------------------//
2
- //
3
- // SVF: Static Value-Flow Analysis
4
- //
5
- // Copyright (C) <2013-2022> <Yulei Sui>
6
- //
7
-
8
- // This program is free software: you can redistribute it and/or modify
9
- // it under the terms of the GNU Affero General Public License as published by
10
- // the Free Software Foundation, either version 3 of the License, or
11
- // (at your option) any later version.
12
-
13
- // This program is distributed in the hope that it will be useful,
14
- // but WITHOUT ANY WARRANTY; without even the implied warranty of
15
- // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16
- // GNU Affero General Public License for more details.
17
-
18
- // You should have received a copy of the GNU Affero General Public License
19
- // along with this program. If not, see <http://www.gnu.org/licenses/>.
20
- //
21
- //===----------------------------------------------------------------------===//
22
- //
23
- // Created by jiawei and xiao on 6/1/23.
24
- //
25
-
26
- #ifndef SVF_CONSEXESTATE_H
27
- #define SVF_CONSEXESTATE_H
28
-
29
- #include "AE/Core/ExeState.h"
30
- #include "AE/Core/SingleAbsValue.h"
31
-
32
- #define NullptrID 0
33
-
34
- namespace SVF
35
- {
36
-
37
- /*!
38
- * Constant Expr Execution State
39
- *
40
- * Constant expr execution state support z3 symbolic value
41
- * and gives a top value when two different constants join
42
- *
43
- * lattice: ⊤ may be constant
44
- * / / | \ \ \
45
- * true ... c0 c1 ... false constant
46
- * \ \ \ | | |
47
- * ⊥ not constant
48
- */
49
- class ConsExeState final : public ExeState
50
- {
51
- friend class SVFIR2ConsExeState;
52
-
53
- public:
54
- typedef Map<u32_t, SingleAbsValue> VarToValMap;
55
- typedef VarToValMap LocToValMap;
56
-
57
- static ConsExeState globalConsES;
58
-
59
- public:
60
- ConsExeState(): ExeState(ExeState::SingleValueK) {}
61
-
62
-
63
- /// Constructor
64
- ConsExeState(VarToValMap varToValMap, LocToValMap locToValMap) : ExeState(ExeState::SingleValueK), _varToVal(
65
- SVFUtil::move(varToValMap)), _locToVal(SVFUtil::move(locToValMap)) {}
66
-
67
- /// Copy Constructor
68
- ConsExeState(const ConsExeState &rhs) : ExeState(rhs), _varToVal(rhs.getVarToVal()),
69
- _locToVal(rhs.getLocToVal())
70
- {
71
-
72
- }
73
-
74
- /// Destructor
75
- ~ConsExeState() override
76
- {
77
- _varToVal.clear();
78
- _locToVal.clear();
79
- }
80
-
81
- /// Copy operator
82
- ConsExeState &operator=(const ConsExeState &rhs);
83
-
84
- /// Move Constructor
85
- ConsExeState(ConsExeState &&rhs) noexcept: ExeState(std::move(rhs)),
86
- _varToVal(SVFUtil::move(rhs._varToVal)), _locToVal(SVFUtil::move(rhs._locToVal))
87
- {
88
-
89
- }
90
-
91
- /// Move operator
92
- ConsExeState &operator=(ConsExeState &&rhs) noexcept;
93
-
94
- /// Name
95
- static inline std::string name()
96
- {
97
- return "ConstantExpr";
98
- }
99
-
100
- using ExeState::operator==;
101
- using ExeState::operator!=;
102
-
103
- bool operator==(const ConsExeState &rhs) const;
104
-
105
- bool operator!=(const ConsExeState &other) const
106
- {
107
- return !(*this == other);
108
- }
109
-
110
- bool operator<(const ConsExeState &rhs) const;
111
-
112
- u32_t hash() const override;
113
-
114
- protected:
115
-
116
- VarToValMap _varToVal; ///< Map a variable (symbol) to its constant value
117
- LocToValMap _locToVal; ///< Map a memory address to its stored constant value
118
-
119
- public:
120
-
121
- /// get memory addresses of variable
122
- virtual Addrs &getAddrs(u32_t id) override
123
- {
124
- auto it = globalConsES._varToAddrs.find(id);
125
- if (it != globalConsES._varToAddrs.end()) return it->second;
126
- return _varToAddrs[id];
127
- }
128
-
129
- /// get constant value of variable
130
- inline SingleAbsValue &operator[](u32_t varId)
131
- {
132
- auto it = globalConsES._varToVal.find(varId);
133
- if (it != globalConsES._varToVal.end())
134
- return it->second;
135
- else
136
- return _varToVal[varId];
137
- }
138
-
139
- /// whether the variable is in varToAddrs table
140
- virtual inline bool inVarToAddrsTable(u32_t id) const override
141
- {
142
- return _varToAddrs.find(id) != _varToAddrs.end() ||
143
- globalConsES._varToAddrs.find(id) != globalConsES._varToAddrs.end();
144
- }
145
-
146
- /// whether the variable is in varToVal table
147
- inline bool inVarToValTable(u32_t varId) const
148
- {
149
- return _varToVal.count(varId) || globalConsES._varToVal.count(varId);
150
- }
151
-
152
- /// whether the memory address stores memory addresses
153
- virtual inline bool inLocToAddrsTable(u32_t id) const override
154
- {
155
- return globalConsES._locToAddrs.find(id) != globalConsES._locToAddrs.end() || inLocalLocToAddrsTable(id);
156
- }
157
-
158
- /// whether the memory address stores constant value
159
- inline bool inLocToValTable(u32_t varId) const
160
- {
161
- return inLocalLocToValTable(varId) || globalConsES._locToVal.count(varId);
162
- }
163
-
164
- inline const VarToValMap &getVarToVal() const
165
- {
166
- return _varToVal;
167
- }
168
-
169
- inline const LocToValMap &getLocToVal() const
170
- {
171
- return _locToVal;
172
- }
173
-
174
- virtual inline bool inLocalLocToAddrsTable(u32_t id) const
175
- {
176
- return _locToAddrs.find(id) != _locToAddrs.end();
177
- }
178
-
179
- inline bool inLocalLocToValTable(u32_t varId) const
180
- {
181
- return _locToVal.count(varId);
182
- }
183
-
184
- inline bool inLocalLocToValTable(const SingleAbsValue& addr) const
185
- {
186
- return _locToVal.count(getInternalID(addr.getNumeral()));
187
- }
188
-
189
- public:
190
-
191
- /// Merge rhs into this
192
- bool joinWith(const ConsExeState &rhs);
193
-
194
- /// Build global execution state
195
- void buildGlobES(ConsExeState &globES, Set<u32_t> &vars);
196
-
197
- /// Update symbolic states based on the summary/side-effect of callee
198
- void applySummary(const ConsExeState &summary);
199
-
200
- inline bool equalVar(u32_t lhs, u32_t rhs)
201
- {
202
- if (!inVarToValTable(lhs) || !inVarToValTable(rhs)) return false;
203
- return eq((*this)[lhs], (*this)[rhs]);
204
- }
205
-
206
- /// Whether state is null state (uninitialized state)
207
- inline bool isNullState() const
208
- {
209
- return _varToVal.size() == 1 && eq((*_varToVal.begin()).second, -1) && _locToVal.empty();
210
- }
211
-
212
- /// Print values of all expressions
213
- void printExprValues() const;
214
-
215
- /// Print values of all expressions
216
- void printExprValues(std::ostream &oss) const override;
217
-
218
- std::string toString() const override;
219
-
220
- std::string pcToString() const;
221
-
222
- std::string varToString(u32_t varId) const;
223
-
224
- std::string locToString(u32_t objId) const;
225
-
226
- bool applySelect(u32_t res, u32_t cond, u32_t top, u32_t fop);
227
-
228
- bool applyPhi(u32_t res, std::vector<u32_t> &ops);
229
-
230
- virtual Addrs &loadAddrs(u32_t addr) override
231
- {
232
- assert(isVirtualMemAddress(addr) && "not virtual address?");
233
- u32_t objId = getInternalID(addr);
234
- auto it = _locToAddrs.find(objId);
235
- if (it != _locToAddrs.end())
236
- {
237
- return it->second;
238
- }
239
- else
240
- {
241
- auto globIt = globalConsES._locToAddrs.find(objId);
242
- if (globIt != globalConsES._locToAddrs.end())
243
- {
244
- return globIt->second;
245
- }
246
- else
247
- {
248
- return getAddrs(0);
249
- }
250
- }
251
- }
252
-
253
- virtual std::string varToAddrs(u32_t varId) const override
254
- {
255
- std::stringstream exprName;
256
- auto it = _varToAddrs.find(varId);
257
- if (it == _varToAddrs.end())
258
- {
259
- auto git = globalConsES._varToAddrs.find(varId);
260
- if (git == globalConsES._varToAddrs.end())
261
- exprName << "Var not in varToAddrs!\n";
262
- else
263
- {
264
- const Addrs &vaddrs = git->second;
265
- if (vaddrs.size() == 1)
266
- {
267
- exprName << "addr: {" << std::dec << getInternalID(*vaddrs.begin()) << "}\n";
268
- }
269
- else
270
- {
271
- exprName << "addr: {";
272
- for (const auto &addr: vaddrs)
273
- {
274
- exprName << std::dec << getInternalID(addr) << ", ";
275
- }
276
- exprName << "}\n";
277
- }
278
- }
279
- }
280
- else
281
- {
282
- const Addrs &vaddrs = it->second;
283
- if (vaddrs.size() == 1)
284
- {
285
- exprName << "addr: {" << std::dec << getInternalID(*vaddrs.begin()) << "}\n";
286
- }
287
- else
288
- {
289
- exprName << "addr: {";
290
- for (const auto &addr: vaddrs)
291
- {
292
- exprName << std::dec << getInternalID(addr) << ", ";
293
- }
294
- exprName << "}\n";
295
- }
296
- }
297
- return SVFUtil::move(exprName.str());
298
- }
299
-
300
- virtual std::string locToAddrs(u32_t objId) const override
301
- {
302
- std::stringstream exprName;
303
- auto it = _locToAddrs.find(objId);
304
- if (it == _locToAddrs.end())
305
- {
306
- auto git = globalConsES._locToAddrs.find(objId);
307
- if (git == globalConsES._locToAddrs.end())
308
- exprName << "Obj not in locToVal!\n";
309
- else
310
- {
311
- const Addrs &vaddrs = git->second;
312
- if (vaddrs.size() == 1)
313
- {
314
- exprName << "addr: {" << std::dec << getInternalID(*vaddrs.begin()) << "}\n";
315
- }
316
- else
317
- {
318
- exprName << "addr: {";
319
- for (const auto &addr: vaddrs)
320
- {
321
- exprName << std::dec << getInternalID(addr) << ", ";
322
- }
323
- exprName << "}\n";
324
- }
325
- }
326
- }
327
- else
328
- {
329
- const Addrs &vaddrs = it->second;
330
- if (vaddrs.size() == 1)
331
- {
332
- exprName << "addr: {" << std::dec << getInternalID(*vaddrs.begin()) << "}\n";
333
- }
334
- else
335
- {
336
- exprName << "addr: {";
337
- for (const auto &addr: vaddrs)
338
- {
339
- exprName << std::dec << getInternalID(addr) << ", ";
340
- }
341
- exprName << "}\n";
342
- }
343
- }
344
- return SVFUtil::move(exprName.str());
345
- }
346
-
347
- /// Empty execution state with a true path constraint
348
- static inline ConsExeState initExeState()
349
- {
350
- VarToValMap mp;
351
- ConsExeState exeState(mp, SVFUtil::move(mp));
352
- return SVFUtil::move(exeState);
353
- }
354
-
355
- /// Empty execution state with a null expr
356
- static inline ConsExeState nullExeState()
357
- {
358
- VarToValMap mp;
359
- ConsExeState exeState(mp, SVFUtil::move(mp));
360
- exeState._varToVal[NullptrID] = -1;
361
- return SVFUtil::move(exeState);
362
- }
363
-
364
- public:
365
-
366
-
367
-
368
- s64_t getNumber(u32_t lhs);
369
-
370
- static inline SingleAbsValue getIntOneZ3Expr()
371
- {
372
- return getContext().int_val(1);
373
- }
374
-
375
- static inline SingleAbsValue getIntZeroZ3Expr()
376
- {
377
- return getContext().int_val(0);
378
- }
379
-
380
- static inline SingleAbsValue getTrueZ3Expr()
381
- {
382
- return getContext().bool_val(true);
383
- }
384
-
385
- static inline SingleAbsValue getFalseZ3Expr()
386
- {
387
- return getContext().bool_val(false);
388
- }
389
-
390
- public:
391
-
392
- /// Store value to location
393
- bool store(const SingleAbsValue &loc, const SingleAbsValue &value);
394
-
395
- /// Load value at location
396
- SingleAbsValue load(const SingleAbsValue &loc);
397
-
398
- /// Return int value from an expression if it is a numeral, otherwise return an approximate value
399
- static inline s32_t z3Expr2NumValue(const SingleAbsValue &e)
400
- {
401
- assert(e.is_numeral() && "not numeral?");
402
- int64_t i;
403
- if(e.getExpr().is_numeral_i64(i))
404
- return e.get_numeral_int64();
405
- else
406
- {
407
- return e.leq(0) ? INT32_MIN : INT32_MAX;
408
- }
409
- }
410
-
411
- /// Whether two var to value map is equivalent
412
- static bool eqVarToValMap(const VarToValMap &pre, const VarToValMap &nxt);
413
-
414
-
415
- /// Whether lhs is less than rhs
416
- static bool lessThanVarToValMap(const VarToValMap &lhs, const VarToValMap &rhs);
417
-
418
-
419
- private:
420
-
421
-
422
- static bool assign(SingleAbsValue &lhs, const SingleAbsValue &rhs);
423
-
424
- inline bool store(u32_t objId, const SingleAbsValue &z3Expr)
425
- {
426
- SingleAbsValue &lhs = _locToVal[objId];
427
- if (!eq(lhs, z3Expr.simplify()))
428
- {
429
- lhs = z3Expr.simplify();
430
- return true;
431
- }
432
- else
433
- return false;
434
- }
435
-
436
- inline SingleAbsValue load(u32_t objId);
437
- }; // end class ConExeState
438
-
439
- } // end namespace SVF
440
-
441
- /// Specialized hash for ConExeState
442
- template<>
443
- struct std::hash<SVF::ConsExeState>
444
- {
445
- size_t operator()(const SVF::ConsExeState &exeState) const
446
- {
447
- return exeState.hash();
448
- }
449
- };
450
-
451
-
452
-
453
- #endif // SVF_CONSEXESTATE_H