Static Value-Flow Analysis
Loading...
Searching...
No Matches
Public Types | Public Member Functions | Protected Member Functions | Protected Attributes | Private Member Functions | Private Attributes | List of all members
SVF::MRGenerator Class Reference

#include <MemRegion.h>

Inheritance diagram for SVF::MRGenerator:
SVF::DistinctMRG SVF::IntraDisjointMRG SVF::InterDisjointMRG

Public Types

typedef FIFOWorkList< NodeIDWorkList
 
typedef OrderedSet< const MemRegion *, MemRegion::equalMemRegionMRSet
 Get typedef from Pointer Analysis.
 
typedef Map< const PAGEdge *, const FunObjVar * > PAGEdgeToFunMap
 
typedef OrderedSet< NodeBS, SVFUtil::equalNodeBSPointsToList
 
typedef Map< const FunObjVar *, NodeBSFunToPointsToMap
 
typedef Map< const FunObjVar *, PointsToListFunToPointsTosMap
 
typedef OrderedMap< NodeBS, NodeBS, SVFUtil::equalNodeBSPtsToRepPtsSetMap
 
typedef Map< const FunObjVar *, MRSetFunToMRsMap
 Map a function to its region set.
 
typedef Map< const LoadStmt *, MRSetLoadsToMRsMap
 
typedef Map< const StoreStmt *, MRSetStoresToMRsMap
 
typedef Map< const CallICFGNode *, MRSetCallSiteToMRsMap
 
typedef Map< const LoadStmt *, NodeBSLoadsToPointsToMap
 Map loads/stores/callsites to their cpts set.
 
typedef Map< const StoreStmt *, NodeBSStoresToPointsToMap
 
typedef Map< const CallICFGNode *, NodeBSCallSiteToPointsToMap
 
typedef Map< const FunObjVar *, NodeBSFunToNodeBSMap
 Maps Mod-Ref analysis.
 
typedef Map< const CallICFGNode *, NodeBSCallSiteToNodeBSMap
 Map a callsite to its indirect refs/mods of memory objects.
 
typedef Map< NodeID, NodeBSNodeToPTSSMap
 
typedef SVFIR::SVFStmtList SVFStmtList
 SVFIR edge list.
 
typedef SCCDetection< CallGraph * > SCC
 Call Graph SCC.
 

Public Member Functions

MRSetgetMRSet ()
 
const NodeBSgetRepPointsTo (const NodeBS &cpts) const
 Get superset cpts set.
 
const MemRegiongetMR (const NodeBS &cpts) const
 Get a memory region according to cpts.
 
u32_t getMRNum () const
 
virtual ~MRGenerator ()
 Destructor.
 
virtual void generateMRs ()
 Start generating memory regions.
 
const FunObjVargetFunction (const PAGEdge *pagEdge) const
 Get the function which SVFIR Edge located.
 
MRSetgetFunMRSet (const FunObjVar *fun)
 Get Memory Region set.
 
MRSetgetLoadMRSet (const LoadStmt *load)
 
MRSetgetStoreMRSet (const StoreStmt *store)
 
bool hasRefMRSet (const CallICFGNode *cs)
 
bool hasModMRSet (const CallICFGNode *cs)
 
MRSetgetCallSiteRefMRSet (const CallICFGNode *cs)
 
MRSetgetCallSiteModMRSet (const CallICFGNode *cs)
 
bool hasSVFStmtList (const ICFGNode *icfgNode)
 Whether this instruction has SVFIR Edge.
 
SVFStmtListgetPAGEdgesFromInst (const ICFGNode *node)
 Given an instruction, get all its the PAGEdge (statement) in sequence.
 
NodeBS getModInfoForCall (const CallICFGNode *cs)
 getModRefInfo APIs
 
NodeBS getRefInfoForCall (const CallICFGNode *cs)
 
ModRefInfo getModRefInfo (const CallICFGNode *cs)
 
ModRefInfo getModRefInfo (const CallICFGNode *cs, const SVFVar *V)
 
ModRefInfo getModRefInfo (const CallICFGNode *cs1, const CallICFGNode *cs2)
 

Protected Member Functions

 MRGenerator (BVDataPTAImpl *p, bool ptrOnly)
 
void createMR (const FunObjVar *fun, const NodeBS &cpts)
 Generate a memory region and put in into functions which use it.
 
void collectGlobals ()
 Collect all global variables for later escape analysis.
 
virtual void collectModRefForLoadStore ()
 Generate regions for loads/stores.
 
virtual void collectModRefForCall ()
 Generate regions for calls/rets.
 
virtual void partitionMRs ()
 Partition regions.
 
virtual void updateAliasMRs ()
 Update aliased regions for loads/stores/callsites.
 
virtual void sortPointsTo (const NodeBS &cpts)
 Given a condition pts, insert into cptsToRepCPtsMap for region generation.
 
virtual bool isAliasedMR (const NodeBS &cpts, const MemRegion *mr)
 Whether a region is aliased with a conditional points-to.
 
virtual void getAliasMemRegions (MRSet &aliasMRs, const NodeBS &cpts, const FunObjVar *fun)
 Get all aliased mem regions from function fun according to cpts.
 
virtual void getMRsForLoad (MRSet &aliasMRs, const NodeBS &cpts, const FunObjVar *)
 Get memory regions for a load statement according to cpts.
 
virtual void getMRsForCallSiteRef (MRSet &aliasMRs, const NodeBS &cpts, const FunObjVar *)
 Get memory regions for call site ref according to cpts.
 
virtual void modRefAnalysis (CallGraphNode *callGraphNode, WorkList &worklist)
 Mod-Ref analysis for callsite invoking this callGraphNode.
 
virtual bool handleCallsiteModRef (NodeBS &mod, NodeBS &ref, const CallICFGNode *cs, const FunObjVar *fun)
 Get Mod-Ref of a callee function.
 
void addCPtsToStore (NodeBS &cpts, const StoreStmt *st, const FunObjVar *fun)
 Add cpts to store/load.
 
void addCPtsToLoad (NodeBS &cpts, const LoadStmt *ld, const FunObjVar *fun)
 
void addCPtsToCallSiteRefs (NodeBS &cpts, const CallICFGNode *cs)
 
void addCPtsToCallSiteMods (NodeBS &cpts, const CallICFGNode *cs)
 
bool hasCPtsList (const FunObjVar *fun) const
 
PointsToListgetPointsToList (const FunObjVar *fun)
 
FunToPointsTosMapgetFunToPointsToList ()
 
void addRefSideEffectOfFunction (const FunObjVar *fun, const NodeBS &refs)
 Add/Get methods for side-effect of functions and callsites.
 
void addModSideEffectOfFunction (const FunObjVar *fun, const NodeBS &mods)
 Add indirect def an memory object in the function.
 
bool addRefSideEffectOfCallSite (const CallICFGNode *cs, const NodeBS &refs)
 Add indirect uses an memory object in the function.
 
bool addModSideEffectOfCallSite (const CallICFGNode *cs, const NodeBS &mods)
 Add indirect def an memory object in the function.
 
const NodeBSgetRefSideEffectOfFunction (const FunObjVar *fun)
 Get indirect refs of a function.
 
const NodeBSgetModSideEffectOfFunction (const FunObjVar *fun)
 Get indirect mods of a function.
 
const NodeBSgetRefSideEffectOfCallSite (const CallICFGNode *cs)
 Get indirect refs of a callsite.
 
const NodeBSgetModSideEffectOfCallSite (const CallICFGNode *cs)
 Get indirect mods of a callsite.
 
bool hasRefSideEffectOfCallSite (const CallICFGNode *cs)
 Has indirect refs of a callsite.
 
bool hasModSideEffectOfCallSite (const CallICFGNode *cs)
 Has indirect mods of a callsite.
 

Protected Attributes

MRSet memRegSet
 A set of All memory regions.
 
PtsToRepPtsSetMap cptsToRepCPtsMap
 Map a condition pts to its rep conditional pts (super set points-to)
 

Private Member Functions

void destroy ()
 Clean up memory.
 
void collectCallSitePts (const CallICFGNode *cs)
 
NodeBSCollectPtsChain (NodeID id)
 
NodeBSgetCallSiteArgsPts (const CallICFGNode *cs)
 Return the pts chain of all callsite arguments.
 
NodeBSgetCallSiteRetPts (const CallICFGNode *cs)
 Return the pts chain of the return parameter of the callsite.
 
bool isNonLocalObject (NodeID id, const FunObjVar *curFun) const
 
