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

#include <BasicBlockG.h>

Inheritance diagram for SVF::SVFBasicBlock:
SVF::GenericNode< NodeTy, EdgeTy > SVF::SVFValue

Public Types

typedef std::vector< constICFGNode * >::const_iterator const_iterator
 
- Public Types inherited from SVF::GenericNode< NodeTy, EdgeTy >
typedef NodeTy NodeType
 
typedef EdgeTy EdgeType
 
typedef OrderedSet< EdgeType *, typename EdgeType::equalGEdge > GEdgeSetTy
 Edge kind.
 
typedef GEdgeSetTy::iterator iterator
 
typedef GEdgeSetTy::const_iterator const_iterator
 
- Public Types inherited from SVF::SVFValue
enum  GNodeK {
  IntraBlock , GlobalBlock , FunEntryBlock , FunExitBlock ,
  FunCallBlock , FunRetBlock , ValNode , ArgValNode ,
  FunValNode , GepValNode , RetValNode , VarargValNode ,
  GlobalValNode , ConstAggValNode , ConstDataValNode , BlackHoleValNode ,
  ConstFPValNode , ConstIntValNode , ConstNullptrValNode , DummyValNode ,
  ObjNode , GepObjNode , BaseObjNode , FunObjNode ,
  HeapObjNode , StackObjNode , GlobalObjNode , ConstAggObjNode ,
  ConstDataObjNode , ConstFPObjNode , ConstIntObjNode , ConstNullptrObjNode ,
  DummyObjNode , Cmp , BinaryOp , UnaryOp ,
  Branch , DummyVProp , NPtr , FRet ,
  ARet , AParm , FParm , Addr ,
  Copy , Gep , Store , Load ,
  TPhi , TIntraPhi , TInterPhi , FPIN ,
  FPOUT , APIN , APOUT , MPhi ,
  MIntraPhi , MInterPhi , CallNodeKd , CDNodeKd ,
  CFLNodeKd , CHNodeKd , ConstraintNodeKd , TCTNodeKd ,
  DCHNodeKd , BasicBlockKd , OtherKd
}
 

Public Member Functions

 SVFBasicBlock (NodeID id, const FunObjVar *f)
 Constructor without name.
 
 SVFBasicBlock ()=delete
 
 ~SVFBasicBlock ()
 
const std::vector< const ICFGNode * > & getICFGNodeList () const
 
const_iterator begin () const
 
const_iterator end () const
 
void setFun (const FunObjVar *f)
 
void addSuccBasicBlock (const SVFBasicBlock *succ2)
 
void addPredBasicBlock (const SVFBasicBlock *pred2)
 
const FunObjVargetParent () const
 
const FunObjVargetFunction () const
 
const ICFGNodefront () const
 
const ICFGNodeback () const
 
std::vector< const SVFBasicBlock * > getSuccessors () const
 
std::vector< const SVFBasicBlock * > getPredecessors () const
 
u32_t getNumSuccessors () const
 
u32_t getBBSuccessorPos (const SVFBasicBlock *Succ)
 
u32_t getBBSuccessorPos (const SVFBasicBlock *Succ) const
 
u32_t getBBPredecessorPos (const SVFBasicBlock *succbb)
 
u32_t getBBPredecessorPos (const SVFBasicBlock *succbb) const
 
const std::string toString () const
 
- Public Member Functions inherited from SVF::GenericNode< NodeTy, EdgeTy >
 GenericNode (NodeID i, GNodeK k, const SVFType *svfType=nullptr)
 Constructor.
 
virtual ~GenericNode ()
 Destructor.
 
bool hasIncomingEdge () const
 Has incoming/outgoing edge set.
 
bool hasOutgoingEdge () const
 
iterator OutEdgeBegin ()
 iterators
 
iterator OutEdgeEnd ()
 
iterator InEdgeBegin ()
 
iterator InEdgeEnd ()
 
