Static Value-Flow Analysis
Loading...
Searching...
No Matches
SVFIR.h
Go to the documentation of this file.
1//===- SVFIR.h -- IR of SVF ---------------------------------------------//
2//
3// SVF: Static Value-Flow Analysis
4//
5// Copyright (C) <2013-> <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 * SVFIR.h
25 *
26 * Created on: 31, 12, 2021
27 * Author: Yulei Sui
28 */
29
30#ifndef INCLUDE_SVFIR_H_
31#define INCLUDE_SVFIR_H_
32
33#include "Graphs/IRGraph.h"
34
35namespace SVF
36{
37class CommonCHGraph;
42class SVFIR : public IRGraph
43{
44 friend class SVFIRBuilder;
45 friend class ExternalPAG;
46 friend class PAGBuilderFromFile;
48 friend class SVFIRWriter;
49 friend class SVFIRReader;
50 friend class BVDataPTAImpl;
51
52public:
57 typedef std::vector<const SVFStmt*> SVFStmtList;
58 typedef std::vector<const SVFVar*> SVFVarList;
67 typedef std::pair<NodeID, APOffset> NodeOffset;
68 typedef std::pair<NodeID, AccessPath> NodeAccessPath;
72 typedef std::pair<const SVFType*, std::vector<AccessPath>> SVFTypeLocSetsPair;
75
76private:
96 ICFG* icfg; // ICFG
97 CommonCHGraph* chgraph; // class hierarchy graph
100
101 static std::unique_ptr<SVFIR> pag;
102 static std::string pagReadFromTxt;
103
104 std::string moduleIdentifier;
105
107 SVFIR(bool buildFromFile);
108
110 void destroy();
111
112public:
113
115
116 static inline SVFIR* getPAG(bool buildFromFile = false)
117 {
118 if (pag == nullptr)
119 {
120 pag = std::unique_ptr<SVFIR>(new SVFIR(buildFromFile));
121 }
122 return pag.get();
123 }
124 static void releaseSVFIR()
125 {
126 pag = nullptr;
127 }
129
131 {
132 return memToFieldsMap;
133 }
136 {
137 return GepObjVarMap;
138 }
141 {
142 return candidatePointers;
143 }
146
148 virtual ~SVFIR()
149 {
150 destroy();
151 }
153
154
155 static void handleBlackHole(bool b);
157
159 inline void setICFG(ICFG* i)
160 {
161 icfg = i;
162 }
163 inline ICFG* getICFG() const
164 {
165 assert(icfg->totalICFGNode>0 && "empty ICFG! Build SVF IR first!");
166 return icfg;
167 }
169 inline void setCHG(CommonCHGraph* c)
170 {
171 chgraph = c;
172 }
174 {
175 assert(chgraph && "empty ICFG! Build SVF IR first!");
176 return chgraph;
177 }
178
181 {
182 callGraph = c;
183 }
185 {
186 assert(callGraph && "empty CallGraph! Build SVF IR first!");
187 return callGraph;
188 }
189
190 const FunObjVar* getFunObjVar(const std::string& name);
191
192 inline const std::string& getModuleIdentifier() const
193 {
194 if (pagReadFromTxt.empty())
195 {
196 assert(!moduleIdentifier.empty() &&
197 "No module found! Reading from a file other than LLVM-IR?");
198 return moduleIdentifier;
199 }
200 else
201 {
202 return pagReadFromTxt;
203 }
204 }
205
206 static inline std::string pagFileName()
207 {
208 return pagReadFromTxt;
209 }
210
211 static inline bool pagReadFromTXT()
212 {
213 return !pagReadFromTxt.empty();
214 }
215
216 static inline void setPagFromTXT(const std::string& txt)
217 {
219 }
220
221 inline void setModuleIdentifier(const std::string& moduleIdentifier)
222 {
223 this->moduleIdentifier = moduleIdentifier;
224 }
225
227
228
230 {
231 return KindToSVFStmtSetMap[kind];
232 }
239 inline bool hasSVFStmtList(const ICFGNode* inst) const
240 {
241 return icfgNode2SVFStmtsMap.find(inst) != icfgNode2SVFStmtsMap.end();
242 }
243 inline bool hasPTASVFStmtList(const ICFGNode* inst) const
244 {
245 return icfgNode2PTASVFStmtsMap.find(inst) !=
247 }
250 {
251 return icfgNode2SVFStmtsMap[inst];
252 }
255 {
256 return icfgNode2PTASVFStmtsMap[inst];
257 }
260 {
261 edge->setICFGNode(inst);
262 icfgNode2SVFStmtsMap[inst].push_back(edge);
263 if (edge->isPTAEdge())
264 icfgNode2PTASVFStmtsMap[inst].push_back(edge);
265 }
278 {
279 return globSVFStmtSet;
280 }
282 inline const CallSiteSet& getCallSiteSet() const
283 {
284 return callSiteSet;
285 }
287 inline bool isPhiNode(const SVFVar* node) const
288 {
289 return phiNodeMap.find(node) != phiNodeMap.end();
290 }
291
293 inline bool hasFunArgsList(const FunObjVar* func) const
294 {
295 return (funArgsListMap.find(func) != funArgsListMap.end());
296 }
299 {
300 return funArgsListMap;
301 }
303 inline const SVFVarList& getFunArgsList(const FunObjVar* func) const
304 {
305 FunToArgsListMap::const_iterator it = funArgsListMap.find(func);
306 assert(it != funArgsListMap.end() && "this function doesn't have arguments");
307 return it->second;
308 }
310 inline bool hasCallSiteArgsMap(const CallICFGNode* cs) const
311 {
312 return (callSiteArgsListMap.find(cs) != callSiteArgsListMap.end());
313 }
316 {
317 return callSiteArgsListMap;
318 }
320 inline const SVFVarList& getCallSiteArgsList(const CallICFGNode* cs) const
321 {
322 CSToArgsListMap::const_iterator it = callSiteArgsListMap.find(cs);
323 assert(it != callSiteArgsListMap.end() && "this call site doesn't have arguments");
324 return it->second;
325 }
328 {
329 return callSiteRetMap;
330 }
332 inline const SVFVar* getCallSiteRet(const RetICFGNode* cs) const
333 {
334 CSToRetMap::const_iterator it = callSiteRetMap.find(cs);
335 assert(it != callSiteRetMap.end() && "this call site doesn't have return");
336 return it->second;
337 }
338 inline bool callsiteHasRet(const RetICFGNode* cs) const
339 {
340 return callSiteRetMap.find(cs) != callSiteRetMap.end();
341 }
344 {
345 return funRetMap;
346 }
348 inline const SVFVar* getFunRet(const FunObjVar* func) const
349 {
350 FunToRetMap::const_iterator it = funRetMap.find(func);
351 assert(it != funRetMap.end() && "this function doesn't have return");
352 return it->second;
353 }
354 inline bool funHasRet(const FunObjVar* func) const
355 {
356 return funRetMap.find(func) != funRetMap.end();
357 }
359
361
363 {
364 return GepValObjMap.size();
365 }
367 {
368 return GepObjVarMap.size();
369 }
371
374 const AccessPath& ap) const;
375
377
379 {
381 }
382 inline NodeID getFunPtr(const CallICFGNode* cs) const
383 {
384 CallSiteToFunPtrMap::const_iterator it = indCallSiteToFunPtrMap.find(cs);
385 assert(it!=indCallSiteToFunPtrMap.end() && "indirect callsite not have a function pointer?");
386 return it->second;
387 }
389 {
390 FunPtrToCallSitesMap::const_iterator it = funPtrToCallSitesMap.find(funPtr);
391 assert(it!=funPtrToCallSitesMap.end() && "function pointer not used at any indirect callsite?");
392 return it->second;
393 }
394 inline bool isIndirectCallSites(const CallICFGNode* cs) const
395 {
396 return (indCallSiteToFunPtrMap.find(cs) != indCallSiteToFunPtrMap.end());
397 }
398 inline bool isFunPtr(NodeID id) const
399 {
400 return (funPtrToCallSitesMap.find(id) != funPtrToCallSitesMap.end());
401 }
403
406 {
407 return getIntraPAGEdge(getGNode(src), getGNode(dst), kind);
408 }
410 {
411 SVFStmt edge(src, dst, kind, false);
413 SVFStmt::SVFStmtSetTy::const_iterator it = edgeSet.find(&edge);
414 assert(it != edgeSet.end() && "can not find pag edge");
415 return (*it);
416 }
418
422
423 inline const BaseObjVar* getBaseObject(NodeID id) const
424 {
425 const SVFVar* node = getGNode(id);
426 if(const GepObjVar* gepObjVar = SVFUtil::dyn_cast<GepObjVar>(node))
427 return SVFUtil::dyn_cast<BaseObjVar>(
428 getGNode(gepObjVar->getBaseNode()));
429 else
430 return SVFUtil::dyn_cast<BaseObjVar>(node);
431 }
432
433 inline const ValVar* getBaseValVar(NodeID id) const
434 {
435 const SVFVar* node = getGNode(id);
436 if(const GepValVar* gepVar = SVFUtil::dyn_cast<GepValVar>(node))
437 return gepVar->getBaseNode();
438 else
439 return SVFUtil::dyn_cast<ValVar>(node);
440 }
442
444 NodeID getGepObjVar(const BaseObjVar* baseObj, const APOffset& ap);
446 NodeID getGepObjVar(NodeID id, const APOffset& ap) ;
448
449 inline NodeID getFIObjVar(const BaseObjVar* obj) const
450 {
451 return obj->getId();
452 }
453 inline NodeID getFIObjVar(NodeID id) const
454 {
455 return getBaseObjVar(id);
456 }
458
460
461
462 inline bool isBlkObjOrConstantObj(NodeID id) const
463 {
464 return (isBlkObj(id) || isConstantObj(id));
465 }
466
467 inline bool isConstantObj(NodeID id) const
468 {
469 const BaseObjVar* obj = getBaseObject(id);
470 assert(obj && "not an object node?");
471 return isConstantSym(id) ||
472 obj->isConstDataOrConstGlobal();
473 }
475
477
478
479 inline NodeID getBaseObjVar(NodeID id) const
480 {
481 return getBaseObject(id)->getId();
482 }
484
486
492 {
493 return addDummyValNode(NodeIDAllocator::get()->allocateValueId(), nullptr);
494 }
496 {
497 return addDummyObjNode(NodeIDAllocator::get()->allocateObjectId(), type);
498 }
500
501 bool isValidPointer(NodeID nodeId) const;
502
503 bool isValidTopLevelPtr(const SVFVar* node);
505
507 void print();
508
509private:
510
513 {
514 bool added = KindToSVFStmtSetMap[edge->getEdgeKind()].insert(edge).second;
515 (void)added; // Suppress warning of unused variable under release build
516 assert(added && "duplicated edge, not added!!!");
518 if (edge->isPTAEdge() || (SVFUtil::isa<CopyStmt>(edge) && SVFUtil::cast<CopyStmt>(edge)->isInt2Ptr()))
519 {
521 KindToPTASVFStmtSetMap[edge->getEdgeKind()].insert(edge);
522 }
523 }
525
526
527 inline void addFunArgs(const FunObjVar* fun, const SVFVar* arg)
528 {
531 funArgsListMap[fun].push_back(arg);
532 }
534 inline void addFunRet(const FunObjVar* fun, const SVFVar* ret)
535 {
538 funRetMap[fun] = ret;
539 }
541 inline void addCallSiteArgs(CallICFGNode* callBlockNode,const ValVar* arg)
542 {
543 callBlockNode->addActualParms(arg);
544 callSiteArgsListMap[callBlockNode].push_back(arg);
545 }
548 {
549 retBlockNode->addActualRet(arg);
551 }
554 {
555 bool added = indCallSiteToFunPtrMap.emplace(cs, funPtr).second;
556 (void) added;
557 funPtrToCallSitesMap[funPtr].insert(cs);
558 assert(added && "adding the same indirect callsite twice?");
559 }
560
562
563
564 inline NodeID addValNode(NodeID i, const SVFType* type, const ICFGNode* icfgNode)
565 {
566 SVFVar *node = new ValVar(i, type, icfgNode, ValVar::ValNode);
567 return addValNode(node);
568 }
569
570 NodeID addFunValNode(NodeID i, const ICFGNode* icfgNode, const FunObjVar* funObjVar, const SVFType* type)
571 {
572 FunValVar* node = new FunValVar(i, icfgNode, funObjVar, type);
573 return addValNode(node);
574 }
575
576 NodeID addArgValNode(NodeID i, u32_t argNo, const ICFGNode* icfgNode, const FunObjVar* callGraphNode, const SVFType* type)
577 {
578 ArgValVar* node =
579 new ArgValVar(i, argNo, icfgNode, callGraphNode, type);
580 return addValNode(node);
581 }
582
583 inline NodeID addConstantFPValNode(const NodeID i, double dval,
584 const ICFGNode* icfgNode, const SVFType* type)
585 {
586 SVFVar* node = new ConstFPValVar(i, dval, icfgNode, type);
587 return addNode(node);
588 }
589
590 inline NodeID addConstantIntValNode(NodeID i, const std::pair<s64_t, u64_t>& intValue,
591 const ICFGNode* icfgNode, const SVFType* type)
592 {
593 SVFVar* node = new ConstIntValVar(i, intValue.first, intValue.second, icfgNode, type);
594 return addNode(node);
595 }
596
597 inline NodeID addConstantNullPtrValNode(const NodeID i, const ICFGNode* icfgNode, const SVFType* type)
598 {
599 SVFVar* node = new ConstNullPtrValVar(i, icfgNode, type);
600 return addNode(node);
601 }
602
603 inline NodeID addGlobalValNode(const NodeID i, const ICFGNode* icfgNode, const SVFType* svfType)
604 {
605 SVFVar* node = new GlobalValVar(i, icfgNode, svfType);
606 return addNode(node);
607 }
608
609 inline NodeID addConstantAggValNode(const NodeID i, const ICFGNode* icfgNode, const SVFType* svfType)
610 {
611 SVFVar* node = new ConstAggValVar(i, icfgNode, svfType);
612 return addNode(node);
613 }
614
615 inline NodeID addConstantDataValNode(const NodeID i, const ICFGNode* icfgNode, const SVFType* type)
616 {
617 SVFVar* node = new ConstDataValVar(i, icfgNode, type);
618 return addNode(node);
619 }
620
621
623 inline NodeID addObjNode(NodeID i, ObjTypeInfo* ti, const SVFType* type, const ICFGNode* node)
624 {
625 return addFIObjNode( i, ti, type, node);
626 }
627
632 {
633 memToFieldsMap[i].set(i);
634 HeapObjVar *heapObj = new HeapObjVar(i, ti, type, node);
635 return addObjNode(heapObj);
636 }
637
642 {
643 memToFieldsMap[i].set(i);
644 StackObjVar *stackObj = new StackObjVar(i, ti, type, node);
645 return addObjNode(stackObj);
646 }
647
649 {
650 memToFieldsMap[id].set(id);
651 FunObjVar* funObj = new FunObjVar(id, ti, type, node);
652 return addObjNode(funObj);
653 }
654
655
656 inline NodeID addConstantFPObjNode(NodeID i, ObjTypeInfo* ti, double dval, const SVFType* type, const ICFGNode* node)
657 {
658 memToFieldsMap[i].set(i);
659 ConstFPObjVar* conObj = new ConstFPObjVar(i, dval, ti, type, node);
660 return addObjNode(conObj);
661 }
662
663
664 inline NodeID addConstantIntObjNode(NodeID i, ObjTypeInfo* ti, const std::pair<s64_t, u64_t>& intValue, const SVFType* type, const ICFGNode* node)
665 {
666 memToFieldsMap[i].set(i);
668 new ConstIntObjVar(i, intValue.first, intValue.second, ti, type, node);
669 return addObjNode(conObj);
670 }
671
672
674 {
675 memToFieldsMap[i].set(i);
677 return addObjNode(conObj);
678 }
679
680 inline NodeID addGlobalObjNode(const NodeID i, ObjTypeInfo* ti, const SVFType* type, const ICFGNode* node)
681 {
682 memToFieldsMap[i].set(i);
683 GlobalObjVar* gObj = new GlobalObjVar(i, ti, type, node);
684 return addObjNode(gObj);
685 }
687 {
688 memToFieldsMap[i].set(i);
690 return addObjNode(conObj);
691 }
693 {
694 memToFieldsMap[i].set(i);
696 return addObjNode(conObj);
697 }
698
700 inline NodeID addRetNode(NodeID i, const FunObjVar* callGraphNode, const SVFType* type, const ICFGNode* icn)
701 {
702 SVFVar *node = new RetValPN(i, callGraphNode, type, icn);
703 return addRetNode(callGraphNode, node);
704 }
706 inline NodeID addVarargNode(NodeID i, const FunObjVar* val, const SVFType* type, const ICFGNode* n)
707 {
708 SVFVar *node = new VarArgValPN(i, val, type, n);
709 return addNode(node);
710 }
711
713 NodeID addGepValNode(NodeID curInst, const ValVar* base, const AccessPath& ap, NodeID i, const SVFType* type, const ICFGNode* node);
715 NodeID addGepObjNode(const BaseObjVar* baseObj, const APOffset& apOffset, const NodeID gepId);
718 {
719 memToFieldsMap[i].set(i);
720 BaseObjVar* baseObj = new BaseObjVar(i, ti, type, node);
721 return addObjNode(baseObj);
722 }
723
724
726
728
730 {
731 return addValNode(new DummyValVar(i, node));
732 }
734 {
735 if (idToObjTypeInfoMap().find(i) == idToObjTypeInfoMap().end())
736 {
739 return addObjNode(new DummyObjVar(i, ti, nullptr, type));
740 }
741 else
742 {
743 return addObjNode(new DummyObjVar(i, getObjTypeInfo(i), nullptr, type));
744 }
745 }
746
752 {
754 }
756 {
757 return addDummyValNode(getBlkPtr(), nullptr);
758 }
760
763 {
764 assert(node && "node cannot be nullptr.");
765 assert(hasGNode(node->getId()) == false &&
766 "This NodeID clashes here. Please check NodeIDAllocator. Switch "
767 "Strategy::DBUG to SEQ or DENSE");
768 return addNode(node);
769 }
772 {
773 assert(node && "node cannot be nullptr.");
774 assert(hasGNode(node->getId()) == false &&
775 "This NodeID clashes here. Please check NodeIDAllocator. Switch "
776 "Strategy::DBUG to SEQ or DENSE");
777 return addNode(node);
778 }
780 inline NodeID addRetNode(const FunObjVar*, SVFVar *node)
781 {
782 return addNode(node);
783 }
785 inline NodeID addVarargNode(const FunObjVar*, SVFVar *node)
786 {
787 return addNode(node);
788 }
789
791 inline void addGlobalPAGEdge(const SVFStmt* edge)
792 {
793 globSVFStmtSet.insert(edge);
794 }
796 inline void addCallSite(const CallICFGNode* call)
797 {
798 callSiteSet.insert(call);
799 }
801
802
806
815 u32_t opcode);
817 UnaryOPStmt* addUnaryOPStmt(NodeID src, NodeID dst, u32_t opcode);
824 StoreStmt* addStoreStmt(NodeID src, NodeID dst, const ICFGNode* val);
826 CallPE* addCallPE(NodeID src, NodeID dst, const CallICFGNode* cs,
827 const FunEntryICFGNode* entry);
829 RetPE* addRetPE(NodeID src, NodeID dst, const CallICFGNode* cs,
830 const FunExitICFGNode* exit);
832 GepStmt* addGepStmt(NodeID src, NodeID dst, const AccessPath& ap,
833 bool constGep);
835 GepStmt* addNormalGepStmt(NodeID src, NodeID dst, const AccessPath& ap);
837 GepStmt* addVariantGepStmt(NodeID src, NodeID dst, const AccessPath& ap);
840 const FunEntryICFGNode* entry);
843 const FunExitICFGNode* exit);
845
848};
849
850typedef SVFIR PAG;
851
852} // End namespace SVF
853
854
855
856#endif /* INCLUDE_SVFIR_H_ */
newitem type
Definition cJSON.cpp:2739
cJSON * n
Definition cJSON.cpp:2558
const cJSON *const b
Definition cJSON.h:255
const char *const name
Definition cJSON.h:264
Class representing a function argument variable in the SVFIR.
NodeID getId() const
Get the memory object id.
std::vector< std::pair< const ICFGNode *, s32_t > > SuccAndCondPairVec
void addActualParms(const ValVar *ap)
Add actual parameters.
Definition ICFGNode.h:488
Common base for class hierarchy graph. Only implements what PointerAnalysis needs.
Definition CHG.h:51
void addFormalParms(const SVFVar *fp)
Add formal parameters.
Definition ICFGNode.h:307
void addFormalRet(const SVFVar *fr)
Add formal return parameter.
Definition ICFGNode.h:375
bool hasGNode(NodeID id) const
Has a node.
NodeType * getGNode(NodeID id) const
Get a node.
Class representing a heap object variable in the SVFIR.
NodeID totalICFGNode
Definition ICFG.h:66
FunExitICFGNode * getFunExitICFGNode(const FunObjVar *fun)
Add a function exit node.
Definition ICFG.cpp:249
FunEntryICFGNode * getFunEntryICFGNode(const FunObjVar *fun)
Add a function entry node.
Definition ICFG.cpp:242
Set< const SVFStmt * > SVFStmtSet
Definition IRGraph.h:106
NodeID addNode(SVFVar *node)
Add a node into the graph.
Definition IRGraph.h:118
NodeID getBlkPtr() const
Definition IRGraph.h:255
NodeID getBlackHoleNode() const
Definition IRGraph.h:247
SVFStmt::KindToSVFStmtMapTy KindToSVFStmtSetMap
SVFIR edge map containing all PAGEdges.
Definition IRGraph.h:109
ObjTypeInfo * createObjTypeInfo(const SVFType *type)
Create an objectInfo based on LLVM type (value is null, and type could be null, representing a dummy ...
Definition IRGraph.cpp:231
static bool isBlkObj(NodeID id)
Definition IRGraph.h:165
u32_t totalPTAPAGEdge
Definition IRGraph.h:113
static bool isConstantSym(NodeID id)
Definition IRGraph.h:169
ObjTypeInfo * getObjTypeInfo(NodeID id) const
Definition IRGraph.h:234
NodeID getConstantNode() const
Definition IRGraph.h:251
SVFStmt::KindToSVFStmtMapTy KindToPTASVFStmtSetMap
SVFIR edge map containing only pointer-related edges, i.e., both LHS and RHS are of pointer type.
Definition IRGraph.h:110
IDToTypeInfoMapTy & idToObjTypeInfoMap()
Get different kinds of syms maps.
Definition IRGraph.h:212
static NodeIDAllocator * get(void)
Return (singleton) allocator.
static void releaseSVFIR()
Definition SVFIR.h:124
NodeID addGepObjNode(const BaseObjVar *baseObj, const APOffset &apOffset, const NodeID gepId)
Add a field obj node, this method can only invoked by getGepObjVar.
Definition SVFIR.cpp:466
const CallSiteSet & getCallSiteSet() const
Get all callsites.
Definition SVFIR.h:282
CSToArgsListMap & getCallSiteArgsMap()
Get callsite argument list.
Definition SVFIR.h:315
NodeID addObjNode(NodeID i, ObjTypeInfo *ti, const SVFType *type, const ICFGNode *node)
Add a memory obj node.
Definition SVFIR.h:623
SVFStmt::SVFStmtSetTy & getPTASVFStmtSet(SVFStmt::PEDGEK kind)
Get PTA edges set according to its kind.
Definition SVFIR.h:234
NodeID addDummyValNode(NodeID i, const ICFGNode *node)
Add a dummy value/object node according to node ID (llvm value is null)
Definition SVFIR.h:729
bool hasPTASVFStmtList(const ICFGNode *inst) const
Definition SVFIR.h:243
GepStmt * addVariantGepStmt(NodeID src, NodeID dst, const AccessPath &ap)
Add Variant(Gep) edge.
Definition SVFIR.cpp:382
SVFStmt::SVFStmtSetTy & getSVFStmtSet(SVFStmt::PEDGEK kind)
Get/set methods to get SVFStmts based on their kinds and ICFGNodes.
Definition SVFIR.h:229
Map< const SVFVar *, PhiStmt * > PHINodeMap
Definition SVFIR.h:59
bool funHasRet(const FunObjVar *func) const
Definition SVFIR.h:354
NodeOffsetMap GepObjVarMap
Map a pair<base,off> to a gep obj node id.
Definition SVFIR.h:83
CallSiteToFunPtrMap indCallSiteToFunPtrMap
Map an indirect callsite to its function pointer.
Definition SVFIR.h:91
NodeID addGlobalValNode(const NodeID i, const ICFGNode *icfgNode, const SVFType *svfType)
Definition SVFIR.h:603
CopyStmt * addCopyStmt(NodeID src, NodeID dst, CopyStmt::CopyKind type)
Add Copy edge.
Definition SVFIR.cpp:81
CSToRetMap callSiteRetMap
Map a callsite to its callsite returns PAGNodes.
Definition SVFIR.h:89
NodeID addObjNode(SVFVar *node)
Add a memory obj node.
Definition SVFIR.h:771
NodeID getGepValVar(NodeID curInst, NodeID base, const AccessPath &ap) const
Due to constraint expression, curInst is used to distinguish different instructions (e....
Definition SVFIR.cpp:522
CallGraph * getCallGraph()
Definition SVFIR.h:184
RetPE * addRetPE(NodeID src, NodeID dst, const CallICFGNode *cs, const FunExitICFGNode *exit)
Add Return edge.
Definition SVFIR.cpp:276
NodeID getFunPtr(const CallICFGNode *cs) const
Definition SVFIR.h:382
bool hasFunArgsList(const FunObjVar *func) const
Function has arguments list.
Definition SVFIR.h:293
NodeID addGlobalObjNode(const NodeID i, ObjTypeInfo *ti, const SVFType *type, const ICFGNode *node)
Definition SVFIR.h:680
GepStmt * addGepStmt(NodeID src, NodeID dst, const AccessPath &ap, bool constGep)
Add Gep edge.
Definition SVFIR.cpp:344
void print()
Print SVFIR.
Definition SVFIR.cpp:557
static void handleBlackHole(bool b)
SVFIR build configurations.
Definition SVFIR.cpp:690
NodeID addConstantFPObjNode(NodeID i, ObjTypeInfo *ti, double dval, const SVFType *type, const ICFGNode *node)
Definition SVFIR.h:656
NodeID addValNode(SVFVar *node)
Add a value (pointer) node.
Definition SVFIR.h:762
void addToStmt2TypeMap(SVFStmt *edge)
Map a SVFStatement type to a set of corresponding SVF statements.
Definition SVFIR.h:512
friend class ExternalPAG
Definition SVFIR.h:45
NodeID addBlackholePtrNode()
Definition SVFIR.h:755
Set< const CallICFGNode * > CallSiteSet
Definition SVFIR.h:53
NodeID addBlackholeObjNode()
Definition SVFIR.h:747
void addFunArgs(const FunObjVar *fun, const SVFVar *arg)
Get/set method for function/callsite arguments and returns.
Definition SVFIR.h:527
CommonCHGraph * chgraph
Definition SVFIR.h:97
Map< const CallICFGNode *, SVFVarList > CSToArgsListMap
Definition SVFIR.h:61
SVFStmt * addBlackHoleAddrStmt(NodeID node)
Set a pointer points-to black hole (e.g. int2ptr)
Definition SVFIR.cpp:294
NodeID addDummyObjNode(NodeID i, const SVFType *type)
Definition SVFIR.h:733
NodeID addHeapObjNode(NodeID i, ObjTypeInfo *ti, const SVFType *type, const ICFGNode *node)
Definition SVFIR.h:631
LoadStmt * addLoadStmt(NodeID src, NodeID dst)
Add Load edge.
Definition SVFIR.cpp:221
NodeID addGepValNode(NodeID curInst, const ValVar *base, const AccessPath &ap, NodeID i, const SVFType *type, const ICFGNode *node)
Add a temp field value node, this method can only invoked by getGepValVar.
Definition SVFIR.cpp:403
GepStmt * addNormalGepStmt(NodeID src, NodeID dst, const AccessPath &ap)
Add Offset(Gep) edge.
Definition SVFIR.cpp:363
u32_t getFieldObjNodeNum() const
Definition SVFIR.h:366
MemObjToFieldsMap memToFieldsMap
Map a mem object id to all its fields.
Definition SVFIR.h:84
Map< const RetICFGNode *, const SVFVar * > CSToRetMap
Definition SVFIR.h:62
virtual ~SVFIR()
Destructor.
Definition SVFIR.h:148
bool isIndirectCallSites(const CallICFGNode *cs) const
Definition SVFIR.h:394
void addFunRet(const FunObjVar *fun, const SVFVar *ret)
Add function returns.
Definition SVFIR.h:534
SVFStmt * getIntraPAGEdge(SVFVar *src, SVFVar *dst, SVFStmt::PEDGEK kind)
Definition SVFIR.h:409
PHINodeMap phiNodeMap
A set of phi copy edges.
Definition SVFIR.h:86
NodeBS getFieldsAfterCollapse(NodeID id)
Definition SVFIR.cpp:504
std::pair< NodeID, APOffset > NodeOffset
Definition SVFIR.h:67
NodeID addVarargNode(const FunObjVar *, SVFVar *node)
Add a unique vararg node for a procedure.
Definition SVFIR.h:785
Map< const ICFGNode *, SVFStmtList > ICFGNode2SVFStmtsMap
Definition SVFIR.h:65
NodeID addFunObjNode(NodeID id, ObjTypeInfo *ti, const SVFType *type, const ICFGNode *node)
Definition SVFIR.h:648
FunToRetMap funRetMap
Map a function to its unique function return PAGNodes.
Definition SVFIR.h:90
NodeID getGepObjVar(const BaseObjVar *baseObj, const APOffset &ap)
Get a field SVFIR Object node according to base mem obj and offset.
Definition SVFIR.cpp:439
NodeID addStackObjNode(NodeID i, ObjTypeInfo *ti, const SVFType *type, const ICFGNode *node)
Definition SVFIR.h:641
OrderedMap< const CallICFGNode *, NodeID > CallSiteToFunPtrMap
Definition SVFIR.h:54
static std::string pagFileName()
Definition SVFIR.h:206
CallPE * addCallPE(NodeID src, NodeID dst, const CallICFGNode *cs, const FunEntryICFGNode *entry)
Add Call edge.
Definition SVFIR.cpp:258
NodeID addConstantNullPtrValNode(const NodeID i, const ICFGNode *icfgNode, const SVFType *type)
Definition SVFIR.h:597
SVFStmtList & getSVFStmtList(const ICFGNode *inst)
Given an instruction, get all its PAGEdges.
Definition SVFIR.h:249
bool isValidTopLevelPtr(const SVFVar *node)
Definition SVFIR.cpp:673
bool isConstantObj(NodeID id) const
Definition SVFIR.h:467
bool isPhiNode(const SVFVar *node) const
Whether this SVFVar is a result operand a of phi node.
Definition SVFIR.h:287
static bool pagReadFromTXT()
Definition SVFIR.h:211
OrderedNodeSet & getAllValidPtrs()
Return valid pointers.
Definition SVFIR.h:140
bool hasSVFStmtList(const ICFGNode *inst) const
Whether this instruction has SVFIR Edge.
Definition SVFIR.h:239
TypeLocSetsMap typeLocSetsMap
Map an arg to its base SVFType* and all its field location sets.
Definition SVFIR.h:82
std::vector< const SVFVar * > SVFVarList
Definition SVFIR.h:58
TDJoinPE * addThreadJoinPE(NodeID src, NodeID dst, const CallICFGNode *cs, const FunExitICFGNode *exit)
Add Thread join edge for parameter passing.
Definition SVFIR.cpp:323
CallGraph * callGraph
all the callsites of a program
Definition SVFIR.h:99
Map< NodeID, NodeID > NodeToNodeMap
Definition SVFIR.h:66
static std::string pagReadFromTxt
Definition SVFIR.h:102
NodeID addConstantDataObjNode(const NodeID i, ObjTypeInfo *ti, const SVFType *type, const ICFGNode *node)
Definition SVFIR.h:692
CSToRetMap & getCallSiteRets()
Get callsite return.
Definition SVFIR.h:327
void destroy()
Clean up memory.
Definition SVFIR.cpp:544
void addToSVFStmtList(ICFGNode *inst, SVFStmt *edge)
Add a SVFStmt into instruction map.
Definition SVFIR.h:259
std::vector< const SVFStmt * > SVFStmtList
Definition SVFIR.h:57
const BaseObjVar * getBaseObject(NodeID id) const
Definition SVFIR.h:423
SVFStmtSet globSVFStmtSet
Global PAGEdges without control flow information.
Definition SVFIR.h:85
void addCallSiteRets(RetICFGNode *retBlockNode, const SVFVar *arg)
Add callsite returns.
Definition SVFIR.h:547
NodeID addConstantDataValNode(const NodeID i, const ICFGNode *icfgNode, const SVFType *type)
Definition SVFIR.h:615
std::pair< NodeID, AccessPath > NodeAccessPath
Definition SVFIR.h:68
void setICFG(ICFG *i)
Set/Get ICFG.
Definition SVFIR.h:159
NodeID addFIObjNode(NodeID i, ObjTypeInfo *ti, const SVFType *type, const ICFGNode *node)
Add a field-insensitive node, this method can only invoked by getFIGepObjNode.
Definition SVFIR.h:717
NodeID getBaseObjVar(NodeID id) const
Base and Offset methods for Value and Object node.
Definition SVFIR.h:479
Map< NodeAccessPath, NodeID > NodeAccessPathMap
Definition SVFIR.h:70
std::string moduleIdentifier
Definition SVFIR.h:104
const FunObjVar * getFunObjVar(const std::string &name)
Definition SVFIR.cpp:47
CmpStmt * addCmpStmt(NodeID op1, NodeID op2, NodeID dst, u32_t predict)
Add Copy edge.
Definition SVFIR.cpp:144
FunToRetMap & getFunRets()
Get function return list.
Definition SVFIR.h:343
SVFStmtSet & getGlobalSVFStmtSet()
Get global PAGEdges (not in a procedure)
Definition SVFIR.h:277
void addCallSiteArgs(CallICFGNode *callBlockNode, const ValVar *arg)
Add callsite arguments.
Definition SVFIR.h:541
AddrStmt * addAddrStmt(NodeID src, NodeID dst)
Add an edge into SVFIR.
Definition SVFIR.cpp:63
FunToArgsListMap funArgsListMap
Map a function to a list of all its formal parameters.
Definition SVFIR.h:87
ICFGNode2SVFStmtsMap icfgNode2SVFStmtsMap
Map an ICFGNode to its SVFStmts.
Definition SVFIR.h:79
NodeID addConstantAggObjNode(const NodeID i, ObjTypeInfo *ti, const SVFType *type, const ICFGNode *node)
Definition SVFIR.h:686
NodeID addConstantIntValNode(NodeID i, const std::pair< s64_t, u64_t > &intValue, const ICFGNode *icfgNode, const SVFType *type)
Definition SVFIR.h:590
ICFG * getICFG() const
Definition SVFIR.h:163
u32_t getFieldValNodeNum() const
Node and edge statistics.
Definition SVFIR.h:362
NodeID addFunValNode(NodeID i, const ICFGNode *icfgNode, const FunObjVar *funObjVar, const SVFType *type)
Definition SVFIR.h:570
NodeID addConstantFPValNode(const NodeID i, double dval, const ICFGNode *icfgNode, const SVFType *type)
Definition SVFIR.h:583
UnaryOPStmt * addUnaryOPStmt(NodeID src, NodeID dst, u32_t opcode)
Add Unary edge.
Definition SVFIR.cpp:185
NodeID addConstantAggValNode(const NodeID i, const ICFGNode *icfgNode, const SVFType *svfType)
Definition SVFIR.h:609
NodeID addConstantNullPtrObjNode(const NodeID i, ObjTypeInfo *ti, const SVFType *type, const ICFGNode *node)
Definition SVFIR.h:673
std::pair< const SVFType *, std::vector< AccessPath > > SVFTypeLocSetsPair
Definition SVFIR.h:72
TDForkPE * addThreadForkPE(NodeID src, NodeID dst, const CallICFGNode *cs, const FunEntryICFGNode *entry)
Add Thread fork edge for parameter passing.
Definition SVFIR.cpp:305
bool isFunPtr(NodeID id) const
Definition SVFIR.h:398
SVFStmt * getIntraPAGEdge(NodeID src, NodeID dst, SVFStmt::PEDGEK kind)
Get an edge according to src, dst and kind.
Definition SVFIR.h:405
BinaryOPStmt * addBinaryOPStmt(NodeID op1, NodeID op2, NodeID dst, u32_t opcode)
Add Copy edge.
Definition SVFIR.cpp:165
bool hasCallSiteArgsMap(const CallICFGNode *cs) const
Callsite has argument list.
Definition SVFIR.h:310
friend class SVFIRReader
Definition SVFIR.h:49
NodeBS & getAllFieldsObjVars(const BaseObjVar *obj)
Get all fields of an object.
Definition SVFIR.cpp:483
void addCallSite(const CallICFGNode *call)
Add callsites.
Definition SVFIR.h:796
static std::unique_ptr< SVFIR > pag
call graph
Definition SVFIR.h:101
NodeID addValNode(NodeID i, const SVFType *type, const ICFGNode *icfgNode)
add node into SVFIR
Definition SVFIR.h:564
StoreStmt * addStoreStmt(NodeID src, NodeID dst, const ICFGNode *val)
Add Store edge.
Definition SVFIR.cpp:240
NodeID addVarargNode(NodeID i, const FunObjVar *val, const SVFType *type, const ICFGNode *n)
Add a unique vararg node for a procedure.
Definition SVFIR.h:706
void addToTypeLocSetsMap(NodeID argId, SVFTypeLocSetsPair &locSets)
Add a base SVFType* and all its field location sets to an arg NodeId.
Definition SVFIR.h:267
CSToArgsListMap callSiteArgsListMap
Map a callsite to a list of all its actual parameters.
Definition SVFIR.h:88
void setCHG(CommonCHGraph *c)
Set/Get CHG.
Definition SVFIR.h:169
NodeOffsetMap & getGepObjNodeMap()
Return GepObjVarMap.
Definition SVFIR.h:135
const CallSiteToFunPtrMap & getIndirectCallsites() const
Add/get indirect callsites.
Definition SVFIR.h:378
CommonCHGraph * getCHG()
Definition SVFIR.h:173
bool callsiteHasRet(const RetICFGNode *cs) const
Definition SVFIR.h:338
NodeID addDummyValNode()
Definition SVFIR.h:491
SVFStmtList & getPTASVFStmtList(const ICFGNode *inst)
Given an instruction, get all its PTA PAGEdges.
Definition SVFIR.h:254
ICFGNode2SVFStmtsMap icfgNode2PTASVFStmtsMap
Map an ICFGNode to its PointerAnalysis related SVFStmts.
Definition SVFIR.h:80
Map< NodeID, NodeBS > MemObjToFieldsMap
Definition SVFIR.h:56
Map< NodePair, NodeID > NodePairSetMap
Definition SVFIR.h:74
PhiStmt * addPhiStmt(NodeID res, NodeID opnd, const ICFGNode *pred)
Add phi node information.
Definition SVFIR.cpp:99
OrderedNodeSet candidatePointers
Definition SVFIR.h:95
ICFG * icfg
Definition SVFIR.h:96
void setModuleIdentifier(const std::string &moduleIdentifier)
Definition SVFIR.h:221
CallSiteSet callSiteSet
Definition SVFIR.h:98
friend class SVFIRWriter
Definition SVFIR.h:48
friend class TypeBasedHeapCloning
Definition SVFIR.h:47
const SVFVarList & getCallSiteArgsList(const CallICFGNode *cs) const
Get callsite argument list.
Definition SVFIR.h:320
NodeID getFIObjVar(NodeID id) const
Definition SVFIR.h:453
Map< const FunObjVar *, const SVFVar * > FunToRetMap
Definition SVFIR.h:63
SelectStmt * addSelectStmt(NodeID res, NodeID op1, NodeID op2, NodeID cond)
Add SelectStmt.
Definition SVFIR.cpp:123
void setCallGraph(CallGraph *c)
Set/Get CG.
Definition SVFIR.h:180
static SVFIR * getPAG(bool buildFromFile=false)
Singleton design here to make sure we only have one instance during any analysis.
Definition SVFIR.h:116
Map< const FunObjVar *, SVFStmtSet > FunToPAGEdgeSetMap
Definition SVFIR.h:64
NodeID addConstantIntObjNode(NodeID i, ObjTypeInfo *ti, const std::pair< s64_t, u64_t > &intValue, const SVFType *type, const ICFGNode *node)
Definition SVFIR.h:664
Map< NodeID, SVFTypeLocSetsPair > TypeLocSetsMap
Definition SVFIR.h:73
GepValueVarMap GepValObjMap
Map a pair<base,off> to a gep value node id.
Definition SVFIR.h:81
const ValVar * getBaseValVar(NodeID id) const
Definition SVFIR.h:433
Map< const FunObjVar *, SVFVarList > FunToArgsListMap
Definition SVFIR.h:60
bool isBlkObjOrConstantObj(NodeID id) const
Get black hole and constant id.
Definition SVFIR.h:462
const CallSiteSet & getIndCallSites(NodeID funPtr) const
Definition SVFIR.h:388
Map< NodeID, NodeAccessPathMap > GepValueVarMap
Definition SVFIR.h:71
bool isValidPointer(NodeID nodeId) const
Whether a node is a valid pointer.
Definition SVFIR.cpp:658
Map< NodeID, CallSiteSet > FunPtrToCallSitesMap
Definition SVFIR.h:55
const SVFVar * getCallSiteRet(const RetICFGNode *cs) const
Get callsite return.
Definition SVFIR.h:332
void addGlobalPAGEdge(const SVFStmt *edge)
Add global PAGEdges (not in a procedure)
Definition SVFIR.h:791
const std::string & getModuleIdentifier() const
Definition SVFIR.h:192
BranchStmt * addBranchStmt(NodeID br, NodeID cond, const BranchStmt::SuccAndCondPairVec &succs)
Add BranchStmt.
Definition SVFIR.cpp:203
Map< NodeOffset, NodeID > NodeOffsetMap
Definition SVFIR.h:69
const SVFVarList & getFunArgsList(const FunObjVar *func) const
Get function arguments list.
Definition SVFIR.h:303
NodeID addRetNode(const FunObjVar *, SVFVar *node)
Add a unique return node for a procedure.
Definition SVFIR.h:780
const SVFVar * getFunRet(const FunObjVar *func) const
Get function return list.
Definition SVFIR.h:348
void addIndirectCallsites(const CallICFGNode *cs, NodeID funPtr)
Add indirect callsites.
Definition SVFIR.h:553
FunToArgsListMap & getFunArgsMap()
Get function arguments list.
Definition SVFIR.h:298
void initialiseCandidatePointers()
Initialize candidate pointers.
Definition SVFIR.cpp:642
NodeID addRetNode(NodeID i, const FunObjVar *callGraphNode, const SVFType *type, const ICFGNode *icn)
Add a unique return node for a procedure.
Definition SVFIR.h:700
static void setPagFromTXT(const std::string &txt)
Definition SVFIR.h:216
NodeID getFIObjVar(const BaseObjVar *obj) const
Get a field-insensitive obj SVFIR node according to a mem obj.
Definition SVFIR.h:449
FunPtrToCallSitesMap funPtrToCallSitesMap
Definition SVFIR.h:92
NodeID addArgValNode(NodeID i, u32_t argNo, const ICFGNode *icfgNode, const FunObjVar *callGraphNode, const SVFType *type)
Definition SVFIR.h:576
SVFTypeLocSetsPair & getTypeLocSetsMap(NodeID argId)
Given an arg NodeId, get its base SVFType* and all its field location sets.
Definition SVFIR.h:272
NodeID addDummyObjNode(const SVFType *type)
Definition SVFIR.h:495
MemObjToFieldsMap & getMemToFieldsMap()
Return memToFieldsMap.
Definition SVFIR.h:130
NodeID addConstantObjNode()
Definition SVFIR.h:751
GenericNode< SVFVar, SVFStmt >::GEdgeSetTy SVFStmtSetTy
NodeID getId() const
Get ID.
Definition SVFValue.h:158
Represents a stack-allocated object variable in the SVFIR (SVF Intermediate Representation) @inherits...
for isBitcode
Definition BasicTypes.h:68
OrderedSet< NodeID > OrderedNodeSet
u32_t NodeID
Definition GeneralType.h:56
s64_t APOffset
Definition GeneralType.h:60
llvm::IRBuilder IRBuilder
Definition BasicTypes.h:74
SVFIR PAG
Definition SVFIR.h:850
unsigned u32_t
Definition GeneralType.h:47