void getEscapObjviaGlobals (NodeBS &globs, const NodeBS &pts)
 Get all the objects in callee's modref escaped via global objects (the chain pts of globals)
 

Private Attributes

BVDataPTAImplpta
 
SCCcallGraphSCC
 
CallGraphcallGraph
 
bool ptrOnlyMSSA
 
FunToMRsMap funToMRsMap
 Map a function to all its memory regions.
 
LoadsToMRsMap loadsToMRsMap
 Map a load SVFIR Edge to its memory regions sets in order for inserting mus in Memory SSA.
 
StoresToMRsMap storesToMRsMap
 Map a store SVFIR Edge to its memory regions sets in order for inserting chis in Memory SSA.
 
CallSiteToMRsMap callsiteToRefMRsMap
 Map a callsite to its refs regions.
 
CallSiteToMRsMap callsiteToModMRsMap
 Map a callsite to its mods regions.
 
LoadsToPointsToMap loadsToPointsToMap
 Map a load SVFIR Edge to its CPts set map.
 
StoresToPointsToMap storesToPointsToMap
 Map a store SVFIR Edge to its CPts set map.
 
CallSiteToPointsToMap callsiteToRefPointsToMap
 Map a callsite to it refs cpts set.
 
CallSiteToPointsToMap callsiteToModPointsToMap
 Map a callsite to it mods cpts set.
 
FunToPointsTosMap funToPointsToMap
 Map a function to all of its conditional points-to sets.
 
PAGEdgeToFunMap pagEdgeToFunMap
 Map a PAGEdge to its fun.
 
FunToPointsToMap funToRefsMap
 Map a function to its indirect uses of memory objects.
 
FunToPointsToMap funToModsMap
 Map a function to its indirect defs of memory objects.
 
CallSiteToPointsToMap csToRefsMap
 Map a callsite to its indirect uses of memory objects.
 
CallSiteToPointsToMap csToModsMap
 Map a callsite to its indirect defs of memory objects.
 
CallSiteToPointsToMap csToCallSiteArgsPtsMap
 Map a callsite to all its object might pass into its callees.
 
CallSiteToPointsToMap csToCallSiteRetPtsMap
 Map a callsite to all its object might return from its callees.
 
NodeToPTSSMap cachedPtsChainMap
 Map a pointer to its cached points-to chain;.
 
NodeBS allGlobals
 All global variable SVFIR node ids.
 

Detailed Description

Memory Region Partitioning

Definition at line 131 of file MemRegion.h.

Member Typedef Documentation

◆ CallSiteToMRsMap

Definition at line 155 of file MemRegion.h.

◆ CallSiteToNodeBSMap

Map a callsite to its indirect refs/mods of memory objects.

Definition at line 170 of file MemRegion.h.

◆ CallSiteToPointsToMap

Definition at line 162 of file MemRegion.h.

◆ FunToMRsMap

Map a function to its region set.

Definition at line 149 of file MemRegion.h.

◆ FunToNodeBSMap

Maps Mod-Ref analysis.

Map a function to its indirect refs/mods of memory objects

Definition at line 168 of file MemRegion.h.

◆ FunToPointsToMap

Definition at line 144 of file MemRegion.h.

◆ FunToPointsTosMap

Definition at line 145 of file MemRegion.h.

◆ LoadsToMRsMap

Map loads/stores to its mem regions, TODO:visitAtomicCmpXchgInst, visitAtomicRMWInst??

Definition at line 153 of file MemRegion.h.

◆ LoadsToPointsToMap

Map loads/stores/callsites to their cpts set.

Definition at line 160 of file MemRegion.h.

◆ MRSet

Get typedef from Pointer Analysis.

Define mem region set

Definition at line 141 of file MemRegion.h.

◆ NodeToPTSSMap

Definition at line 173 of file MemRegion.h.

◆ PAGEdgeToFunMap

Definition at line 142 of file MemRegion.h.

◆ PointsToList

Definition at line 143 of file MemRegion.h.

◆ PtsToRepPtsSetMap

Definition at line 146 of file MemRegion.h.

◆ SCC

Call Graph SCC.

Definition at line 178 of file MemRegion.h.

◆ StoresToMRsMap

Definition at line 154 of file MemRegion.h.

◆ StoresToPointsToMap

Definition at line 161 of file MemRegion.h.

◆ SVFStmtList

SVFIR edge list.

Definition at line 176 of file MemRegion.h.

◆ WorkList

Definition at line 135 of file MemRegion.h.

Constructor & Destructor Documentation

◆ MRGenerator()

MRGenerator::MRGenerator ( BVDataPTAImpl p,
bool  ptrOnly 
)
protected

Definition at line 41 of file MemRegion.cpp.

41 :
43{
46}
cJSON * p
Definition cJSON.cpp:2559
CallGraph * callGraph
Definition MemRegion.h:199
SCCDetection< CallGraph * > SCC
Call Graph SCC.
Definition MemRegion.h:178
BVDataPTAImpl * pta
Definition MemRegion.h:197
CallGraph * getCallGraph() const
Return call graph.
llvm::IRBuilder IRBuilder
Definition BasicTypes.h:74

◆ ~MRGenerator()

virtual SVF::MRGenerator::~MRGenerator ( )
inlinevirtual

Destructor.

Definition at line 424 of file MemRegion.h.

425 {
426 destroy();
427 }
void destroy()
Clean up memory.
Definition MemRegion.cpp:51

Member Function Documentation

◆ addCPtsToCallSiteMods()

void SVF::MRGenerator::addCPtsToCallSiteMods ( NodeBS cpts,
const CallICFGNode cs 
)
inlineprotected

Definition at line 356 of file MemRegion.h.

357 {
358 callsiteToModPointsToMap[cs] |= cpts;
359 funToPointsToMap[cs->getCaller()].insert(cpts);
360 }
FunToPointsTosMap funToPointsToMap
Map a function to all of its conditional points-to sets.
Definition MemRegion.h:222
CallSiteToPointsToMap callsiteToModPointsToMap
Map a callsite to it mods cpts set.
Definition MemRegion.h:219

◆ addCPtsToCallSiteRefs()

void SVF::MRGenerator::addCPtsToCallSiteRefs ( NodeBS cpts,
const CallICFGNode cs 
)
inlineprotected

Definition at line 351 of file MemRegion.h.

352 {
353 callsiteToRefPointsToMap[cs] |= cpts;
354 funToPointsToMap[cs->getCaller()].insert(cpts);
355 }
CallSiteToPointsToMap callsiteToRefPointsToMap
Map a callsite to it refs cpts set.
Definition MemRegion.h:217

◆ addCPtsToLoad()

void SVF::MRGenerator::addCPtsToLoad ( NodeBS cpts,
const LoadStmt ld,
const FunObjVar fun 
)
inlineprotected

Definition at line 345 of file MemRegion.h.

346 {
347 loadsToPointsToMap[ld] = cpts;
348 funToPointsToMap[fun].insert(cpts);
350 }
void addRefSideEffectOfFunction(const FunObjVar *fun, const NodeBS &refs)
Add/Get methods for side-effect of functions and callsites.
LoadsToPointsToMap loadsToPointsToMap
Map a load SVFIR Edge to its CPts set map.
Definition MemRegion.h:213

◆ addCPtsToStore()

void SVF::MRGenerator::addCPtsToStore ( NodeBS cpts,
const StoreStmt st,
const FunObjVar fun 
)
inlineprotected

Add cpts to store/load.

Definition at line 339 of file MemRegion.h.

340 {
341 storesToPointsToMap[st] = cpts;
342 funToPointsToMap[fun].insert(cpts);
344 }
void addModSideEffectOfFunction(const FunObjVar *fun, const NodeBS &mods)
Add indirect def an memory object in the function.
StoresToPointsToMap storesToPointsToMap
Map a store SVFIR Edge to its CPts set map.
Definition MemRegion.h:215

◆ addModSideEffectOfCallSite()

bool MRGenerator::addModSideEffectOfCallSite ( const CallICFGNode cs,
const NodeBS mods 
)
protected

Add indirect def an memory object in the function.

Add indirect def an memory object in the function

Definition at line 444 of file MemRegion.cpp.

445{
446 if(!mods.empty())
447 {
452 return csToModsMap[cs] |= modset;
453 }
454 return false;
455}
const FunObjVar * getCaller() const
Return callsite.
Definition ICFGNode.h:464
CallSiteToPointsToMap csToModsMap
Map a callsite to its indirect defs of memory objects.
Definition MemRegion.h:233
NodeBS & getCallSiteArgsPts(const CallICFGNode *cs)
Return the pts chain of all callsite arguments.
Definition MemRegion.h:255
void getEscapObjviaGlobals(NodeBS &globs, const NodeBS &pts)
Get all the objects in callee's modref escaped via global objects (the chain pts of globals)
NodeBS & getCallSiteRetPts(const CallICFGNode *cs)
Return the pts chain of the return parameter of the callsite.
Definition MemRegion.h:260

