Static Value-Flow Analysis
Loading...
Searching...
No Matches
Public Types | Public Member Functions | Static Public Member Functions | List of all members
SVF::CondPTAImpl< Cond > Class Template Referenceabstract

#include <PointerAnalysisImpl.h>

Inheritance diagram for SVF::CondPTAImpl< Cond >:
SVF::PointerAnalysis

Public Types

typedef CondVar< CondCVar
 
typedef CondStdSet< CVarCPtSet
 
typedef PTData< CVar, Set< CVar >, CVar, CPtSetPTDataTy
 
typedef MutablePTData< CVar, Set< CVar >, CVar, CPtSetMutPTDataTy
 
typedef Map< NodeID, PointsToPtrToBVPtsMap
 
typedef Map< NodeID, NodeSetPtrToNSMap
 map a pointer to its BitVector points-to representation
 
typedef Map< NodeID, CPtSetPtrToCPtsMap
 
- Public Types inherited from SVF::PointerAnalysis
enum  PTATY {
  Andersen_BASE , Andersen_WPA , AndersenSCD_WPA , AndersenSFR_WPA ,
  AndersenWaveDiff_WPA , Steensgaard_WPA , CSCallString_WPA , CSSummary_WPA ,
  FSDATAFLOW_WPA , FSSPARSE_WPA , VFS_WPA , FSCS_WPA ,
  CFLFICI_WPA , CFLFSCI_WPA , CFLFSCS_WPA , TypeCPP_WPA ,
  FieldS_DDA , FlowS_DDA , PathS_DDA , Cxt_DDA ,
  Default_PTA
}
 Pointer analysis type list. More...
 
enum  PTAImplTy { BaseImpl , BVDataImpl , CondImpl }
 Implementation type: BVDataPTAImpl or CondPTAImpl. More...
 
typedef Set< const CallICFGNode * > CallSiteSet
 Indirect call edges type, map a callsite to a set of callees.
 
typedef SVFIR::CallSiteToFunPtrMap CallSiteToFunPtrMap
 
typedef Set< const FunObjVar * > FunctionSet
 
typedef OrderedMap< const CallICFGNode *, FunctionSetCallEdgeMap
 
typedef SCCDetection< CallGraph * > CallGraphSCC
 
typedef Set< const GlobalObjVar * > VTableSet
 
typedef Set< const FunObjVar * > VFunSet
 

Public Member Functions

 CondPTAImpl (SVFIR *pag, PointerAnalysis::PTATY type)
 map a pointer to its conditional points-to set
 
virtual ~CondPTAImpl ()
 Destructor.
 
void destroy ()
 Release memory.
 
PTDataTygetPTDataTy () const
 Get points-to data.
 
MutPTDataTygetMutPTDataTy () const
 
bool hasPtsMap (void) const
 
const MutPTDataTy::PtsMapgetPtsMap () const
 
- Public Member Functions inherited from SVF::PointerAnalysis
ICFGgetICFG () const
 Get ICFG.
 
u32_t getNumOfResolvedIndCallEdge () const
 Return number of resolved indirect call edges.
 
CallGraphgetCallGraph () const
 Return call graph.
 
CallGraphSCCgetCallGraphSCC () const
 Return call graph SCC.
 
 PointerAnalysis (SVFIR *pag, PTATY ty=Default_PTA, bool alias_check=true)
 Constructor.
 
PTATY getAnalysisTy () const
 Type of pointer analysis.
 
PTAImplTy getImplTy () const
 Return implementation type of the pointer analysis.
 
bool printStat ()
 Whether print statistics.
 
void disablePrintStat ()
 Whether print statistics.
 
CallEdgeMapgetIndCallMap ()
 Get callees from an indirect callsite.
 
bool hasIndCSCallees (const CallICFGNode *cs) const
 
const FunctionSetgetIndCSCallees (const CallICFGNode *cs) const
 
virtual void resolveIndCalls (const CallICFGNode *cs, const PointsTo &target, CallEdgeMap &newEdges)
 Resolve indirect call edges.
 
void callGraphSCCDetection ()
 PTACallGraph SCC related methods.
 
NodeID getCallGraphSCCRepNode (NodeID id) const
 Get SCC rep node of a SVFG node.
 
bool inSameCallGraphSCC (const FunObjVar *fun1, const FunObjVar *fun2)
 Return TRUE if this edge is inside a PTACallGraph SCC, i.e., src node and dst node are in the same SCC on the SVFG.
 
bool isInRecursion (const FunObjVar *fun) const
 
bool isLocalVarInRecursiveFun (NodeID id) const
 Whether a local variable is in function recursions.
 
