Static Value-Flow Analysis
Loading...
Searching...
No Matches
SVFValue.h
Go to the documentation of this file.
1//===- BasicTypes.h -- Basic types used in SVF-------------------------------//
2//
3// SVF: Static Value-Flow Analysis
4//
5// Copyright (C) <2013-2017> <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/*
24 * BasicTypes.h
25 *
26 * Created on: Apr 1, 2014
27 * Author: Yulei Sui
28 */
29
30#ifndef INCLUDE_SVFIR_SVFVALUE_H_
31#define INCLUDE_SVFIR_SVFVALUE_H_
32
33#include "SVFIR/SVFType.h"
34#include "Graphs/GraphPrinter.h"
35
36
37namespace SVF
38{
39
40
42{
43
44public:
45
46 enum GNodeK
47 {
48 // ┌─────────────────────────────────────────────────────────────────────────┐
49 // │ ICFGNode: Classes of inter-procedural and intra-procedural control flow │
50 // │ graph nodes (Parent class: ICFGNode) │
51 // └─────────────────────────────────────────────────────────────────────────┘
52 IntraBlock, // ├── Represents a node within a single procedure
53 GlobalBlock, // ├── Represents a global-level block
54 // │ └─ Subclass: InterICFGNode
55 FunEntryBlock, // │ ├── Entry point of a function
56 FunExitBlock, // │ ├── Exit point of a function
57 FunCallBlock, // │ ├── Call site in the function
58 FunRetBlock, // │ └── Return site in the function
59
60 // ┌─────────────────────────────────────────────────────────────────────────┐
61 // │ SVFVar: Classes of variable nodes (Parent class: SVFVar) │
62 // │ Includes two main subclasses: ValVar and ObjVar │
63 // └─────────────────────────────────────────────────────────────────────────┘
64 // └─ Subclass: ValVar (Top-level variable nodes)
65 ValNode, // ├── Represents a standard value variable
66 ArgValNode, // ├── Represents an argument value variable
67 FunValNode, // ├── Represents a function value variable
68 GepValNode, // ├── Represents a GEP value variable
69 RetValNode, // ├── Represents a return value node
70 VarargValNode, // ├── Represents a variadic argument node
71 GlobalValNode, // ├── Represents a global variable node
72 ConstAggValNode, // ├── Represents a constant aggregate value node
73 // │ └─ Subclass: ConstDataValVar
74 ConstDataValNode, // │ ├── Represents a constant data variable
75 BlackHoleValNode, // │ ├── Represents a black hole node
76 ConstFPValNode, // │ ├── Represents a constant floating-point value node
77 ConstIntValNode, // │ ├── Represents a constant integer value node
78 ConstNullptrValNode, // │ └── Represents a constant nullptr value node
79 // │ └─ Subclass: DummyValVar
80 DummyValNode, // │ └── Dummy node for uninitialized values
81
82 // └─ Subclass: ObjVar (Object variable nodes)
83 ObjNode, // ├── Represents an object variable
84 // │ └─ Subclass: GepObjVar
85 GepObjNode, // │ ├── Represents a GEP object variable
86 // │ └─ Subclass: BaseObjVar
87 BaseObjNode, // │ ├── Represents a base object node
88 FunObjNode, // │ ├── Represents a function object
89 HeapObjNode, // │ ├── Represents a heap object
90 StackObjNode, // │ ├── Represents a stack object
91 GlobalObjNode, // │ ├── Represents a global object
92 ConstAggObjNode, // │ ├── Represents a constant aggregate object
93 // │ └─ Subclass: ConstDataObjVar
94 ConstDataObjNode, // │ ├── Represents a constant data object
95 ConstFPObjNode, // │ ├── Represents a constant floating-point object
96 ConstIntObjNode, // │ ├── Represents a constant integer object
97 ConstNullptrObjNode, // │ └── Represents a constant nullptr object
98 // │ └─ Subclass: DummyObjVar
99 DummyObjNode, // │ └── Dummy node for uninitialized objects
100
101 // ┌─────────────────────────────────────────────────────────────────────────┐
102 // │ VFGNode: Classes of Value Flow Graph (VFG) node kinds (Parent class: │
103 // │ VFGNode) │
104 // │ Includes operation nodes and specialized subclasses │
105 // └─────────────────────────────────────────────────────────────────────────┘
106 Cmp, // ├── Represents a comparison operation
107 BinaryOp, // ├── Represents a binary operation
108 UnaryOp, // ├── Represents a unary operation
109 Branch, // ├── Represents a branch operation
110 DummyVProp, // ├── Dummy node for value propagation
111 NPtr, // ├── Represents a null pointer operation
112 // │ └─ Subclass: ArgumentVFGNode
113 FRet, // │ ├── Represents a function return value
114 ARet, // │ ├── Represents an argument return value
115 AParm, // │ ├── Represents an argument parameter
116 FParm, // │ └── Represents a function parameter
117 // │ └─ Subclass: StmtVFGNode
118 Addr, // │ ├── Represents an address operation
119 Copy, // │ ├── Represents a copy operation
120 Gep, // │ ├── Represents a GEP operation
121 Store, // │ ├── Represents a store operation
122 Load, // │ └── Represents a load operation
123 // │ └─ Subclass: PHIVFGNode
124 TPhi, // │ ├── Represents a type-based PHI node
125 TIntraPhi, // │ ├── Represents an intra-procedural PHI node
126 TInterPhi, // │ └── Represents an inter-procedural PHI node
127 // │ └─ Subclass: MRSVFGNode
128 FPIN, // │ ├── Function parameter input
129 FPOUT, // │ ├── Function parameter output
130 APIN, // │ ├── Argument parameter input
131 APOUT, // │ └── Argument parameter output
132 // │ └─ Subclass: MSSAPHISVFGNode
133 MPhi, // │ ├── Memory PHI node
134 MIntraPhi, // │ ├── Intra-procedural memory PHI node
135 MInterPhi, // │ └── Inter-procedural memory PHI node
136
137 // ┌─────────────────────────────────────────────────────────────────────────┐
138 // │ Additional specific graph node types │
139 // └─────────────────────────────────────────────────────────────────────────┘
140 CallNodeKd, // Callgraph node
141 CDNodeKd, // Control dependence graph node
142 CFLNodeKd, // CFL graph node
143 CHNodeKd, // Class hierarchy graph node
144 ConstraintNodeKd, // Constraint graph node
145 TCTNodeKd, // Thread creation tree node
146 DCHNodeKd, // DCHG node
147 BasicBlockKd, // Basic block node
148 OtherKd // Other node kind
149 };
150
151
152 SVFValue(NodeID i, GNodeK k, const SVFType* ty = nullptr): id(i),nodeKind(k), type(ty)
153 {
154
155 }
156
158 inline NodeID getId() const
159 {
160 return id;
161 }
162
164 inline GNodeK getNodeKind() const
165 {
166 return nodeKind;
167 }
168
169 virtual const SVFType* getType() const
170 {
171 return type;
172 }
173
174 inline virtual void setName(const std::string& nameInfo)
175 {
176 name = nameInfo;
177 }
178
179 inline virtual void setName(std::string&& nameInfo)
180 {
181 name = std::move(nameInfo);
182 }
183
184 virtual const std::string& getName() const
185 {
186 return name;
187 }
188
189 inline virtual void setSourceLoc(const std::string& sourceCodeInfo)
190 {
192 }
193
194 virtual const std::string getSourceLoc() const
195 {
196 return sourceLoc;
197 }
198
199 const std::string valueOnlyToString() const;
200
201
202protected:
205 const SVFType* type;
206
207 std::string name;
208 std::string sourceLoc;
209
211 //{@ Check node kind
212 static inline bool isICFGNodeKinds(GNodeK n)
213 {
214 static_assert(FunRetBlock - IntraBlock == 5,
215 "the number of ICFGNodeKinds has changed, make sure "
216 "the range is correct");
218 }
219
220 static inline bool isInterICFGNodeKind(GNodeK n)
221 {
222 static_assert(FunRetBlock - FunEntryBlock == 3,
223 "the number of InterICFGNodeKind has changed, make sure "
224 "the range is correct");
226 }
227
228 static inline bool isSVFVarKind(GNodeK n)
229 {
230 static_assert(DummyObjNode - ValNode == 26,
231 "The number of SVFVarKinds has changed, make sure the "
232 "range is correct");
233
235 }
236
237 static inline bool isValVarKinds(GNodeK n)
238 {
239 static_assert(DummyValNode - ValNode == 13,
240 "The number of ValVarKinds has changed, make sure the "
241 "range is correct");
243 }
244
245
246 static inline bool isConstantDataValVar(GNodeK n)
247 {
248 static_assert(ConstNullptrValNode - ConstDataValNode == 4,
249 "The number of ConstantDataValVarKinds has changed, make "
250 "sure the range is correct");
252 }
253
254 static inline bool isObjVarKinds(GNodeK n)
255 {
256 static_assert(DummyObjNode - ObjNode == 12,
257 "The number of ObjVarKinds has changed, make sure the "
258 "range is correct");
260 }
261
262 static inline bool isBaseObjVarKinds(GNodeK n)
263 {
264 static_assert(DummyObjNode - BaseObjNode == 10,
265 "The number of BaseObjVarKinds has changed, make sure the "
266 "range is correct");
268 }
269
271 {
272 static_assert(ConstNullptrObjNode - ConstDataObjNode == 3,
273 "The number of ConstantDataObjVarKinds has changed, make "
274 "sure the range is correct");
276 }
277
278 static inline bool isVFGNodeKinds(GNodeK n)
279 {
280 static_assert(MInterPhi - Cmp == 24,
281 "The number of VFGNodeKinds has changed, make sure the "
282 "range is correct");
284 }
285
286 static inline bool isArgumentVFGNodeKinds(GNodeK n)
287 {
288 static_assert(FParm - FRet == 3,
289 "The number of ArgumentVFGNodeKinds has changed, make "
290 "sure the range is correct");
291 return n <= FParm && n >= FRet;
292 }
293
294 static inline bool isStmtVFGNodeKinds(GNodeK n)
295 {
296 static_assert(Load - Addr == 4,
297 "The number of StmtVFGNodeKinds has changed, make sure "
298 "the range is correct");
299 return n <= Load && n >= Addr;
300 }
301
302 static inline bool isPHIVFGNodeKinds(GNodeK n)
303 {
304 static_assert(TInterPhi - TPhi == 2,
305 "The number of PHIVFGNodeKinds has changed, make sure "
306 "the range is correct");
308 }
309
310 static inline bool isMRSVFGNodeKinds(GNodeK n)
311 {
312 static_assert(MInterPhi - FPIN == 6,
313 "The number of MRSVFGNodeKinds has changed, make sure "
314 "the range is correct");
316 }
317
318 static inline bool isMSSAPHISVFGNodeKinds(GNodeK n)
319 {
320 static_assert(MInterPhi - MPhi == 2,
321 "The number of MSSAPHISVFGNodeKinds has changed, make "
322 "sure the range is correct");
324 }
326};
327
328
329template <typename F, typename S>
330OutStream& operator<< (OutStream &o, const std::pair<F, S> &var)
331{
332 o << "<" << var.first << ", " << var.second << ">";
333 return o;
334}
335
336}
337
338#endif /* INCLUDE_SVFIR_SVFVALUE_H_ */
cJSON * n
Definition cJSON.cpp:2558
SVFValue(NodeID i, GNodeK k, const SVFType *ty=nullptr)
Definition SVFValue.h:152
@ ConstNullptrObjNode
Definition SVFValue.h:97
@ ConstNullptrValNode
Definition SVFValue.h:78
static bool isArgumentVFGNodeKinds(GNodeK n)
Definition SVFValue.h:286
static bool isMSSAPHISVFGNodeKinds(GNodeK n)
Definition SVFValue.h:318
NodeID getId() const
Get ID.
Definition SVFValue.h:158
static bool isInterICFGNodeKind(GNodeK n)
Definition SVFValue.h:220
static bool isConstantDataValVar(GNodeK n)
Definition SVFValue.h:246
virtual void setSourceLoc(const std::string &sourceCodeInfo)
Definition SVFValue.h:189
static bool isObjVarKinds(GNodeK n)
Definition SVFValue.h:254
virtual const SVFType * getType() const
Definition SVFValue.h:169
GNodeK nodeKind
Node kind.
Definition SVFValue.h:204
static bool isBaseObjVarKinds(GNodeK n)
Definition SVFValue.h:262
GNodeK getNodeKind() const
Get node kind.
Definition SVFValue.h:164
NodeID id
Node ID.
Definition SVFValue.h:203
virtual const std::string getSourceLoc() const
Definition SVFValue.h:194
virtual const std::string & getName() const
Definition SVFValue.h:184
std::string sourceLoc
Source code information of this value.
Definition SVFValue.h:208
const std::string valueOnlyToString() const
Definition LLVMUtil.cpp:735
static bool isConstantDataObjVarKinds(GNodeK n)
Definition SVFValue.h:270
static bool isPHIVFGNodeKinds(GNodeK n)
Definition SVFValue.h:302
static bool isICFGNodeKinds(GNodeK n)
Helper functions to check node kinds.
Definition SVFValue.h:212
static bool isValVarKinds(GNodeK n)
Definition SVFValue.h:237
static bool isSVFVarKind(GNodeK n)
Definition SVFValue.h:228
std::string name
Definition SVFValue.h:207
virtual void setName(const std::string &nameInfo)
Definition SVFValue.h:174
static bool isVFGNodeKinds(GNodeK n)
Definition SVFValue.h:278
virtual void setName(std::string &&nameInfo)
Definition SVFValue.h:179
static bool isMRSVFGNodeKinds(GNodeK n)
Definition SVFValue.h:310
static bool isStmtVFGNodeKinds(GNodeK n)
Definition SVFValue.h:294
const SVFType * type
SVF type.
Definition SVFValue.h:205
for isBitcode
Definition BasicTypes.h:68
u32_t NodeID
Definition GeneralType.h:56
std::ostream OutStream
Definition GeneralType.h:46
llvm::IRBuilder IRBuilder
Definition BasicTypes.h:74
IntervalValue operator<<(const IntervalValue &lhs, const IntervalValue &rhs)
Left binary shift of IntervalValues.