◆ addModSideEffectOfFunction()

void MRGenerator::addModSideEffectOfFunction ( const FunObjVar fun,
const NodeBS mods 
)
protected

Add indirect def an memory object in the function.

Add indirect def an memory object in the function

Definition at line 416 of file MemRegion.cpp.

417{
418 for(NodeBS::iterator it = mods.begin(), eit = mods.end(); it!=eit; ++it)
419 {
420 if(isNonLocalObject(*it,fun))
421 funToModsMap[fun].set(*it);
422 }
423}
set(THREADS_PREFER_PTHREAD_FLAG ON) find_package(Threads REQUIRED) add_llvm_executable(wpa wpa.cpp) target_link_libraries(wpa PUBLIC $
Definition CMakeLists.txt:1
FunToPointsToMap funToModsMap
Map a function to its indirect defs of memory objects.
Definition MemRegion.h:229
bool isNonLocalObject(NodeID id, const FunObjVar *curFun) const

◆ addRefSideEffectOfCallSite()

bool MRGenerator::addRefSideEffectOfCallSite ( const CallICFGNode cs,
const NodeBS refs 
)
protected

Add indirect uses an memory object in the function.

Add indirect uses an memory object in the function

Definition at line 428 of file MemRegion.cpp.

429{
430 if(!refs.empty())
431 {
436 return csToRefsMap[cs] |= refset;
437 }
438 return false;
439}
CallSiteToPointsToMap csToRefsMap
Map a callsite to its indirect uses of memory objects.
Definition MemRegion.h:231

◆ addRefSideEffectOfFunction()

void MRGenerator::addRefSideEffectOfFunction ( const FunObjVar fun,
const NodeBS refs 
)
protected

Add/Get methods for side-effect of functions and callsites.

Add indirect uses an memory object in the function

Definition at line 404 of file MemRegion.cpp.

405{
406 for(NodeBS::iterator it = refs.begin(), eit = refs.end(); it!=eit; ++it)
407 {
408 if(isNonLocalObject(*it,fun))
409 funToRefsMap[fun].set(*it);
410 }
411}
FunToPointsToMap funToRefsMap
Map a function to its indirect uses of memory objects.
Definition MemRegion.h:227

◆ collectCallSitePts()

void MRGenerator::collectCallSitePts ( const CallICFGNode cs)
private

Get all objects might pass into and pass out of callee(s) from a callsite

collect the pts chain of the callsite arguments

collect the pts chain of the return argument

Definition at line 461 of file MemRegion.cpp.

462{
465 SVFIR* pag = pta->getPAG();
466 CallICFGNode* callBlockNode = const_cast<CallICFGNode*>(cs);
468
469 WorkList worklist;
470 if (pag->hasCallSiteArgsMap(callBlockNode))
471 {
472 const SVFIR::SVFVarList& args = pta->getPAG()->getCallSiteArgsList(callBlockNode);
473 for(SVFIR::SVFVarList::const_iterator itA = args.begin(), ieA = args.end(); itA!=ieA; ++itA)
474 {
475 const PAGNode* node = *itA;
476 if(node->isPointer())
477 worklist.push(node->getId());
478 }
479 }
480
481 while(!worklist.empty())
482 {
483 NodeID nodeId = worklist.pop();
484 const NodeBS& tmp = pta->getPts(nodeId).toNodeBS();
485 for(NodeBS::iterator it = tmp.begin(), eit = tmp.end(); it!=eit; ++it)
487 }
488
491
493 {
494 const PAGNode* node = pta->getPAG()->getCallSiteRet(retBlockNode);
495 if(node->isPointer())
496 {
497 const NodeBS& tmp = pta->getPts(node->getId()).toNodeBS();
498 for(NodeBS::iterator it = tmp.begin(), eit = tmp.end(); it!=eit; ++it)
500 }
501 }
502
503}
const PointsTo & getPts(NodeID id) override
const RetICFGNode * getRetICFGNode() const
Return callsite.
Definition ICFGNode.h:451
CallSiteToPointsToMap csToCallSiteRetPtsMap
Map a callsite to all its object might return from its callees.
Definition MemRegion.h:237
FIFOWorkList< NodeID > WorkList
Definition MemRegion.h:135
NodeBS & CollectPtsChain(NodeID id)
CallSiteToPointsToMap csToCallSiteArgsPtsMap
Map a callsite to all its object might pass into its callees.
Definition MemRegion.h:235
SVFIR * getPAG() const
NodeBS toNodeBS() const
Returns this points-to set as a NodeBS.
Definition PointsTo.cpp:313
std::vector< const SVFVar * > SVFVarList
Definition SVFIR.h:58
bool hasCallSiteArgsMap(const CallICFGNode *cs) const
Callsite has argument list.
Definition SVFIR.h:310
bool callsiteHasRet(const RetICFGNode *cs) const
Definition SVFIR.h:338
const SVFVarList & getCallSiteArgsList(const CallICFGNode *cs) const
Get callsite argument list.
Definition SVFIR.h:320
const SVFVar * getCallSiteRet(const RetICFGNode *cs) const
Get callsite return.
Definition SVFIR.h:332
NodeID getId() const
Get ID.
Definition SVFValue.h:158
virtual bool isPointer() const
Check if this variable represents a pointer.
u32_t NodeID
Definition GeneralType.h:56

◆ collectGlobals()

void MRGenerator::collectGlobals ( )
protected

Collect all global variables for later escape analysis.

Collect globals for escape analysis

Definition at line 104 of file MemRegion.cpp.

105{
106 SVFIR* pag = pta->getPAG();
107 for (SVFIR::iterator nIter = pag->begin(); nIter != pag->end(); ++nIter)
108 {
109 if(ObjVar* obj = SVFUtil::dyn_cast<ObjVar>(nIter->second))
110 {
111 if (pag->getBaseObject(obj->getId())->isGlobalObj())
112 {
113 allGlobals.set(nIter->first);
115 }
116 }
117 }
118}
bool isGlobalObj() const
iterator begin()
Iterators.
IDToNodeMapTy::iterator iterator
Node Iterators.
NodeBS allGlobals
All global variable SVFIR node ids.
Definition MemRegion.h:243
const BaseObjVar * getBaseObject(NodeID id) const
Definition SVFIR.h:423
void set(unsigned Idx)

◆ collectModRefForCall()

void MRGenerator::collectModRefForCall ( )
protectedvirtual

Generate regions for calls/rets.

Generate memory regions for calls

collect points-to information for callsites

handle all sub scc nodes of this rep node

Get mod-ref of all callsites calling callGraphNode

mods are treated as both def and use of memory objects

Definition at line 226 of file MemRegion.cpp.

227{
228
229 DBOUT(DGENERAL, outs() << pasMsg("\t\tCollect Callsite PointsTo \n"));
230
232 for(SVFIR::CallSiteSet::const_iterator it = pta->getPAG()->getCallSiteSet().begin(),
233 eit = pta->getPAG()->getCallSiteSet().end(); it!=eit; ++it)
234 {
236 }
237
238 DBOUT(DGENERAL, outs() << pasMsg("\t\tPerform Callsite Mod-Ref \n"));
239
240 WorkList worklist = callGraphSCC->revTopoNodeStack();
241
242 while(!worklist.empty())
243 {
244 NodeID callGraphNodeID = worklist.front();
245 worklist.pop();
247 const NodeBS& subNodes = callGraphSCC->subNodes(callGraphNodeID);
248 for(NodeBS::iterator it = subNodes.begin(), eit = subNodes.end(); it!=eit; ++it)
249 {
253 }
254 }
255
256 DBOUT(DGENERAL, outs() << pasMsg("\t\tAdd PointsTo to Callsites \n"));
257
258 for (const CallICFGNode* callBlockNode : pta->getPAG()->getCallSiteSet())
259 {
260 if(hasRefSideEffectOfCallSite(callBlockNode))
261 {
262 NodeBS refs = getRefSideEffectOfCallSite(callBlockNode);
263 addCPtsToCallSiteRefs(refs,callBlockNode);
264 }
265 if(hasModSideEffectOfCallSite(callBlockNode))
266 {
267 NodeBS mods = getModSideEffectOfCallSite(callBlockNode);
269 addCPtsToCallSiteMods(mods,callBlockNode);
270 addCPtsToCallSiteRefs(mods,callBlockNode);
271 }
272 }
273}
#define DBOUT(TYPE, X)
LLVM debug macros, define type of your DBUG model of each pass.
Definition SVFType.h:498
#define DGENERAL
Definition SVFType.h:504
const CallGraphNode * getCallGraphNode(const std::string &name)
Get call graph node.
bool hasModSideEffectOfCallSite(const CallICFGNode *cs)
Has indirect mods of a callsite.
Definition MemRegion.h:411
void addCPtsToCallSiteRefs(NodeBS &cpts, const CallICFGNode *cs)
Definition MemRegion.h:351
bool hasRefSideEffectOfCallSite(const CallICFGNode *cs)
Has indirect refs of a callsite.
Definition MemRegion.h:406
void collectCallSitePts(const CallICFGNode *cs)
void addCPtsToCallSiteMods(NodeBS &cpts, const CallICFGNode *cs)
Definition MemRegion.h:356
const NodeBS & getRefSideEffectOfCallSite(const CallICFGNode *cs)
Get indirect refs of a callsite.
Definition MemRegion.h:396
const NodeBS & getModSideEffectOfCallSite(const CallICFGNode *cs)
Get indirect mods of a callsite.
Definition MemRegion.h:401
virtual void modRefAnalysis(CallGraphNode *callGraphNode, WorkList &worklist)
Mod-Ref analysis for callsite invoking this callGraphNode.
const CallSiteSet & getCallSiteSet() const
Get all callsites.
Definition SVFIR.h:282
iterator begin() const
std::string pasMsg(const std::string &msg)
Print each pass/phase message by converting a string into blue string output.
Definition SVFUtil.cpp:101
std::ostream & outs()
Overwrite llvm::outs()
Definition SVFUtil.h:52

◆ collectModRefForLoadStore()

void MRGenerator::collectModRefForLoadStore ( )
protectedvirtual

Generate regions for loads/stores.

Generate memory regions for loads/stores

if this function does not have any caller, then we do not care its MSSA

Definition at line 173 of file MemRegion.cpp.

174{
175
177 for (const auto& item: *svfirCallGraph)
178 {
179 const FunObjVar& fun = *item.second->getFunction();
180
183 continue;
184
185 for (FunObjVar::const_bb_iterator iter = fun.begin(), eiter = fun.end();
186 iter != eiter; ++iter)
187 {
188 const SVFBasicBlock* bb = iter->second;
189 for (const auto& inst: bb->getICFGNodeList())
190 {
192 for (SVFStmtList::iterator bit = pagEdgeList.begin(), ebit =
193 pagEdgeList.end(); bit != ebit; ++bit)
194 {
195 const PAGEdge* inst = *bit;
196 pagEdgeToFunMap[inst] = &fun;
197 if (const StoreStmt *st = SVFUtil::dyn_cast<StoreStmt>(inst))
198 {
199 NodeBS cpts(pta->getPts(st->getLHSVarID()).toNodeBS());
200 // TODO: change this assertion check later when we have conditional points-to set
201 if (cpts.empty())
202 continue;
203 assert(!cpts.empty() && "null pointer!!");
204 addCPtsToStore(cpts, st, &fun);
205 }
206
207 else if (const LoadStmt *ld = SVFUtil::dyn_cast<LoadStmt>(inst))
208 {
209 NodeBS cpts(pta->getPts(ld->getRHSVarID()).toNodeBS());
210 // TODO: change this assertion check later when we have conditional points-to set
211 if (cpts.empty())
212 continue;
213 assert(!cpts.empty() && "null pointer!!");
214 addCPtsToLoad(cpts, ld, &fun);
215 }
216 }
217 }
218 }
219 }
220}
cJSON * item
Definition cJSON.h:222
BasicBlockGraph::IDToNodeMapTy::const_iterator const_bb_iterator
const_bb_iterator begin() const
bool isUncalledFunction() const
const_bb_iterator end() const
SVFStmtList & getPAGEdgesFromInst(const ICFGNode *node)
Given an instruction, get all its the PAGEdge (statement) in sequence.
void addCPtsToLoad(NodeBS &cpts, const LoadStmt *ld, const FunObjVar *fun)
Definition MemRegion.h:345
void addCPtsToStore(NodeBS &cpts, const StoreStmt *st, const FunObjVar *fun)
Add cpts to store/load.
Definition MemRegion.h:339
SVFIR::SVFStmtList SVFStmtList
SVFIR edge list.
Definition MemRegion.h:176
PAGEdgeToFunMap pagEdgeToFunMap
Map a PAGEdge to its fun.
Definition MemRegion.h:224
static const Option< bool > IgnoreDeadFun
Definition Options.h:139
CallGraph * getCallGraph()
Definition SVFIR.h:184
static SVFIR * getPAG(bool buildFromFile=false)
Singleton design here to make sure we only have one instance during any analysis.
Definition SVFIR.h:116

◆ CollectPtsChain()

NodeBS & MRGenerator::CollectPtsChain ( NodeID  id)
private

Recursively collect all points-to of the whole struct fields

Definition at line 509 of file MemRegion.cpp.

510{
512 NodeToPTSSMap::iterator it = cachedPtsChainMap.find(baseId);
513 if(it!=cachedPtsChainMap.end())
514 return it->second;
515 else
516 {
519
520 WorkList worklist;
521 for(NodeBS::iterator it = pts.begin(), eit = pts.end(); it!=eit; ++it)
522 worklist.push(*it);
523
524 while(!worklist.empty())
525 {
526 NodeID nodeId = worklist.pop();
527 const NodeBS& tmp = pta->getPts(nodeId).toNodeBS();
528 for(NodeBS::iterator it = tmp.begin(), eit = tmp.end(); it!=eit; ++it)
529 {
531 }
532 }
533 return pts;
534 }
535
536}
bool push(const Data &data)
Definition WorkList.h:165
NodeToPTSSMap cachedPtsChainMap
Map a pointer to its cached points-to chain;.
Definition MemRegion.h:240
NodeBS getFieldsAfterCollapse(NodeID id)
Definition SVFIR.cpp:504
NodeID getBaseObjVar(NodeID id) const
Base and Offset methods for Value and Object node.
Definition SVFIR.h:479

◆ createMR()

void MRGenerator::createMR ( const FunObjVar fun,
const NodeBS cpts 
)
protected

Generate a memory region and put in into functions which use it.

Generate a memory region and put in into functions which use it

Definition at line 69 of file MemRegion.cpp.

70{
71 const NodeBS& repCPts = getRepPointsTo(cpts);
73 MRSet::const_iterator mit = memRegSet.find(&mr);
74 if(mit!=memRegSet.end())
75 {
76 const MemRegion* mr = *mit;
77 MRSet& mrs = funToMRsMap[fun];
78 if(mrs.find(mr)==mrs.end())
79 mrs.insert(mr);
80 }
81 else
82 {
84 memRegSet.insert(m);
85 funToMRsMap[fun].insert(m);
86 }
87}
FunToMRsMap funToMRsMap
Map a function to all its memory regions.
Definition MemRegion.h:203
OrderedSet< const MemRegion *, MemRegion::equalMemRegion > MRSet
Get typedef from Pointer Analysis.
Definition MemRegion.h:141
const NodeBS & getRepPointsTo(const NodeBS &cpts) const
Get superset cpts set.
Definition MemRegion.h:186
MRSet memRegSet
A set of All memory regions.
Definition MemRegion.h:276
Memory Region class.
Definition MemRegion.h:56

◆ destroy()

void MRGenerator::destroy ( )
private

Clean up memory.

Clean up memory

Definition at line 51 of file MemRegion.cpp.

52{
53
54 for (MRSet::iterator it = memRegSet.begin(), eit = memRegSet.end();
55 it != eit; ++it)
56 {
57 delete *it;
58 }
59
60 delete callGraphSCC;
61 callGraphSCC = nullptr;
62 callGraph = nullptr;
63 pta = nullptr;
64}

◆ generateMRs()

void MRGenerator::generateMRs ( )
virtual

Start generating memory regions.

Generate memory regions according to pointer analysis results Attach regions on loads/stores

collect mod-ref for loads/stores

collect mod-ref for calls

Partition memory regions

attach memory regions for loads/stores/calls

Definition at line 124 of file MemRegion.cpp.

125{
126
127 DBOUT(DGENERAL, outs() << pasMsg("Generate Memory Regions \n"));
128
130
131 callGraphSCC->find();
132
133 DBOUT(DGENERAL, outs() << pasMsg("\tCollect ModRef For Load/Store \n"));
134
137
138 DBOUT(DGENERAL, outs() << pasMsg("\tCollect ModRef For const CallICFGNode*\n"));
139
142
143 DBOUT(DGENERAL, outs() << pasMsg("\tPartition Memory Regions \n"));
145 partitionMRs();
148}
virtual void collectModRefForLoadStore()
Generate regions for loads/stores.
virtual void collectModRefForCall()
Generate regions for calls/rets.
virtual void updateAliasMRs()
Update aliased regions for loads/stores/callsites.
virtual void partitionMRs()
Partition regions.
void collectGlobals()
Collect all global variables for later escape analysis.

◆ getAliasMemRegions()

virtual void SVF::MRGenerator::getAliasMemRegions ( MRSet aliasMRs,
const NodeBS cpts,
const FunObjVar fun 
)
inlineprotectedvirtual

Get all aliased mem regions from function fun according to cpts.

Definition at line 307 of file MemRegion.h.

308 {
309 for(MRSet::const_iterator it = funToMRsMap[fun].begin(), eit = funToMRsMap[fun].end(); it!=eit; ++it)
310 {
311 if(isAliasedMR(cpts,*it))
312 aliasMRs.insert(*it);
313 }
314 }
virtual bool isAliasedMR(const NodeBS &cpts, const MemRegion *mr)
Whether a region is aliased with a conditional points-to.
Definition MemRegion.h:302

◆ getCallSiteArgsPts()

NodeBS & SVF::MRGenerator::getCallSiteArgsPts ( const CallICFGNode cs)
inlineprivate

Return the pts chain of all callsite arguments.

Definition at line 255 of file MemRegion.h.

256 {
257 return csToCallSiteArgsPtsMap[cs];
258 }

◆ getCallSiteModMRSet()

MRSet & SVF::MRGenerator::getCallSiteModMRSet ( const CallICFGNode cs)
inline

Definition at line 465 of file MemRegion.h.

466 {
467 return callsiteToModMRsMap[cs];
468 }
CallSiteToMRsMap callsiteToModMRsMap
Map a callsite to its mods regions.
Definition MemRegion.h:211

◆ getCallSiteRefMRSet()

MRSet & SVF::MRGenerator::getCallSiteRefMRSet ( const CallICFGNode cs)
inline

Definition at line 461 of file MemRegion.h.

462 {
463 return callsiteToRefMRsMap[cs];
464 }
CallSiteToMRsMap callsiteToRefMRsMap
Map a callsite to its refs regions.
Definition MemRegion.h:209

◆ getCallSiteRetPts()

NodeBS & SVF::MRGenerator::getCallSiteRetPts ( const CallICFGNode cs)
inlineprivate

Return the pts chain of the return parameter of the callsite.

Definition at line 260 of file MemRegion.h.

261 {
262 return csToCallSiteRetPtsMap[cs];
263 }

◆ getEscapObjviaGlobals()

void MRGenerator::getEscapObjviaGlobals ( NodeBS globs,
const NodeBS calleeModRef 
)
private

Get all the objects in callee's modref escaped via global objects (the chain pts of globals)

Get all the objects in callee's modref escaped via global objects (the chain pts of globals) Otherwise, the object in callee's modref would not escape through globals

Definition at line 543 of file MemRegion.cpp.

544{
545 for(NodeBS::iterator it = calleeModRef.begin(), eit = calleeModRef.end(); it!=eit; ++it)
546 {
547 const BaseObjVar* pVar = pta->getPAG()->getBaseObject(*it);
548 (void)pVar;
549 //(void)obj; // Suppress warning of unused variable under release build
550 assert(pVar && "object not found!!");
551 if(allGlobals.test(*it))
552 globs.set(*it);
553 }
554}
bool test(unsigned Idx) const

◆ getFunction()

const FunObjVar * SVF::MRGenerator::getFunction ( const PAGEdge pagEdge) const
inline

Get the function which SVFIR Edge located.

Definition at line 433 of file MemRegion.h.

434 {
435 PAGEdgeToFunMap::const_iterator it = pagEdgeToFunMap.find(pagEdge);
436 assert(it!=pagEdgeToFunMap.end() && "can not find its function, it is a global SVFIR edge");
437 return it->second;
438 }

◆ getFunMRSet()

MRSet & SVF::MRGenerator::getFunMRSet ( const FunObjVar fun)
inline

Get Memory Region set.

Definition at line 441 of file MemRegion.h.

442 {
443 return funToMRsMap[fun];
444 }

◆ getFunToPointsToList()

FunToPointsTosMap & SVF::MRGenerator::getFunToPointsToList ( )
inlineprotected

Definition at line 369 of file MemRegion.h.

370 {
371 return funToPointsToMap;
372 }

◆ getLoadMRSet()

MRSet & SVF::MRGenerator::getLoadMRSet ( const LoadStmt load)
inline

Definition at line 445 of file MemRegion.h.

446 {
447 return loadsToMRsMap[load];
448 }
LoadsToMRsMap loadsToMRsMap
Map a load SVFIR Edge to its memory regions sets in order for inserting mus in Memory SSA.
Definition MemRegion.h:205

◆ getModInfoForCall()

NodeBS MRGenerator::getModInfoForCall ( const CallICFGNode cs)

getModRefInfo APIs

Collect mod ref for external callsite other than heap alloc external call

Obtain the mod sets for a call, used for external ModRefInfo queries

Definition at line 656 of file MemRegion.cpp.

657{
658 if (isExtCall(cs) && !isHeapAllocExtCall(cs))
659 {
661 NodeBS mods;
662 for (SVFStmtList::const_iterator bit = pagEdgeList.begin(), ebit =
663 pagEdgeList.end(); bit != ebit; ++bit)
664 {
665 const PAGEdge* edge = *bit;
666 if (const StoreStmt* st = SVFUtil::dyn_cast<StoreStmt>(edge))
667 mods |= pta->getPts(st->getLHSVarID()).toNodeBS();
668 }
669 return mods;
670 }
671 else
672 {
674 }
675}
bool isHeapAllocExtCall(const ICFGNode *cs)
Definition SVFUtil.cpp:357
bool isExtCall(const FunObjVar *fun)
Definition SVFUtil.cpp:437

◆ getModRefInfo() [1/3]

ModRefInfo MRGenerator::getModRefInfo ( const CallICFGNode cs)

Determine whether a CallSite instruction can mod or ref any memory location

Definition at line 705 of file MemRegion.cpp.

706{
707 bool ref = !getRefInfoForCall(cs).empty();
708 bool mod = !getModInfoForCall(cs).empty();
709
710 if (mod && ref)
711 return ModRefInfo::ModRef;
712 else if (ref)
713 return ModRefInfo::Ref;
714 else if (mod)
715 return ModRefInfo::Mod;
716 else
718}
NodeBS getRefInfoForCall(const CallICFGNode *cs)
NodeBS getModInfoForCall(const CallICFGNode *cs)
getModRefInfo APIs
@ Ref
Definition SVFType.h:535
@ NoModRef
Definition SVFType.h:537
@ ModRef
Definition SVFType.h:534
@ Mod
Definition SVFType.h:536

◆ getModRefInfo() [2/3]

ModRefInfo MRGenerator::getModRefInfo ( const CallICFGNode cs,
const SVFVar V 
)

Determine whether a const CallICFGNode* instruction can mod or ref a specific memory location pointed by V

Definition at line 724 of file MemRegion.cpp.

725{
726 bool ref = false;
727 bool mod = false;
728
729 const NodeBS pts(pta->getPts(V->getId()).toNodeBS());
730 const NodeBS csRef = getRefInfoForCall(cs);
731 const NodeBS csMod = getModInfoForCall(cs);
736
737 if (csRefExpanded.intersects(ptsExpanded))
738 ref = true;
739 if (csModExpanded.intersects(ptsExpanded))
740 mod = true;
741
742 if (mod && ref)
743 return ModRefInfo::ModRef;
744 else if (ref)
745 return ModRefInfo::Ref;
746 else if (mod)
747 return ModRefInfo::Mod;
748 else
750}
virtual void expandFIObjs(const PointsTo &pts, PointsTo &expandedPts)
Expand FI objects.

◆ getModRefInfo() [3/3]

ModRefInfo MRGenerator::getModRefInfo ( const CallICFGNode cs1,
const CallICFGNode cs2 
)

Determine mod-ref relations between two const CallICFGNode* instructions

return NoModRef neither two callsites ref or mod any memory

Ref: cs1 ref memory mod by cs2

Mod: cs1 mod memory ref or mod by cs2

ModRef: cs1 ref and mod memory mod by cs2

Definition at line 755 of file MemRegion.cpp.

756{
757 bool ref = false;
758 bool mod = false;
759
763
773
775 if (cs1RefExpanded.intersects(cs2ModExpanded))
776 ref = true;
778 if (cs1ModExpanded.intersects(cs2RefExpanded) || cs1ModExpanded.intersects(cs2ModExpanded))
779 mod = true;
781 if (cs1RefExpanded.intersects(cs2ModExpanded) && cs1ModExpanded.intersects(cs2ModExpanded))
782 ref = mod = true;
783
784 if (ref && mod)
785 return ModRefInfo::ModRef;
786 else if (ref)
787 return ModRefInfo::Ref;
788 else if (mod)
789 return ModRefInfo::Mod;
790 else
792}
ModRefInfo getModRefInfo(const CallICFGNode *cs)

◆ getModSideEffectOfCallSite()

const NodeBS & SVF::MRGenerator::getModSideEffectOfCallSite ( const CallICFGNode cs)
inlineprotected

Get indirect mods of a callsite.

Definition at line 401 of file MemRegion.h.

402 {
403 return csToModsMap[cs];
404 }

◆ getModSideEffectOfFunction()

const NodeBS & SVF::MRGenerator::getModSideEffectOfFunction ( const FunObjVar fun)
inlineprotected

Get indirect mods of a function.

Definition at line 391 of file MemRegion.h.

392 {
393 return funToModsMap[fun];
394 }

◆ getMR()

const MemRegion * MRGenerator::getMR ( const NodeBS cpts) const

Get a memory region according to cpts.

Generate a memory region and put in into functions which use it

Definition at line 92 of file MemRegion.cpp.

93{
94 MemRegion mr(getRepPointsTo(cpts));
95 MRSet::iterator mit = memRegSet.find(&mr);
96 assert(mit!=memRegSet.end() && "memory region not found!!");
97 return *mit;
98}

◆ getMRNum()

u32_t SVF::MRGenerator::getMRNum ( ) const
inline

Definition at line 418 of file MemRegion.h.

419 {
420 return memRegSet.size();
421 }

◆ getMRSet()

MRSet & SVF::MRGenerator::getMRSet ( )
inline

Definition at line 180 of file MemRegion.h.

181 {
182 return memRegSet;
183 }

◆ getMRsForCallSiteRef()

virtual void SVF::MRGenerator::getMRsForCallSiteRef ( MRSet aliasMRs,
const NodeBS cpts,
const FunObjVar  
)
inlineprotectedvirtual

Get memory regions for call site ref according to cpts.

Reimplemented in SVF::DistinctMRG, and SVF::IntraDisjointMRG.

Definition at line 324 of file MemRegion.h.

325 {
326 const MemRegion* mr = getMR(cpts);
327 aliasMRs.insert(mr);
328 }
const MemRegion * getMR(const NodeBS &cpts) const
Get a memory region according to cpts.
Definition MemRegion.cpp:92

◆ getMRsForLoad()

virtual void SVF::MRGenerator::getMRsForLoad ( MRSet aliasMRs,
const NodeBS cpts,
const FunObjVar  
)
inlineprotectedvirtual

Get memory regions for a load statement according to cpts.

Reimplemented in SVF::InterDisjointMRG, SVF::DistinctMRG, and SVF::IntraDisjointMRG.

Definition at line 317 of file MemRegion.h.

318 {
319 const MemRegion* mr = getMR(cpts);
320 aliasMRs.insert(mr);
321 }

◆ getPAGEdgesFromInst()

SVFIR::SVFStmtList & MRGenerator::getPAGEdgesFromInst ( const ICFGNode node)

Given an instruction, get all its the PAGEdge (statement) in sequence.

Definition at line 160 of file MemRegion.cpp.

161{
162 SVFIR* pag = pta->getPAG();
163 if (ptrOnlyMSSA)
164 return pag->getPTASVFStmtList(node);
165 else
166 return pag->getSVFStmtList(node);
167}
SVFStmtList & getSVFStmtList(const ICFGNode *inst)
Given an instruction, get all its PAGEdges.
Definition SVFIR.h:249
SVFStmtList & getPTASVFStmtList(const ICFGNode *inst)
Given an instruction, get all its PTA PAGEdges.
Definition SVFIR.h:254

◆ getPointsToList()

PointsToList & SVF::MRGenerator::getPointsToList ( const FunObjVar fun)
inlineprotected

Definition at line 365 of file MemRegion.h.

366 {
367 return funToPointsToMap[fun];
368 }

◆ getRefInfoForCall()

NodeBS MRGenerator::getRefInfoForCall ( const CallICFGNode cs)

Obtain the ref sets for a call, used for external ModRefInfo queries

Definition at line 680 of file MemRegion.cpp.

681{
682 if (isExtCall(cs) && !isHeapAllocExtCall(cs))
683 {
685 NodeBS refs;
686 for (SVFStmtList::const_iterator bit = pagEdgeList.begin(), ebit =
687 pagEdgeList.end(); bit != ebit; ++bit)
688 {
689 const PAGEdge* edge = *bit;
690 if (const LoadStmt* ld = SVFUtil::dyn_cast<LoadStmt>(edge))
691 refs |= pta->getPts(ld->getRHSVarID()).toNodeBS();
692 }
693 return refs;
694 }
695 else
696 {
698 }
699}

◆ getRefSideEffectOfCallSite()

const NodeBS & SVF::MRGenerator::getRefSideEffectOfCallSite ( const CallICFGNode cs)
inlineprotected

Get indirect refs of a callsite.

Definition at line 396 of file MemRegion.h.

397 {
398 return csToRefsMap[cs];
399 }

◆ getRefSideEffectOfFunction()

const NodeBS & SVF::MRGenerator::getRefSideEffectOfFunction ( const FunObjVar fun)
inlineprotected

Get indirect refs of a function.

Definition at line 386 of file MemRegion.h.

387 {
388 return funToRefsMap[fun];
389 }

◆ getRepPointsTo()

const NodeBS & SVF::MRGenerator::getRepPointsTo ( const NodeBS cpts) const
inline

Get superset cpts set.

Definition at line 186 of file MemRegion.h.

187 {
188 PtsToRepPtsSetMap::const_iterator it = cptsToRepCPtsMap.find(cpts);
189 assert(it!=cptsToRepCPtsMap.end() && "can not find superset of cpts??");
190 return it->second;
191 }
PtsToRepPtsSetMap cptsToRepCPtsMap
Map a condition pts to its rep conditional pts (super set points-to)
Definition MemRegion.h:278

◆ getStoreMRSet()

MRSet & SVF::MRGenerator::getStoreMRSet ( const StoreStmt store)
inline

Definition at line 449 of file MemRegion.h.

450 {
451 return storesToMRsMap[store];
452 }
StoresToMRsMap storesToMRsMap
Map a store SVFIR Edge to its memory regions sets in order for inserting chis in Memory SSA.
Definition MemRegion.h:207

◆ handleCallsiteModRef()

bool MRGenerator::handleCallsiteModRef ( NodeBS mod,
NodeBS ref,
const CallICFGNode cs,
const FunObjVar callee 
)
protectedvirtual

Get Mod-Ref of a callee function.

Get Mod-Ref of a callee function

if a callee is a heap allocator function, then its mod set of this callsite is the heap object.

otherwise, we find the mod/ref sets from the callee function, who has definition and been processed

Definition at line 589 of file MemRegion.cpp.

590{
592 if(isHeapAllocExtCall(cs))
593 {
595 for (SVFStmtList::const_iterator bit = pagEdgeList.begin(),
596 ebit = pagEdgeList.end(); bit != ebit; ++bit)
597 {
598 const PAGEdge* edge = *bit;
599 if (const AddrStmt* addr = SVFUtil::dyn_cast<AddrStmt>(edge))
600 mod.set(addr->getRHSVarID());
601 }
602 }
604 else
605 {
608 }
609 // add ref set
611 // add mod set
613
614 return refchanged || modchanged;
615}
const NodeBS & getModSideEffectOfFunction(const FunObjVar *fun)
Get indirect mods of a function.
Definition MemRegion.h:391
const NodeBS & getRefSideEffectOfFunction(const FunObjVar *fun)
Get indirect refs of a function.
Definition MemRegion.h:386
bool addRefSideEffectOfCallSite(const CallICFGNode *cs, const NodeBS &refs)
Add indirect uses an memory object in the function.
bool addModSideEffectOfCallSite(const CallICFGNode *cs, const NodeBS &mods)
Add indirect def an memory object in the function.

◆ hasCPtsList()

bool SVF::MRGenerator::hasCPtsList ( const FunObjVar fun) const
inlineprotected

Definition at line 361 of file MemRegion.h.

362 {
363 return funToPointsToMap.find(fun)!=funToPointsToMap.end();
364 }

◆ hasModMRSet()

bool SVF::MRGenerator::hasModMRSet ( const CallICFGNode cs)
inline

Definition at line 457 of file MemRegion.h.

458 {
459 return callsiteToModMRsMap.find(cs)!=callsiteToModMRsMap.end();
460 }

◆ hasModSideEffectOfCallSite()

bool SVF::MRGenerator::hasModSideEffectOfCallSite ( const CallICFGNode cs)
inlineprotected

Has indirect mods of a callsite.

Definition at line 411 of file MemRegion.h.

412 {
413 return csToModsMap.find(cs) != csToModsMap.end();
414 }

◆ hasRefMRSet()

bool SVF::MRGenerator::hasRefMRSet ( const CallICFGNode cs)
inline

Definition at line 453 of file MemRegion.h.

454 {
455 return callsiteToRefMRsMap.find(cs)!=callsiteToRefMRsMap.end();
456 }

◆ hasRefSideEffectOfCallSite()

bool SVF::MRGenerator::hasRefSideEffectOfCallSite ( const CallICFGNode cs)
inlineprotected

Has indirect refs of a callsite.

Definition at line 406 of file MemRegion.h.

407 {
408 return csToRefsMap.find(cs) != csToRefsMap.end();
409 }

◆ hasSVFStmtList()

bool MRGenerator::hasSVFStmtList ( const ICFGNode icfgNode)

Whether this instruction has SVFIR Edge.

Definition at line 150 of file MemRegion.cpp.

151{
152 SVFIR* pag = pta->getPAG();
153 if (ptrOnlyMSSA)
154 return pag->hasPTASVFStmtList(node);
155 else
156 return pag->hasSVFStmtList(node);
157}
bool hasPTASVFStmtList(const ICFGNode *inst) const
Definition SVFIR.h:243
bool hasSVFStmtList(const ICFGNode *inst) const
Whether this instruction has SVFIR Edge.
Definition SVFIR.h:239

◆ isAliasedMR()

virtual bool SVF::MRGenerator::isAliasedMR ( const NodeBS cpts,
const MemRegion mr 
)
inlineprotectedvirtual

Whether a region is aliased with a conditional points-to.

Definition at line 302 of file MemRegion.h.

303 {
304 return mr->getPointsTo().intersects(cpts);
305 }

◆ isNonLocalObject()

bool MRGenerator::isNonLocalObject ( NodeID  id,
const FunObjVar curFun 
) const
private

Whether the object node is a non-local object including global, heap, and stack variable in recursions

if the object is heap or global

or if the local variable of its callers or a local variable is in function recursion cycles

Definition at line 560 of file MemRegion.cpp.

561{
562 //ABTest
563 const BaseObjVar* obj = pta->getPAG()->getBaseObject(id);
564 assert(obj && "object not found!!");
566 const BaseObjVar* pVar = pta->getPAG()->getBaseObject(id);
567 assert(pVar && "object not found!");
568 if(obj->isGlobalObj() || SVFUtil::isa<HeapObjVar, DummyObjVar>(pVar))
569 return true;
572 else if(SVFUtil::isa<StackObjVar>(pVar))
573 {
574 if(const FunObjVar* svffun = pVar->getFunction())
575 {
576 if(svffun!=curFun)
577 return true;
578 else
579 return callGraphSCC->isInCycle(callGraph->getCallGraphNode(svffun)->getId());
580 }
581 }
582
583 return false;
584}
virtual const FunObjVar * getFunction() const
Get containing function, or null for globals/constants.

◆ modRefAnalysis()

void MRGenerator::modRefAnalysis ( CallGraphNode callGraphNode,
WorkList worklist 
)
protectedvirtual

Mod-Ref analysis for callsite invoking this callGraphNode.

Call site mod-ref analysis Compute mod-ref of all callsites invoking this call graph node

add ref/mod set of callee to its invocation callsites at caller

handle direct callsites

handle indirect callsites

Definition at line 621 of file MemRegion.cpp.

622{
623
625 for(CallGraphNode::iterator it = callGraphNode->InEdgeBegin(), eit = callGraphNode->InEdgeEnd();
626 it!=eit; ++it)
627 {
629
631 for(CallGraphEdge::CallInstSet::iterator cit = edge->getDirectCalls().begin(),
632 ecit = edge->getDirectCalls().end(); cit!=ecit; ++cit)
633 {
634 NodeBS mod, ref;
635 const CallICFGNode* cs = (*cit);
636 bool modrefchanged = handleCallsiteModRef(mod, ref, cs, callGraphNode->getFunction());
637 if(modrefchanged)
638 worklist.push(edge->getSrcID());
639 }
641 for(CallGraphEdge::CallInstSet::iterator cit = edge->getIndirectCalls().begin(),
642 ecit = edge->getIndirectCalls().end(); cit!=ecit; ++cit)
643 {
644 NodeBS mod, ref;
645 const CallICFGNode* cs = (*cit);
646 bool modrefchanged = handleCallsiteModRef(mod, ref, cs, callGraphNode->getFunction());
647 if(modrefchanged)
648 worklist.push(edge->getSrcID());
649 }
650 }
651}
const FunObjVar * getFunction() const
Get function of this call node.
Definition CallGraph.h:191
GEdgeSetTy::iterator iterator
iterator InEdgeBegin()
iterator InEdgeEnd()
virtual bool handleCallsiteModRef(NodeBS &mod, NodeBS &ref, const CallICFGNode *cs, const FunObjVar *fun)
Get Mod-Ref of a callee function.

◆ partitionMRs()

void MRGenerator::partitionMRs ( )
protectedvirtual

Partition regions.

Partition memory regions

Compute all superset of all condition points-to sets TODO: we may need some refined region partitioning algorithm here For now, we just collapse all refs/mods objects at callsites into one region Consider modularly partition memory regions to speed up analysis (only partition regions within function scope)

Generate memory regions according to condition pts after computing superset

Reimplemented in SVF::DistinctMRG, SVF::IntraDisjointMRG, and SVF::InterDisjointMRG.

Definition at line 314 of file MemRegion.cpp.

315{
316
321 for(FunToPointsTosMap::iterator it = getFunToPointsToList().begin(), eit = getFunToPointsToList().end();
322 it!=eit; ++it)
323 {
324 for(PointsToList::iterator cit = it->second.begin(), ecit = it->second.end(); cit!=ecit; ++cit)
325 {
327 }
328 }
330 for(FunToPointsTosMap::iterator it = getFunToPointsToList().begin(), eit = getFunToPointsToList().end();
331 it!=eit; ++it)
332 {
333 const FunObjVar* fun = it->first;
334 for(PointsToList::iterator cit = it->second.begin(), ecit = it->second.end(); cit!=ecit; ++cit)
335 {
336 createMR(fun,*cit);
337 }
338 }
339
340}
void createMR(const FunObjVar *fun, const NodeBS &cpts)
Generate a memory region and put in into functions which use it.
Definition MemRegion.cpp:69
FunToPointsTosMap & getFunToPointsToList()
Definition MemRegion.h:369
virtual void sortPointsTo(const NodeBS &cpts)
Given a condition pts, insert into cptsToRepCPtsMap for region generation.

◆ sortPointsTo()

void MRGenerator::sortPointsTo ( const NodeBS cpts)
protectedvirtual

Given a condition pts, insert into cptsToRepCPtsMap for region generation.

Given a condition pts, insert into cptsToRepCPtsMap Always map it to its superset(rep) cpts according to existing items 1) map cpts to its superset(rep) which exists in the map, otherwise its superset is itself 2) adjust existing items in the map if their supersets are cpts

