Static Value-Flow Analysis
Loading...
Searching...
No Matches
SymbolTableBuilder.cpp
Go to the documentation of this file.
1//===- SymbolTableBuilder.cpp -- Symbol Table builder---------------------//
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 * SymbolTableBuilder.cpp
25 *
26 * Created on: Apr 28, 2014
27 * Author: Yulei Sui
28 */
29
30#include <memory>
31
32#include "SVF-LLVM/BasicTypes.h"
33#include "SVF-LLVM/CppUtil.h"
34#include "SVF-LLVM/GEPTypeBridgeIterator.h" // include bridge_gep_iterator
35#include "SVF-LLVM/LLVMUtil.h"
38#include "Util/Options.h"
39#include "Util/SVFUtil.h"
41
42using namespace SVF;
43using namespace SVFUtil;
44using namespace LLVMUtil;
45
59
73
74
79{
81
82 // Pointer #0 always represents the null pointer.
83 assert(svfir->totalSymNum++ == IRGraph::NullPtr && "Something changed!");
84
85 // Pointer #1 always represents the pointer points-to black hole.
86 assert(svfir->totalSymNum++ == IRGraph::BlkPtr && "Something changed!");
87
88 // Object #2 is black hole the object that may point to any object
89 assert(svfir->totalSymNum++ == IRGraph::BlackHole && "Something changed!");
91
92 // Object #3 always represents the unique constant of a program (merging all constants if Options::ModelConsts is disabled)
93 assert(svfir->totalSymNum++ == IRGraph::ConstantObj && "Something changed!");
95
97 {
98 // Add symbols for all the globals .
99 for (const GlobalVariable& gv : M.globals())
100 {
101 collectSym(&gv);
102 }
103
104 // Add symbols for all the global aliases
105 for (const GlobalAlias& ga : M.aliases())
106 {
107 collectSym(&ga);
108 collectSym(ga.getAliasee());
109 }
110
111 // Add symbols for all of the functions and the instructions in them.
112 for (const Function& fun : M.functions())
113 {
114 collectSym(&fun);
115 collectRet(&fun);
116 if (fun.getFunctionType()->isVarArg())
117 collectVararg(&fun);
118
119 // Add symbols for all formal parameters.
120 for (const Argument& arg : fun.args())
121 {
122 collectSym(&arg);
123 }
124
125 // collect and create symbols inside the function body
126 for (const Instruction& inst : instructions(fun))
127 {
128 collectSym(&inst);
129
130 // initialization for some special instructions
131 //{@
132 if (const StoreInst* st = SVFUtil::dyn_cast<StoreInst>(&inst))
133 {
134 collectSym(st->getPointerOperand());
135 collectSym(st->getValueOperand());
136 }
137 else if (const LoadInst* ld =
138 SVFUtil::dyn_cast<LoadInst>(&inst))
139 {
140 collectSym(ld->getPointerOperand());
141 }
142 else if (const AllocaInst* alloc =
143 SVFUtil::dyn_cast<AllocaInst>(&inst))
144 {
145 collectSym(alloc->getArraySize());
146 }
147 else if (const PHINode* phi = SVFUtil::dyn_cast<PHINode>(&inst))
148 {
149 for (u32_t i = 0; i < phi->getNumIncomingValues(); ++i)
150 {
151 collectSym(phi->getIncomingValue(i));
152 }
153 }
154 else if (const GetElementPtrInst* gep =
155 SVFUtil::dyn_cast<GetElementPtrInst>(&inst))
156 {
157 collectSym(gep->getPointerOperand());
158 for (u32_t i = 0; i < gep->getNumOperands(); ++i)
159 {
160 collectSym(gep->getOperand(i));
161 }
162 }
163 else if (const SelectInst* sel =
164 SVFUtil::dyn_cast<SelectInst>(&inst))
165 {
166 collectSym(sel->getTrueValue());
167 collectSym(sel->getFalseValue());
168 collectSym(sel->getCondition());
169 }
170 else if (const BinaryOperator* binary =
171 SVFUtil::dyn_cast<BinaryOperator>(&inst))
172 {
173 for (u32_t i = 0; i < binary->getNumOperands(); i++)
174 collectSym(binary->getOperand(i));
175 }
176 else if (const UnaryOperator* unary =
177 SVFUtil::dyn_cast<UnaryOperator>(&inst))
178 {
179 for (u32_t i = 0; i < unary->getNumOperands(); i++)
180 collectSym(unary->getOperand(i));
181 }
182 else if (const CmpInst* cmp = SVFUtil::dyn_cast<CmpInst>(&inst))
183 {
184 for (u32_t i = 0; i < cmp->getNumOperands(); i++)
185 collectSym(cmp->getOperand(i));
186 }
187 else if (const CastInst* cast =
188 SVFUtil::dyn_cast<CastInst>(&inst))
189 {
190 collectSym(cast->getOperand(0));
191 }
192 else if (const ReturnInst* ret =
193 SVFUtil::dyn_cast<ReturnInst>(&inst))
194 {
195 if (ret->getReturnValue())
196 collectSym(ret->getReturnValue());
197 }
198 else if (const BranchInst* br =
199 SVFUtil::dyn_cast<BranchInst>(&inst))
200 {
201 Value* opnd = br->isConditional() ? br->getCondition() : br->getOperand(0);
203 }
204 else if (const SwitchInst* sw =
205 SVFUtil::dyn_cast<SwitchInst>(&inst))
206 {
207 collectSym(sw->getCondition());
208 }
209 else if (isNonInstricCallSite(&inst))
210 {
211
212 const CallBase* cs = LLVMUtil::getLLVMCallSite(&inst);
213 for (u32_t i = 0; i < cs->arg_size(); i++)
214 {
215 collectSym(cs->getArgOperand(i));
216 }
217 // Calls to inline asm need to be added as well because the
218 // callee isn't referenced anywhere else.
219 const Value* Callee = cs->getCalledOperand();
221
222 // TODO handle inlineAsm
225 {
227 }
228 }
230 }
231 }
232 }
233
236 {
238 }
239}
240
242{
243 Type *valType = val->getType();
245 if(isGepConstantExpr(val) || SVFUtil::isa<GetElementPtrInst>(val))
246 {
248 gi = bridge_gep_begin(SVFUtil::cast<User>(val)),
249 ge = bridge_gep_end(SVFUtil::cast<User>(val));
250 gi != ge; ++gi)
251 {
252 const Type* gepTy = *gi;
254 }
255 }
256}
257
262{
263
264 //TODO: filter the non-pointer type // if (!SVFUtil::isa<PointerType>(val->getType())) return;
265
267 outs()
268 << "collect sym from ##"
269 << llvmModuleSet()->getSVFValue(val)->toString()
270 << " \n");
271 //TODO handle constant expression value here??
272 handleCE(val);
273
274 // create a value sym
276
279
280 // create an object If it is a heap, stack, global, function.
281 if (isObject(val))
282 {
284 }
285}
286
291{
292 // collect and record special sym here
294 {
295 return;
296 }
297 LLVMModuleSet::ValueToIDMapTy::iterator iter = llvmModuleSet()->valSymMap.find(val);
298 if (iter == llvmModuleSet()->valSymMap.end())
299 {
300 // create val sym and sym type
302 llvmModuleSet()->valSymMap.insert(std::make_pair(val, id));
304 outs() << "create a new value sym " << id << "\n");
306 if (const GlobalVariable* globalVar = SVFUtil::dyn_cast<GlobalVariable>(val))
308 }
309
312}
313
318{
320 LLVMModuleSet::ValueToIDMapTy::iterator iter = llvmModuleSet()->objSymMap.find(val);
321 if (iter == llvmModuleSet()->objSymMap.end())
322 {
323 // if the object pointed by the pointer is a constant data (e.g., i32 0) or a global constant object (e.g. string)
324 // then we treat them as one ConstantObj
326 {
327 llvmModuleSet()->objSymMap.insert(std::make_pair(val, svfir->constantSymID()));
328 }
329 // otherwise, we will create an object for each abstract memory location
330 else
331 {
332 // create obj sym and sym type
334 llvmModuleSet()->objSymMap.insert(std::make_pair(val, id));
336 outs() << "create a new obj sym " << id << "\n");
337
338 // create a memory object
340 assert(svfir->objTypeInfoMap.find(id) == svfir->objTypeInfoMap.end());
341 svfir->objTypeInfoMap[id] = ti;
342 }
343 }
344}
345
350{
351
352 LLVMModuleSet::FunToIDMapTy::iterator iter =
354 if (iter == llvmModuleSet()->returnSymMap.end())
355 {
357 llvmModuleSet()->returnSymMap.insert(std::make_pair(val, id));
358 DBOUT(DMemModel, outs() << "create a return sym " << id << "\n");
359 }
360}
361
366{
367 LLVMModuleSet::FunToIDMapTy::iterator iter =
369 if (iter == llvmModuleSet()->varargSymMap.end())
370 {
372 llvmModuleSet()->varargSymMap.insert(std::make_pair(val, id));
373 DBOUT(DMemModel, outs() << "create a vararg sym " << id << "\n");
374 }
375}
376
381{
382 if (const Constant* ref = SVFUtil::dyn_cast<Constant>(val))
383 {
384 if (const ConstantExpr* ce = isGepConstantExpr(ref))
385 {
386 DBOUT(DMemModelCE, outs() << "handle constant expression "
387 << llvmModuleSet()
389 ->toString()
390 << "\n");
391 collectVal(ce);
392
393 // handle the recursive constant express case
394 // like (gep (bitcast (gep X 1)) 1); the inner gep is ce->getOperand(0)
395 for (u32_t i = 0; i < ce->getNumOperands(); ++i)
396 {
397 collectVal(ce->getOperand(i));
398 handleCE(ce->getOperand(i));
399 }
400 }
401 else if (const ConstantExpr* ce = isCastConstantExpr(ref))
402 {
403 DBOUT(DMemModelCE, outs() << "handle constant expression "
404 << llvmModuleSet()
406 ->toString()
407 << "\n");
408 collectVal(ce);
409 collectVal(ce->getOperand(0));
410 // handle the recursive constant express case
411 // like (gep (bitcast (gep X 1)) 1); the inner gep is ce->getOperand(0)
412 handleCE(ce->getOperand(0));
413 }
414 else if (const ConstantExpr* ce = isSelectConstantExpr(ref))
415 {
416 DBOUT(DMemModelCE, outs() << "handle constant expression "
417 << llvmModuleSet()
419 ->toString()
420 << "\n");
421 collectVal(ce);
422 collectVal(ce->getOperand(0));
423 collectVal(ce->getOperand(1));
424 collectVal(ce->getOperand(2));
425 // handle the recursive constant express case
426 // like (gep (bitcast (gep X 1)) 1); the inner gep is ce->getOperand(0)
427 handleCE(ce->getOperand(0));
428 handleCE(ce->getOperand(1));
429 handleCE(ce->getOperand(2));
430 }
431 // if we meet a int2ptr, then it points-to black hole
433 {
435 const Constant* opnd = int2Ptrce->getOperand(0);
436 handleCE(opnd);
437 }
439 {
441 const Constant* opnd = ptr2Intce->getOperand(0);
442 handleCE(opnd);
443 }
445 {
447 }
448 else if (isBinaryConstantExpr(ref))
449 {
451 }
452 else if (isUnaryConstantExpr(ref))
453 {
454 // we don't handle unary constant expression like fneg(x) now
456 }
457 else if (SVFUtil::isa<ConstantAggregate>(ref))
458 {
459 // we don't handle constant aggregate like constant vectors
461 }
462 else
463 {
464 assert(!SVFUtil::isa<ConstantExpr>(val) &&
465 "we don't handle all other constant expression for now!");
467 }
468 }
469}
470
475{
476 assert(G);
477
478 //The type this global points to
479 const Type* T = G->getValueType();
480 bool is_array = 0;
481 //An array is considered a single variable of its type.
482 while (const ArrayType* AT = SVFUtil::dyn_cast<ArrayType>(T))
483 {
484 T = AT->getElementType();
485 is_array = true;
486 }
487
488 if (SVFUtil::isa<StructType>(T))
489 {
490 //A struct may be used in constant GEP expr.
491 for (const User* user : G->users())
492 {
493 handleCE(user);
494 }
495 }
496 else if (is_array)
497 {
498 for (const User* user : G->users())
499 {
500 handleCE(user);
501 }
502 }
503
504 if (G->hasInitializer())
505 {
506 handleGlobalInitializerCE(G->getInitializer());
507 }
508}
509
514{
515
516 if (C->getType()->isSingleValueType())
517 {
518 if (const ConstantExpr* E = SVFUtil::dyn_cast<ConstantExpr>(C))
519 {
520 handleCE(E);
521 }
522 else
523 {
524 collectVal(C);
525 }
526 }
527 else if (SVFUtil::isa<ConstantArray>(C))
528 {
529 for (u32_t i = 0, e = C->getNumOperands(); i != e; i++)
530 {
531 handleGlobalInitializerCE(SVFUtil::cast<Constant>(C->getOperand(i)));
532 }
533 }
534 else if (SVFUtil::isa<ConstantStruct>(C))
535 {
536 for (u32_t i = 0, e = C->getNumOperands(); i != e; i++)
537 {
538 handleGlobalInitializerCE(SVFUtil::cast<Constant>(C->getOperand(i)));
539 }
540 }
541 else if(const ConstantData* data = SVFUtil::dyn_cast<ConstantData>(C))
542 {
544 {
545 if (const ConstantDataSequential* seq =
546 SVFUtil::dyn_cast<ConstantDataSequential>(data))
547 {
548 for(u32_t i = 0; i < seq->getNumElements(); i++)
549 {
550 const Constant* ct = seq->getElementAsConstant(i);
552 }
553 }
554 else
555 {
556 assert(
557 (SVFUtil::isa<ConstantAggregateZero, UndefValue>(data)) &&
558 "Single value type data should have been handled!");
559 }
560 }
561 }
562 else
563 {
564 //TODO:assert(SVFUtil::isa<ConstantVector>(C),"what else do we have");
565 }
566}
567
572
573
578
583{
584 const Value* startValue = inst;
585 const PointerType *originalPType = SVFUtil::dyn_cast<PointerType>(inst->getType());
586 const Type* inferedType = nullptr;
587 assert(originalPType && "empty type?");
589 {
590 if(const Value* v = getFirstUseViaCastInst(inst))
591 {
592 if (const PointerType *newTy = SVFUtil::dyn_cast<PointerType>(v->getType()))
593 {
595 }
596 }
598 }
600 {
601 const CallBase* cs = LLVMUtil::getLLVMCallSite(inst);
602 u32_t arg_pos = LLVMUtil::getHeapAllocHoldingArgPosition(cs->getCalledFunction());
603 const Value* arg = cs->getArgOperand(arg_pos);
604 originalPType = SVFUtil::dyn_cast<PointerType>(arg->getType());
606 }
607 else
608 {
609 assert( false && "not a heap allocation instruction?");
610 }
611
613
614 return inferedType;
615}
616
617/*
618 * Initial the memory object here
619 */
621{
622 const Type* objTy = nullptr;
623
624 const Instruction* I = SVFUtil::dyn_cast<Instruction>(val);
625
626 // We consider two types of objects:
627 // (1) A heap/static object from a callsite
628 if (I && isNonInstricCallSite(I))
629 {
631 }
632 // (2) Other objects (e.g., alloca, global, etc.)
633 else
634 {
635 if (SVFUtil::isa<PointerType>(val->getType()))
636 {
637 if (const AllocaInst *allocaInst = SVFUtil::dyn_cast<AllocaInst>(val))
638 {
639 // get the type of the allocated memory
640 // e.g., for `%retval = alloca i64, align 4`, we return i64
641 objTy = allocaInst->getAllocatedType();
642 }
643 else if (const GlobalValue *global = SVFUtil::dyn_cast<GlobalValue>(val))
644 {
645 // get the pointee type of the global pointer (begins with @ symbol in llvm)
646 objTy = global->getValueType();
647 }
648 else
649 {
651 assert(false && "not an allocation or global?");
652 }
653 }
654 }
655
656 if (objTy)
657 {
659 ObjTypeInfo* typeInfo = new ObjTypeInfo(
660 llvmModuleSet()->getSVFType(objTy),
662 initTypeInfo(typeInfo,val, objTy);
663 return typeInfo;
664 }
665 else
666 {
667 writeWrnMsg("try to create an object with a non-pointer type.");
668 writeWrnMsg(val->getName().str());
669 writeWrnMsg("(" + getSourceLoc(val) + ")");
671 {
672 ObjTypeInfo* typeInfo = new ObjTypeInfo(
673 llvmModuleSet()->getSVFType(val->getType()),
674 0);
675 initTypeInfo(typeInfo,val, val->getType());
676 return typeInfo;
677 }
678 else
679 {
680 assert(false && "Memory object must be either (1) held by a pointer-typed ref value or (2) a constant value (e.g., 10).");
681 abort();
682 }
683 }
684}
685
690{
691 const Type *elemTy = llvmModuleSet()->getLLVMType(typeinfo->getType());
692 // Find the inter nested array element
693 while (const ArrayType* AT = SVFUtil::dyn_cast<ArrayType>(elemTy))
694 {
695 elemTy = AT->getElementType();
696 if (SVFUtil::isa<GlobalVariable>(val) &&
697 SVFUtil::cast<GlobalVariable>(val)->hasInitializer() &&
698 SVFUtil::isa<ConstantArray>(
699 SVFUtil::cast<GlobalVariable>(val)->getInitializer()))
701 else
703 }
704 if (SVFUtil::isa<StructType>(elemTy))
705 {
706 if (SVFUtil::isa<GlobalVariable>(val) &&
707 SVFUtil::cast<GlobalVariable>(val)->hasInitializer() &&
708 SVFUtil::isa<ConstantStruct>(
709 SVFUtil::cast<GlobalVariable>(val)->getInitializer()))
711 else
713 }
714}
715
731{
732 if(const llvm::CallInst* callInst = llvm::dyn_cast<llvm::CallInst>(val))
733 {
734 if (const llvm::Function* calledFunction =
735 callInst->getCalledFunction())
736 {
737 std::vector<const Value*> args;
738 // Heap alloc functions have annoation like "AllocSize:Arg1"
740 {
741 if (annotation.find("AllocSize:") != std::string::npos)
742 {
743 std::string allocSize = annotation.substr(10);
744 std::stringstream ss(allocSize);
745 std::string token;
746 // Analyaze annotation string and attract Arg list
747 while (std::getline(ss, token, '*'))
748 {
749 if (token.rfind("Arg", 0) == 0)
750 {
752 std::istringstream(token.substr(3)) >> argIndex;
754 {
755 args.push_back(
756 callInst->getArgOperand(argIndex));
757 }
758 }
759 }
760 }
761 }
762 u64_t product = 1;
763 if (args.size() > 0)
764 {
765 // for annotations like "AllocSize:Arg0*Arg1"
766 for (const llvm::Value* arg : args)
767 {
768 if (const llvm::ConstantInt* constIntArg =
769 llvm::dyn_cast<llvm::ConstantInt>(arg))
770 {
771 // Multiply the constant Value if all Args are const
773 }
774 else
775 {
776 // if Arg list has non-const value, return 0 to indicate it is non const byte size
777 return 0;
778 }
779 }
780 // If all the Args are const, return product
781 return product;
782 }
783 else
784 {
785 // for annotations like "AllocSize:UNKNOWN"
786 return 0;
787 }
788 }
789 }
790 // if it is not CallInst or CallInst has no CalledFunction, return 0 to indicate it is non const byte size
791 return 0;
792}
793
798{
800 analyzeObjType(typeinfo, val);
801 const Type* objTy = llvmModuleSet()->getLLVMType(typeinfo->getType());
802 if(SVFUtil::isa<ArrayType>(objTy))
803 return getNumOfElements(objTy);
804 else if(const StructType* st = SVFUtil::dyn_cast<StructType>(objTy))
805 {
809 typeinfo->resetTypeForHeapStaticObj(llvmModuleSet()->getSVFType(
810 llvmModuleSet()->getTypeInference()->ptrType()));
811 else
812 return getNumOfElements(objTy);
813 }
814 return typeinfo->getMaxFieldOffsetLimit();
815}
816
821{
823 {
825 analyzeObjType(typeinfo,castUse);
826 }
827 else
828 {
830 }
831}
832
837 const Type* objTy)
838{
839
840 u32_t elemNum = 1;
841 // init byteSize = 0, If byteSize is changed in the following process,
842 // it means that ObjTypeInfo has a Constant Byte Size
843 u32_t byteSize = 0;
844 // Global variable
845 // if val is Function Obj, byteSize is not set
846 if (SVFUtil::isa<Function>(val))
847 {
849 analyzeObjType(typeinfo,val);
850 elemNum = getNumOfElements(objTy);
851 }
854 else if(const AllocaInst* allocaInst = SVFUtil::dyn_cast<AllocaInst>(val))
855 {
857 analyzeObjType(typeinfo,val);
860 if(const ConstantInt* sz = SVFUtil::dyn_cast<ConstantInt>(allocaInst->getArraySize()))
861 {
863 byteSize = LLVMUtil::getIntegerValue(sz).second * typeinfo->getType()->getByteSize();
864 }
866 else
867 {
868 elemNum = getNumOfElements(objTy);
869 byteSize = 0;
870 }
871 }
874 else if(SVFUtil::isa<GlobalVariable>(val))
875 {
879 analyzeObjType(typeinfo,val);
880 elemNum = getNumOfElements(objTy);
881 byteSize = typeinfo->getType()->getByteSize();
882 }
884 else if (SVFUtil::isa<Instruction>(val) &&
886 SVFUtil::cast<Instruction>(val)))
887 {
888 elemNum = analyzeHeapObjType(typeinfo,val);
889 // analyze heap alloc like (malloc/calloc/...), the alloc functions have
890 // annotation like "AllocSize:Arg1". Please refer to extapi.c.
891 // e.g. calloc(4, 10), annotation is "AllocSize:Arg0*Arg1",
892 // it means byteSize = 4 (Arg0) * 10 (Arg1) = 40
893 byteSize = analyzeHeapAllocByteSize(val);
894 }
896 {
897 analyzeStaticObjType(typeinfo,val);
898 // user input data, label its field as infinite here
899 elemNum = typeinfo->getMaxFieldOffsetLimit();
900 byteSize = typeinfo->getType()->getByteSize();
901 }
903 {
905 elemNum = getNumOfFlattenElements(val->getType());
906 byteSize = typeinfo->getType()->getByteSize();
907 }
908 else
909 {
910 assert("what other object do we have??");
911 abort();
912 }
913
914 // Reset maxOffsetLimit if it is over the total fieldNum of this object
915 if(typeinfo->getMaxFieldOffsetLimit() > elemNum)
916 typeinfo->setNumOfElements(elemNum);
917
918 // set ByteSize. If ByteSize > 0, this typeinfo has constant type.
919 // If ByteSize == 0, this typeinfo has 1) zero byte 2) non-const byte size
920 // If ByteSize>MaxFieldLimit, set MaxFieldLimit to the byteSize;
921 byteSize = Options::MaxFieldLimit() > byteSize? byteSize: Options::MaxFieldLimit();
922 typeinfo->setByteSizeOfObj(byteSize);
923}
924
929{
930 assert(ety && "type is null?");
931 u32_t numOfFields = 1;
932 if (SVFUtil::isa<StructType, ArrayType>(ety))
933 {
935 }
936 return numOfFields;
937}
938
947
#define DBOUT(TYPE, X)
LLVM debug macros, define type of your DBUG model of each pass.
Definition SVFType.h:498
#define DMemModelCE
Definition SVFType.h:508
#define DMemModel
Definition SVFType.h:507
NodeID constantSymID() const
Definition IRGraph.h:188
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
IDToTypeInfoMapTy objTypeInfoMap
map a memory sym id to its obj
Definition IRGraph.h:88
NodeID totalSymNum
total number of symbols
Definition IRGraph.h:101
static bool isConstantSym(NodeID id)
Definition IRGraph.h:169
ValueToIDMapTy valSymMap
map a value to its sym id
Definition LLVMModule.h:112
FunToIDMapTy varargSymMap
vararg map
Definition LLVMModule.h:115
const std::vector< std::string > & getExtFuncAnnotations(const Function *fun)
SVFType * getSVFType(const Type *T)
Get or create SVFType and typeinfo.
const Type * getLLVMType(const SVFType *T) const
Get LLVM Type.
ValueToIDMapTy objSymMap
map a obj reference to its sym id
Definition LLVMModule.h:113
FunToIDMapTy returnSymMap
return map
Definition LLVMModule.h:114
const std::vector< std::reference_wrapper< Module > > & getLLVMModules() const
Definition LLVMModule.h:155
ObjTypeInference * getTypeInference()
NodeID allocateValueId(void)
Allocate a value ID as determined by the strategy.
static NodeIDAllocator * get(void)
Return (singleton) allocator.
NodeID allocateObjectId(void)
Allocate an object ID as determined by the strategy.
NodeID endSymbolAllocation(void)
Notify the allocator that all symbols have had IDs allocated.
void typeSizeDiffTest(const PointerType *oPTy, const Type *iTy, const Value *val)
const Type * inferObjType(const Value *var)
get or infer the type of the object pointed by the value
void validateTypeCheck(const CallBase *cs)
validate type inference
void resetTypeForHeapStaticObj(const SVFType *t)
Definition ObjTypeInfo.h:79
u32_t getMaxFieldOffsetLimit()
Get max field offset limit.
const SVFType * getType() const
Get LLVM type.
Definition ObjTypeInfo.h:98
void setByteSizeOfObj(u32_t size)
Set the byte size of this object.
void setFlag(MEMTYPE mask)
Flag for this object type.
void setNumOfElements(u32_t num)
Set the number of elements of this object.
static Option< bool > ModelArrays
Definition Options.h:188
static const Option< bool > EnableTypeCheck
Definition Options.h:131
static const Option< bool > SymTabPrint
Definition Options.h:190
static Option< bool > ModelConsts
Definition Options.h:187
static const Option< u32_t > MaxFieldLimit
Maximum number of field derivations for an object.
Definition Options.h:38
StInfo * getTypeInfo()
Definition SVFType.h:230
u32_t getByteSize() const
Definition SVFType.h:244
u32_t getNumOfFlattenElements() const
Return number of elements after flattening (including array elements)
Definition SVFType.h:139
u32_t getNumOfFlattenFields() const
Return the number of fields after flattening (ignoring array elements)
Definition SVFType.h:145
const Type * inferTypeOfHeapObjOrStaticObj(const Instruction *inst)
Get the reference type of heap/static object from an allocation site.
void handleGlobalInitializerCE(const Constant *C)
void collectRet(const Function *val)
ObjTypeInfo * createObjTypeInfo(const Value *val)
Create an objectInfo based on LLVM value.
const Type * inferObjType(const Value *startValue)
Forward collect all possible infer sites starting from a value.
void collectSVFTypeInfo(const Value *val)
collect the syms
LLVMModuleSet * llvmModuleSet()
ObjTypeInference * getTypeInference()
ObjTypeInfo * createBlkObjTypeInfo(NodeID symId)
u32_t getNumOfFlattenElements(const Type *T)
Number of flattened elements of an array or struct.
u32_t getNumOfElements(const Type *ety)
Return size of this object based on LLVM value.
void handleGlobalCE(const GlobalVariable *G)
Handle constant expression.
u32_t analyzeHeapObjType(ObjTypeInfo *typeinfo, const Value *val)
Analyse types of heap and static objects.
u32_t analyzeHeapAllocByteSize(const Value *val)
Analyze byte size of heap alloc function (e.g. malloc/calloc/...)
void collectObj(const Value *val)
void buildMemModel()
Start building memory model.
ObjTypeInfo * createConstantObjTypeInfo(NodeID symId)
void collectVal(const Value *val)
void handleCE(const Value *val)
void collectSym(const Value *val)
void collectVararg(const Function *val)
void initTypeInfo(ObjTypeInfo *typeinfo, const Value *value, const Type *ty)
Initialize TypeInfo based on LLVM Value.
void analyzeObjType(ObjTypeInfo *typeinfo, const Value *val)
Analyse types of all flattened fields of this object.
StInfo * getOrAddSVFTypeInfo(const Type *T)
Get a reference to StructInfo.
void analyzeStaticObjType(ObjTypeInfo *typeinfo, const Value *val)
Analyse types of heap and static objects.
bool isHeapAllocExtCallViaRet(const Instruction *inst)
Definition LLVMUtil.cpp:633
const Value * getFirstUseViaCastInst(const Value *val)
Definition LLVMUtil.cpp:277
const CallBase * getLLVMCallSite(const Value *value)
Return LLVM callsite given a value.
Definition LLVMUtil.h:91
const ConstantExpr * isBinaryConstantExpr(const Value *val)
Definition LLVMUtil.h:290
bool isHeapAllocExtCall(const Instruction *inst)
Definition LLVMUtil.h:396
bool isConstantObjSym(const Value *val)
Check whether this value points-to a constant object.
Definition CppUtil.cpp:672
const ConstantExpr * isInt2PtrConstantExpr(const Value *val)
Definition LLVMUtil.h:225
const ConstantExpr * isSelectConstantExpr(const Value *val)
Definition LLVMUtil.h:255
const ConstantExpr * isTruncConstantExpr(const Value *val)
Definition LLVMUtil.h:265
std::pair< s64_t, u64_t > getIntegerValue(const ConstantInt *intValue)
Definition LLVMUtil.h:82
bool isNullPtrSym(const Value *val)
Check whether this value is a black hole.
Definition LLVMUtil.h:125
std::string dumpValueAndDbgInfo(const Value *val)
Definition LLVMUtil.cpp:622
bool isConstDataOrAggData(const Value *val)
Return true if the value refers to constant data, e.g., i32 0.
Definition LLVMUtil.h:368
const std::string getSourceLoc(const Value *val)
Definition LLVMUtil.cpp:452
const ConstantExpr * isPtr2IntConstantExpr(const Value *val)
Definition LLVMUtil.h:235
const Value * getGlobalRep(const Value *val)
find the unique defined global across multiple modules
Definition LLVMUtil.cpp:439
const ConstantExpr * isUnaryConstantExpr(const Value *val)
Definition LLVMUtil.h:301
const ConstantExpr * isCastConstantExpr(const Value *val)
Definition LLVMUtil.h:245
bool isBlackholeSym(const Value *val)
Check whether this value is a black hole.
Definition LLVMUtil.h:119
bool isHeapAllocExtCallViaArg(const Instruction *inst)
Definition LLVMUtil.cpp:648
bool isObject(const Value *ref)
Return true if this value refers to a object.
Definition LLVMUtil.cpp:59
bool ArgInProgEntryFunction(const Value *val)
Return true if this is an argument of a program entry function (e.g. main)
Definition LLVMUtil.h:164
const ConstantExpr * isGepConstantExpr(const Value *val)
Return corresponding constant expression, otherwise return nullptr.
Definition LLVMUtil.h:215
u32_t getHeapAllocHoldingArgPosition(const Function *fun)
Definition LLVMUtil.cpp:400
bool isNonInstricCallSite(const Instruction *inst)
Whether an instruction is a callsite in the application code, excluding llvm intrinsic calls.
Definition LLVMUtil.cpp:720
const ConstantExpr * isCmpConstantExpr(const Value *val)
Definition LLVMUtil.h:279
void increaseStackSize()
Increase the stack size limit.
Definition SVFUtil.cpp:229
std::enable_if_t<!is_simple_type< Y >::value, typename cast_retty< X, const Y >::ret_type > cast(const Y &Val)
Definition Casting.h:360
std::ostream & errs()
Overwrite llvm::errs()
Definition SVFUtil.h:58
void writeWrnMsg(const std::string &msg)
Writes a message run through wrnMsg.
Definition SVFUtil.cpp:68
std::ostream & outs()
Overwrite llvm::outs()
Definition SVFUtil.h:52
bool classTyHasVTable(const StructType *ty)
Definition CppUtil.cpp:569
for isBitcode
Definition BasicTypes.h:68
llvm::GlobalVariable GlobalVariable
Definition BasicTypes.h:130
llvm::GlobalAlias GlobalAlias
Definition BasicTypes.h:128
llvm::ArrayType ArrayType
Definition BasicTypes.h:95
llvm::Type Type
Definition BasicTypes.h:83
llvm::CallBase CallBase
Definition BasicTypes.h:146
llvm::UnaryOperator UnaryOperator
Definition BasicTypes.h:180
llvm::StructType StructType
LLVM types.
Definition BasicTypes.h:94
unsigned long long u64_t
Definition GeneralType.h:49
llvm::AllocaInst AllocaInst
Definition BasicTypes.h:150
llvm::SwitchInst SwitchInst
Definition BasicTypes.h:155
u32_t NodeID
Definition GeneralType.h:56
llvm::Argument Argument
Definition BasicTypes.h:145
llvm::LoadInst LoadInst
Definition BasicTypes.h:149
llvm::CmpInst CmpInst
Definition BasicTypes.h:159
llvm::Function Function
Definition BasicTypes.h:85
llvm::GlobalValue GlobalValue
Definition BasicTypes.h:88
llvm::ConstantData ConstantData
Definition BasicTypes.h:116
llvm::Instruction Instruction
Definition BasicTypes.h:87
llvm::Constant Constant
Definition BasicTypes.h:124
llvm::ConstantDataSequential ConstantDataSequential
Definition BasicTypes.h:119
llvm::Value Value
LLVM Basic classes.
Definition BasicTypes.h:82
llvm::ConstantExpr ConstantExpr
Definition BasicTypes.h:120
llvm::IRBuilder IRBuilder
Definition BasicTypes.h:74
llvm::CastInst CastInst
Definition BasicTypes.h:158
llvm::Module Module
Definition BasicTypes.h:84
llvm::PointerType PointerType
Definition BasicTypes.h:96
llvm::BinaryOperator BinaryOperator
Definition BasicTypes.h:179
llvm::StoreInst StoreInst
Definition BasicTypes.h:148
llvm::SelectInst SelectInst
Definition BasicTypes.h:174
llvm::GetElementPtrInst GetElementPtrInst
Definition BasicTypes.h:162
llvm::ReturnInst ReturnInst
Definition BasicTypes.h:157
llvm::PHINode PHINode
Definition BasicTypes.h:165
llvm::BranchInst BranchInst
Definition BasicTypes.h:154
unsigned u32_t
Definition GeneralType.h:47
llvm::ConstantInt ConstantInt
Definition BasicTypes.h:125
llvm::User User
Definition BasicTypes.h:142