virtual const std::string PTAName () const
 Return PTA name.
 
CommonCHGraphgetCHGraph () const
 get CHGraph
 
void getVFnsFromCHA (const CallICFGNode *cs, VFunSet &vfns)
 
void getVFnsFromPts (const CallICFGNode *cs, const PointsTo &target, VFunSet &vfns)
 
void connectVCallToVFns (const CallICFGNode *cs, const VFunSet &vfns, CallEdgeMap &newEdges)
 
virtual void resolveCPPIndCalls (const CallICFGNode *cs, const PointsTo &target, CallEdgeMap &newEdges)
 Resolve cpp indirect call edges.
 
SVFIRgetPAG () const
 
PTAStatgetStat () const
 Get PTA stat.
 
OrderedNodeSetgetAllValidPtrs ()
 Get all Valid Pointers for resolution.
 
virtual void initialize ()
 Initialization of a pointer analysis, including building symbol table and SVFIR etc.
 
virtual void analyze ()=0
 Start Analysis here (main part of pointer analysis). It needs to be implemented in child class.
 
virtual void computeDDAPts (NodeID)
 Compute points-to results on-demand, overridden by derived classes.
 
void printIndCSTargets (const CallICFGNode *cs, const FunctionSet &targets)
 Print targets of a function pointer.
 
virtual void dumpAllPts ()
 
virtual void dumpPts (NodeID ptr, const PointsTo &pts)
 
void printIndCSTargets ()
 
void dumpAllTypes ()
 
void dumpStat ()
 Dump the statistics.
 
bool containBlackHoleNode (const PointsTo &pts)
 Determine whether a points-to contains a black hole or constant node.
 
bool containConstantNode (const PointsTo &pts)
 
virtual bool isBlkObjOrConstantObj (NodeID ptd) const
 
bool isHeapMemObj (NodeID id) const
 Whether this object is heap or array.
 
bool isArrayMemObj (NodeID id) const
 
bool isFIObjNode (NodeID id) const
 
NodeID getBaseObjVar (NodeID id)
 
NodeID getFIObjVar (NodeID id)
 
NodeID getGepObjVar (NodeID id, const APOffset &ap)
 
virtual const NodeBSgetAllFieldsObjVars (NodeID id)
 
void setObjFieldInsensitive (NodeID id)
 
bool isFieldInsensitive (NodeID id) const
 

Static Public Member Functions

static bool classof (const PointerAnalysis *pta)
 
PTDataTyptD
 Points-to data.
 
bool normalized
 Normalized flag.
 
PtrToBVPtsMap ptrToBVPtsMap
 Normal points-to representation (without conditions)
 
PtrToNSMap objToNSRevPtsMap
 Normal points-to representation (without conditions)
 
PtrToCPtsMap ptrToCPtsMap
 Conditional points-to representation (with conditions)
 
virtual const CPtSetgetPts (CVar id)
 
virtual const Set< CVar > & getRevPts (CVar nodeId)
 
virtual void clearPts ()
 Clear all data.
 
bool overlap (const CPtSet &cpts1, const CPtSet &cpts2) const
 Whether cpts1 and cpts2 have overlap points-to targets.
 
void expandFIObjs (const CPtSet &cpts, CPtSet &expandedCpts)
 Expand all fields of an aggregate in all points-to sets.
 
virtual void dumpCPts ()
 Print out conditional pts.
 
virtual PointsTo getBVPointsTo (const CPtSet &cpts) const
 Given a conditional pts return its bit vector points-to.
 
virtual PointsTogetPts (NodeID ptr)
 Given a pointer return its bit vector points-to.
 
virtual const CPtSetgetCondPointsTo (NodeID ptr)
 Given a pointer return its conditional points-to.
 
virtual NodeSetgetRevPts (NodeID obj)
 Given an object return all pointers points to this object.
 
virtual AliasResult alias (const SVFVar *V1, const SVFVar *V2)
 Interface expose to users of our pointer analysis, given Value infos.
 
virtual AliasResult alias (NodeID node1, NodeID node2)
 Interface expose to users of our pointer analysis, given two pointers.
 
virtual AliasResult alias (const CVar &var1, const CVar &var2)
 Interface expose to users of our pointer analysis, given conditional variables.
 
virtual AliasResult alias (const CPtSet &pts1, const CPtSet &pts2)
 Interface expose to users of our pointer analysis, given two conditional points-to sets.
 
bool containBlackHoleNode (const CPtSet &cpts)
 Test blk node for cpts.
 
bool containConstantNode (const CPtSet &cpts)
 Test constant node for cpts.
 