Definition at line 281 of file MemRegion.cpp.

282{
283
284 if(cptsToRepCPtsMap.find(cpts)!=cptsToRepCPtsMap.end())
285 return;
286
288 NodeBS repCPts = cpts;
289 for(PtsToRepPtsSetMap::iterator it = cptsToRepCPtsMap.begin(),
290 eit = cptsToRepCPtsMap.end(); it!=eit; ++it)
291 {
292 NodeBS& existCPts = it->second;
293 if(cpts.contains(existCPts))
294 {
295 subSetList.insert(it->first);
296 }
297 else if(existCPts.contains(cpts))
298 {
300 }
301 }
302
303 for(PointsToList::iterator it = subSetList.begin(), eit = subSetList.end(); it!=eit; ++it)
304 {
305 cptsToRepCPtsMap[*it] = cpts;
306 }
307
309}
bool contains(const SparseBitVector< ElementSize > &RHS) const
OrderedSet< PointsTo, equalPointsTo > PointsToList
Definition SVFUtil.h:168

◆ updateAliasMRs()

void MRGenerator::updateAliasMRs ( )
protectedvirtual

Update aliased regions for loads/stores/callsites.

Update aliased regions for loads/stores/callsites

update stores with its aliased regions

update callsites with its aliased regions

Definition at line 345 of file MemRegion.cpp.