const_iterator OutEdgeBegin () const
 
const_iterator OutEdgeEnd () const
 
const_iterator InEdgeBegin () const
 
const_iterator InEdgeEnd () const
 
virtual iterator directOutEdgeBegin ()
 Iterators used for SCC detection, overwrite it in child class if necessary.
 
virtual iterator directOutEdgeEnd ()
 
virtual iterator directInEdgeBegin ()
 
virtual iterator directInEdgeEnd ()
 
virtual const_iterator directOutEdgeBegin () const
 
virtual const_iterator directOutEdgeEnd () const
 
virtual const_iterator directInEdgeBegin () const
 
virtual const_iterator directInEdgeEnd () const
 
bool addIncomingEdge (EdgeType *inEdge)
 Add incoming and outgoing edges.
 
bool addOutgoingEdge (EdgeType *outEdge)
 
EdgeTypehasIncomingEdge (EdgeType *edge) const
 Find incoming and outgoing edges.
 
EdgeTypehasOutgoingEdge (EdgeType *edge) const
 
const GEdgeSetTygetOutEdges () const
 
const GEdgeSetTygetInEdges () const
 
u32_t removeIncomingEdge (EdgeType *edge)
 
u32_t removeOutgoingEdge (EdgeType *edge)
 
- Public Member Functions inherited from SVF::SVFValue
 SVFValue (NodeID i, GNodeK k, const SVFType *ty=nullptr)
 
NodeID getId () const
 Get ID.
 
GNodeK getNodeKind () const
 Get node kind.
 
virtual const SVFTypegetType () const
 
virtual void setName (const std::string &nameInfo)
 
virtual void setName (std::string &&nameInfo)
 
virtual const std::string & getName () const
 
virtual void setSourceLoc (const std::string &sourceCodeInfo)
 
virtual const std::string getSourceLoc () const
 
const std::string valueOnlyToString () const
 

Static Public Member Functions

static bool classof (const SVFValue *node)
 
static bool classof (const SVFBasicBlock *node)
 
- Static Public Member Functions inherited from SVF::GenericNode< NodeTy, EdgeTy >
static bool classof (const GenericNode< NodeTy, EdgeTy > *)
 
static bool classof (const SVFValue *)
 

Public Attributes

std::vector< const SVFBasicBlock * > succBBs
 
std::vector< const SVFBasicBlock * > predBBs
 

Protected Member Functions

void addICFGNode (const ICFGNode *icfgNode)
 Function where this BasicBlock is.
 

Private Attributes

std::vector< const ICFGNode * > allICFGNodes
 all ICFGNodes in this BasicBlock
 
const FunObjVarfun
 

Friends

class LLVMModuleSet
 
class SVFIRWriter
 
class SVFIRReader
 
class SVFIRBuilder
 
class FunObjVar
 
class ICFGBuilder
 
class ICFG
 
OutStreamoperator<< (OutStream &o, const SVFBasicBlock &node)
 

Additional Inherited Members

- Static Protected Member Functions inherited from SVF::SVFValue
static bool isICFGNodeKinds (GNodeK n)
 Helper functions to check node kinds.
 
static bool isInterICFGNodeKind (GNodeK n)
 
static bool isSVFVarKind (GNodeK n)
 
static bool isValVarKinds (GNodeK n)
 
static bool isConstantDataValVar (GNodeK n)
 
static bool isObjVarKinds (GNodeK n)
 
static bool isBaseObjVarKinds (GNodeK n)
 
static bool isConstantDataObjVarKinds (GNodeK n)
 
static bool isVFGNodeKinds (GNodeK n)
 
static bool isArgumentVFGNodeKinds (GNodeK n)
 
static bool isStmtVFGNodeKinds (GNodeK n)
 
static bool isPHIVFGNodeKinds (GNodeK n)
 
static bool isMRSVFGNodeKinds (GNodeK n)
 