virtual bool isCondCompatible (const Cond &cxt1, const Cond &cxt2, bool singleton) const =0
 Whether two conditions are compatible (to be implemented by child class)
 
void dumpTopLevelPtsTo ()
 Dump points-to information of top-level pointers.
 
virtual void finalize ()
 Finalization of pointer analysis, and normalize points-to information to Bit Vector representation.
 
virtual bool unionPts (CVar id, const CPtSet &target)
 
virtual bool unionPts (CVar id, CVar ptd)
 
virtual bool addPts (CVar id, CVar ptd)
 
bool mustAlias (const CVar &var1, const CVar &var2)
 Internal interface to be used for conditional points-to set queries.
 
bool contains (const CPtSet &cpts1, const CPtSet &cpts2)
 
bool isSameVar (const CVar &var1, const CVar &var2) const
 Whether two pointers/objects are the same one by considering their conditions.
 
virtual void normalizePointsTo ()
 Normalize points-to information to BitVector/conditional representation.
 

Additional Inherited Members

- Static Public Attributes inherited from SVF::PointerAnalysis
static const std::string aliasTestMayAlias = "MAYALIAS"
 
static const std::string aliasTestMayAliasMangled = "_Z8MAYALIASPvS_"
 
static const std::string aliasTestNoAlias = "NOALIAS"
 
static const std::string aliasTestNoAliasMangled = "_Z7NOALIASPvS_"
 
static const std::string aliasTestPartialAlias = "PARTIALALIAS"
 
static const std::string aliasTestPartialAliasMangled = "_Z12PARTIALALIASPvS_"
 
static const std::string aliasTestMustAlias = "MUSTALIAS"
 
static const std::string aliasTestMustAliasMangled = "_Z9MUSTALIASPvS_"
 
static const std::string aliasTestFailMayAlias = "EXPECTEDFAIL_MAYALIAS"
 
static const std::string aliasTestFailMayAliasMangled = "_Z21EXPECTEDFAIL_MAYALIASPvS_"
 
static const std::string aliasTestFailNoAlias = "EXPECTEDFAIL_NOALIAS"
 
static const std::string aliasTestFailNoAliasMangled = "_Z20EXPECTEDFAIL_NOALIASPvS_"
 
- Protected Member Functions inherited from SVF::PointerAnalysis
const CallSiteToFunPtrMapgetIndirectCallsites () const
 Return all indirect callsites.
 
NodeID getFunPtr (const CallICFGNode *cs) const
 Return function pointer PAGNode at a callsite cs.
 
virtual void validateTests ()
 Alias check functions to verify correctness of pointer analysis.
 
virtual void validateSuccessTests (std::string fun)
 
virtual void validateExpectedFailureTests (std::string fun)
 
void resetObjFieldSensitive ()
 Reset all object node as field-sensitive.
 
- Protected Attributes inherited from SVF::PointerAnalysis
bool print_stat
 User input flags.
 
bool alias_validation
 Flag for validating points-to/alias results.
 
u32_t OnTheFlyIterBudgetForStat
 Flag for iteration budget for on-the-fly statistics.
 
PTATY ptaTy
 Pointer analysis Type.
 
PTAImplTy ptaImplTy
 PTA implementation type.
 
PTAStatstat
 Statistics.
 
CallGraphcallgraph
 Call graph used for pointer analysis.
 
CallGraphSCCcallGraphSCC
 SCC for PTACallGraph.
 
ICFGicfg
 Interprocedural control-flow graph.
 
CommonCHGraphchgraph
 CHGraph.
 
- Static Protected Attributes inherited from SVF::PointerAnalysis
static SVFIRpag = nullptr
 SVFIR.
 

Detailed Description

template<class Cond>
class SVF::CondPTAImpl< Cond >

Pointer analysis implementation which uses conditional points-to map data structure (context/path sensitive analysis)

Definition at line 247 of file PointerAnalysisImpl.h.

Member Typedef Documentation

◆ CPtSet

Definition at line 252 of file PointerAnalysisImpl.h.

◆ CVar

Definition at line 251 of file PointerAnalysisImpl.h.

◆ MutPTDataTy

Definition at line 254 of file PointerAnalysisImpl.h.

◆ PTDataTy

Definition at line 253 of file PointerAnalysisImpl.h.

◆ PtrToBVPtsMap

template<class Cond >
typedef Map<NodeID,PointsTo> SVF::CondPTAImpl< Cond >::PtrToBVPtsMap

Definition at line 255 of file PointerAnalysisImpl.h.

◆ PtrToCPtsMap

template<class Cond >
typedef Map<NodeID,CPtSet> SVF::CondPTAImpl< Cond >::PtrToCPtsMap