346{
347
349 for(StoresToPointsToMap::const_iterator it = storesToPointsToMap.begin(), eit = storesToPointsToMap.end(); it!=eit; ++it)
350 {
352 const FunObjVar* fun = getFunction(it->first);
353 const NodeBS& storeCPts = it->second;
355 for(MRSet::iterator ait = aliasMRs.begin(), eait = aliasMRs.end(); ait!=eait; ++ait)
356 {
357 storesToMRsMap[it->first].insert(*ait);
358 }
359 }
360
361 for(LoadsToPointsToMap::const_iterator it = loadsToPointsToMap.begin(), eit = loadsToPointsToMap.end(); it!=eit; ++it)
362 {
364 const FunObjVar* fun = getFunction(it->first);
365 const NodeBS& loadCPts = it->second;
367 for(MRSet::iterator ait = aliasMRs.begin(), eait = aliasMRs.end(); ait!=eait; ++ait)
368 {
369 loadsToMRsMap[it->first].insert(*ait);
370 }
371 }
372
374 for(CallSiteToPointsToMap::const_iterator it = callsiteToModPointsToMap.begin(),
375 eit = callsiteToModPointsToMap.end(); it!=eit; ++it)
376 {
377 const FunObjVar* fun = it->first->getCaller();
379 const NodeBS& callsiteModCPts = it->second;
381 for(MRSet::iterator ait = aliasMRs.begin(), eait = aliasMRs.end(); ait!=eait; ++ait)
382 {
383 callsiteToModMRsMap[it->first].insert(*ait);
384 }
385 }
386 for(CallSiteToPointsToMap::const_iterator it = callsiteToRefPointsToMap.begin(),
387 eit = callsiteToRefPointsToMap.end(); it!=eit; ++it)
388 {
389 const FunObjVar* fun = it->first->getCaller();
391 const NodeBS& callsiteRefCPts = it->second;
393 for(MRSet::iterator ait = aliasMRs.begin(), eait = aliasMRs.end(); ait!=eait; ++ait)
394 {
395 callsiteToRefMRsMap[it->first].insert(*ait);
396 }
397 }
398}
virtual void getAliasMemRegions(MRSet &aliasMRs, const NodeBS &cpts, const FunObjVar *fun)
Get all aliased mem regions from function fun according to cpts.
Definition MemRegion.h:307
const FunObjVar * getFunction(const PAGEdge *pagEdge) const
Get the function which SVFIR Edge located.
Definition MemRegion.h:433
virtual void getMRsForCallSiteRef(MRSet &aliasMRs, const NodeBS &cpts, const FunObjVar *)
Get memory regions for call site ref according to cpts.
Definition MemRegion.h:324
virtual void getMRsForLoad(MRSet &aliasMRs, const NodeBS &cpts, const FunObjVar *)
Get memory regions for a load statement according to cpts.
Definition MemRegion.h:317