static bool isMSSAPHISVFGNodeKinds (GNodeK n)
 
- Protected Attributes inherited from SVF::SVFValue
NodeID id
 Node ID.
 
GNodeK nodeKind
 Node kind.
 
const SVFTypetype
 SVF type.
 
std::string name
 
std::string sourceLoc
 Source code information of this value.
 

Detailed Description

Definition at line 73 of file BasicBlockG.h.

Member Typedef Documentation

◆ const_iterator

Definition at line 84 of file BasicBlockG.h.

Constructor & Destructor Documentation

◆ SVFBasicBlock() [1/2]

SVF::SVFBasicBlock::SVFBasicBlock ( NodeID  id,
const FunObjVar f 
)
inline

Constructor without name.

Definition at line 108 of file BasicBlockG.h.

109 {
110
111 }
const FunObjVar * fun
Definition BasicBlockG.h:90
GenericNode< SVFBasicBlock, BasicBlockEdge > GenericBasicBlockNodeTy
Definition BasicBlockG.h:72
llvm::IRBuilder IRBuilder
Definition BasicTypes.h:74

◆ SVFBasicBlock() [2/2]

SVF::SVFBasicBlock::SVFBasicBlock ( )
delete

◆ ~SVFBasicBlock()

SVF::SVFBasicBlock::~SVFBasicBlock ( )
inline

Definition at line 113 of file BasicBlockG.h.

114 {
115
116 }

Member Function Documentation

◆ addICFGNode()

void SVF::SVFBasicBlock::addICFGNode ( const ICFGNode icfgNode)
inlineprotected

Function where this BasicBlock is.

attributes to be set only through Module builders e.g., LLVMModule

Definition at line 97 of file BasicBlockG.h.

98 {
100 icfgNode) == getICFGNodeList().end() && "duplicated icfgnode");
101 allICFGNodes.push_back(icfgNode);
102 }
const std::vector< const ICFGNode * > & getICFGNodeList() const
std::vector< const ICFGNode * > allICFGNodes
all ICFGNodes in this BasicBlock
Definition BasicBlockG.h:89
const_iterator end() const
const_iterator begin() const

◆ addPredBasicBlock()

void SVF::SVFBasicBlock::addPredBasicBlock ( const SVFBasicBlock pred2)
inline

Definition at line 175 of file BasicBlockG.h.

176 {
177 // check if the edge already exists
178 for (auto edge: this->getInEdges())
179 {
180 if (edge->getSrcNode() == pred2)
181 return;
182 }
183 SVFBasicBlock* pred = const_cast<SVFBasicBlock*>(pred2);
184 BasicBlockEdge* edge = new BasicBlockEdge(pred, this);
185 this->addIncomingEdge(edge);
186 pred->addOutgoingEdge(edge);
187 this->predBBs.push_back(pred);
188 pred->succBBs.push_back(this);
189 }
const GEdgeSetTy & getInEdges() const
bool addIncomingEdge(EdgeType *inEdge)
Add incoming and outgoing edges.
SVFBasicBlock()=delete
std::vector< const SVFBasicBlock * > predBBs
Definition BasicBlockG.h:86

◆ addSuccBasicBlock()

void SVF::SVFBasicBlock::addSuccBasicBlock ( const SVFBasicBlock succ2)
inline

Definition at line 158 of file BasicBlockG.h.

159 {
160 // check if the edge already exists
161 for (auto edge: this->getOutEdges())
162 {
163 if (edge->getDstNode() == succ2)
164 return;
165 }
166
167 SVFBasicBlock* succ = const_cast<SVFBasicBlock*>(succ2);
168 BasicBlockEdge* edge = new BasicBlockEdge(this, succ);
169 this->addOutgoingEdge(edge);
170 succ->addIncomingEdge(edge);
171 this->succBBs.push_back(succ);
172 succ->predBBs.push_back(this);
173 }
const GEdgeSetTy & getOutEdges() const
bool addOutgoingEdge(EdgeType *outEdge)
std::vector< const SVFBasicBlock * > succBBs
Definition BasicBlockG.h:85