Definition at line 257 of file PointerAnalysisImpl.h.

◆ PtrToNSMap

template<class Cond >
typedef Map<NodeID, NodeSet> SVF::CondPTAImpl< Cond >::PtrToNSMap

map a pointer to its BitVector points-to representation

Definition at line 256 of file PointerAnalysisImpl.h.

Constructor & Destructor Documentation

◆ CondPTAImpl()

template<class Cond >
SVF::CondPTAImpl< Cond >::CondPTAImpl ( SVFIR pag,
PointerAnalysis::PTATY  type 
)
inline

map a pointer to its conditional points-to set

Constructor

Definition at line 260 of file PointerAnalysisImpl.h.

261 {
262 if (type == PathS_DDA || type == Cxt_DDA)
263 ptD = new MutPTDataTy();
264 else
265 assert(false && "no points-to data available");
266
268 }
newitem type
Definition cJSON.cpp:2739
bool normalized
Normalized flag.
MutablePTData< CVar, Set< CVar >, CVar, CPtSet > MutPTDataTy
PTDataTy * ptD
Points-to data.
@ Cxt_DDA
context sensitive DDA
@ PathS_DDA
Guarded value-flow DDA.
PointerAnalysis(SVFIR *pag, PTATY ty=Default_PTA, bool alias_check=true)
Constructor.
PTAImplTy ptaImplTy
PTA implementation type.
@ CondImpl
Represents CondPTAImpl.
static SVFIR * pag
SVFIR.
llvm::IRBuilder IRBuilder
Definition BasicTypes.h:74

◆ ~CondPTAImpl()

template<class Cond >
virtual SVF::CondPTAImpl< Cond >::~CondPTAImpl ( )
inlinevirtual

Destructor.

Definition at line 271 of file PointerAnalysisImpl.h.

272 {
273 destroy();
274 }
void destroy()
Release memory.

Member Function Documentation

◆ addPts()

template<class Cond >
virtual bool SVF::CondPTAImpl< Cond >::addPts ( CVar  id,
CVar  ptd 
)
inlineprotectedvirtual

Definition at line 384 of file PointerAnalysisImpl.h.

385 {
386 return ptD->addPts(id,ptd);
387 }

◆ alias() [1/4]

template<class Cond >
virtual AliasResult SVF::CondPTAImpl< Cond >::alias ( const CPtSet pts1,
const CPtSet pts2 
)
inlinevirtual

Interface expose to users of our pointer analysis, given two conditional points-to sets.

Definition at line 522 of file PointerAnalysisImpl.h.

523 {
530 else if(this->getAnalysisTy()==PathS_DDA && contains(cpts1,cpts2) && contains(cpts2,cpts1))
531 {
533 }
534 else if(overlap(cpts1,cpts2))
536 else
538 }
CondStdSet< CVar > CPtSet
bool contains(const CPtSet &cpts1, const CPtSet &cpts2)
void expandFIObjs(const CPtSet &cpts, CPtSet &expandedCpts)
Expand all fields of an aggregate in all points-to sets.
bool containBlackHoleNode(const CPtSet &cpts)
Test blk node for cpts.
bool overlap(const CPtSet &cpts1, const CPtSet &cpts2) const
Whether cpts1 and cpts2 have overlap points-to targets.
PTATY getAnalysisTy() const
Type of pointer analysis.
@ MustAlias
Definition SVFType.h:544
@ MayAlias
Definition SVFType.h:543
@ NoAlias
Definition SVFType.h:542

◆ alias() [2/4]

template<class Cond >
virtual AliasResult SVF::CondPTAImpl< Cond >::alias ( const CVar var1,
const CVar var2 
)
inlinevirtual

Interface expose to users of our pointer analysis, given conditional variables.

Definition at line 517 of file PointerAnalysisImpl.h.

518 {
519 return alias(getPts(var1),getPts(var2));
520 }
virtual AliasResult alias(const SVFVar *V1, const SVFVar *V2)
Interface expose to users of our pointer analysis, given Value infos.
virtual const CPtSet & getPts(CVar id)

◆ alias() [3/4]

template<class Cond >
virtual AliasResult SVF::CondPTAImpl< Cond >::alias ( const SVFVar V1,
const SVFVar V2 
)
inlinevirtual

Interface expose to users of our pointer analysis, given Value infos.

Implements SVF::PointerAnalysis.

Definition at line 507 of file PointerAnalysisImpl.h.

508 {
509 return alias(V1->getId(), V2->getId());
510 }

◆ alias() [4/4]