Member Data Documentation

◆ allGlobals

NodeBS SVF::MRGenerator::allGlobals
private

All global variable SVFIR node ids.

Definition at line 243 of file MemRegion.h.

◆ cachedPtsChainMap

NodeToPTSSMap SVF::MRGenerator::cachedPtsChainMap
private

Map a pointer to its cached points-to chain;.

Definition at line 240 of file MemRegion.h.

◆ callGraph

CallGraph* SVF::MRGenerator::callGraph
private

Definition at line 199 of file MemRegion.h.

◆ callGraphSCC

SCC* SVF::MRGenerator::callGraphSCC
private

Definition at line 198 of file MemRegion.h.

◆ callsiteToModMRsMap

CallSiteToMRsMap SVF::MRGenerator::callsiteToModMRsMap
private

Map a callsite to its mods regions.

Definition at line 211 of file MemRegion.h.

◆ callsiteToModPointsToMap

CallSiteToPointsToMap SVF::MRGenerator::callsiteToModPointsToMap
private

Map a callsite to it mods cpts set.

Definition at line 219 of file MemRegion.h.

◆ callsiteToRefMRsMap

CallSiteToMRsMap SVF::MRGenerator::callsiteToRefMRsMap
private

Map a callsite to its refs regions.

Definition at line 209 of file MemRegion.h.

