47using namespace SVFUtil;
107 assert(
pag &&
"SVFIR has not been built!");
154 if(
ObjVar* node = SVFUtil::dyn_cast<ObjVar>(
nIter->second))
238 if (SVFUtil::isa<DummyObjVar, DummyValVar>(node))
243 outs() <<
"\nNodeID " << node->
getId() <<
"\n";
258 if (SVFUtil::isa<DummyObjVar> (node))
260 outs() <<
"##<Dummy Obj > id:" << node->
getId();
267 outs() <<
"\nPtr " << node->
getId() <<
" ";
271 outs() <<
"\t\tPointsTo: {empty}\n\n";
275 outs() <<
"\t\tPointsTo: { ";
287 if(SVFUtil::isa<ObjVar>(node) ==
false)
290 outs() <<
"!!Target NodeID " <<
ptd <<
"\t [";
292 if (SVFUtil::isa<DummyValVar>(node))
293 outs() <<
"DummyVal\n";
294 else if (SVFUtil::isa<DummyObjVar>(node))
295 outs() <<
"Dummy Obj id: " << node->
getId() <<
"]\n";
301 outs() <<
"Source Loc: "
302 <<
pagNode->getSourceLoc() <<
"] \n";
314 outs() <<
"\nCallSite: ";
317 outs() <<
"\t with Targets: ";
321 FunctionSet::const_iterator
fit =
targets.begin();
331 outs() <<
"\n\tNo Targets!";
342 outs() <<
"==================Function Pointer Targets==================\n";
344 CallEdgeMap::const_iterator
it =
callEdges.begin();
354 CallSiteToFunPtrMap::const_iterator
csIt =
indCS.begin();
355 CallSiteToFunPtrMap::const_iterator
csEit =
indCS.end();
361 outs() <<
"\nNodeID: " <<
csIt->second;
362 outs() <<
"\nCallSite: ";
365 outs() <<
"\n\t!!!has no targets!!!\n";
386 wrnMsg(
"Resolved Indirect Call Edges are Out-Of-Budget, please increase the limit");
394 if(
obj->isFunction())
468 for (VFunSet::const_iterator
fit =
vfns.begin(),
509 outs() <<
"[" << this->
PTAName() <<
"] Checking " << fun <<
"\n";
516 &&
"arguments should be two pointers!!");
545 assert(
false &&
"not supported alias check!!");
551 outs() <<
sucMsg(
"\t SUCCESS :") << fun <<
" check <id:" <<
id1 <<
", id:" <<
id2 <<
"> at ("
552 <<
callNode->getSourceLoc() <<
")\n";
556 <<
" check <id:" <<
id1 <<
", id:" <<
id2
557 <<
"> at (" <<
callNode->getSourceLoc() <<
")\n";
558 assert(
false &&
"test case failed!");
574 outs() <<
"[" << this->
PTAName() <<
"] Checking " << fun <<
"\n";
581 &&
"arguments should be two pointers!!");
600 assert(
false &&
"not supported alias check!!");
606 outs() <<
sucMsg(
"\t EXPECTED-FAILURE :") << fun <<
" check <id:" <<
id1 <<
", id:" <<
id2 <<
"> at ("
607 <<
callNode->getSourceLoc() <<
")\n";
611 <<
callNode->getSourceLoc() <<
")\n";
612 assert(
false &&
"test case failed!");
void addIndirectCallGraphEdge(const CallICFGNode *cs, const FunObjVar *callerFun, const FunObjVar *calleeFun)
Add indirect call edges.
void dump(const std::string &filename)
Dump the graph.
void verifyCallGraph()
Issue a warning if the function which has indirect call sites can not be reached from program entry.
const std::string toString() const override
const std::string getSourceLoc() const override
bool isVirtualCall() const
const FunObjVar * getCaller() const
Return callsite.
virtual const VFunSet & getCSVFsBasedonCHA(const CallICFGNode *cs)=0
virtual bool csHasVFnsBasedonCHA(const CallICFGNode *cs)=0
virtual const VTableSet & getCSVtblsBasedonCHA(const CallICFGNode *cs)=0
virtual void getVFnsFromVtbls(const CallICFGNode *cs, const VTableSet &vtbls, VFunSet &virtualFunctions)=0
virtual bool csHasVtblsBasedonCHA(const CallICFGNode *cs)=0
virtual const FunObjVar * getFunction() const
Get containing function, or null for globals/constants.
const FunObjVar * getDefFunForMultipleModule() const
iterator begin()
Iterators.
IDToNodeMapTy::iterator iterator
Node Iterators.
NodeType * getGNode(NodeID id) const
Get a node.
void printFlattenFields(const SVFType *type)
Debug method.
bool isBuiltFromFile()
Whether this SVFIR built from a txt file.
static const Option< bool > CallGraphDotGraph
static const Option< bool > EnableThreadCallGraph
static const Option< bool > PTSPrint
static const Option< bool > EnableAliasCheck
static const Option< bool > PTSAllPrint
static const Option< bool > TypePrint
static Option< bool > UsePreCompFieldSensitive
static const Option< u32_t > IndirectCallLimit
static const Option< bool > FuncPointerPrint
static const Option< bool > ConnectVCallOnCHA
static const Option< bool > PStat
static const Option< u32_t > StatBudget
void performStat() override
void getVFnsFromPts(const CallICFGNode *cs, const PointsTo &target, VFunSet &vfns)
void destroy()
Release the memory.
virtual void validateTests()
Alias check functions to verify correctness of pointer analysis.
PTATY
Pointer analysis type list.
CommonCHGraph * chgraph
CHGraph.
static const std::string aliasTestNoAliasMangled
bool isLocalVarInRecursiveFun(NodeID id) const
Whether a local variable is in function recursions.
virtual void finalize()
Finalization of a pointer analysis, including checking alias correctness.
static const std::string aliasTestMayAliasMangled
PointerAnalysis(SVFIR *pag, PTATY ty=Default_PTA, bool alias_check=true)
Constructor.
static const std::string aliasTestFailNoAlias
virtual void dumpPts(NodeID ptr, const PointsTo &pts)
static const std::string aliasTestFailMayAlias
bool print_stat
User input flags.
OrderedMap< const CallICFGNode *, FunctionSet > CallEdgeMap
Set< const GlobalObjVar * > VTableSet
virtual void initialize()
Initialization of a pointer analysis, including building symbol table and SVFIR etc.
virtual ~PointerAnalysis()
Destructor.
PTAImplTy ptaImplTy
PTA implementation type.
PTAStat * stat
Statistics.
virtual void dumpTopLevelPtsTo()
static const std::string aliasTestFailMayAliasMangled
void connectVCallToVFns(const CallICFGNode *cs, const VFunSet &vfns, CallEdgeMap &newEdges)
CallGraph * getCallGraph() const
Return call graph.
OrderedNodeSet & getAllValidPtrs()
Get all Valid Pointers for resolution.
void resetObjFieldSensitive()
Reset all object node as field-sensitive.
static const std::string aliasTestMustAlias
static const std::string aliasTestMayAlias
Set< const FunObjVar * > FunctionSet
virtual void validateSuccessTests(std::string fun)
const CallSiteToFunPtrMap & getIndirectCallsites() const
Return all indirect callsites.
static const std::string aliasTestPartialAlias
virtual void dumpAllPts()
virtual AliasResult alias(const SVFVar *V1, const SVFVar *V2)=0
Interface exposed to users of our pointer analysis, given Value infos.
virtual void resolveIndCalls(const CallICFGNode *cs, const PointsTo &target, CallEdgeMap &newEdges)
Resolve indirect call edges.
CallGraph * callgraph
Call graph used for pointer analysis.
bool alias_validation
Flag for validating points-to/alias results.
void callGraphSCCDetection()
PTACallGraph SCC related methods.
void dumpStat()
Dump the statistics.
virtual void validateExpectedFailureTests(std::string fun)
bool hasIndCSCallees(const CallICFGNode *cs) const
virtual void resolveCPPIndCalls(const CallICFGNode *cs, const PointsTo &target, CallEdgeMap &newEdges)
Resolve cpp indirect call edges.
@ BaseImpl
Represents PointerAnalaysis.
CallEdgeMap & getIndCallMap()
Get callees from an indirect callsite.
static const std::string aliasTestNoAlias
static const std::string aliasTestPartialAliasMangled
u32_t getNumOfResolvedIndCallEdge() const
Return number of resolved indirect call edges.
SVFIR::CallSiteToFunPtrMap CallSiteToFunPtrMap
NodeID getFunPtr(const CallICFGNode *cs) const
Return function pointer PAGNode at a callsite cs.
void getVFnsFromCHA(const CallICFGNode *cs, VFunSet &vfns)
CallGraphSCC * callGraphSCC
SCC for PTACallGraph.
static const std::string aliasTestMustAliasMangled
virtual const std::string PTAName() const
Return PTA name.
static const std::string aliasTestFailNoAliasMangled
Set< const FunObjVar * > VFunSet
u32_t OnTheFlyIterBudgetForStat
Flag for iteration budget for on-the-fly statistics.
const CallSiteSet & getCallSiteSet() const
Get all callsites.
bool isIndirectCallSites(const CallICFGNode *cs) const
static bool pagReadFromTXT()
const BaseObjVar * getBaseObject(NodeID id) const
const FunObjVar * getFunObjVar(const std::string &name)
const ValVar * getBaseValVar(NodeID id) const
NodeID getId() const
Get ID.
virtual const SVFType * getType() const
virtual const std::string getSourceLoc() const
virtual const std::string & getName() const
virtual const FunObjVar * getFunction() const
Get containing function, or null for globals/constants.
std::string sucMsg(const std::string &msg)
Returns successful message by converting a string into green string output.
const ObjVar * getObjVarOfValVar(const ValVar *valVar)
std::string errMsg(const std::string &msg)
Print error message by converting a string into red string output.
std::ostream & errs()
Overwrite llvm::errs()
bool matchArgs(const CallICFGNode *cs, const FunObjVar *callee)
std::string wrnMsg(const std::string &msg)
Returns warning message by converting a string into yellow string output.
std::ostream & outs()
Overwrite llvm::outs()
llvm::IRBuilder IRBuilder