template<class Cond >
virtual AliasResult SVF::CondPTAImpl< Cond >::alias ( NodeID  node1,
NodeID  node2 
)
inlinevirtual

Interface expose to users of our pointer analysis, given two pointers.

Implements SVF::PointerAnalysis.

Definition at line 512 of file PointerAnalysisImpl.h.

513 {
515 }
virtual const CPtSet & getCondPointsTo(NodeID ptr)
Given a pointer return its conditional points-to.

◆ classof()

template<class Cond >
static bool SVF::CondPTAImpl< Cond >::classof ( const PointerAnalysis pta)
inlinestatic

Definition at line 276 of file PointerAnalysisImpl.h.

277 {
278 return pta->getImplTy() == CondImpl;
279 }

◆ clearPts()

template<class Cond >
virtual void SVF::CondPTAImpl< Cond >::clearPts ( )
inlinevirtual

Clear all data.

Definition at line 326 of file PointerAnalysisImpl.h.

327 {
328 ptD->clear();
329 }

◆ containBlackHoleNode()

template<class Cond >
bool SVF::CondPTAImpl< Cond >::containBlackHoleNode ( const CPtSet cpts)
inline

Test blk node for cpts.

Definition at line 540 of file PointerAnalysisImpl.h.

541 {
542 for(typename CPtSet::const_iterator cit = cpts.begin(), ecit=cpts.end(); cit!=ecit; ++cit)
543 {
544 if(cit->get_id() == pag->getBlackHoleNode())
545 return true;
546 }
547 return false;
548 }
OrderedSet< Element >::const_iterator const_iterator
NodeID getBlackHoleNode() const
Definition IRGraph.h:247

◆ containConstantNode()

template<class Cond >
bool SVF::CondPTAImpl< Cond >::containConstantNode ( const CPtSet cpts)
inline

Test constant node for cpts.

Definition at line 550 of file PointerAnalysisImpl.h.

551 {
552 for(typename CPtSet::const_iterator cit = cpts.begin(), ecit=cpts.end(); cit!=ecit; ++cit)
553 {
554 if(cit->get_id() == pag->getConstantNode())
555 return true;
556 }
557 return false;
558 }
NodeID getConstantNode() const
Definition IRGraph.h:251

◆ contains()

template<class Cond >
bool SVF::CondPTAImpl< Cond >::contains ( const CPtSet cpts1,
const CPtSet cpts2 
)
inlineprotected

Definition at line 407 of file PointerAnalysisImpl.h.

408 {
409 if (cpts1.empty() || cpts2.empty())
410 return false;
411
412 for (typename CPtSet::const_iterator it2 = cpts2.begin(); it2 != cpts2.end(); ++it2)
413 {
414 bool hasObj = false;
415 for (typename CPtSet::const_iterator it1 = cpts1.begin(); it1 != cpts1.end(); ++it1)
416 {
417 if(isSameVar(*it1,*it2))
418 {
419 hasObj = true;
420 break;
421 }
422 }
423 if(hasObj == false)
424 return false;
425 }
426 return true;
427 }
bool isSameVar(const CVar &var1, const CVar &var2) const
Whether two pointers/objects are the same one by considering their conditions.

◆ destroy()

template<class Cond >
void SVF::CondPTAImpl< Cond >::destroy ( )
inline

Release memory.

Definition at line 282 of file PointerAnalysisImpl.h.

283 {
284 delete ptD;
285 ptD = nullptr;
286 }

◆ dumpCPts()

template<class Cond >
virtual void SVF::CondPTAImpl< Cond >::dumpCPts ( )
inlinevirtual

Print out conditional pts.

Reimplemented from SVF::PointerAnalysis.

Definition at line 475 of file PointerAnalysisImpl.h.

476 {
477 ptD->dumpPTData();
478 }

◆ dumpTopLevelPtsTo()

template<class Cond >
void SVF::CondPTAImpl< Cond >::dumpTopLevelPtsTo ( )
inlinevirtual

Dump points-to information of top-level pointers.

Reimplemented from SVF::PointerAnalysis.

Definition at line 563 of file PointerAnalysisImpl.h.