◆ callsiteToRefPointsToMap

CallSiteToPointsToMap SVF::MRGenerator::callsiteToRefPointsToMap
private

Map a callsite to it refs cpts set.

Definition at line 217 of file MemRegion.h.

◆ cptsToRepCPtsMap

PtsToRepPtsSetMap SVF::MRGenerator::cptsToRepCPtsMap
protected

Map a condition pts to its rep conditional pts (super set points-to)

Definition at line 278 of file MemRegion.h.

◆ csToCallSiteArgsPtsMap

CallSiteToPointsToMap SVF::MRGenerator::csToCallSiteArgsPtsMap
private

Map a callsite to all its object might pass into its callees.

Definition at line 235 of file MemRegion.h.

◆ csToCallSiteRetPtsMap

CallSiteToPointsToMap SVF::MRGenerator::csToCallSiteRetPtsMap
private

Map a callsite to all its object might return from its callees.

Definition at line 237 of file MemRegion.h.

◆ csToModsMap

CallSiteToPointsToMap SVF::MRGenerator::csToModsMap
private

Map a callsite to its indirect defs of memory objects.

Definition at line 233 of file MemRegion.h.

◆ csToRefsMap

CallSiteToPointsToMap SVF::MRGenerator::csToRefsMap
private

Map a callsite to its indirect uses of memory objects.

