Static Value-Flow Analysis
|
#include <ContextDDA.h>
Public Member Functions | |
ContextDDA (SVFIR *_pag, DDAClient *client) | |
Constructor. | |
virtual | ~ContextDDA () |
Destructor. | |
virtual void | initialize () override |
Initialization of the analysis. | |
virtual void | finalize () override |
Finalize analysis. | |
virtual void | analyze () override |
dummy analyze method | |
virtual void | computeDDAPts (NodeID id) override |
Compute points-to set for an unconditional pointer. | |
virtual const CxtPtSet & | computeDDAPts (const CxtVar &cxtVar) |
Compute points-to set for a context-sensitive pointer. | |
void | handleOutOfBudgetDpm (const CxtLocDPItem &dpm) |
Handle out-of-budget dpm. | |
virtual CxtPtSet | getConservativeCPts (const CxtLocDPItem &dpm) override |
Override parent method. | |
virtual NodeID | getPtrNodeID (const CxtVar &var) const override |
Override parent method. | |
virtual bool | handleBKCondition (CxtLocDPItem &dpm, const SVFGEdge *edge) override |
Handle condition for context or path analysis (backward analysis) | |
virtual bool | isHeapCondMemObj (const CxtVar &var, const StoreSVFGNode *store) override |
bool | testIndCallReachability (CxtLocDPItem &dpm, const FunObjVar *callee, const CallICFGNode *cs) |
refine indirect call edge | |
CallSiteID | getCSIDAtCall (CxtLocDPItem &dpm, const SVFGEdge *edge) |
get callsite id from call, return 0 if it is a spurious call edge | |
CallSiteID | getCSIDAtRet (CxtLocDPItem &dpm, const SVFGEdge *edge) |
get callsite id from return, return 0 if it is a spurious return edge | |
virtual void | popRecursiveCallSites (CxtLocDPItem &dpm) |
Pop recursive callsites. | |
virtual bool | isEdgeInRecursion (CallSiteID csId) |
Whether call/return inside recursion. | |
virtual void | updateCallGraphAndSVFG (const CxtLocDPItem &dpm, const CallICFGNode *cs, SVFGEdgeSet &svfgEdges) override |
Update call graph. | |
bool | edgeInCallGraphSCC (const SVFGEdge *edge) |
Return TRUE if this edge is inside a SVFG SCC, i.e., src node and dst node are in the same SCC on the SVFG. | |
virtual CxtPtSet | processGepPts (const GepSVFGNode *gep, const CxtPtSet &srcPts) override |
processGep node | |
virtual void | handleAddr (CxtPtSet &pts, const CxtLocDPItem &dpm, const AddrSVFGNode *addr) override |
Handle Address SVFGNode to add proper conditional points-to. | |
virtual bool | propagateViaObj (const CxtVar &storeObj, const CxtVar &loadObj) override |
Propagate along indirect value-flow if two objects of load and store are same. | |
virtual bool | isCondCompatible (const ContextCond &cxt1, const ContextCond &cxt2, bool singleton) const override |
bool | isInsensitiveCallRet (const SVFGEdge *edge) |
Whether this edge is treated context-insensitively. | |
ConstSVFGEdgeSet & | getInsensitiveEdgeSet () |
Return insensitive edge set. | |
virtual void | dumpContexts (const ContextCond &cxts) |
dump context call strings | |
virtual const std::string | PTAName () const override |
Return PTA name. | |
![]() | |
CondPTAImpl (SVFIR *pag, PointerAnalysis::PTATY type) | |
map a pointer to its conditional points-to set | |
virtual | ~CondPTAImpl () |
Destructor. | |
void | destroy () |
Release memory. | |
PTDataTy * | getPTDataTy () const |
Get points-to data. | |
MutPTDataTy * | getMutPTDataTy () const |
bool | hasPtsMap (void) const |
const MutPTDataTy::PtsMap & | getPtsMap () const |
virtual const CPtSet & | getPts (CVar id) |
virtual PointsTo & | getPts (NodeID ptr) |
Given a pointer return its bit vector points-to. | |
virtual const Set< CVar > & | getRevPts (CVar nodeId) |
virtual NodeSet & | getRevPts (NodeID obj) |
Given an object return all pointers points to this object. | |
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 const CPtSet & | getCondPointsTo (NodeID ptr) |
Given a pointer return its conditional points-to. | |
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. | |
void | dumpTopLevelPtsTo () |
Dump points-to information of top-level pointers. | |
![]() | |
ICFG * | getICFG () const |
Get ICFG. | |
u32_t | getNumOfResolvedIndCallEdge () const |
Return number of resolved indirect call edges. | |
CallGraph * | getCallGraph () const |
Return call graph. | |
CallGraphSCC * | getCallGraphSCC () 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. | |
CallEdgeMap & | getIndCallMap () |
Get callees from an indirect callsite. | |
bool | hasIndCSCallees (const CallICFGNode *cs) const |
const FunctionSet & | getIndCSCallees (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. | |
CommonCHGraph * | getCHGraph () 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. | |
SVFIR * | getPAG () const |
PTAStat * | getStat () const |
Get PTA stat. | |
OrderedNodeSet & | getAllValidPtrs () |
Get all Valid Pointers for resolution. | |
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 NodeBS & | getAllFieldsObjVars (NodeID id) |
void | setObjFieldInsensitive (NodeID id) |
bool | isFieldInsensitive (NodeID id) const |
![]() | |
DDAVFSolver () | |
Constructor. | |
virtual | ~DDAVFSolver () |
Destructor. | |
NodeBS & | getCandidateQueries () |
Return candidate pointers for DDA. | |
virtual CxtLocDPItem | getDPIm (const CxtVar &var, const SVFGNode *loc) const |
Given CVar and location (SVFGNode) return a new DPItem. | |
virtual bool | unionDDAPts (CxtPtSet &pts, const CxtPtSet &targetPts) |
Union pts. | |
virtual bool | unionDDAPts (CxtLocDPItem dpm, const CxtPtSet &targetPts) |
Union pts. | |
virtual void | addDDAPts (CxtPtSet &pts, const CxtVar &var) |
Add pts. | |
SVFG * | getSVFG () const |
Return SVFG. | |
SVFGSCC * | getSVFGSCC () const |
Return SVFGSCC. | |
void | dumpCPtSet (const CxtPtSet &cpts) const |
virtual const CxtPtSet & | findPT (const CxtLocDPItem &dpm) |
Compute points-to. | |
Private Attributes | |
ConstSVFGEdgeSet | insensitveEdges |
insensitive call-return edges | |
FlowDDA * | flowDDA |
downgrade to flowDDA if out-of-budget | |
DDAClient * | _client |
DDA client. | |
Context-, Flow- Sensitive Demand-driven Analysis
Definition at line 54 of file ContextDDA.h.
Constructor.
Constructor
Definition at line 42 of file ContextDDA.cpp.
|
virtual |
|
inlineoverridevirtual |
dummy analyze method
Implements SVF::PointerAnalysis.
Definition at line 74 of file ContextDDA.h.
Compute points-to set for a context-sensitive pointer.
Compute points-to set for a context-sensitive pointer
Definition at line 75 of file ContextDDA.cpp.
|
overridevirtual |
Compute points-to set for an unconditional pointer.
Compute points-to set for an unconditional pointer
Reimplemented from SVF::PointerAnalysis.
Definition at line 105 of file ContextDDA.cpp.
|
inlinevirtual |
Return TRUE if this edge is inside a SVFG SCC, i.e., src node and dst node are in the same SCC on the SVFG.
Definition at line 160 of file ContextDDA.h.
|
inlineoverridevirtual |
Finalize analysis.
Reimplemented from SVF::CondPTAImpl< ContextCond >.
Definition at line 68 of file ContextDDA.h.
|
inlineoverridevirtual |
Override parent method.
Implements SVF::DDAVFSolver< CxtVar, CxtPtSet, CxtLocDPItem >.
Definition at line 86 of file ContextDDA.h.
CallSiteID ContextDDA::getCSIDAtCall | ( | CxtLocDPItem & | dpm, |
const SVFGEdge * | edge | ||
) |
get callsite id from call, return 0 if it is a spurious call edge
get callsite id from call, return 0 if it is a spurious call edge translate the callsite id from pre-computed callgraph on SVFG to the one on current callgraph
Definition at line 210 of file ContextDDA.cpp.
CallSiteID ContextDDA::getCSIDAtRet | ( | CxtLocDPItem & | dpm, |
const SVFGEdge * | edge | ||
) |
get callsite id from return, return 0 if it is a spurious return edge
get callsite id from return, return 0 if it is a spurious return edge translate the callsite id from pre-computed callgraph on SVFG to the one on current callgraph
Definition at line 234 of file ContextDDA.cpp.
|
inline |
Return insensitive edge set.
Definition at line 207 of file ContextDDA.h.
Override parent method.
Implements SVF::DDAVFSolver< CxtVar, CxtPtSet, CxtLocDPItem >.
Definition at line 100 of file ContextDDA.h.
|
inlineoverridevirtual |
Handle Address SVFGNode to add proper conditional points-to.
whether this object is set field-insensitive during pre-analysis
Implements SVF::DDAVFSolver< CxtVar, CxtPtSet, CxtLocDPItem >.
Definition at line 177 of file ContextDDA.h.
|
overridevirtual |
Handle condition for context or path analysis (backward analysis)
Handle conditions during backward traversing.
we don't handle context in recursions, they treated as assignments
we don't handle context in recursions, they treated as assignments
TODO: When this call site id is contained in current call string, we may find a recursion. Try to solve this later.
Reimplemented from SVF::DDAVFSolver< CxtVar, CxtPtSet, CxtLocDPItem >.
Definition at line 256 of file ContextDDA.cpp.
void ContextDDA::handleOutOfBudgetDpm | ( | const CxtLocDPItem & | dpm | ) |
Handle out-of-budget dpm.
Handle out-of-budget dpm
Definition at line 115 of file ContextDDA.cpp.
|
overridevirtual |
Initialization of the analysis.
Analysis initialization
Reimplemented from SVF::PointerAnalysis.
Definition at line 62 of file ContextDDA.cpp.
|
inlineoverridevirtual |
Whether two call string contexts are compatible which may represent the same memory object compare with call strings from last few callsite ids (most recent ids to objects): compatible : (e.g., 123 == 123, 123 == 23). not compatible (e.g., 123 != 423)
context conditions of local(not in recursion) and global variables are compatible
Implements SVF::CondPTAImpl< ContextCond >.
Definition at line 136 of file ContextDDA.cpp.
|
inlinevirtual |
Whether call/return inside recursion.
Definition at line 134 of file ContextDDA.h.
|
overridevirtual |
we exclude concrete heap given the following conditions: (1) concrete calling context (not involved in recursion and not exceed the maximum context limit) (2) not inside loop
Reimplemented from SVF::DDAVFSolver< CxtVar, CxtPtSet, CxtLocDPItem >.
Definition at line 335 of file ContextDDA.cpp.
Whether this edge is treated context-insensitively.
Definition at line 202 of file ContextDDA.h.
|
inlinevirtual |
Pop recursive callsites.
Definition at line 123 of file ContextDDA.h.
|
overridevirtual |
processGep node
Generate field objects for structs
Implements SVF::DDAVFSolver< CxtVar, CxtPtSet, CxtLocDPItem >.
Definition at line 154 of file ContextDDA.cpp.
|
inlineoverridevirtual |
Propagate along indirect value-flow if two objects of load and store are same.
Reimplemented from SVF::DDAVFSolver< CxtVar, CxtPtSet, CxtLocDPItem >.
Definition at line 191 of file ContextDDA.h.
Return PTA name.
Reimplemented from SVF::PointerAnalysis.
Definition at line 217 of file ContextDDA.h.
bool ContextDDA::testIndCallReachability | ( | CxtLocDPItem & | dpm, |
const FunObjVar * | callee, | ||
const CallICFGNode * | cs | ||
) |
refine indirect call edge
Definition at line 189 of file ContextDDA.cpp.
|
inlineoverridevirtual |
Update call graph.
Reimplemented from SVF::DDAVFSolver< CxtVar, CxtPtSet, CxtLocDPItem >.
Definition at line 142 of file ContextDDA.h.
|
private |
DDA client.
Definition at line 225 of file ContextDDA.h.
|
private |
downgrade to flowDDA if out-of-budget
Definition at line 224 of file ContextDDA.h.
|
private |
insensitive call-return edges
Definition at line 223 of file ContextDDA.h.