564 {
565 for (OrderedNodeSet::iterator nIter = this->getAllValidPtrs().begin(); nIter != this->getAllValidPtrs().end(); ++nIter)
566 {
567 const PAGNode* node = this->getPAG()->getGNode(*nIter);
568 if (this->getPAG()->isValidTopLevelPtr(node))
569 {
570 if (SVFUtil::isa<DummyObjVar>(node))
571 {
572 SVFUtil::outs() << "##<Blackhole or constant> id:" << node->getId();
573 }
574 else if (!SVFUtil::isa<DummyValVar>(node))
575 {
576 SVFUtil::outs() << "##<" << node->toString() << "> ";
577 //SVFUtil::outs() << "Source Loc: " << SVFUtil::getSourceLoc(node->getValue());
578 }
579
580 const PointsTo& pts = getPts(node->getId());
581 SVFUtil::outs() << "\nNodeID " << node->getId() << " ";
582 if (pts.empty())
583 {
584 SVFUtil::outs() << "\t\tPointsTo: {empty}\n\n";
585 }
586 else
587 {
588 SVFUtil::outs() << "\t\tPointsTo: { ";
589 for (PointsTo::iterator it = pts.begin(), eit = pts.end(); it != eit; ++it)
590 SVFUtil::outs() << *it << " ";
591 SVFUtil::outs() << "}\n\n";
592 }
593 }
594 }
595
596 SVFUtil::outs().flush();
597 }
NodeType * getGNode(NodeID id) const
Get a node.
SVFIR * getPAG() const
OrderedNodeSet & getAllValidPtrs()
Get all Valid Pointers for resolution.
const_iterator iterator
Definition PointsTo.h:40
NodeID getId() const
Get ID.
Definition SVFValue.h:158
std::ostream & outs()
Overwrite llvm::outs()
Definition SVFUtil.h:52
SVFVar PAGNode
Definition IRGraph.h:42

◆ expandFIObjs()

template<class Cond >
void SVF::CondPTAImpl< Cond >::expandFIObjs ( const CPtSet cpts,
CPtSet expandedCpts 
)
inline

Expand all fields of an aggregate in all points-to sets.

Definition at line 346 of file PointerAnalysisImpl.h.

347 {
348 expandedCpts = cpts;;
349 for(typename CPtSet::const_iterator cit = cpts.begin(), ecit=cpts.end(); cit!=ecit; ++cit)
350 {
351 if(pag->getBaseObjVar(cit->get_id())==cit->get_id())
352 {
353 NodeBS& fields = pag->getAllFieldsObjVars(cit->get_id());
354 for(NodeBS::iterator it = fields.begin(), eit = fields.end(); it!=eit; ++it)
355 {
356 CVar cvar(cit->get_cond(),*it);
357 expandedCpts.set(cvar);
358 }
359 }
360 }
361 }
NodeID getBaseObjVar(NodeID id) const
Base and Offset methods for Value and Object node.
Definition SVFIR.h:479
NodeBS & getAllFieldsObjVars(const BaseObjVar *obj)
Get all fields of an object.
Definition SVFIR.cpp:483
SparseBitVectorIterator iterator
SparseBitVector NodeBS
Definition GeneralType.h:62

◆ finalize()

template<class Cond >
virtual void SVF::CondPTAImpl< Cond >::finalize ( )
inlineprotectedvirtual

Finalization of pointer analysis, and normalize points-to information to Bit Vector representation.

Reimplemented from SVF::PointerAnalysis.

Reimplemented in SVF::ContextDDA.

Definition at line 366 of file PointerAnalysisImpl.h.

367 {
370 }
virtual void normalizePointsTo()
Normalize points-to information to BitVector/conditional representation.
virtual void finalize()
Finalization of a pointer analysis, including checking alias correctness.

◆ getBVPointsTo()

template<class Cond >
virtual PointsTo SVF::CondPTAImpl< Cond >::getBVPointsTo ( const CPtSet cpts) const
inlinevirtual

Given a conditional pts return its bit vector points-to.

Definition at line 480 of file PointerAnalysisImpl.h.

481 {
482 PointsTo pts;
483 for(typename CPtSet::const_iterator cit = cpts.begin(), ecit=cpts.end(); cit!=ecit; ++cit)
484 pts.set(cit->get_id());
485 return pts;
486 }

◆ getCondPointsTo()

template<class Cond >
virtual const CPtSet & SVF::CondPTAImpl< Cond >::getCondPointsTo ( NodeID  ptr)
inlinevirtual

Given a pointer return its conditional points-to.

Definition at line 494 of file PointerAnalysisImpl.h.

495 {
496 assert(normalized && "Pts of all context-vars have to be merged/normalized. Want to use getPts(CVar cvar)??");
497 return ptrToCPtsMap[ptr];
498 }
PtrToCPtsMap ptrToCPtsMap
Conditional points-to representation (with conditions)

◆ getMutPTDataTy()

template<class Cond >
MutPTDataTy * SVF::CondPTAImpl< Cond >::getMutPTDataTy ( ) const
inline

Definition at line 294 of file PointerAnalysisImpl.h.