◆ back()

const ICFGNode * SVF::SVFBasicBlock::back ( ) const
inline

Definition at line 209 of file BasicBlockG.h.

210 {
211 assert(!allICFGNodes.empty() && "bb empty?");
212 return allICFGNodes.back();
213 }

◆ begin()

const_iterator SVF::SVFBasicBlock::begin ( ) const
inline

Definition at line 142 of file BasicBlockG.h.

143 {
144 return allICFGNodes.begin();
145 }

◆ classof() [1/2]

static bool SVF::SVFBasicBlock::classof ( const SVFBasicBlock node)
inlinestatic

Definition at line 123 of file BasicBlockG.h.

124 {
125 return true;
126 }

◆ classof() [2/2]

static bool SVF::SVFBasicBlock::classof ( const SVFValue node)
inlinestatic

Definition at line 118 of file BasicBlockG.h.

119 {
120 return node->getNodeKind() == SVFValue::BasicBlockKd;
121 }

◆ end()

const_iterator SVF::SVFBasicBlock::end ( ) const
inline

Definition at line 147 of file BasicBlockG.h.

148 {
149 return allICFGNodes.end();
150 }

◆ front()

const ICFGNode * SVF::SVFBasicBlock::front ( ) const
inline

Definition at line 203 of file BasicBlockG.h.

204 {
205 assert(!allICFGNodes.empty() && "bb empty?");
206 return allICFGNodes.front();
207 }

◆ getBBPredecessorPos() [1/2]

u32_t SVF::SVFBasicBlock::getBBPredecessorPos ( const SVFBasicBlock succbb)
inline

Definition at line 263 of file BasicBlockG.h.

264 {
265 u32_t pos = 0;
267 {
268 if(PredBB == this)
269 return pos;
270 ++pos;
271 }
272 assert(false && "Didn't find predecessor edge?");
273 return pos;
274 }
unsigned u32_t
Definition CommandLine.h:18
std::vector< const SVFBasicBlock * > getPredecessors() const

◆ getBBPredecessorPos() [2/2]

u32_t SVF::SVFBasicBlock::getBBPredecessorPos ( const SVFBasicBlock succbb) const
inline

Definition at line 275 of file BasicBlockG.h.

276 {
277 u32_t pos = 0;
279 {
280 if(PredBB == this)
281 return pos;
282 ++pos;
283 }
284 assert(false && "Didn't find predecessor edge?");
285 return pos;
286 }

◆ getBBSuccessorPos() [1/2]

u32_t SVF::SVFBasicBlock::getBBSuccessorPos ( const SVFBasicBlock Succ)
inline

Definition at line 238 of file BasicBlockG.h.

239 {
240 u32_t i = 0;
241 for (const SVFBasicBlock* SuccBB: succBBs)
242 {
243 if (SuccBB == Succ)
244 return i;
245 i++;
246 }
247 assert(false && "Didn't find successor edge?");
248 return 0;
249 }

◆ getBBSuccessorPos() [2/2]

u32_t SVF::SVFBasicBlock::getBBSuccessorPos ( const SVFBasicBlock Succ) const
inline

Definition at line 250 of file BasicBlockG.h.

251 {
252 u32_t i = 0;
253 for (const SVFBasicBlock* SuccBB: succBBs)
254 {
255 if (SuccBB == Succ)
256 return i;
257 i++;
258 }
259 assert(false && "Didn't find successor edge?");
260 return 0;
261
262 }

◆ getFunction()

const FunObjVar * SVF::SVFBasicBlock::getFunction ( ) const
inline

Definition at line 197 of file BasicBlockG.h.

198 {
199 assert(fun && "Function is null?");
200 return fun;
201 }

◆ getICFGNodeList()

const std::vector< const ICFGNode * > & SVF::SVFBasicBlock::getICFGNodeList ( ) const
inline

Definition at line 137 of file BasicBlockG.h.

138 {
139 return allICFGNodes;
140 }

◆ getNumSuccessors()

u32_t SVF::SVFBasicBlock::getNumSuccessors ( ) const
inline

Definition at line 234 of file BasicBlockG.h.

235 {
236 return this->getOutEdges().size();
237 }

◆ getParent()

const FunObjVar * SVF::SVFBasicBlock::getParent ( ) const
inline

Definition at line 191 of file BasicBlockG.h.

192 {
193 assert(fun && "Function is null?");
194 return fun;
195 }

◆ getPredecessors()

std::vector< const SVFBasicBlock * > SVF::SVFBasicBlock::getPredecessors ( ) const
inline

Definition at line 225 of file BasicBlockG.h.

226 {
227 std::vector<const SVFBasicBlock*> res;
228 for (auto edge : this->getInEdges())
229 {
230 res.push_back(edge->getSrcNode());
231 }
232 return res;
233 }

◆ getSuccessors()

std::vector< const SVFBasicBlock * > SVF::SVFBasicBlock::getSuccessors ( ) const
inline

Definition at line 215 of file BasicBlockG.h.

216 {
217 std::vector<const SVFBasicBlock*> res;
218 for (auto edge : this->getOutEdges())
219 {
220 res.push_back(edge->getDstNode());
221 }
222 return res;
223 }

◆ setFun()

void SVF::SVFBasicBlock::setFun ( const FunObjVar f)
inline

Definition at line 153 of file BasicBlockG.h.

154 {
155 fun = f;
156 }

◆ toString()

const std::string SVFBasicBlock::toString ( ) const

Definition at line 13 of file BasicBlockG.cpp.

14{
15 std::string str;
16 std::stringstream rawstr(str);
17 rawstr << "----------"<< "SVFBasicBlock: " << getName() <<"----------\n";
18 for (const ICFGNode* icfgNode : allICFGNodes)
19 {
20 rawstr << icfgNode->toString();
21 }
22 rawstr << "\n----------------------------------------\n";
23 return rawstr.str();
24}
virtual const std::string & getName() const
Definition SVFValue.h:184

Friends And Related Symbol Documentation

◆ FunObjVar

Definition at line 79 of file BasicBlockG.h.

◆ ICFG

friend class ICFG
friend

Definition at line 81 of file BasicBlockG.h.

◆ ICFGBuilder

Definition at line 80 of file BasicBlockG.h.

◆ LLVMModuleSet

Definition at line 75 of file BasicBlockG.h.

◆ operator<<

OutStream & operator<< ( OutStream o,
const SVFBasicBlock node 
)
friend

Definition at line 129 of file BasicBlockG.h.

130 {
131 o << node.toString();
132 return o;
133 }

◆ SVFIRBuilder

Definition at line 78 of file BasicBlockG.h.

◆ SVFIRReader

friend class SVFIRReader
friend

Definition at line 77 of file BasicBlockG.h.

◆ SVFIRWriter

friend class SVFIRWriter
friend

Definition at line 76 of file BasicBlockG.h.

Member Data Documentation

◆ allICFGNodes

std::vector<const ICFGNode*> SVF::SVFBasicBlock::allICFGNodes
private

all ICFGNodes in this BasicBlock

Definition at line 89 of file BasicBlockG.h.

◆ fun

const FunObjVar* SVF::SVFBasicBlock::fun
private

Definition at line 90 of file BasicBlockG.h.

◆ predBBs

std::vector<const SVFBasicBlock*> SVF::SVFBasicBlock::predBBs

Definition at line 86 of file BasicBlockG.h.

◆ succBBs

std::vector<const SVFBasicBlock*> SVF::SVFBasicBlock::succBBs

Definition at line 85 of file BasicBlockG.h.


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