Static Value-Flow Analysis
Loading...
Searching...
No Matches
SVFLLVMValue.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_SVFLLVM_SVFVALUE_H_
31#define INCLUDE_SVFLLVM_SVFVALUE_H_
32
33#include "SVFIR/SVFType.h"
34#include "Graphs/GraphPrinter.h"
35#include "Util/Casting.h"
36#include "Graphs/BasicBlockG.h"
37#include "SVFIR/SVFValue.h"
39
40namespace SVF
41{
42
45
46class CallGraphNode;
47class SVFInstruction;
48class SVFBasicBlock;
49class SVFArgument;
50class SVFFunction;
51class SVFType;
52
54{
55 friend class SVFIRWriter;
56 friend class SVFIRReader;
57 friend class LLVMModuleSet;
58
59public:
60 typedef s64_t GNodeK;
61
63 {
66 };
67
68private:
72
73protected:
74 const SVFType* type;
75 std::string name;
76 std::string sourceLoc;
83
87 {
88 constDataOrAggData = true;
89 }
91 {
92 ptrInUncalledFun = true;
93 }
95public:
96 SVFLLVMValue() = delete;
97 virtual ~SVFLLVMValue() = default;
98
100 inline GNodeK getKind() const
101 {
102 return kind;
103 }
104
105 inline const std::string &getName() const
106 {
107 return name;
108 }
109
110 inline void setName(std::string&& n)
111 {
112 name = std::move(n);
113 }
114
115 inline virtual const SVFType* getType() const
116 {
117 return type;
118 }
119 inline bool isConstDataOrAggData() const
120 {
121 return constDataOrAggData;
122 }
123 inline bool ptrInUncalledFunction() const
124 {
125 return ptrInUncalledFun;
126 }
127 inline virtual void setSourceLoc(const std::string& sourceCodeInfo)
128 {
130 }
131 inline virtual const std::string getSourceLoc() const
132 {
133 return sourceLoc;
134 }
135
137 std::string toString() const;
138
140
142 {
143 return os << value.toString();
144 }
146};
147
148class ArgValVar;
149
151{
152 friend class LLVMModuleSet;
153 friend class SVFIRWriter;
154 friend class SVFIRReader;
155 friend class SVFIRBuilder;
156
157public:
158 typename BasicBlockGraph::IDToNodeMapTy::iterator iterator;
159 typedef BasicBlockGraph::IDToNodeMapTy::const_iterator const_iterator;
163
164private:
165 bool isDecl;
169 bool isNotRet;
170 bool varArg;
174 std::vector<const ArgValVar*> allArgs;
177
178protected:
179
180 inline void addArgument(const ArgValVar* arg)
181 {
182 allArgs.push_back(arg);
183 }
184
189
190 inline void setIsNotRet(bool notRet)
191 {
193 }
194
196 {
198 }
200
201public:
202 SVFFunction(const SVFType* ty,const SVFFunctionType* ft, bool declare, bool intrinsic, bool addrTaken, bool varg, SVFLoopAndDomInfo* ld);
203 SVFFunction(void) = delete;
204 virtual ~SVFFunction();
205
206 static inline bool classof(const SVFLLVMValue *node)
207 {
208 return node->getKind() == SVFFunc;
209 }
210
212 {
213 return loopAndDom;
214 }
215 inline bool isDeclaration() const
216 {
217 return isDecl;
218 }
219
221 {
222 this->bbGraph = graph;
223 }
224
226 {
227 return bbGraph;
228 }
229
231 {
232 return bbGraph;
233 }
234
235 inline bool isIntrinsic() const
236 {
237 return intrinsic;
238 }
239
240 inline bool hasAddressTaken() const
241 {
242 return addrTaken;
243 }
244
246 inline const SVFFunctionType* getFunctionType() const
247 {
248 return funcType;
249 }
250
252 inline const SVFType* getReturnType() const
253 {
254 return funcType->getReturnType();
255 }
256
258 {
259 if(realDefFun==nullptr)
260 return this;
261 return realDefFun;
262 }
263
264 u32_t arg_size() const;
265 const ArgValVar* getArg(u32_t idx) const;
266 bool isVarArg() const;
267
268 inline bool hasBasicBlock() const
269 {
270 return bbGraph && bbGraph->begin() != bbGraph->end();
271 }
272
273 inline const SVFBasicBlock* getEntryBlock() const
274 {
275 assert(hasBasicBlock() && "function does not have any Basicblock, external function?");
276 assert(bbGraph->begin()->second->getInEdges().size() == 0 && "the first basic block is not entry block");
277 return bbGraph->begin()->second;
278 }
279
282 const SVFBasicBlock* getExitBB() const;
283
284 void setExitBlock(SVFBasicBlock *bb);
285
286 inline const SVFBasicBlock* front() const
287 {
288 return getEntryBlock();
289 }
290
291 inline const SVFBasicBlock* back() const
292 {
293 assert(hasBasicBlock() && "function does not have any Basicblock, external function?");
297 return std::prev(bbGraph->end())->second;
298 }
299
300 inline const_iterator begin() const
301 {
302 return bbGraph->begin();
303 }
304
305 inline const_iterator end() const
306 {
307 return bbGraph->end();
308 }
309
310
311 inline const std::vector<const SVFBasicBlock*>& getReachableBBs() const
312 {
313 return loopAndDom->getReachableBBs();
314 }
315
316 inline bool isUncalledFunction() const
317 {
318 return isUncalled;
319 }
320
321 inline bool hasReturn() const
322 {
323 return !isNotRet;
324 }
325
326 inline void getExitBlocksOfLoop(const SVFBasicBlock* bb, BBList& exitbbs) const
327 {
329 }
330
331 inline bool hasLoopInfo(const SVFBasicBlock* bb) const
332 {
333 return loopAndDom->hasLoopInfo(bb);
334 }
335
336 const LoopBBs& getLoopInfo(const SVFBasicBlock* bb) const
337 {
338 return loopAndDom->getLoopInfo(bb);
339 }
340
341 inline const SVFBasicBlock* getLoopHeader(const BBList& lp) const
342 {
343 return loopAndDom->getLoopHeader(lp);
344 }
345
346 inline bool loopContainsBB(const BBList& lp, const SVFBasicBlock* bb) const
347 {
348 return loopAndDom->loopContainsBB(lp,bb);
349 }
350
352 {
353 return loopAndDom->getDomTreeMap();
354 }
355
357 {
359 }
360
361 inline bool isLoopHeader(const SVFBasicBlock* bb) const
362 {
363 return loopAndDom->isLoopHeader(bb);
364 }
365
366 inline bool dominate(const SVFBasicBlock* bbKey, const SVFBasicBlock* bbValue) const
367 {
369 }
370
371 inline bool postDominate(const SVFBasicBlock* bbKey, const SVFBasicBlock* bbValue) const
372 {
374 }
375};
376
382
383
384
385} // End namespace SVF
386
387#endif /* INCLUDE_SVFLLVM_SVFVALUE_H_ */
#define false
Definition cJSON.cpp:70
cJSON * n
Definition cJSON.cpp:2558
Class representing a function argument variable in the SVFIR.
iterator begin()
Iterators.
const SVFType * getReturnType() const
Definition SVFType.h:336
bool intrinsic
return true if this function does not have a body
bool dominate(const SVFBasicBlock *bbKey, const SVFBasicBlock *bbValue) const
BasicBlockGraph * bbGraph
a 'single' basic block having no successors and containing return instruction in a function
bool varArg
return true if this function never returns
const LoopBBs & getLoopInfo(const SVFBasicBlock *bb) const
bool loopContainsBB(const BBList &lp, const SVFBasicBlock *bb) const
bool isUncalled
return true if this function is address-taken (for indirect call purposes)
BasicBlockGraph * getBasicBlockGraph()
const ArgValVar * getArg(u32_t idx) const
const_iterator end() const
SVFBasicBlock * exitBlock
all formal arguments of this function
void setIsUncalledFunction(bool uncalledFunction)
bool addrTaken
return true if this function is an intrinsic function (e.g., llvm.dbg), which does not reside in the ...
const std::vector< const SVFBasicBlock * > & getReachableBBs() const
BasicBlockGraph::IDToNodeMapTy::const_iterator const_iterator
BasicBlockGraph::IDToNodeMapTy::iterator iterator
const_iterator begin() const
std::vector< const ArgValVar * > allArgs
the definition of a function across multiple modules
SVFLoopAndDomInfo * getLoopAndDomInfo()
virtual ~SVFFunction()
void getExitBlocksOfLoop(const SVFBasicBlock *bb, BBList &exitbbs) const
bool hasReturn() const
const SVFBasicBlock * getEntryBlock() const
bool hasAddressTaken() const
const SVFFunction * realDefFun
the loop and dominate information
bool isIntrinsic() const
SVFFunction(void)=delete
bool isUncalledFunction() const
SVFLoopAndDomInfo::LoopBBs LoopBBs
friend class SVFIRReader
bool hasBasicBlock() const
const SVFType * getReturnType() const
Returns the FunctionType.
const BasicBlockGraph * getBasicBlockGraph() const
const SVFFunctionType * getFunctionType() const
Returns the FunctionType.
void setIsNotRet(bool notRet)
void addArgument(const ArgValVar *arg)
the basic block graph of this function
bool isDeclaration() const
u32_t arg_size() const
const SVFFunction * getDefFunForMultipleModule() const
static bool classof(const SVFLLVMValue *node)
void setExitBlock(SVFBasicBlock *bb)
const SVFBasicBlock * back() const
const SVFBasicBlock * getExitBB() const
friend class SVFIRWriter
void setBasicBlockGraph(BasicBlockGraph *graph)
bool isNotRet
return true if this function is never called
bool postDominate(const SVFBasicBlock *bbKey, const SVFBasicBlock *bbValue) const
SVFLoopAndDomInfo::BBList BBList
const SVFFunctionType * funcType
return true if this function supports variable arguments
const Map< const SVFBasicBlock *, BBSet > & getDomFrontierMap() const
const SVFBasicBlock * front() const
const Map< const SVFBasicBlock *, BBSet > & getDomTreeMap() const
SVFLoopAndDomInfo::BBSet BBSet
bool isVarArg() const
bool hasLoopInfo(const SVFBasicBlock *bb) const
SVFLoopAndDomInfo * loopAndDom
FunctionType, which is different from the type (PointerType) of this SVFFunction.
void setDefFunForMultipleModule(const SVFFunction *deffun)
const SVFBasicBlock * getLoopHeader(const BBList &lp) const
bool isLoopHeader(const SVFBasicBlock *bb) const
GNodeK kind
used for classof
GNodeK getKind() const
Get the type of this SVFValue.
SVFLLVMValue(const SVFType *ty, SVFValKind k=SVFVal)
Constructor without name.
virtual const SVFType * getType() const
std::string sourceLoc
bool isConstDataOrAggData() const
friend OutStream & operator<<(OutStream &os, const SVFLLVMValue &value)
Overloading operator << for dumping ICFG node ID.
void setName(std::string &&n)
std::string name
Short name of value for printing & debugging.
void setPtrInUncalledFunction()
virtual ~SVFLLVMValue()=default
SVFLLVMValue()=delete
bool ptrInUncalledFun
true if this pointer is in an uncalled function
virtual void setSourceLoc(const std::string &sourceCodeInfo)
bool ptrInUncalledFunction() const
virtual const std::string getSourceLoc() const
const std::string & getName() const
friend class SVFIRReader
std::string toString() const
Needs to be implemented by a SVF front end.
Definition LLVMUtil.cpp:746
friend class SVFIRWriter
bool constDataOrAggData
true if this value is a ConstantData (e.g., numbers, string, floats) or a constantAggregate
const SVFType * type
Type of this SVFValue.
void setConstDataOrAggData()
const LoopBBs & getLoopInfo(const SVFBasicBlock *bb) const
Definition SVFValue.cpp:30
const Map< const SVFBasicBlock *, BBSet > & getDomFrontierMap() const
Map< const SVFBasicBlock *, BBSet > & getDomTreeMap()
std::vector< const SVFBasicBlock * > BBList
bool dominate(const SVFBasicBlock *bbKey, const SVFBasicBlock *bbValue) const
Definition SVFValue.cpp:56
bool isLoopHeader(const SVFBasicBlock *bb) const
Definition SVFValue.cpp:143
void getExitBlocksOfLoop(const SVFBasicBlock *bb, BBList &exitbbs) const
Definition SVFValue.cpp:37
const BBList & getReachableBBs() const
const SVFBasicBlock * getLoopHeader(const LoopBBs &lp) const
bool hasLoopInfo(const SVFBasicBlock *bb) const
Set< const SVFBasicBlock * > BBSet
bool loopContainsBB(const LoopBBs &lp, const SVFBasicBlock *bb) const
bool postDominate(const SVFBasicBlock *bbKey, const SVFBasicBlock *bbValue) const
Definition SVFValue.cpp:87
for isBitcode
Definition BasicTypes.h:68
std::string dumpLLVMValue(const SVFLLVMValue *svfValue)
std::ostream OutStream
Definition GeneralType.h:46
llvm::IRBuilder IRBuilder
Definition BasicTypes.h:74
unsigned u32_t
Definition GeneralType.h:47
signed long long s64_t
Definition GeneralType.h:50