295 {
296 MutPTDataTy* mut = SVFUtil::dyn_cast<MutPTDataTy>(ptD);
297 assert(mut && "BVDataPTAImpl::getMutPTDataTy: not a MutPTDataTy!");
298 return mut;
299 }

◆ getPTDataTy()

template<class Cond >
PTDataTy * SVF::CondPTAImpl< Cond >::getPTDataTy ( ) const
inline

Get points-to data.

Definition at line 289 of file PointerAnalysisImpl.h.

290 {
291 return ptD;
292 }

◆ getPts() [1/2]

template<class Cond >
virtual const CPtSet & SVF::CondPTAImpl< Cond >::getPts ( CVar  id)
inlinevirtual

Get points-to and reverse points-to

Definition at line 315 of file PointerAnalysisImpl.h.

316 {
317 return ptD->getPts(id);
318 }

◆ getPts() [2/2]

template<class Cond >
virtual PointsTo & SVF::CondPTAImpl< Cond >::getPts ( NodeID  ptr)
inlinevirtual

Given a pointer return its bit vector points-to.

Implements SVF::PointerAnalysis.

Definition at line 488 of file PointerAnalysisImpl.h.

489 {
490 assert(normalized && "Pts of all context-var have to be merged/normalized. Want to use getPts(CVar cvar)??");
491 return ptrToBVPtsMap[ptr];
492 }
PtrToBVPtsMap ptrToBVPtsMap
Normal points-to representation (without conditions)

◆ getPtsMap()

template<class Cond >
const MutPTDataTy::PtsMap & SVF::CondPTAImpl< Cond >::getPtsMap ( ) const
inline

Definition at line 306 of file PointerAnalysisImpl.h.

307 {
308 if (MutPTDataTy *m = SVFUtil::dyn_cast<MutPTDataTy>(ptD)) return m->getPtsMap();
309 assert(false && "CondPTAImpl::getPtsMap: not a PTData with a PtsMap!");
310 exit(1);
311 }

◆ getRevPts() [1/2]

template<class Cond >
virtual const Set< CVar > & SVF::CondPTAImpl< Cond >::getRevPts ( CVar  nodeId)
inlinevirtual

Definition at line 319 of file PointerAnalysisImpl.h.

320 {
321 return ptD->getRevPts(nodeId);
322 }

◆ getRevPts() [2/2]

template<class Cond >
virtual NodeSet & SVF::CondPTAImpl< Cond >::getRevPts ( NodeID  obj)
inlinevirtual

Given an object return all pointers points to this object.

Implements SVF::PointerAnalysis.

Definition at line 500 of file PointerAnalysisImpl.h.

501 {
502 assert(normalized && "Pts of all context-var have to be merged/normalized. Want to use getPts(CVar cvar)??");
503 return objToNSRevPtsMap[obj];
504 }
PtrToNSMap objToNSRevPtsMap
Normal points-to representation (without conditions)

◆ hasPtsMap()

template<class Cond >
bool SVF::CondPTAImpl< Cond >::hasPtsMap ( void  ) const
inline

Definition at line 301 of file PointerAnalysisImpl.h.

302 {
303 return SVFUtil::isa<MutPTDataTy>(ptD);
304 }

◆ isCondCompatible()

template<class Cond >
virtual bool SVF::CondPTAImpl< Cond >::isCondCompatible ( const Cond cxt1,
const Cond cxt2,
bool  singleton 
) const
pure virtual

Whether two conditions are compatible (to be implemented by child class)

Implemented in SVF::ContextDDA.

◆ isSameVar()

template<class Cond >
bool SVF::CondPTAImpl< Cond >::isSameVar ( const CVar var1,
const CVar var2 
) const
inlineprotected

Whether two pointers/objects are the same one by considering their conditions.

we distinguish context sensitive memory allocation here

Definition at line 430 of file PointerAnalysisImpl.h.

431 {
432 if(var1.get_id() != var2.get_id())
433 return false;
434
436 bool singleton = !(isHeapMemObj(var1.get_id()) || isLocalVarInRecursiveFun(var1.get_id()));
437 return isCondCompatible(var1.get_cond(),var2.get_cond(),singleton);
438 }
virtual bool isCondCompatible(const Cond &cxt1, const Cond &cxt2, bool singleton) const =0
Whether two conditions are compatible (to be implemented by child class)
bool isLocalVarInRecursiveFun(NodeID id) const
Whether a local variable is in function recursions.
bool isHeapMemObj(NodeID id) const
Whether this object is heap or array.

◆ mustAlias()

template<class Cond >
bool SVF::CondPTAImpl< Cond >::mustAlias ( const CVar var1,
const CVar var2 
)
inlineprotected

Internal interface to be used for conditional points-to set queries.

Definition at line 392 of file PointerAnalysisImpl.h.

393 {
394 if(isSameVar(var1,var2))
395 return true;
396
397 bool singleton = !(isHeapMemObj(var1.get_id()) || isLocalVarInRecursiveFun(var1.get_id()));
398 if(isCondCompatible(var1.get_cond(),var2.get_cond(),singleton) == false)
399 return false;
400
401 const CPtSet& cpts1 = getPts(var1);
402 const CPtSet& cpts2 = getPts(var2);
403 return (contains(cpts1,cpts2) && contains(cpts2,cpts1));
404 }

◆ normalizePointsTo()

template<class Cond >
virtual void SVF::CondPTAImpl< Cond >::normalizePointsTo ( )
inlineprotectedvirtual

Normalize points-to information to BitVector/conditional representation.

Definition at line 442 of file PointerAnalysisImpl.h.

443 {
444 normalized = true;
445 if (hasPtsMap())
446 {
447 const typename MutPTDataTy::PtsMap& ptsMap = getPtsMap();
448 for(typename MutPTDataTy::PtsMap::const_iterator it = ptsMap.begin(), eit=ptsMap.end(); it!=eit; ++it)
449 {
450 for(typename CPtSet::const_iterator cit = it->second.begin(), ecit=it->second.end(); cit!=ecit; ++cit)
451 {
452 ptrToBVPtsMap[(it->first).get_id()].set(cit->get_id());
453 objToNSRevPtsMap[cit->get_id()].insert((it->first).get_id());
454 ptrToCPtsMap[(it->first).get_id()].set(*cit);
455 }
456 }
457 }
458 else
459 {
460 assert(false && "CondPTAImpl::NormalizePointsTo: could not normalize points-to sets");
461 }
462 }
bool hasPtsMap(void) const
const MutPTDataTy::PtsMap & getPtsMap() const
Map< Key, DataSet > PtsMap

◆ overlap()

template<class Cond >
bool SVF::CondPTAImpl< Cond >::overlap ( const CPtSet cpts1,
const CPtSet cpts2 
) const
inline

Whether cpts1 and cpts2 have overlap points-to targets.

Definition at line 332 of file PointerAnalysisImpl.h.

333 {
334 for (typename CPtSet::const_iterator it1 = cpts1.begin(); it1 != cpts1.end(); ++it1)
335 {
336 for (typename CPtSet::const_iterator it2 = cpts2.begin(); it2 != cpts2.end(); ++it2)
337 {
338 if(isSameVar(*it1,*it2))
339 return true;
340 }
341 }
342 return false;
343 }

◆ unionPts() [1/2]

template<class Cond >
virtual bool SVF::CondPTAImpl< Cond >::unionPts ( CVar  id,
const CPtSet target 
)
inlineprotectedvirtual

Union/add points-to, and add the reverse points-to for node collapse purpose To be noted that adding reverse pts might incur 10% total overhead during solving

Definition at line 374 of file PointerAnalysisImpl.h.

375 {
376 return ptD->unionPts(id, target);
377 }

◆ unionPts() [2/2]

template<class Cond >
virtual bool SVF::CondPTAImpl< Cond >::unionPts ( CVar  id,
CVar  ptd 
)
inlineprotectedvirtual

Definition at line 379 of file PointerAnalysisImpl.h.

380 {
381 return ptD->unionPts(id,ptd);
382 }

Member Data Documentation

◆ normalized

template<class Cond >
bool SVF::CondPTAImpl< Cond >::normalized
protected

Normalized flag.

Definition at line 466 of file PointerAnalysisImpl.h.

◆ objToNSRevPtsMap

template<class Cond >
PtrToNSMap SVF::CondPTAImpl< Cond >::objToNSRevPtsMap
protected

Normal points-to representation (without conditions)

Definition at line 470 of file PointerAnalysisImpl.h.

◆ ptD

template<class Cond >
PTDataTy* SVF::CondPTAImpl< Cond >::ptD
protected

Points-to data.

Definition at line 464 of file PointerAnalysisImpl.h.

◆ ptrToBVPtsMap

template<class Cond >
PtrToBVPtsMap SVF::CondPTAImpl< Cond >::ptrToBVPtsMap
protected

Normal points-to representation (without conditions)

Definition at line 468 of file PointerAnalysisImpl.h.

◆ ptrToCPtsMap

template<class Cond >
PtrToCPtsMap SVF::CondPTAImpl< Cond >::ptrToCPtsMap
protected

Conditional points-to representation (with conditions)

Definition at line 472 of file PointerAnalysisImpl.h.


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