37using namespace SVFUtil;
125 rawstr <<
it->second->getId() <<
", ";
142 rawstr <<
"BinaryOPVFGNode ID: " <<
getId() <<
" ";
146 rawstr <<
it->second->getId() <<
", ";
167 rawstr <<
it->second->getId() <<
", ";
218 rawstr <<
it->second->getId() <<
", ";
229 rawstr <<
"IntraPHIVFGNode ID: " <<
getId() <<
" ";
233 rawstr <<
it->second->getId() <<
", ";
260 rawstr <<
"ArgumentVFGNode ID: " <<
getId() <<
" ";
276 rawstr <<
"ActualParmVFGNode ID: " <<
getId() <<
" ";
293 rawstr <<
"FormalParmVFGNode ID: " <<
getId() <<
" ";
310 rawstr <<
"ActualRetVFGNode ID: " <<
getId() <<
" ";
328 rawstr <<
"FormalRetVFGNode ID: " <<
getId() <<
" ";
457 for (SVFStmt::SVFStmtSetTy::iterator
iter = addrs.begin(),
eiter =
465 for (SVFStmt::SVFStmtSetTy::iterator
iter =
copys.begin(),
eiter =
475 for (SVFStmt::SVFStmtSetTy::iterator
iter =
ngeps.begin(),
eiter =
483 for (SVFStmt::SVFStmtSetTy::iterator
iter =
loads.begin(),
eiter =
498 for (SVFStmt::SVFStmtSetTy::iterator
iter =
forks.begin(),
eiter =
555 if (
func->isVarArg())
590 const RetPE* retPE = SVFUtil::cast<RetPE>(*
cit);
592 retPEs.insert(retPE);
602 for (SVFStmt::SVFStmtSetTy::iterator
iter =
phis.begin(),
eiter =
638 for (SVFStmt::SVFStmtSetTy::iterator
iter =
brs.begin(),
eiter =
647 for (SVFStmt::SVFStmtSetTy::iterator
iter =
cmps.begin(),
eiter =
667 assert(
edge->isDirectVFGEdge() &&
"this should be a direct value flow edge!");
692 assert(
edge->isCallDirectVFGEdge() &&
"this should be a direct value flow edge!");
712 assert(
edge->isRetDirectVFGEdge() &&
"this should be a direct value flow edge!");
737 if(SVFUtil::isa<AddrVFGNode>(
stmtNode))
740 if (
stmtNode->getPAGSrcNode()->isConstDataOrAggDataButNotNullPtr() ==
false)
746 for (
const auto &
varType:
gepStmt->getOffsetVarAndGepTypePairVec())
754 if(SVFUtil::isa<StoreVFGNode>(
stmtNode) && (
stmtNode->getPAGDstNode()->isConstDataOrAggDataButNotNullPtr() ==
false))
764 if (
it->second->isConstDataOrAggDataButNotNullPtr() ==
false)
772 if (
it->second->isConstDataOrAggDataButNotNullPtr() ==
false)
780 if (
it->second->isConstDataOrAggDataButNotNullPtr() ==
false)
788 if (
it->second->isConstDataOrAggDataButNotNullPtr() ==
false)
800 if (
actualParm->getParam()->isConstDataOrAggDataButNotNullPtr() ==
false)
822 const CallICFGNode* callBlockNode = (*it)->getCallSite();
835 for (SVFStmt::SVFStmtSetTy::iterator
iter =
forks.begin(),
eiter =
845 for (SVFStmt::SVFStmtSetTy::iterator
iter =
joins.begin(),
eiter =
938 PointerAnalysis::CallEdgeMap::const_iterator
iter = pta->
getIndCallMap().begin();
943 assert(
newcs->isIndirectCall() &&
"this is not an indirect call?");
1012 return addr->getPAGDstNode();
1013 else if(
const CopyVFGNode*
copy = SVFUtil::dyn_cast<CopyVFGNode>(node))
1014 return copy->getPAGDstNode();
1015 else if(
const GepVFGNode*
gep = SVFUtil::dyn_cast<GepVFGNode>(node))
1016 return gep->getPAGDstNode();
1017 else if(
const LoadVFGNode* load = SVFUtil::dyn_cast<LoadVFGNode>(node))
1018 return load->getPAGDstNode();
1019 else if(
const PHIVFGNode*
phi = SVFUtil::dyn_cast<PHIVFGNode>(node))
1020 return phi->getRes();
1021 else if(
const CmpVFGNode*
cmp = SVFUtil::dyn_cast<CmpVFGNode>(node))
1022 return cmp->getRes();
1024 return bop->getRes();
1026 return uop->getRes();
1027 else if(
const ActualParmVFGNode* ap = SVFUtil::dyn_cast<ActualParmVFGNode>(node))
1028 return ap->getParam();
1030 return fp->getParam();
1032 return ar->getRev();
1034 return fr->getRet();
1038 assert(
false &&
"unexpected node kind!");
1049 return fp->getFun();
1053 if(
phi->isFormalParmPHI())
1054 return phi->getFun();
1109 return getSimpleNodeLabel(node, graph);
1111 return getCompleteNodeLabel(node, graph);
1133 rawstr << ap->toString();
1143 else if(SVFUtil::isa<NullPtrVFGNode>(node))
1155 else if(
CmpVFGNode*
cmp = SVFUtil::dyn_cast<CmpVFGNode>(node))
1164 assert(
false &&
"what else kinds of nodes do we have??");
1187 else if(
CmpVFGNode*
cmp = SVFUtil::dyn_cast<CmpVFGNode>(node))
1191 else if(
PHIVFGNode*
phi = SVFUtil::dyn_cast<PHIVFGNode>(node))
1201 rawstr << ap->toString();
1215 else if (
MRSVFGNode* mr = SVFUtil::dyn_cast<MRSVFGNode>(node))
1217 rawstr << mr->toString();
1224 assert(
false &&
"what else kinds of nodes do we have??");
1237 if (SVFUtil::isa<AddrStmt>(
edge))
1241 else if (SVFUtil::isa<CopyStmt>(
edge))
1245 else if (SVFUtil::isa<RetPE>(
edge))
1247 rawstr <<
"color=black,style=dotted";
1249 else if (SVFUtil::isa<GepStmt>(
edge))
1251 rawstr <<
"color=purple";
1253 else if (SVFUtil::isa<StoreStmt>(
edge))
1257 else if (SVFUtil::isa<LoadStmt>(
edge))
1263 assert(0 &&
"No such kind edge!!");
1267 else if (SVFUtil::isa<CmpVFGNode>(node))
1271 else if (SVFUtil::isa<BinaryOPVFGNode>(node))
1275 else if (SVFUtil::isa<UnaryOPVFGNode>(node))
1279 else if(SVFUtil::isa<PHIVFGNode>(node))
1283 else if(SVFUtil::isa<NullPtrVFGNode>(node))
1287 else if(SVFUtil::isa<FormalParmVFGNode>(node))
1289 rawstr <<
"color=yellow,penwidth=2";
1291 else if(SVFUtil::isa<ActualParmVFGNode>(node))
1293 rawstr <<
"color=yellow,penwidth=2";
1295 else if (SVFUtil::isa<ActualRetVFGNode>(node))
1297 rawstr <<
"color=yellow,penwidth=2";
1299 else if (SVFUtil::isa<FormalRetVFGNode>(node))
1301 rawstr <<
"color=yellow,penwidth=2";
1303 else if (SVFUtil::isa<MRSVFGNode>(node))
1305 rawstr <<
"color=orange,penwidth=2";
1307 else if (SVFUtil::isa<BranchVFGNode>(node))
1309 rawstr <<
"color=gold,penwidth=2";
1312 assert(
false &&
"no such kind of node!!");
1319 template<
class EdgeIter>
1324 if (SVFUtil::isa<DirectSVFGEdge>(
edge))
1326 if (SVFUtil::isa<CallDirSVFGEdge>(
edge))
1327 return "style=solid,color=red";
1328 else if (SVFUtil::isa<RetDirSVFGEdge>(
edge))
1329 return "style=solid,color=blue";
1331 return "style=solid";
1333 else if (SVFUtil::isa<IndirectSVFGEdge>(
edge))
1335 if (SVFUtil::isa<CallIndSVFGEdge>(
edge))
1336 return "style=dashed,color=red";
1337 else if (SVFUtil::isa<RetIndSVFGEdge>(
edge))
1338 return "style=dashed,color=blue";
1340 return "style=dashed";
1344 assert(
false &&
"what else edge we have?");
1349 template<
class EdgeIter>
#define DBOUT(TYPE, X)
LLVM debug macros, define type of your DBUG model of each pass.
const std::string toString() const override
const PAGNode * getParam() const
Return parameter.
const NodeBS getDefSVFVars() const override
Return the left hand side SVF Vars.
const CallICFGNode * getCallSite() const
Return callsite.
const CallICFGNode * getCallSite() const
Return callsite.
const std::string toString() const override
const NodeBS getDefSVFVars() const override
Return the left hand side SVF Vars.
const PAGNode * getRev() const
Receive parameter at callsite.
const NodeBS getDefSVFVars() const override
Return the left hand side SVF Vars.
const std::string toString() const override
const std::string toString() const override
const SVFVar * getValue() const override
Return the corresponding LLVM value, if possible, nullptr otherwise.
SVFVar * getLHSVar() const
const PAGNode * getRes() const
const NodeBS getDefSVFVars() const override
Return the left hand side SVF Vars.
const SVFVar * getValue() const override
Return the corresponding LLVM value, if possible, nullptr otherwise.
const std::string toString() const override
OPVers::const_iterator opVerBegin() const
OPVers::const_iterator opVerEnd() const
virtual const std::string toString() const override
virtual const std::string toString() const override
const NodeBS getDefSVFVars() const override
Return the left hand side SVF Vars.
const BranchStmt * brstmt
CallSiteID getCallSiteId() const
Return callsite ID.
virtual const std::string toString() const
const RetICFGNode * getRetICFGNode() const
Return callsite.
const std::string getSourceLoc() const override
OPVers::const_iterator opVerBegin() const
const std::string toString() const override
const PAGNode * getRes() const
const NodeBS getDefSVFVars() const override
Return the left hand side SVF Vars.
OPVers::const_iterator opVerEnd() const
const SVFVar * getValue() const override
Return the corresponding LLVM value, if possible, nullptr otherwise.
const NodeBS getDefSVFVars() const override
Return the left hand side SVF Vars.
const std::string toString() const override
virtual const std::string toString() const
NodeID getSrcID() const
get methods of the components
iterator begin()
Iterators.
NodeType * getGNode(NodeID id) const
Get a node.
bool hasIncomingEdge() const
Has incoming/outgoing edge set.
bool hasOutgoingEdge() const
const GEdgeSetTy & getOutEdges() const
const NodeBS getDefSVFVars() const override
Return the left hand side SVF Vars.
const std::string toString() const override
static void WriteGraphToFile(SVF::OutStream &O, const std::string &GraphName, const GraphType >, bool simple=false)
virtual const FunObjVar * getFun() const
Return the function of this ICFGNode.
NodeID getNullPtr() const
NodeID getVarargNode(const FunObjVar *func) const
getVarargNode - Return the unique node representing the variadic argument of a variadic function.
bool isFormalParmPHI() const
const std::string toString() const override
virtual const std::string toString() const
const std::string toString() const override
const std::string toString() const override
const NodeBS getDefSVFVars() const override
Return the left hand side SVF Vars.
const std::string toString() const override
const NodeBS getDefSVFVars() const override
Return the left hand side SVF Vars.
const PAGNode * getPAGNode() const
Return corresponding PAGNode.
static const Option< bool > EnableThreadCallGraph
OPVers::const_iterator opVerBegin() const
const PAGNode * getRes() const
const NodeBS getDefSVFVars() const override
Return the left hand side SVF Vars.
const std::string toString() const override
OPVers::const_iterator opVerEnd() const
PHIVFGNode(NodeID id, const PAGNode *r, VFGNodeK k=TPhi)
Constructor.
const SVFVar * getValue() const override
Return the corresponding LLVM value, if possible, nullptr otherwise.
Set< const FunObjVar * > FunctionSet
CallEdgeMap & getIndCallMap()
Get callees from an indirect callsite.
virtual const std::string toString() const
CallSiteID getCallSiteId() const
Return callsite ID.
CSToArgsListMap & getCallSiteArgsMap()
Get callsite argument list.
bool funHasRet(const FunObjVar *func) const
bool hasFunArgsList(const FunObjVar *func) const
Function has arguments list.
std::vector< const SVFVar * > SVFVarList
CSToRetMap & getCallSiteRets()
Get callsite return.
FunToRetMap & getFunRets()
Get function return list.
bool hasCallSiteArgsMap(const CallICFGNode *cs) const
Callsite has argument list.
bool callsiteHasRet(const RetICFGNode *cs) const
const SVFVarList & getCallSiteArgsList(const CallICFGNode *cs) const
Get callsite argument list.
static SVFIR * getPAG(bool buildFromFile=false)
Singleton design here to make sure we only have one instance during any analysis.
const SVFVar * getCallSiteRet(const RetICFGNode *cs) const
Get callsite return.
const SVFVarList & getFunArgsList(const FunObjVar *func) const
Get function arguments list.
const SVFVar * getFunRet(const FunObjVar *func) const
Get function return list.
FunToArgsListMap & getFunArgsMap()
Get function arguments list.
const SVFVar * getValue() const
GenericNode< SVFVar, SVFStmt >::GEdgeSetTy SVFStmtSetTy
virtual const std::string toString() const
NodeID getId() const
Get ID.
virtual const std::string & getName() const
const std::string valueOnlyToString() const
virtual bool isConstDataOrAggDataButNotNullPtr() const
Check if this variable represents constant data/metadata but not null pointer.
bool hasIncomingEdges(SVFStmt::PEDGEK kind) const
SVFStmt::SVFStmtSetTy::iterator getIncomingEdgesBegin(SVFStmt::PEDGEK kind) const
Edge iterators.
virtual const std::string toString() const
Get string representation.
SVFStmt::SVFStmtSetTy::iterator getIncomingEdgesEnd(SVFStmt::PEDGEK kind) const
NodeID getPAGDstNodeID() const
const PAGEdge * getPAGEdge() const
const SVFVar * getValue() const override
Return the corresponding LLVM value, if possible, nullptr otherwise.
const std::string toString() const override
const NodeBS getDefSVFVars() const override
Return the left hand side SVF Vars.
const std::string toString() const override
const NodeBS getDefSVFVars() const override
Return the left hand side SVF Vars.
OPVers::const_iterator opVerBegin() const
virtual const std::string toString() const override
const PAGNode * getRes() const
OPVers::const_iterator opVerEnd() const
static GEdgeFlag makeEdgeFlagWithInvokeID(GEdgeKind k, CallSiteID cs)
Compute the unique edgeFlag value from edge kind and CallSiteID.
virtual const std::string toString() const
virtual const std::string toString() const
VFGEdge::VFGEdgeSetTy VFGEdgeSetTy
void updateCallGraph(PointerAnalysis *pta)
Update VFG based on pointer analysis results.
VFGEdge * addInterEdgeFromAPToFP(ActualParmVFGNode *src, FormalParmVFGNode *dst, CallSiteID csId)
Add inter VF edge from actual to formal parameters.
void addStoreVFGNode(const StoreStmt *store)
VFGEdge * addInterEdgeFromFRToAR(FormalRetVFGNode *src, ActualRetVFGNode *dst, CallSiteID csId)
Add inter VF edge from callee return to callsite receive parameter.
void addBranchVFGNode(const BranchStmt *edge)
Add a BranchVFGNode.
virtual SVFStmt::SVFStmtSetTy & getPAGEdgeSet(SVFStmt::PEDGEK kind)
Get PAGEdge set.
const PAGNode * getLHSTopLevPtr(const VFGNode *node) const
FormalParmVFGNode * getFormalParmVFGNode(const PAGNode *fparm) const
VFGNodeIDToNodeMapTy::iterator iterator
ActualRetVFGNode * getActualRetVFGNode(const PAGNode *aret) const
VFGEdge * addRetEdge(NodeID srcId, NodeID dstId, CallSiteID csId)
virtual void connectAParamAndFParam(const PAGNode *csArg, const PAGNode *funArg, const CallICFGNode *cbn, CallSiteID csId, VFGEdgeSetTy &edges)
Connect VFG nodes between caller and callee for indirect call site.
FormalRetVFGNode * getFormalRetVFGNode(const PAGNode *fret) const
void addVFGNodes()
Create VFG nodes.
void addLoadVFGNode(const LoadStmt *load)
Add a Load VFG node.
CallSiteID getCallSiteID(const CallICFGNode *cs, const FunObjVar *func) const
Get callsite given a callsiteID.
VFGEdge * addIntraDirectVFEdge(NodeID srcId, NodeID dstId)
void checkIntraEdgeParents(const VFGNode *srcNode, const VFGNode *dstNode)
sanitize Intra edges, verify that both nodes belong to the same function.
void addCopyVFGNode(const CopyStmt *copy)
Add a Copy VFG node.
void addGepVFGNode(const GepStmt *gep)
Add a Gep VFG node.
void addNullPtrVFGNode(const PAGNode *pagNode)
void addActualRetVFGNode(const PAGNode *ret, const CallICFGNode *cs)
Add a callsite Receive VFG node.
void addUnaryOPVFGNode(const UnaryOPStmt *edge)
Add a UnaryOperator VFG node.
void addFormalParmVFGNode(const PAGNode *fparm, const FunObjVar *fun, CallPESet &callPEs)
Add a formal parameter VFG node.
void addActualParmVFGNode(const PAGNode *aparm, const CallICFGNode *cs)
void addCmpVFGNode(const CmpStmt *edge)
Add a Compare VFG node.
NodeID getDef(const PAGNode *pagNode) const
bool addVFGEdge(VFGEdge *edge)
Add VFG edge.
virtual bool isInterestedPAGNode(const SVFVar *node) const
bool hasBlackHoleConstObjAddrAsDef(const PAGNode *pagNode) const
Whether a PAGNode has a blackhole or const object as its definition.
ActualParmVFGNode * getActualParmVFGNode(const PAGNode *aparm, const CallICFGNode *cs) const
bool isPhiCopyEdge(const PAGEdge *copy) const
VFGNode * getVFGNode(NodeID id) const
Get a VFG node.
const FunObjVar * isFunEntryVFGNode(const VFGNode *node) const
Whether a node is function entry VFGNode.
VFG(CallGraph *callgraph, VFGK k=FULLSVFG)
Constructor.
VFGEdge * addCallEdge(NodeID srcId, NodeID dstId, CallSiteID csId)
virtual void connectFRetAndARet(const PAGNode *funReturn, const PAGNode *csReturn, CallSiteID csId, VFGEdgeSetTy &edges)
Connect formal-ret and actual ret.
bool hasDef(const PAGNode *pagNode) const
FormalRetVFGNode::RetPESet RetPESet
VFGEdge * hasIntraVFGEdge(VFGNode *src, VFGNode *dst, VFGEdge::VFGEdgeK kind)
Whether we has a SVFG edge.
void addBinaryOPVFGNode(const BinaryOPStmt *edge)
Add a BinaryOperator VFG node.
void addAddrVFGNode(const AddrStmt *addr)
Add an Address VFG node.
VFGEdge * hasInterVFGEdge(VFGNode *src, VFGNode *dst, VFGEdge::VFGEdgeK kind, CallSiteID csId)
FormalParmVFGNode::CallPESet CallPESet
void connectDirectVFGEdges()
Create edges between VFG nodes within a function.
VFGEdge * getIntraVFGEdge(const VFGNode *src, const VFGNode *dst, VFGEdge::VFGEdgeK kind)
Get a SVFG edge according to src and dst.
void view()
Dump graph into dot file.
VFGEdge * hasThreadVFGEdge(VFGNode *src, VFGNode *dst, VFGEdge::VFGEdgeK kind)
void dump(const std::string &file, bool simple=false)
Dump graph into dot file.
virtual void connectCallerAndCallee(const CallICFGNode *cs, const FunObjVar *callee, VFGEdgeSetTy &edges)
Connect VFG nodes between caller and callee for indirect call site.
void addFormalRetVFGNode(const PAGNode *uniqueFunRet, const FunObjVar *fun, RetPESet &retPEs)
void destroy()
Clean up memory.
void addIntraPHIVFGNode(const MultiOpndStmt *edge)
Add an llvm PHI VFG node.
std::string pasMsg(const std::string &msg)
Print each pass/phase message by converting a string into blue string output.
bool matchArgs(const CallICFGNode *cs, const FunObjVar *callee)
std::ostream & outs()
Overwrite llvm::outs()
void ViewGraph(const GraphType &G, const std::string &name, bool ShortNames=false, GraphProgram::Name Program=GraphProgram::DOT)
llvm::IRBuilder IRBuilder
static std::string getCompleteNodeLabel(NodeType *node, VFG *)
Return label of a VFG node with MemSSA information.
static std::string getNodeAttributes(NodeType *node, VFG *)
static std::string getEdgeSourceLabel(NodeType *, EdgeIter EI)
DOTGraphTraits(bool isSimple=false)
static std::string getEdgeAttributes(NodeType *, EdgeIter EI, VFG *)
std::string getNodeLabel(NodeType *node, VFG *graph)
static std::string getSimpleNodeLabel(NodeType *node, VFG *)
Return label of a VFG node without MemSSA information.
static std::string getGraphName(VFG *)
Return name of the graph.