Definition at line 231 of file MemRegion.h.

◆ funToModsMap

FunToPointsToMap SVF::MRGenerator::funToModsMap
private

Map a function to its indirect defs of memory objects.

Definition at line 229 of file MemRegion.h.

◆ funToMRsMap

FunToMRsMap SVF::MRGenerator::funToMRsMap
private

Map a function to all its memory regions.

Definition at line 203 of file MemRegion.h.

◆ funToPointsToMap

FunToPointsTosMap SVF::MRGenerator::funToPointsToMap
private

Map a function to all of its conditional points-to sets.

Definition at line 222 of file MemRegion.h.

◆ funToRefsMap

FunToPointsToMap SVF::MRGenerator::funToRefsMap
private

Map a function to its indirect uses of memory objects.

Definition at line 227 of file MemRegion.h.

◆ loadsToMRsMap

LoadsToMRsMap SVF::MRGenerator::loadsToMRsMap
private

Map a load SVFIR Edge to its memory regions sets in order for inserting mus in Memory SSA.

Definition at line 205 of file MemRegion.h.

◆ loadsToPointsToMap

LoadsToPointsToMap SVF::MRGenerator::loadsToPointsToMap
private

Map a load SVFIR Edge to its CPts set map.

Definition at line 213 of file MemRegion.h.

◆ memRegSet

MRSet SVF::MRGenerator::memRegSet
protected

A set of All memory regions.

Definition at line 276 of file MemRegion.h.

◆ pagEdgeToFunMap

PAGEdgeToFunMap SVF::MRGenerator::pagEdgeToFunMap
private

Map a PAGEdge to its fun.

Definition at line 224 of file MemRegion.h.

◆ pta

BVDataPTAImpl* SVF::MRGenerator::pta
private

Definition at line 197 of file MemRegion.h.

◆ ptrOnlyMSSA

bool SVF::MRGenerator::ptrOnlyMSSA
private

Definition at line 200 of file MemRegion.h.

◆ storesToMRsMap

StoresToMRsMap SVF::MRGenerator::storesToMRsMap
private

Map a store SVFIR Edge to its memory regions sets in order for inserting chis in Memory SSA.

Definition at line 207 of file MemRegion.h.

◆ storesToPointsToMap

StoresToPointsToMap SVF::MRGenerator::storesToPointsToMap
private

Map a store SVFIR Edge to its CPts set map.

Definition at line 215 of file MemRegion.h.


The documentation for this class was generated from the following files: