Static Value-Flow Analysis
Loading...
Searching...
No Matches
Namespaces | Classes | Typedefs | Enumerations | Functions
SVF Namespace Reference

for isBitcode More...

Namespaces

namespace  cppUtil
 
namespace  DOT
 
namespace  GraphProgram
 
namespace  LLVMUtil
 
namespace  SVFUtil
 

Classes

class  AbsExtAPI
 Handles external API calls and manages abstract states. More...
 
class  AbstractInterpretation
 AbstractInterpretation is same as Abstract Execution. More...
 
class  AbstractState
 
class  AbstractValue
 
class  AccessPath
 
class  ActualINSVFGNode
 
class  ActualOUTSVFGNode
 
class  ActualParmVFGNode
 
class  ActualRetVFGNode
 
class  AddrCGEdge
 
class  AddressValue
 
class  AddrStmt
 
class  AddrVFGNode
 
class  AEDetector
 Base class for all detectors. More...
 
class  AEException
 Exception class for handling errors in Abstract Execution. More...
 
class  AEStat
 AEStat: Statistic for AE. More...
 
class  AliasCFLGraphBuilder
 AliasCFLGraphBuilder: a CFLGraphBuilder specialized for handling aliasing. More...
 
class  AliasDDAClient
 
class  Andersen
 
class  AndersenBase
 
class  AndersenSCD
 
class  AndersenSFR
 
class  AndersenStat
 
class  AndersenWaveDiff
 
class  Annotator
 
class  ArgumentVFGNode
 
class  AssignStmt
 
class  BaseObjVar
 
class  BinaryOPStmt
 
class  BinaryOPVFGNode
 
class  BitVector
 
class  BoundedDouble
 
class  BoundedInt
 A class representing a bounded 64-bit integer. More...
 
class  BranchStmt
 
class  BranchVFGNode
 
class  BreakConstantGEPs
 
class  BufferOverflowBug
 
class  BufOverflowDetector
 Detector for identifying buffer overflow issues. More...
 
class  BVDataPTAImpl
 
class  CallCFGEdge
 
class  CallCHI
 
class  CallDirSVFGEdge
 
class  CallGraph
 
class  CallGraphBuilder
 
class  CallGraphEdge
 
class  CallGraphNode
 
class  CallICFGNode
 
class  CallIndSVFGEdge
 
class  CallMU
 
class  CallPE
 
class  CDG
 
class  CDGBuilder
 
class  CDGEdge
 
class  CDGNode
 
class  CFGNormalizer
 
class  CFGrammar
 
class  CFLAlias
 
class  CFLBase
 CFL Client Base Class. More...
 
class  CFLEdge
 
class  CFLFIFOWorkList
 
class  CFLGramGraphChecker
 
class  CFLGraph
 
class  CFLGraphBuilder
 
class  CFLNode
 
class  CFLSolver
 
class  CFLStat
 
class  CFLSVFGBuilder
 
class  CFLVF
 
class  CHEdge
 
class  CHGBuilder
 
class  CHGraph
 
class  CHNode
 
class  CmpStmt
 
class  CmpVFGNode
 
class  CommonCHGraph
 Common base for class hierarchy graph. Only implements what PointerAnalysis needs. More...
 
class  CondPointsToSet
 
class  CondPTAImpl
 
class  CondStdSet
 
class  CondVar
 
class  ConstraintEdge
 
class  ConstraintGraph
 
class  ConstraintNode
 
class  ContextCond
 
class  ContextDDA
 
class  CopyCGEdge
 
class  CopyStmt
 
class  CopyVFGNode
 
class  CoreBitVector
 
class  CSC
 
class  CxtDPItem
 
class  CxtProc
 
class  CxtStmt
 
class  CxtStmtDPItem
 
class  CxtThread
 
class  CxtThreadProc
 
class  CxtThreadStmt
 
class  DCHEdge
 
class  DCHGraph
 Dwarf based CHG. More...
 
class  DCHNode
 
class  DDAClient
 
class  DDAPass
 
class  DDAStat
 
class  DDAVFSolver
 
struct  DefaultDOTGraphTraits
 
class  DFPTData
 
class  DiffPTData
 
class  DirectSVFGEdge
 
class  DistinctMRG
 
struct  DOTGraphTraits
 
struct  DOTGraphTraits< CallGraph * >
 
struct  DOTGraphTraits< CFLGraph * >
 
struct  DOTGraphTraits< CHGraph * >
 
struct  DOTGraphTraits< ConstraintGraph * >
 
struct  DOTGraphTraits< ICFG * >
 
struct  DOTGraphTraits< IRGraph * >
 
struct  DOTGraphTraits< PTACallGraph * >
 
struct  DOTGraphTraits< SVF::CDG * >
 
struct  DOTGraphTraits< SVFG * >
 
struct  DOTGraphTraits< TCT * >
 
struct  DOTGraphTraits< VFG * >
 
class  DoubleFreeBug
 
class  DoubleFreeChecker
 
class  DPItem
 
class  DummyObjVar
 
class  DummyValVar
 
class  DummyVersionPropSVFGNode
 
class  EntryCHI
 
class  ExtAPI
 
class  FIFOWorkList
 
class  FileChecker
 
class  FileNeverCloseBug
 
class  FilePartialCloseBug
 
class  FILOWorkList
 
class  FlowDDA
 
class  FlowSensitive
 
class  FlowSensitiveStat
 
class  ForkJoinAnalysis
 
class  FormalINSVFGNode
 
class  FormalOUTSVFGNode
 
class  FormalParmVFGNode
 
class  FormalRetVFGNode
 
class  FullBufferOverflowBug
 
class  FullNullPtrDereferenceBug
 
class  FunEntryICFGNode
 
class  FunExitICFGNode
 
class  FunObjVar
 
class  FunptrDDAClient
 
class  FunValVar
 
class  GenericBug
 
class  GenericEdge
 
class  GenericGraph
 
class  GenericGraphReader
 
struct  GenericGraphTraits
 
struct  GenericGraphTraits< Inverse< Inverse< T > > >
 
struct  GenericGraphTraits< Inverse< SVF::CallGraphNode * > >
 Inverse GenericGraphTraits specializations for call graph node, it is used for inverse traversal. More...
 
struct  GenericGraphTraits< Inverse< SVF::CDGNode * > >
 Inverse GenericGraphTraits specializations for call graph node, it is used for inverse ICFGTraversal. More...
 
struct  GenericGraphTraits< Inverse< SVF::CFLNode * > >
 Inverse GenericGraphTraits specializations for call graph node, it is used for inverse traversal. More...
 
struct  GenericGraphTraits< Inverse< SVF::CHNode * > >
 
struct  GenericGraphTraits< Inverse< SVF::ConstraintNode * > >
 Inverse GenericGraphTraits specializations for Value flow node, it is used for inverse traversal. More...
 
struct  GenericGraphTraits< Inverse< SVF::DCHNode * > >
 Inverse GenericGraphTraits specializations for call graph node, it is used for inverse traversal. More...
 
struct  GenericGraphTraits< Inverse< SVF::GenericNode< NodeTy, EdgeTy > * > >
 
struct  GenericGraphTraits< Inverse< SVF::ICFGNode * > >
 Inverse GenericGraphTraits specializations for call graph node, it is used for inverse traversal. More...
 
struct  GenericGraphTraits< Inverse< SVF::PTACallGraphNode * > >
 Inverse GenericGraphTraits specializations for call graph node, it is used for inverse traversal. More...
 
struct  GenericGraphTraits< Inverse< SVF::SVFVar * > >
 Inverse GenericGraphTraits specializations for SVFIR node, it is used for inverse traversal. More...
 
struct  GenericGraphTraits< Inverse< SVF::TCTNode * > >
 Inverse GenericGraphTraits specializations for Value flow node, it is used for inverse traversal. More...
 
struct  GenericGraphTraits< Inverse< SVF::VFGNode * > >
 Inverse GenericGraphTraits specializations for call graph node, it is used for inverse traversal. More...
 
struct  GenericGraphTraits< SVF::CallGraph * >
 
struct  GenericGraphTraits< SVF::CallGraphNode * >
 
struct  GenericGraphTraits< SVF::CDG * >
 
struct  GenericGraphTraits< SVF::CDGNode * >
 
struct  GenericGraphTraits< SVF::CFLGraph * >
 
struct  GenericGraphTraits< SVF::CFLNode * >
 
struct  GenericGraphTraits< SVF::CHGraph * >
 
struct  GenericGraphTraits< SVF::CHNode * >
 
struct  GenericGraphTraits< SVF::ConstraintGraph * >
 
struct  GenericGraphTraits< SVF::ConstraintNode * >
 
struct  GenericGraphTraits< SVF::DCHGraph * >
 
struct  GenericGraphTraits< SVF::DCHNode * >
 
struct  GenericGraphTraits< SVF::GenericGraph< NodeTy, EdgeTy > * >
 
struct  GenericGraphTraits< SVF::GenericNode< NodeTy, EdgeTy > * >
 
struct  GenericGraphTraits< SVF::ICFG * >
 
struct  GenericGraphTraits< SVF::ICFGNode * >
 
struct  GenericGraphTraits< SVF::IRGraph * >
 
struct  GenericGraphTraits< SVF::PTACallGraph * >
 
struct  GenericGraphTraits< SVF::PTACallGraphNode * >
 
struct  GenericGraphTraits< SVF::SVFG * >
 
struct  GenericGraphTraits< SVF::SVFVar * >
 
struct  GenericGraphTraits< SVF::TCT * >
 
struct  GenericGraphTraits< SVF::TCTNode * >
 
struct  GenericGraphTraits< SVF::VFG * >
 
struct  GenericGraphTraits< SVF::VFGNode * >
 
class  GenericGraphWriter
 
class  GenericNode
 
class  GepCGEdge
 
class  GepObjVar
 
class  GepStmt
 
class  GepValVar
 
class  GepVFGNode
 
class  GlobalICFGNode
 
class  GrammarBase
 
class  GrammarBuilder
 
class  GraphPrinter
 
class  GraphReachSolver
 
class  GraphWriter
 
class  HareParForEdge
 
struct  has_edgetype
 
struct  has_edgetype< T, std::void_t< typename T::EdgeType > >
 
struct  has_nodetype
 
struct  has_nodetype< T, std::void_t< typename T::NodeType > >
 
struct  Hash
 provide extra hash function for std::pair handling More...
 
struct  Hash< CoreBitVector >
 
struct  Hash< NodePair >
 
struct  Hash< std::pair< S, T > >
 
class  HeapObjVar
 Class representing a heap object variable in the SVFIR. More...
 
class  ICFG
 
class  ICFGBuilder
 
class  ICFGEdge
 
class  ICFGNode
 
class  ICFGReader
 
class  ICFGStat
 
class  ICFGWriter
 
class  ICFGWTO
 
class  IndirectSVFGEdge
 
class  InterDisjointMRG
 
class  InterICFGNode
 
class  InterMSSAPHISVFGNode
 
class  InterPHIVFGNode
 
class  IntervalValue
 
class  IntraCFGEdge
 
class  IntraDirSVFGEdge
 
class  IntraDisjointMRG
 
class  IntraICFGNode
 
class  IntraIndSVFGEdge
 
class  IntraMSSAPHISVFGNode
 
class  IntraPHIVFGNode
 
struct  Inverse
 
class  IRGraph
 
class  iter_adaptor_base
 
class  iter_facade_base
 
class  iter_range
 
struct  KindBaseHelper
 Type trait to get base type. Helper struct to detect inheritance from Node/Edge. More...
 
struct  LeadingZerosCounter
 
class  LeakChecker
 
class  List
 
class  LLVMLoopAnalysis
 
class  LLVMModuleSet
 
class  LoadCGEdge
 
class  LoadMU
 
class  LoadStmt
 
class  LoadVFGNode
 
class  LockAnalysis
 
class  mapped_iter
 
class  MemObj
 
class  MemRegion
 Memory Region class. More...
 
class  MemSSA
 
class  MemSSAStat
 
class  MergeFunctionRets
 
class  MHP
 
class  MRGenerator
 
class  MRSVFGNode
 
class  MRVer
 
class  MSSACHI
 
class  MSSADEF
 
class  MSSAMU
 
class  MSSAPHI
 
class  MSSAPHISVFGNode
 
class  MTA
 
class  MTAStat
 
class  MultiOpndStmt
 
class  MutableDFPTData
 
class  MutableDiffPTData
 DiffPTData implemented with points-to sets which are updated continuously. More...
 
class  MutableIncDFPTData
 Incremental version of the mutable data-flow points-to data structure. More...
 
class  MutablePTData
 PTData implemented using points-to sets which are created once and updated continuously. More...
 
class  MutableVersionedPTData
 
class  NeverFreeBug
 
class  NodeIDAllocator
 
class  NormalGepCGEdge
 
class  NullPtrVFGNode
 
class  ObjTypeInference
 
class  ObjTypeInfo
 
class  ObjVar
 
class  Options
 Carries around command line options. More...
 
class  PAGBuilderFromFile
 
class  PartialBufferOverflowBug
 
class  PartialLeakBug
 
class  PartialNullPtrDereferenceBug
 
class  PersistentDFPTData
 DFPTData backed by a PersistentPointsToCache. More...
 
class  PersistentDiffPTData
 DiffPTData implemented with a persistent points-to backing. More...
 
class  PersistentIncDFPTData
 Incremental version of the persistent data-flow points-to data structure. More...
 
class  PersistentPointsToCache
 
class  PersistentPTData
 PTData backed by a PersistentPointsToCache. More...
 
class  PersistentVersionedPTData
 
class  PhiStmt
 
class  PHIVFGNode
 
class  POCRAlias
 
class  POCRHybrid
 
class  POCRHybridSolver
 Solver Utilize Hybrid Representation of Graph. More...
 
class  POCRSolver
 Solver Utilize CFLData. More...
 
struct  pointee_iter
 
class  pointer_iterator
 
class  PointerAnalysis
 
class  PointsTo
 
struct  PopulationCounter
 
struct  PopulationCounter< T, 8 >
 
class  ProgSlice
 
class  PTACallGraph
 
class  PTACallGraphEdge
 
class  PTACallGraphNode
 
class  PTAStat
 
class  PTData
 
class  ReaderIDToObjMap
 Keeps a map from IDs to T objects, such as XXNode. More...
 
class  ReaderPtrPool
 Reverse of WriterPtrPool where T is object type without ID field. More...
 
class  RelationSolver
 
class  RelExeState
 
class  RetCFGEdge
 
class  RetDirSVFGEdge
 
class  RetICFGNode
 
class  RetIndSVFGEdge
 
class  RetMU
 
class  RetPE
 
class  RetPN
 
class  SaberCheckerAPI
 
class  SaberCondAllocator
 
class  SaberSVFGBuilder
 
class  SCCDetection
 
class  SelectStmt
 
class  SparseBitVector
 
struct  SparseBitVectorElement
 
class  SrcSnkDDA
 
class  SrcSnkSolver
 
class  StackObjVar
 Represents a stack-allocated object variable in the SVFIR (SVF Intermediate Representation) @inherits BaseObjVar. More...
 
class  Steensgaard
 
class  StInfo
 
class  StmtDPItem
 
class  StmtVFGNode
 
class  StoreCGEdge
 
class  StoreCHI
 
class  StoreStmt
 
class  StoreVFGNode
 
class  SVFArgument
 
class  SVFArrayType
 
class  SVFBaseNode
 
class  SVFBasicBlock
 
class  SVFBlackHoleValue
 
class  SVFBugEvent
 
class  SVFBugReport
 
class  SVFCallInst
 
class  SVFConstant
 
class  SVFConstantData
 
class  SVFConstantFP
 
class  SVFConstantInt
 
class  SVFConstantNullPtr
 
class  SVFFunction
 
class  SVFFunctionType
 
class  SVFG
 
class  SVFGBuilder
 
class  SVFGlobalValue
 
class  SVFGOPT
 
class  SVFGStat
 
class  SVFInstruction
 
class  SVFIntegerType
 
class  SVFIR
 
class  SVFIRBuilder
 
class  SVFIRReader
 
class  SVFIRWriter
 
class  SVFLoop
 
class  SVFLoopAndDomInfo
 
class  SVFMetadataAsValue
 
class  SVFModule
 
class  SVFModuleReader
 
class  SVFModuleWriter
 
class  SVFOtherType
 
class  SVFOtherValue
 
class  SVFPointerType
 
class  SVFStat
 
class  SVFStmt
 
class  SVFStructType
 
class  SVFType
 
class  SVFValue
 
class  SVFVar
 
class  SymbolTableBuilder
 
class  SymbolTableInfo
 
class  SymbolTableInfoReader
 
class  TCT
 
class  TCTEdge
 
class  TCTNode
 
class  TDForkPE
 
class  TDJoinPE
 
class  ThreadAPI
 
class  ThreadCallGraph
 
class  ThreadForkEdge
 
class  ThreadJoinEdge
 
class  ThreadMHPIndSVFGEdge
 
struct  TrailingZerosCounter
 
class  TypeAnalysis
 
class  UnaryOPStmt
 
class  UnaryOPVFGNode
 
class  ValVar
 
class  VarArgPN
 
class  VariantGepCGEdge
 
class  VersionedFlowSensitive
 
class  VersionedFlowSensitiveStat
 
class  VersionedPTData
 
class  VFCFLGraphBuilder
 VFCFLGraphBuilder: a CFLGraphBuilder specialized for handling value-flow. More...
 
class  VFG
 
class  VFGEdge
 
class  VFGNode
 
class  WPAFSSolver
 
class  WPAMinimumSolver
 
class  WPAPass
 
class  WPASCCSolver
 
class  WPASolver
 
class  WriterPtrPool
 Bookkeeping class to keep track of the IDs of objects that doesn't have any ID. E.g., SVFValue, XXXEdge. More...
 
class  WTO
 
class  WTOComponent
 
class  WTOComponentVisitor
 
class  WTOCycle
 
class  WTOCycleDepth
 
class  WTONode
 
class  Z3Expr
 

Typedefs

typedef llvm::LLVMContext LLVMContext
 
typedef llvm::GlobalObject GlobalObject
 
typedef llvm::Use Use
 
typedef llvm::ModulePass ModulePass
 
typedef llvm::IRBuilder IRBuilder
 
typedef llvm::UnifyFunctionExitNodes UnifyFunctionExitNodes
 
typedef llvm::Value Value
 LLVM Basic classes.
 
typedef llvm::Type Type
 
typedef llvm::Module Module
 
typedef llvm::Function Function
 
typedef llvm::BasicBlock BasicBlock
 
typedef llvm::Instruction Instruction
 
typedef llvm::GlobalValue GlobalValue
 
typedef llvm::SMDiagnostic SMDiagnostic
 
typedef llvm::BlockAddress BlockAddress
 
typedef llvm::StructType StructType
 LLVM types.
 
typedef llvm::ArrayType ArrayType
 
typedef llvm::PointerType PointerType
 
typedef llvm::IntegerType IntegerType
 
typedef llvm::FunctionType FunctionType
 
typedef llvm::MDString MDString
 
typedef llvm::MetadataAsValue MetadataAsValue
 
typedef llvm::StructLayout StructLayout
 
typedef llvm::ConstantStruct ConstantStruct
 
typedef llvm::MemoryLocation MemoryLocation
 
typedef llvm::DataLayout DataLayout
 
typedef llvm::NamedMDNode NamedMDNode
 LLVM metadata and debug information.
 
typedef llvm::MDNode MDNode
 
typedef llvm::DISubprogram DISubprogram
 
typedef llvm::ConstantData ConstantData
 
typedef llvm::ConstantAggregate ConstantAggregate
 
typedef llvm::ConstantAggregateZero ConstantAggregateZero
 
typedef llvm::ConstantDataSequential ConstantDataSequential
 
typedef llvm::ConstantExpr ConstantExpr
 
typedef llvm::ConstantDataArray ConstantDataArray
 
typedef llvm::ConstantArray ConstantArray
 
typedef llvm::Constant Constant
 
typedef llvm::ConstantInt ConstantInt
 
typedef llvm::ConstantFP ConstantFP
 
typedef llvm::ConstantPointerNull ConstantPointerNull
 
typedef llvm::GlobalAlias GlobalAlias
 
typedef llvm::GlobalIFunc GlobalIFunc
 
typedef llvm::GlobalVariable GlobalVariable
 
typedef llvm::DominatorTree DominatorTree
 LLVM Dominators.
 
typedef llvm::DomTreeNode DomTreeNode
 
typedef llvm::DominanceFrontier DominanceFrontier
 
typedef llvm::PostDominatorTree PostDominatorTree
 
typedef llvm::DominanceFrontierBase< llvm::BasicBlock, falseDominanceFrontierBase
 
typedef llvm::Loop Loop
 LLVM Loop.
 
typedef llvm::LoopInfo LoopInfo
 
typedef llvm::User User
 
typedef llvm::Argument Argument
 
typedef llvm::CallBase CallBase
 
typedef llvm::CallInst CallInst
 
typedef llvm::StoreInst StoreInst
 
typedef llvm::LoadInst LoadInst
 
typedef llvm::AllocaInst AllocaInst
 
typedef llvm::AtomicCmpXchgInst AtomicCmpXchgInst
 
typedef llvm::AtomicRMWInst AtomicRMWInst
 
typedef llvm::BitCastInst BitCastInst
 
typedef llvm::BranchInst BranchInst
 
typedef llvm::SwitchInst SwitchInst
 
typedef llvm::CallBrInst CallBrInst
 
typedef llvm::ReturnInst ReturnInst
 
typedef llvm::CastInst CastInst
 
typedef llvm::CmpInst CmpInst
 
typedef llvm::ExtractValueInst ExtractValueInst
 
typedef llvm::ExtractElementInst ExtractElementInst
 
typedef llvm::GetElementPtrInst GetElementPtrInst
 
typedef llvm::InvokeInst InvokeInst
 
typedef llvm::ShuffleVectorInst ShuffleVectorInst
 
typedef llvm::PHINode PHINode
 
typedef llvm::IntToPtrInst IntToPtrInst
 
typedef llvm::InsertValueInst InsertValueInst
 
typedef llvm::FenceInst FenceInst
 
typedef llvm::FreezeInst FreezeInst
 
typedef llvm::UnreachableInst UnreachableInst
 
typedef llvm::InsertElementInst InsertElementInst
 
typedef llvm::LandingPadInst LandingPadInst
 
typedef llvm::ResumeInst ResumeInst
 
typedef llvm::SelectInst SelectInst
 
typedef llvm::VAArgInst VAArgInst
 
typedef llvm::VACopyInst VACopyInst
 
typedef llvm::VAEndInst VAEndInst
 
typedef llvm::VAStartInst VAStartInst
 
typedef llvm::BinaryOperator BinaryOperator
 
typedef llvm::UnaryOperator UnaryOperator
 
typedef llvm::UndefValue UndefValue
 
typedef llvm::GEPOperator GEPOperator
 
typedef std::pair< const BasicBlock *, const ConstantInt * > SuccBBAndCondValPair
 
typedef std::vector< SuccBBAndCondValPairSuccBBAndCondValPairVec
 
typedef llvm::DIType DIType
 
typedef llvm::DICompositeType DICompositeType
 
typedef llvm::DIDerivedType DIDerivedType
 
typedef llvm::DebugInfoFinder DebugInfoFinder
 
typedef llvm::DISubroutineType DISubroutineType
 
typedef llvm::DIBasicType DIBasicType
 
typedef llvm::DISubrange DISubrange
 
typedef llvm::DINode DINode
 
typedef llvm::DINodeArray DINodeArray
 
typedef llvm::DITypeRefArray DITypeRefArray
 
typedef llvm::inst_iterator inst_iterator
 
typedef llvm::const_inst_iterator const_inst_iterator
 
typedef llvm::gep_type_iterator gep_type_iterator
 
typedef llvm::bridge_gep_iterator bridge_gep_iterator
 
typedef llvm::const_pred_iterator const_pred_iterator
 
typedef llvm::ScalarEvolutionWrapperPass ScalarEvolutionWrapperPass
 
typedef llvm::SCEVAddRecExpr SCEVAddRecExpr
 
typedef llvm::SCEVConstant SCEVConstant
 
typedef llvm::ScalarEvolution ScalarEvolution
 
typedef llvm::SCEV SCEV
 
typedef llvm::raw_fd_ostream raw_fd_ostream
 LLVM outputs.
 
typedef llvm::VectorType VectorType
 
typedef llvm::succ_const_iterator succ_const_iterator
 LLVM Iterators.
 
typedef WTOComponent< ICFGICFGWTOComp
 
typedef WTONode< ICFGICFGSingletonWTO
 
typedef WTOCycle< ICFGICFGCycleWTO
 
typedef GrammarBase::Symbol Label
 
typedef CxtStmtDPItem< SVFGNodeCxtLocDPItem
 
typedef StmtDPItem< SVFGNodeLocDPItem
 
typedef GenericEdge< CallGraphNodeGenericCallGraphEdgeTy
 
typedef GenericNode< CallGraphNode, CallGraphEdgeGenericCallGraphNodeTy
 
typedef GenericGraph< CallGraphNode, CallGraphEdgeGenericCallGraphTy
 
typedef GenericEdge< CDGNodeGenericCDGEdgeTy
 
typedef GenericNode< CDGNode, CDGEdgeGenericCDGNodeTy
 
typedef std::vector< std::pair< NodeID, NodeID > > NodePairVector
 
typedef GenericGraph< CDGNode, CDGEdgeGenericCDGTy
 
typedef GenericEdge< CFLNodeGenericCFLEdgeTy
 
typedef GenericNode< CFLNode, CFLEdgeGenericCFLNodeTy
 
typedef GenericGraph< CFLNode, CFLEdgeGenericCFLGraphTy
 Edge-labeled graph for CFL Reachability analysis.
 
typedef Set< const SVFGlobalValue * > VTableSet
 
typedef Set< const SVFFunction * > VFunSet
 
typedef GenericEdge< CHNodeGenericCHEdgeTy
 
typedef GenericNode< CHNode, CHEdgeGenericCHNodeTy
 
typedef GenericGraph< CHNode, CHEdgeGenericCHGraphTy
 class hierarchy graph
 
typedef GenericEdge< ConstraintNodeGenericConsEdgeTy
 
typedef GenericNode< ConstraintNode, ConstraintEdgeGenericConsNodeTy
 
typedef GenericGraph< ICFGNode, ICFGEdgeGenericICFGTy
 
typedef GenericEdge< ICFGNodeGenericICFGEdgeTy
 
typedef GenericNode< ICFGNode, ICFGEdgeGenericICFGNodeTy
 
typedef SVFVar PAGNode
 
typedef SVFStmt PAGEdge
 
typedef GenericEdge< PTACallGraphNodeGenericPTACallGraphEdgeTy
 
typedef GenericNode< PTACallGraphNode, PTACallGraphEdgeGenericPTACallGraphNodeTy
 
typedef GenericGraph< PTACallGraphNode, PTACallGraphEdgeGenericPTACallGraphTy
 
typedef VFGEdge SVFGEdge
 
typedef VFGNode SVFGNode
 
typedef ActualParmVFGNode ActualParmSVFGNode
 
typedef ActualRetVFGNode ActualRetSVFGNode
 
typedef FormalParmVFGNode FormalParmSVFGNode
 
typedef FormalRetVFGNode FormalRetSVFGNode
 
typedef NullPtrVFGNode NullPtrSVFGNode
 
typedef StmtVFGNode StmtSVFGNode
 
typedef AddrVFGNode AddrSVFGNode
 
typedef CopyVFGNode CopySVFGNode
 
typedef StoreVFGNode StoreSVFGNode
 
typedef LoadVFGNode LoadSVFGNode
 
typedef GepVFGNode GepSVFGNode
 
typedef PHIVFGNode PHISVFGNode
 
typedef IntraPHIVFGNode IntraPHISVFGNode
 
typedef InterPHIVFGNode InterPHISVFGNode
 
typedef GenericGraph< VFGNode, VFGEdgeGenericVFGTy
 
typedef GenericEdge< VFGNodeGenericVFGEdgeTy
 
typedef GenericNode< VFGNode, VFGEdgeGenericVFGNodeTy
 
typedef NodeID MRID
 
typedef NodeID MRVERID
 
typedef NodeID MRVERSION
 
typedef GenericEdge< TCTNodeGenericTCTEdgeTy
 
typedef GenericNode< TCTNode, TCTEdgeGenericTCTNodeTy
 
typedef GenericGraph< TCTNode, TCTEdgeGenericThreadCreateTreeTy
 
typedef GraphReachSolver< SVFG *, CxtDPItemCFLSrcSnkSolver
 
using GenericICFGWriter = GenericGraphWriter< ICFGNode, ICFGEdge >
 
using IRGraphWriter = GenericGraphWriter< SVFVar, SVFStmt >
 
using CHGraphWriter = GenericGraphWriter< CHNode, CHEdge >
 
template<typename T >
using KindBaseT = typename KindBaseHelper< T >::type
 
using GenericICFGReader = GenericGraphReader< ICFGNode, ICFGEdge >
 
using CHGraphReader = GenericGraphReader< CHNode, CHEdge >
 
using IRGraphReader = GenericGraphReader< SVFVar, SVFStmt >
 
typedef SVFIR PAG
 
typedef GenericEdge< SVFVarGenericPAGEdgeTy
 
typedef SVF::GraphPrinter GraphPrinter
 LLVM Aliases and constants.
 
typedef GenericNode< SVFVar, SVFStmtGenericPAGNodeTy
 
typedef CondVar< ContextCondCxtVar
 
typedef CondStdSet< CxtVarCxtPtSet
 
typedef std::ostream OutStream
 
typedef unsigned u32_t
 
typedef signed s32_t
 
typedef unsigned long long u64_t
 
typedef signed long long s64_t
 
typedef unsigned char u8_t
 
typedef signed char s8_t
 
typedef unsigned short u16_t
 
typedef signed short s16_t
 
typedef u32_t NodeID
 
typedef u32_t EdgeID
 
typedef unsigned SymID
 
typedef unsigned CallSiteID
 
typedef unsigned ThreadID
 
typedef s64_t APOffset
 
typedef SparseBitVector NodeBS
 
typedef unsigned PointsToID
 
template<typename Key , typename Hash = Hash<Key>, typename KeyEqual = std::equal_to<Key>, typename Allocator = std::allocator<Key>>
using Set = std::unordered_set< Key, Hash, KeyEqual, Allocator >
 
template<typename Key , typename Value , typename Hash = Hash<Key>, typename KeyEqual = std::equal_to<Key>, typename Allocator = std::allocator<std::pair<const Key, Value>>>
using Map = std::unordered_map< Key, Value, Hash, KeyEqual, Allocator >
 
template<typename Key , typename Compare = std::less<Key>, typename Allocator = std::allocator<Key>>
using OrderedSet = std::set< Key, Compare, Allocator >
 
template<typename Key , typename Value , typename Compare = std::less<Key>, typename Allocator = std::allocator<std::pair<const Key, Value>>>
using OrderedMap = std::map< Key, Value, Compare, Allocator >
 
typedef std::pair< NodeID, NodeIDNodePair
 
typedef OrderedSet< NodeIDOrderedNodeSet
 
typedef Set< NodeIDNodeSet
 
typedef Set< NodePairNodePairSet
 
typedef Map< NodePair, NodeIDNodePairMap
 
typedef std::vector< NodeIDNodeVector
 
typedef std::vector< EdgeIDEdgeVector
 
typedef std::stack< NodeIDNodeStack
 
typedef std::list< NodeIDNodeList
 
typedef std::deque< NodeIDNodeDeque
 
typedef NodeSet EdgeSet
 
typedef std::vector< u32_tCallStrCxt
 
typedef unsigned Version
 
typedef Set< VersionVersionSet
 
typedef std::pair< NodeID, VersionVersionedVar
 
typedef Set< VersionedVarVersionedVarSet
 
template<typename WrappedIteratorT , typename T1 = std::remove_reference_t<decltype( **std::declval<WrappedIteratorT>())>, typename T2 = std::add_pointer_t<T1>>
using raw_pointer_iterator = pointer_iterator< pointee_iter< WrappedIteratorT, T1 >, T2 >
 
typedef WPASolver< ConstraintGraph * > WPAConstraintSolver
 
typedef SCCDetection< ConstraintGraph * > CGSCC
 
typedef WPAFSSolver< SVFG * > WPASVFGFSSolver
 

Enumerations

enum class  BuildDirection { plain , bidirection }
 
enum  ModRefInfo { ModRef , Ref , Mod , NoModRef }
 
enum  AliasResult { NoAlias , MayAlias , MustAlias , PartialAlias }
 
enum  ZeroBehavior { ZB_Undefined , ZB_Max , ZB_Width }
 The behavior an operation has on an input of 0. More...
 

Functions

IntervalValue operator+ (const IntervalValue &lhs, const IntervalValue &rhs)
 Add IntervalValues.
 
IntervalValue operator- (const IntervalValue &lhs, const IntervalValue &rhs)
 Subtract IntervalValues.
 
IntervalValue operator* (const IntervalValue &lhs, const IntervalValue &rhs)
 Multiply IntervalValues.
 
IntervalValue operator/ (const IntervalValue &lhs, const IntervalValue &rhs)
 Divide IntervalValues.
 
IntervalValue operator% (const IntervalValue &lhs, const IntervalValue &rhs)
 Divide IntervalValues.
 
IntervalValue operator> (const IntervalValue &lhs, const IntervalValue &rhs)
 
IntervalValue operator< (const IntervalValue &lhs, const IntervalValue &rhs)
 
IntervalValue operator>= (const IntervalValue &lhs, const IntervalValue &rhs)
 
IntervalValue operator<= (const IntervalValue &lhs, const IntervalValue &rhs)
 
IntervalValue operator<< (const IntervalValue &lhs, const IntervalValue &rhs)
 Left binary shift of IntervalValues.
 
IntervalValue operator>> (const IntervalValue &lhs, const IntervalValue &rhs)
 Left binary shift of IntervalValues.
 
IntervalValue operator& (const IntervalValue &lhs, const IntervalValue &rhs)
 Bitwise AND of IntervalValues.
 
IntervalValue operator| (const IntervalValue &lhs, const IntervalValue &rhs)
 Bitwise OR of IntervalValues.
 
IntervalValue operator^ (const IntervalValue &lhs, const IntervalValue &rhs)
 Bitwise XOR of IntervalValues.
 
std::ostream & operator<< (std::ostream &o, const IntervalValue &IntervalValue)
 Write an IntervalValue on a stream.
 
template<class ItTy , class FuncTy >
mapped_iter< ItTy, FuncTymap_iter (ItTy I, FuncTy F)
 
template<class GraphType >
iter_range< typename GenericGraphTraits< GraphType >::nodes_iterator > nodes (const GraphType &G)
 
template<class GraphType >
iter_range< typename GenericGraphTraits< Inverse< GraphType > >::nodes_iterator > inverse_nodes (const GraphType &G)
 
template<class GraphType >
iter_range< typename GenericGraphTraits< GraphType >::ChildIteratorType > children (const typename GenericGraphTraits< GraphType >::NodeRef &G)
 
template<class GraphType >
iter_range< typename GenericGraphTraits< Inverse< GraphType > >::ChildIteratorType > inverse_children (const typename GenericGraphTraits< GraphType >::NodeRef &G)
 
template<class GraphType >
iter_range< typename GenericGraphTraits< GraphType >::ChildEdgeIteratorTypechildren_edges (const typename GenericGraphTraits< GraphType >::NodeRef &G)
 
template<typename GraphType >
std::ofstream & WriteGraph (std::ofstream &O, const GraphType &G, bool ShortNames=false)
 
template<typename GraphType >
std::string WriteGraph (const GraphType &G, bool ShortNames=false, std::string Filename="")
 
template<typename GraphType >
void ViewGraph (const GraphType &G, const std::string &name, bool ShortNames=false, GraphProgram::Name Program=GraphProgram::DOT)
 
PointsTo operator| (const PointsTo &lhs, const PointsTo &rhs)
 Returns a new lhs | rhs.
 
PointsTo operator& (const PointsTo &lhs, const PointsTo &rhs)
 Returns a new lhs & rhs.
 
PointsTo operator- (const PointsTo &lhs, const PointsTo &rhs)
 Returns a new lhs - rhs.
 
std::ostream & operator<< (std::ostream &o, const MRVer &mrver)
 
bool jsonIsBool (const cJSON *item)
 
bool jsonIsBool (const cJSON *item, bool &flag)
 
bool jsonIsNumber (const cJSON *item)
 
bool jsonIsString (const cJSON *item)
 
bool jsonIsNullId (const cJSON *item)
 
bool jsonIsArray (const cJSON *item)
 
bool jsonIsMap (const cJSON *item)
 
bool jsonIsObject (const cJSON *item)
 
bool jsonKeyEquals (const cJSON *item, const char *key)
 
std::pair< const cJSON *, const cJSON * > jsonUnpackPair (const cJSON *item)
 
double jsonGetNumber (const cJSON *item)
 
cJSONjsonCreateNullId ()
 
cJSONjsonCreateObject ()
 
cJSONjsonCreateArray ()
 
cJSONjsonCreateString (const char *str)
 
cJSONjsonCreateIndex (size_t index)
 
cJSONjsonCreateBool (bool flag)
 
cJSONjsonCreateNumber (double num)
 
bool jsonAddPairToMap (cJSON *obj, cJSON *key, cJSON *value)
 
bool jsonAddItemToObject (cJSON *obj, const char *name, cJSON *item)
 
bool jsonAddItemToArray (cJSON *array, cJSON *item)
 
bool jsonAddNumberToObject (cJSON *obj, const char *name, double number)
 Helper function to write a number to a JSON object.
 
bool jsonAddStringToObject (cJSON *obj, const char *name, const char *str)
 
bool jsonAddStringToObject (cJSON *obj, const char *name, const std::string &s)
 
 KIND_BASE (SVFType, getKind)
 
 KIND_BASE (SVFValue, getKind)
 
 KIND_BASE (SVFVar, getNodeKind)
 
 KIND_BASE (SVFStmt, getEdgeKind)
 
 KIND_BASE (ICFGNode, getNodeKind)
 
 KIND_BASE (ICFGEdge, getEdgeKind)
 
 KIND_BASE (CHNode, getNodeKind)
 
 KIND_BASE (CHEdge, getEdgeKind)
 
std::ostream & operator<< (std::ostream &os, const SVFType &type)
 
std::string dumpLLVMValue (const SVFValue *svfValue)
 
template<typename F , typename S >
OutStreamoperator<< (OutStream &o, const std::pair< F, S > &var)
 
template<typename RangeT , typename WrappedIteratorT = decltype(std::begin(std::declval<RangeT>()))>
iter_range< pointee_iter< WrappedIteratorT > > make_pointee_range (RangeT &&Range)
 
template<typename RangeT , typename WrappedIteratorT = decltype(std::begin(std::declval<RangeT>()))>
iter_range< pointer_iterator< WrappedIteratorT > > make_pointer_range (RangeT &&Range)
 
template<class T >
iter_range< Tmake_range (T x, T y)
 
template<typename T >
iter_range< Tmake_range (std::pair< T, T > p)
 
template<typename T >
unsigned countTrailingZeros (T Val, ZeroBehavior ZB=ZB_Width)
 
template<typename T >
unsigned countLeadingZeros (T Val, ZeroBehavior ZB=ZB_Width)
 
template<typename T >
unsigned countPopulation (T Value)
 
template<unsigned ElementSize>
bool operator|= (SparseBitVector< ElementSize > &LHS, const SparseBitVector< ElementSize > *RHS)
 
template<unsigned ElementSize>
bool operator|= (SparseBitVector< ElementSize > *LHS, const SparseBitVector< ElementSize > &RHS)
 
template<unsigned ElementSize>
bool operator&= (SparseBitVector< ElementSize > *LHS, const SparseBitVector< ElementSize > &RHS)
 
template<unsigned ElementSize>
bool operator&= (SparseBitVector< ElementSize > &LHS, const SparseBitVector< ElementSize > *RHS)
 
template<unsigned ElementSize>
SparseBitVector< ElementSizeoperator| (const SparseBitVector< ElementSize > &LHS, const SparseBitVector< ElementSize > &RHS)
 
template<unsigned ElementSize>
SparseBitVector< ElementSizeoperator& (const SparseBitVector< ElementSize > &LHS, const SparseBitVector< ElementSize > &RHS)
 
template<unsigned ElementSize>
SparseBitVector< ElementSizeoperator- (const SparseBitVector< ElementSize > &LHS, const SparseBitVector< ElementSize > &RHS)
 
template<unsigned ElementSize>
void dump (const SparseBitVector< ElementSize > &LHS, std::ostream &out)
 
SVFTypecreateSVFType (SVFType::GNodeK kind, bool isSingleValTy)
 
static SVFValuecreateSVFValue (SVFValue::GNodeK kind, const SVFType *type, std::string &&name)
 
template<typename SmallNumberType >
static void readSmallNumber (const cJSON *obj, SmallNumberType &val)
 
template<typename BigNumberType , typename CStrToVal >
static void readBigNumber (const cJSON *obj, BigNumberType &val, CStrToVal conv)
 
cJSONjsonCreateMap ()
 
 __attribute__ ((weak)) std
 

Detailed Description

for isBitcode

For a more detailed explanation of how External APIs are handled in SVF, please refer to the SVF Wiki: https://github.com/SVF-tools/SVF/wiki/Handling-External-APIs-with-extapi.c.

Contains abstract classes for: PTData: basic points-to data structure derived by all others. DiffPTData: PTData which only propagates new changes, not entire points-to sets. DFPTData: flow-sensitive PTData as defined by Hardekopf and Lin (CGO '11).

Hierarchy (square brackets indicate abstract class):

  +------------> [PTData] <----------------+---------------------+
  |                 ^                      |                     |
  |                 |                      |                     |

MutablePTData [DiffPTData] [DFPTData] [VersionedPTData] ^ ^ ^ | | | MutableDiffPTData MutableDFPTData MutableVersionedPTData ^ | MutableIncDFPTData

PTData (AbstractPointsToDS.h) implementations with a mutable backend. Each Key is given a points-to set which is itself updated till the analysis terminates.

PTData (AbstractPointsToDS.h) implementations with a persistent backend. Each Key is given a cheap points-to ID which refers to some real points-to set.

GraphTraits specialization for constraint graph

GraphTraits specialization

Typedef Documentation

◆ ActualParmSVFGNode

Definition at line 44 of file SVFG.h.

◆ ActualRetSVFGNode

Definition at line 45 of file SVFG.h.

◆ AddrSVFGNode

Definition at line 51 of file SVFG.h.

◆ AllocaInst

typedef llvm::AllocaInst SVF::AllocaInst

Definition at line 150 of file BasicTypes.h.

◆ APOffset

Definition at line 60 of file GeneralType.h.

◆ Argument

typedef llvm::Argument SVF::Argument

Definition at line 145 of file BasicTypes.h.

◆ ArrayType

typedef llvm::ArrayType SVF::ArrayType

Definition at line 95 of file BasicTypes.h.

◆ AtomicCmpXchgInst

typedef llvm::AtomicCmpXchgInst SVF::AtomicCmpXchgInst

Definition at line 151 of file BasicTypes.h.

◆ AtomicRMWInst

typedef llvm::AtomicRMWInst SVF::AtomicRMWInst

Definition at line 152 of file BasicTypes.h.

◆ BasicBlock

typedef llvm::BasicBlock SVF::BasicBlock

Definition at line 86 of file BasicTypes.h.

◆ BinaryOperator

typedef llvm::BinaryOperator SVF::BinaryOperator

Definition at line 179 of file BasicTypes.h.

◆ BitCastInst

typedef llvm::BitCastInst SVF::BitCastInst

Definition at line 153 of file BasicTypes.h.

◆ BlockAddress

typedef llvm::BlockAddress SVF::BlockAddress

Definition at line 91 of file BasicTypes.h.

◆ BranchInst

typedef llvm::BranchInst SVF::BranchInst

Definition at line 154 of file BasicTypes.h.

◆ bridge_gep_iterator

Definition at line 252 of file BasicTypes.h.

◆ CallBase

typedef llvm::CallBase SVF::CallBase

Definition at line 146 of file BasicTypes.h.

◆ CallBrInst

typedef llvm::CallBrInst SVF::CallBrInst

Definition at line 156 of file BasicTypes.h.

◆ CallInst

typedef llvm::CallInst SVF::CallInst

Definition at line 147 of file BasicTypes.h.

◆ CallSiteID

Definition at line 58 of file GeneralType.h.

◆ CallStrCxt

Definition at line 122 of file GeneralType.h.

◆ CastInst

typedef llvm::CastInst SVF::CastInst

Definition at line 158 of file BasicTypes.h.

◆ CFLSrcSnkSolver

Definition at line 49 of file SrcSnkDDA.h.

◆ CGSCC

Definition at line 44 of file CSC.h.

◆ CHGraphReader

Definition at line 930 of file SVFFileSystem.h.

◆ CHGraphWriter

Definition at line 342 of file SVFFileSystem.h.

◆ CmpInst

typedef llvm::CmpInst SVF::CmpInst

Definition at line 159 of file BasicTypes.h.

◆ const_inst_iterator

typedef llvm::const_inst_iterator SVF::const_inst_iterator

Definition at line 250 of file BasicTypes.h.

◆ const_pred_iterator

typedef llvm::const_pred_iterator SVF::const_pred_iterator

Definition at line 254 of file BasicTypes.h.

◆ Constant

typedef llvm::Constant SVF::Constant

Definition at line 124 of file BasicTypes.h.

◆ ConstantAggregate

typedef llvm::ConstantAggregate SVF::ConstantAggregate

Definition at line 117 of file BasicTypes.h.

◆ ConstantAggregateZero

typedef llvm::ConstantAggregateZero SVF::ConstantAggregateZero

Definition at line 118 of file BasicTypes.h.

◆ ConstantArray

typedef llvm::ConstantArray SVF::ConstantArray

Definition at line 123 of file BasicTypes.h.

◆ ConstantData

typedef llvm::ConstantData SVF::ConstantData

Definition at line 116 of file BasicTypes.h.

◆ ConstantDataArray

typedef llvm::ConstantDataArray SVF::ConstantDataArray

Definition at line 121 of file BasicTypes.h.

◆ ConstantDataSequential

typedef llvm::ConstantDataSequential SVF::ConstantDataSequential

Definition at line 119 of file BasicTypes.h.

◆ ConstantExpr

typedef llvm::ConstantExpr SVF::ConstantExpr

Definition at line 120 of file BasicTypes.h.

◆ ConstantFP

typedef llvm::ConstantFP SVF::ConstantFP

Definition at line 126 of file BasicTypes.h.

◆ ConstantInt

typedef llvm::ConstantInt SVF::ConstantInt

Definition at line 125 of file BasicTypes.h.

◆ ConstantPointerNull

typedef llvm::ConstantPointerNull SVF::ConstantPointerNull

Definition at line 127 of file BasicTypes.h.

◆ ConstantStruct

typedef llvm::ConstantStruct SVF::ConstantStruct

Definition at line 106 of file BasicTypes.h.

◆ CopySVFGNode

Definition at line 52 of file SVFG.h.

◆ CxtLocDPItem

Definition at line 49 of file ContextDDA.h.

◆ CxtPtSet

Definition at line 386 of file DPItem.h.

◆ CxtVar

Context-, flow- sensitive DPItem

Context DPItem

Definition at line 385 of file DPItem.h.

◆ DataLayout

typedef llvm::DataLayout SVF::DataLayout

Definition at line 108 of file BasicTypes.h.

◆ DebugInfoFinder

typedef llvm::DebugInfoFinder SVF::DebugInfoFinder

Definition at line 239 of file BasicTypes.h.

◆ DIBasicType

typedef llvm::DIBasicType SVF::DIBasicType

Definition at line 241 of file BasicTypes.h.

◆ DICompositeType

typedef llvm::DICompositeType SVF::DICompositeType

Definition at line 237 of file BasicTypes.h.

◆ DIDerivedType

typedef llvm::DIDerivedType SVF::DIDerivedType

Definition at line 238 of file BasicTypes.h.

◆ DINode

typedef llvm::DINode SVF::DINode

Definition at line 243 of file BasicTypes.h.

◆ DINodeArray

typedef llvm::DINodeArray SVF::DINodeArray

Definition at line 244 of file BasicTypes.h.

◆ DISubprogram

typedef llvm::DISubprogram SVF::DISubprogram

Definition at line 113 of file BasicTypes.h.

◆ DISubrange

typedef llvm::DISubrange SVF::DISubrange

Definition at line 242 of file BasicTypes.h.

◆ DISubroutineType

typedef llvm::DISubroutineType SVF::DISubroutineType

Definition at line 240 of file BasicTypes.h.

◆ DIType

typedef llvm::DIType SVF::DIType

Definition at line 236 of file BasicTypes.h.

◆ DITypeRefArray

typedef llvm::DITypeRefArray SVF::DITypeRefArray

Definition at line 245 of file BasicTypes.h.

◆ DominanceFrontier

typedef llvm::DominanceFrontier SVF::DominanceFrontier

Definition at line 135 of file BasicTypes.h.

◆ DominanceFrontierBase

typedef llvm::DominanceFrontierBase<llvm::BasicBlock, false> SVF::DominanceFrontierBase

Definition at line 137 of file BasicTypes.h.

◆ DominatorTree

typedef llvm::DominatorTree SVF::DominatorTree

LLVM Dominators.

Definition at line 133 of file BasicTypes.h.

◆ DomTreeNode

typedef llvm::DomTreeNode SVF::DomTreeNode

Definition at line 134 of file BasicTypes.h.

◆ EdgeID

Definition at line 56 of file GeneralType.h.

◆ EdgeSet

Definition at line 121 of file GeneralType.h.

◆ EdgeVector

Definition at line 117 of file GeneralType.h.

◆ ExtractElementInst

typedef llvm::ExtractElementInst SVF::ExtractElementInst

Definition at line 161 of file BasicTypes.h.

◆ ExtractValueInst

typedef llvm::ExtractValueInst SVF::ExtractValueInst

Definition at line 160 of file BasicTypes.h.

◆ FenceInst

typedef llvm::FenceInst SVF::FenceInst

Definition at line 168 of file BasicTypes.h.

◆ FormalParmSVFGNode

Definition at line 46 of file SVFG.h.

◆ FormalRetSVFGNode

Definition at line 47 of file SVFG.h.

◆ FreezeInst

typedef llvm::FreezeInst SVF::FreezeInst

Definition at line 169 of file BasicTypes.h.

◆ Function

typedef llvm::Function SVF::Function

Definition at line 85 of file BasicTypes.h.

◆ FunctionType

typedef llvm::FunctionType SVF::FunctionType

Definition at line 98 of file BasicTypes.h.

◆ GenericCallGraphEdgeTy

Definition at line 50 of file CallGraph.h.

◆ GenericCallGraphNodeTy

Definition at line 113 of file CallGraph.h.

◆ GenericCallGraphTy

Pointer Analysis Call Graph used internally for various pointer analysis

Definition at line 170 of file CallGraph.h.

◆ GenericCDGEdgeTy

Definition at line 40 of file CDG.h.

◆ GenericCDGNodeTy

Definition at line 87 of file CDG.h.

◆ GenericCDGTy

Definition at line 140 of file CDG.h.

◆ GenericCFLEdgeTy

Definition at line 44 of file CFLGraph.h.

◆ GenericCFLGraphTy

Edge-labeled graph for CFL Reachability analysis.

Definition at line 171 of file CFLGraph.h.

◆ GenericCFLNodeTy

Definition at line 74 of file CFLGraph.h.

◆ GenericCHEdgeTy

Definition at line 77 of file CHG.h.

◆ GenericCHGraphTy

class hierarchy graph

Definition at line 232 of file CHG.h.

◆ GenericCHNodeTy

Definition at line 107 of file CHG.h.

◆ GenericConsEdgeTy

Self-defined edge for constraint resolution including add/remove/re-target, but all the operations do not affect original SVFIR Edges

Definition at line 47 of file ConsGEdge.h.

◆ GenericConsNodeTy

Constraint node

Definition at line 39 of file ConsGNode.h.

◆ GenericICFGEdgeTy

Interprocedural control-flow and value-flow edge, representing the control- and value-flow dependence between two nodes

Definition at line 43 of file ICFGEdge.h.

◆ GenericICFGNodeTy

Interprocedural control-flow graph node, representing different kinds of program statements including top-level pointers (ValVar) and address-taken objects (ObjVar)

Definition at line 52 of file ICFGNode.h.

◆ GenericICFGReader

Definition at line 929 of file SVFFileSystem.h.

◆ GenericICFGTy

Interprocedural Control-Flow Graph (ICFG)

Definition at line 46 of file ICFG.h.

◆ GenericICFGWriter

Definition at line 323 of file SVFFileSystem.h.

◆ GenericPAGEdgeTy

Definition at line 50 of file SVFStatements.h.

◆ GenericPAGNodeTy

Definition at line 44 of file SVFVariables.h.

◆ GenericPTACallGraphEdgeTy

Definition at line 51 of file PTACallGraph.h.

◆ GenericPTACallGraphNodeTy

Definition at line 174 of file PTACallGraph.h.

◆ GenericPTACallGraphTy

Pointer Analysis Call Graph used internally for various pointer analysis

Definition at line 235 of file PTACallGraph.h.

◆ GenericTCTEdgeTy

Definition at line 49 of file TCT.h.

◆ GenericTCTNodeTy

Definition at line 84 of file TCT.h.

◆ GenericThreadCreateTreeTy

Pointer Analysis Call Graph used internally for various pointer analysis

Definition at line 152 of file TCT.h.

◆ GenericVFGEdgeTy

Interprocedural control-flow and value-flow edge, representing the control- and value-flow dependence between two nodes

Definition at line 43 of file VFGEdge.h.

◆ GenericVFGNodeTy

Interprocedural control-flow graph node, representing different kinds of program statements including top-level pointers (ValVar) and address-taken objects (ObjVar)

Definition at line 45 of file VFGNode.h.

◆ GenericVFGTy

Value Flow Graph (VFG)

Definition at line 49 of file VFG.h.

◆ gep_type_iterator

typedef llvm::gep_type_iterator SVF::gep_type_iterator

Definition at line 251 of file BasicTypes.h.

◆ GEPOperator

typedef llvm::GEPOperator SVF::GEPOperator

Definition at line 182 of file BasicTypes.h.

◆ GepSVFGNode

Definition at line 55 of file SVFG.h.

◆ GetElementPtrInst

typedef llvm::GetElementPtrInst SVF::GetElementPtrInst

Definition at line 162 of file BasicTypes.h.

◆ GlobalAlias

typedef llvm::GlobalAlias SVF::GlobalAlias

Definition at line 128 of file BasicTypes.h.

◆ GlobalIFunc

typedef llvm::GlobalIFunc SVF::GlobalIFunc

Definition at line 129 of file BasicTypes.h.

◆ GlobalObject

typedef llvm::GlobalObject SVF::GlobalObject

Definition at line 71 of file BasicTypes.h.

◆ GlobalValue

typedef llvm::GlobalValue SVF::GlobalValue

Definition at line 88 of file BasicTypes.h.

◆ GlobalVariable

typedef llvm::GlobalVariable SVF::GlobalVariable

Definition at line 130 of file BasicTypes.h.

◆ GraphPrinter

LLVM Aliases and constants.

Definition at line 41 of file SVFValue.h.

◆ ICFGCycleWTO

Definition at line 45 of file ICFGWTO.h.

◆ ICFGSingletonWTO

Definition at line 44 of file ICFGWTO.h.

◆ ICFGWTOComp

Definition at line 43 of file ICFGWTO.h.

◆ InsertElementInst

typedef llvm::InsertElementInst SVF::InsertElementInst

Definition at line 171 of file BasicTypes.h.

◆ InsertValueInst

typedef llvm::InsertValueInst SVF::InsertValueInst

Definition at line 167 of file BasicTypes.h.

◆ inst_iterator

typedef llvm::inst_iterator SVF::inst_iterator

Definition at line 249 of file BasicTypes.h.

◆ Instruction

typedef llvm::Instruction SVF::Instruction

Definition at line 87 of file BasicTypes.h.

◆ IntegerType

typedef llvm::IntegerType SVF::IntegerType

Definition at line 97 of file BasicTypes.h.

◆ InterPHISVFGNode

Definition at line 58 of file SVFG.h.

◆ IntraPHISVFGNode

Definition at line 57 of file SVFG.h.

◆ IntToPtrInst

typedef llvm::IntToPtrInst SVF::IntToPtrInst

Definition at line 166 of file BasicTypes.h.

◆ InvokeInst

typedef llvm::InvokeInst SVF::InvokeInst

Definition at line 163 of file BasicTypes.h.

◆ IRBuilder

typedef llvm::IRBuilder SVF::IRBuilder

Definition at line 74 of file BasicTypes.h.

◆ IRGraphReader

Definition at line 931 of file SVFFileSystem.h.

◆ IRGraphWriter

Definition at line 341 of file SVFFileSystem.h.

◆ KindBaseT

Definition at line 677 of file SVFFileSystem.h.

◆ Label

Definition at line 41 of file CFLSolver.h.

◆ LandingPadInst

typedef llvm::LandingPadInst SVF::LandingPadInst

Definition at line 172 of file BasicTypes.h.

◆ LLVMContext

typedef llvm::LLVMContext SVF::LLVMContext

Definition at line 70 of file BasicTypes.h.

◆ LoadInst

typedef llvm::LoadInst SVF::LoadInst

Definition at line 149 of file BasicTypes.h.

◆ LoadSVFGNode

Definition at line 54 of file SVFG.h.

◆ LocDPItem

Definition at line 48 of file FlowDDA.h.

◆ Loop

typedef llvm::Loop SVF::Loop

LLVM Loop.

Definition at line 140 of file BasicTypes.h.

◆ LoopInfo

typedef llvm::LoopInfo SVF::LoopInfo

Definition at line 141 of file BasicTypes.h.

◆ Map

template<typename Key , typename Value , typename Hash = Hash<Key>, typename KeyEqual = std::equal_to<Key>, typename Allocator = std::allocator<std::pair<const Key, Value>>>
using SVF::Map = typedef std::unordered_map<Key, Value, Hash, KeyEqual, Allocator>

Definition at line 101 of file GeneralType.h.

◆ MDNode

typedef llvm::MDNode SVF::MDNode

Definition at line 112 of file BasicTypes.h.

◆ MDString

typedef llvm::MDString SVF::MDString

Definition at line 101 of file BasicTypes.h.

◆ MemoryLocation

typedef llvm::MemoryLocation SVF::MemoryLocation

Definition at line 107 of file BasicTypes.h.

◆ MetadataAsValue

typedef llvm::MetadataAsValue SVF::MetadataAsValue

Definition at line 102 of file BasicTypes.h.

◆ Module

typedef llvm::Module SVF::Module

Definition at line 84 of file BasicTypes.h.

◆ ModulePass

typedef llvm::ModulePass SVF::ModulePass

Definition at line 73 of file BasicTypes.h.

◆ MRID

Definition at line 50 of file MemRegion.h.

◆ MRVERID

Definition at line 51 of file MemRegion.h.

◆ MRVERSION

Definition at line 52 of file MemRegion.h.

◆ NamedMDNode

typedef llvm::NamedMDNode SVF::NamedMDNode

LLVM metadata and debug information.

Definition at line 111 of file BasicTypes.h.

◆ NodeBS

Definition at line 62 of file GeneralType.h.

◆ NodeDeque

Definition at line 120 of file GeneralType.h.

◆ NodeID

Definition at line 55 of file GeneralType.h.

◆ NodeList

Definition at line 119 of file GeneralType.h.

◆ NodePair

Definition at line 111 of file GeneralType.h.

◆ NodePairMap

Definition at line 115 of file GeneralType.h.

◆ NodePairSet

Definition at line 114 of file GeneralType.h.

◆ NodePairVector

typedef std::vector<std::pair<NodeID, NodeID> > SVF::NodePairVector

Definition at line 139 of file CDG.h.

◆ NodeSet

Definition at line 113 of file GeneralType.h.

◆ NodeStack

Definition at line 118 of file GeneralType.h.

◆ NodeVector

Definition at line 116 of file GeneralType.h.

◆ NullPtrSVFGNode

Definition at line 49 of file SVFG.h.

◆ OrderedMap

template<typename Key , typename Value , typename Compare = std::less<Key>, typename Allocator = std::allocator<std::pair<const Key, Value>>>
using SVF::OrderedMap = typedef std::map<Key, Value, Compare, Allocator>

Definition at line 109 of file GeneralType.h.

◆ OrderedNodeSet

Definition at line 112 of file GeneralType.h.

◆ OrderedSet

template<typename Key , typename Compare = std::less<Key>, typename Allocator = std::allocator<Key>>
using SVF::OrderedSet = typedef std::set<Key, Compare, Allocator>

Definition at line 105 of file GeneralType.h.

◆ OutStream

typedef std::ostream SVF::OutStream

Definition at line 45 of file GeneralType.h.

◆ PAG

Definition at line 746 of file SVFIR.h.

◆ PAGEdge

Definition at line 43 of file IRGraph.h.

◆ PAGNode

Definition at line 42 of file IRGraph.h.

◆ PHINode

typedef llvm::PHINode SVF::PHINode

Definition at line 165 of file BasicTypes.h.

◆ PHISVFGNode

Definition at line 56 of file SVFG.h.

◆ PointerType

typedef llvm::PointerType SVF::PointerType

Definition at line 96 of file BasicTypes.h.

◆ PointsToID

Definition at line 63 of file GeneralType.h.

◆ PostDominatorTree

typedef llvm::PostDominatorTree SVF::PostDominatorTree

Definition at line 136 of file BasicTypes.h.

◆ raw_fd_ostream

typedef llvm::raw_fd_ostream SVF::raw_fd_ostream

LLVM outputs.

Definition at line 264 of file BasicTypes.h.

◆ raw_pointer_iterator

template<typename WrappedIteratorT , typename T1 = std::remove_reference_t<decltype( **std::declval<WrappedIteratorT>())>, typename T2 = std::add_pointer_t<T1>>
using SVF::raw_pointer_iterator = typedef pointer_iterator<pointee_iter<WrappedIteratorT, T1>, T2>

Definition at line 402 of file iterator.h.

◆ ResumeInst

typedef llvm::ResumeInst SVF::ResumeInst

Definition at line 173 of file BasicTypes.h.

◆ ReturnInst

typedef llvm::ReturnInst SVF::ReturnInst

Definition at line 157 of file BasicTypes.h.

◆ s16_t

Definition at line 53 of file GeneralType.h.

◆ s32_t

Definition at line 47 of file GeneralType.h.

◆ s64_t

Definition at line 49 of file GeneralType.h.

◆ s8_t

Definition at line 51 of file GeneralType.h.

◆ ScalarEvolution

typedef llvm::ScalarEvolution SVF::ScalarEvolution

Definition at line 260 of file BasicTypes.h.

◆ ScalarEvolutionWrapperPass

typedef llvm::ScalarEvolutionWrapperPass SVF::ScalarEvolutionWrapperPass

Definition at line 257 of file BasicTypes.h.

◆ SCEV

typedef llvm::SCEV SVF::SCEV

Definition at line 261 of file BasicTypes.h.

◆ SCEVAddRecExpr

typedef llvm::SCEVAddRecExpr SVF::SCEVAddRecExpr

Definition at line 258 of file BasicTypes.h.

◆ SCEVConstant

typedef llvm::SCEVConstant SVF::SCEVConstant

Definition at line 259 of file BasicTypes.h.

◆ SelectInst

typedef llvm::SelectInst SVF::SelectInst

Definition at line 174 of file BasicTypes.h.

◆ Set

template<typename Key , typename Hash = Hash<Key>, typename KeyEqual = std::equal_to<Key>, typename Allocator = std::allocator<Key>>
using SVF::Set = typedef std::unordered_set<Key, Hash, KeyEqual, Allocator>

Definition at line 96 of file GeneralType.h.

◆ ShuffleVectorInst

typedef llvm::ShuffleVectorInst SVF::ShuffleVectorInst

Definition at line 164 of file BasicTypes.h.

◆ SMDiagnostic

typedef llvm::SMDiagnostic SVF::SMDiagnostic

Definition at line 90 of file BasicTypes.h.

◆ StmtSVFGNode

Definition at line 50 of file SVFG.h.

◆ StoreInst

typedef llvm::StoreInst SVF::StoreInst

Definition at line 148 of file BasicTypes.h.

◆ StoreSVFGNode

Definition at line 53 of file SVFG.h.

◆ StructLayout

typedef llvm::StructLayout SVF::StructLayout

Definition at line 105 of file BasicTypes.h.

◆ StructType

typedef llvm::StructType SVF::StructType

LLVM types.

Definition at line 94 of file BasicTypes.h.

◆ succ_const_iterator

typedef llvm::succ_const_iterator SVF::succ_const_iterator

LLVM Iterators.

Definition at line 276 of file BasicTypes.h.

◆ SuccBBAndCondValPair

Definition at line 185 of file BasicTypes.h.

◆ SuccBBAndCondValPairVec

Definition at line 186 of file BasicTypes.h.

◆ SVFGEdge

Definition at line 42 of file SVFG.h.

◆ SVFGNode

Definition at line 43 of file SVFG.h.

◆ SwitchInst

typedef llvm::SwitchInst SVF::SwitchInst

Definition at line 155 of file BasicTypes.h.

◆ SymID

Definition at line 57 of file GeneralType.h.

◆ ThreadID

Definition at line 59 of file GeneralType.h.

◆ Type

typedef llvm::Type SVF::Type

Definition at line 83 of file BasicTypes.h.

◆ u16_t

Definition at line 52 of file GeneralType.h.

◆ u32_t

Definition at line 46 of file GeneralType.h.

◆ u64_t

Definition at line 48 of file GeneralType.h.

◆ u8_t

Definition at line 50 of file GeneralType.h.

◆ UnaryOperator

typedef llvm::UnaryOperator SVF::UnaryOperator

Definition at line 180 of file BasicTypes.h.

◆ UndefValue

typedef llvm::UndefValue SVF::UndefValue

Definition at line 181 of file BasicTypes.h.

◆ UnifyFunctionExitNodes

typedef llvm::UnifyFunctionExitNodes SVF::UnifyFunctionExitNodes

Definition at line 78 of file BasicTypes.h.

◆ UnreachableInst

typedef llvm::UnreachableInst SVF::UnreachableInst

Definition at line 170 of file BasicTypes.h.

◆ Use

typedef llvm::Use SVF::Use

Definition at line 72 of file BasicTypes.h.

◆ User

typedef llvm::User SVF::User

Definition at line 142 of file BasicTypes.h.

◆ VAArgInst

typedef llvm::VAArgInst SVF::VAArgInst

Definition at line 175 of file BasicTypes.h.

◆ VACopyInst

typedef llvm::VACopyInst SVF::VACopyInst

Definition at line 176 of file BasicTypes.h.

◆ VAEndInst

typedef llvm::VAEndInst SVF::VAEndInst

Definition at line 177 of file BasicTypes.h.

◆ Value

typedef llvm::Value SVF::Value

LLVM Basic classes.

Definition at line 82 of file BasicTypes.h.

◆ VAStartInst

typedef llvm::VAStartInst SVF::VAStartInst

Definition at line 178 of file BasicTypes.h.

◆ VectorType

typedef llvm::VectorType SVF::VectorType

Definition at line 267 of file BasicTypes.h.

◆ Version

Definition at line 123 of file GeneralType.h.

◆ VersionedVar

Definition at line 125 of file GeneralType.h.

◆ VersionedVarSet

Definition at line 126 of file GeneralType.h.

◆ VersionSet

Definition at line 124 of file GeneralType.h.

◆ VFunSet

Definition at line 47 of file CHG.h.

◆ VTableSet

Definition at line 46 of file CHG.h.

◆ WPAConstraintSolver

Abstract class of inclusion-based Pointer Analysis

Equivalence-based Pointer Analysis

Definition at line 55 of file Andersen.h.

◆ WPASVFGFSSolver

Flow sensitive whole program pointer analysis

Definition at line 48 of file FlowSensitive.h.

Enumeration Type Documentation

◆ AliasResult

Enumerator
NoAlias 
MayAlias 
MustAlias 
PartialAlias 

Definition at line 526 of file SVFType.h.

527{
528 NoAlias,
529 MayAlias,
530 MustAlias,
532};
@ PartialAlias
Definition SVFType.h:531
@ MustAlias
Definition SVFType.h:530
@ MayAlias
Definition SVFType.h:529
@ NoAlias
Definition SVFType.h:528

◆ BuildDirection

Enumerator
plain 
bidirection 

Definition at line 40 of file CFLGraphBuilder.h.

◆ ModRefInfo

Enumerator
ModRef 
Ref 
Mod 
NoModRef 

Definition at line 518 of file SVFType.h.

519{
520 ModRef,
521 Ref,
522 Mod,
523 NoModRef,
524};
@ Ref
Definition SVFType.h:521
@ NoModRef
Definition SVFType.h:523
@ ModRef
Definition SVFType.h:520
@ Mod
Definition SVFType.h:522

◆ ZeroBehavior

The behavior an operation has on an input of 0.

Enumerator
ZB_Undefined 

The returned value is undefined.

ZB_Max 

The returned value is numeric_limits<T>::max()

ZB_Width 

The returned value is numeric_limits<T>::digits.

Definition at line 36 of file SparseBitVector.h.

37{
41 ZB_Max,
44};
@ ZB_Undefined
The returned value is undefined.
@ ZB_Max
The returned value is numeric_limits<T>::max()
@ ZB_Width
The returned value is numeric_limits<T>::digits.

Function Documentation

◆ __attribute__()

SVF::__attribute__ ( (weak )

Definition at line 10 of file SVFType.cpp.

12{
13 std::ostringstream os;
14 print(os);
15 return os.str();
16}
17
18std::ostream& operator<<(std::ostream& os, const SVFType& type)
19{
20 type.print(os);
21 return os;
22}
static unsigned char * print(const cJSON *const item, cJSON_bool format, const internal_hooks *const hooks)
Definition cJSON.cpp:1189
newitem type
Definition cJSON.cpp:2739
llvm::IRBuilder IRBuilder
Definition BasicTypes.h:74

◆ children()

template<class GraphType >
iter_range< typename GenericGraphTraits< GraphType >::ChildIteratorType > SVF::children ( const typename GenericGraphTraits< GraphType >::NodeRef &  G)

Definition at line 126 of file GraphTraits.h.

◆ children_edges()

template<class GraphType >
iter_range< typename GenericGraphTraits< GraphType >::ChildEdgeIteratorType > SVF::children_edges ( const typename GenericGraphTraits< GraphType >::NodeRef &  G)

◆ countLeadingZeros()

template<typename T >
unsigned SVF::countLeadingZeros ( T  Val,
ZeroBehavior  ZB = ZB_Width 
)

Count number of 0's from the most significant bit to the least stopping at the first 1.

Only unsigned integral types are allowed.

Parameters
ZBthe behavior on an input of 0. Only ZB_Width and ZB_Undefined are valid arguments.

Definition at line 211 of file SparseBitVector.h.

212{
213 static_assert(std::numeric_limits<T>::is_integer &&
214 !std::numeric_limits<T>::is_signed,
215 "Only unsigned integral types are allowed.");
216 return LeadingZerosCounter<T, sizeof(T)>::count(Val, ZB);
217}
int count
Definition cJSON.h:216

◆ countPopulation()

template<typename T >
unsigned SVF::countPopulation ( T  Value)
inline

Count the number of set bits in a value. Ex. countPopulation(0xF000F000) = 8 Returns 0 if the word is zero.

Definition at line 239 of file SparseBitVector.h.

240{
241 static_assert(std::numeric_limits<T>::is_integer &&
242 !std::numeric_limits<T>::is_signed,
243 "Only unsigned integral types are allowed.");
244 return PopulationCounter<T, sizeof(T)>::count(Value);
245}
llvm::Value Value
LLVM Basic classes.
Definition BasicTypes.h:82

◆ countTrailingZeros()

template<typename T >
unsigned SVF::countTrailingZeros ( T  Val,
ZeroBehavior  ZB = ZB_Width 
)

Count number of 0's from the least significant bit to the most stopping at the first 1.

Only unsigned integral types are allowed.

Parameters
ZBthe behavior on an input of 0. Only ZB_Width and ZB_Undefined are valid arguments.

Definition at line 119 of file SparseBitVector.h.

120{
121 static_assert(std::numeric_limits<T>::is_integer &&
122 !std::numeric_limits<T>::is_signed,
123 "Only unsigned integral types are allowed.");
124 return TrailingZerosCounter<T, sizeof(T)>::count(Val, ZB);
125}

◆ createSVFType()

SVFType * SVF::createSVFType ( SVFType::GNodeK  kind,
bool  isSingleValTy 
)

Definition at line 17 of file SVFFileSystem.cpp.

18{
19 switch (kind)
20 {
21 default:
22 ABORT_MSG(kind << " is an impossible SVFTyKind in create()");
23 case SVFType::SVFTy:
24 ABORT_MSG("Creation of RAW SVFType isn't allowed");
25 case SVFType::SVFPointerTy:
26 ABORT_IFNOT(isSingleValTy, "Pointer type must be single-valued");
27 return new SVFPointerType();
28 case SVFType::SVFIntegerTy:
29 ABORT_IFNOT(isSingleValTy, "Integer type must be single-valued");
30 return new SVFIntegerType();
31 case SVFType::SVFFunctionTy:
32 ABORT_IFNOT(!isSingleValTy, "Function type must be multi-valued");
33 return new SVFFunctionType(nullptr);
34 case SVFType::SVFStructTy:
35 ABORT_IFNOT(!isSingleValTy, "Struct type must be multi-valued");
36 return new SVFStructType();
37 case SVFType::SVFArrayTy:
38 ABORT_IFNOT(!isSingleValTy, "Array type must be multi-valued");
39 return new SVFArrayType();
40 case SVFType::SVFOtherTy:
41 return new SVFOtherType(isSingleValTy);
42 }
43}
#define ABORT_MSG(msg)
#define ABORT_IFNOT(condition, msg)

◆ createSVFValue()

static SVFValue * SVF::createSVFValue ( SVFValue::GNodeK  kind,
const SVFType type,
std::string &&  name 
)
static

Definition at line 45 of file SVFFileSystem.cpp.

47{
48 auto creator = [=]() -> SVFValue*
49 {
50 switch (kind)
51 {
52 default:
53 ABORT_MSG(kind << " is an impossible SVFValueKind in create()");
54 case SVFValue::SVFVal:
55 ABORT_MSG("Creation of RAW SVFValue isn't allowed");
56 case SVFValue::SVFFunc:
57 return new SVFFunction(type, {}, {}, {}, {}, {}, {});
58 case SVFValue::SVFBB:
59 return new SVFBasicBlock(type, {});
60 case SVFValue::SVFInst:
61 return new SVFInstruction(type, {}, {}, {});
62 case SVFValue::SVFCall:
63 return new SVFCallInst(type, {}, {}, {});
64 case SVFValue::SVFGlob:
65 return new SVFGlobalValue(type);
66 case SVFValue::SVFArg:
67 return new SVFArgument(type, {}, {}, {});
68 case SVFValue::SVFConst:
69 return new SVFConstant(type);
70 case SVFValue::SVFConstData:
71 return new SVFConstantData(type);
72 case SVFValue::SVFConstInt:
73 return new SVFConstantInt(type, {}, {});
74 case SVFValue::SVFConstFP:
75 return new SVFConstantFP(type, {});
76 case SVFValue::SVFNullPtr:
77 return new SVFConstantNullPtr(type);
78 case SVFValue::SVFBlackHole:
79 return new SVFBlackHoleValue(type);
80 case SVFValue::SVFMetaAsValue:
81 return new SVFMetadataAsValue(type);
82 case SVFValue::SVFOther:
83 return new SVFOtherValue(type);
84 }
85 };
86 auto val = creator();
87 val->setName(std::move(name));
88 return val;
89}
const char *const name
Definition cJSON.h:264

◆ dump()

template<unsigned ElementSize>
void SVF::dump ( const SparseBitVector< ElementSize > &  LHS,
std::ostream &  out 
)

Definition at line 1233 of file SparseBitVector.h.

1234{
1235 out << "[";
1236
1238 be = LHS.end();
1239 if (bi != be)
1240 {
1241 out << *bi;
1242 for (++bi; bi != be; ++bi)
1243 {
1244 out << " " << *bi;
1245 }
1246 }
1247 out << "]\n";
1248}

◆ dumpLLVMValue()

std::string SVF::dumpLLVMValue ( const SVFValue svfValue)

[FOR DEBUG ONLY, DON'T USE IT UNSIDE svf!] Converts an SVFValue to corresponding LLVM::Value, then get the string representation of it. Use it only when you are debugging. Don't use it in any SVF algorithm because it relies on information stored in LLVM bc.

◆ inverse_children()

template<class GraphType >
iter_range< typename GenericGraphTraits< Inverse< GraphType > >::ChildIteratorType > SVF::inverse_children ( const typename GenericGraphTraits< GraphType >::NodeRef &  G)

Definition at line 134 of file GraphTraits.h.

135{
136 return make_range(GenericGraphTraits<Inverse<GraphType>>::child_begin(G),
138}

◆ inverse_nodes()

template<class GraphType >
iter_range< typename GenericGraphTraits< Inverse< GraphType > >::nodes_iterator > SVF::inverse_nodes ( const GraphType &  G)

Definition at line 118 of file GraphTraits.h.

119{
120 return make_range(GenericGraphTraits<Inverse<GraphType>>::nodes_begin(G),
122}

◆ jsonAddItemToArray()

bool SVF::jsonAddItemToArray ( cJSON array,
cJSON item 
)

Definition at line 936 of file SVFFileSystem.cpp.

937{
939}
cJSON * item
Definition cJSON.h:222

◆ jsonAddItemToObject()

bool SVF::jsonAddItemToObject ( cJSON obj,
const char name,
cJSON item 
)

Definition at line 930 of file SVFFileSystem.cpp.

931{
934}
static const Option< bool > humanReadableOption("human-readable", "Whether to output human-readable JSON", true)

◆ jsonAddNumberToObject()

bool SVF::jsonAddNumberToObject ( cJSON obj,
const char name,
double  number 
)

Helper function to write a number to a JSON object.

Definition at line 779 of file SVFFileSystem.cpp.

780{
782 return jsonAddItemToObject(obj, name, node);
783}
const char *const const double number
Definition cJSON.h:268
bool jsonAddItemToObject(cJSON *obj, const char *name, cJSON *item)
Definition cJSON.h:104

◆ jsonAddPairToMap()

bool SVF::jsonAddPairToMap ( cJSON obj,
cJSON key,
cJSON value 
)

Definition at line 921 of file SVFFileSystem.cpp.

922{
925 jsonAddItemToArray(pair, value);
927 return pair;
928}
bool jsonAddItemToArray(cJSON *array, cJSON *item)

◆ jsonAddStringToObject() [1/2]

bool SVF::jsonAddStringToObject ( cJSON obj,
const char name,
const char str 
)

Definition at line 785 of file SVFFileSystem.cpp.

786{
788 return jsonAddItemToObject(obj, name, node);
789}

◆ jsonAddStringToObject() [2/2]

bool SVF::jsonAddStringToObject ( cJSON obj,
const char name,
const std::string &  s 
)

Definition at line 791 of file SVFFileSystem.cpp.

792{
793 return jsonAddStringToObject(obj, name, s.c_str());
794}
bool jsonAddStringToObject(cJSON *obj, const char *name, const char *str)

◆ jsonCreateArray()

cJSON * SVF::jsonCreateArray ( )

Definition at line 886 of file SVFFileSystem.cpp.

887{
888 return cJSON_CreateArray();
889}

◆ jsonCreateBool()

cJSON * SVF::jsonCreateBool ( bool  flag)

Definition at line 910 of file SVFFileSystem.cpp.

911{
912 bool hr = humanReadableOption();
914}

◆ jsonCreateIndex()

cJSON * SVF::jsonCreateIndex ( size_t  index)

Definition at line 902 of file SVFFileSystem.cpp.

903{
904 constexpr size_t maxPreciseIntInDouble = (1ull << 53);
905 (void)maxPreciseIntInDouble; // silence unused warning
908}
int index
Definition cJSON.h:170

◆ jsonCreateMap()

cJSON * SVF::jsonCreateMap ( )

Definition at line 891 of file SVFFileSystem.cpp.

892{
893 // Don't use cJSON_CreateObject() here, because it only allows string keys.
894 return cJSON_CreateArray();
895}

◆ jsonCreateNullId()

cJSON * SVF::jsonCreateNullId ( )

Definition at line 875 of file SVFFileSystem.cpp.

876{
877 // TODO: optimize
878 return cJSON_CreateNull();
879}

◆ jsonCreateNumber()

cJSON * SVF::jsonCreateNumber ( double  num)

Definition at line 916 of file SVFFileSystem.cpp.

917{
918 return cJSON_CreateNumber(num);
919}

◆ jsonCreateObject()

cJSON * SVF::jsonCreateObject ( )

Definition at line 881 of file SVFFileSystem.cpp.

882{
884}

◆ jsonCreateString()

cJSON * SVF::jsonCreateString ( const char str)

Definition at line 897 of file SVFFileSystem.cpp.

898{
900}

◆ jsonGetNumber()

double SVF::jsonGetNumber ( const cJSON item)

Definition at line 869 of file SVFFileSystem.cpp.

870{
871 ABORT_IFNOT(jsonIsNumber(item), "Expected number for " << JSON_KEY(item));
872 return item->valuedouble;
873}
#define JSON_KEY(json)
bool jsonIsNumber(const cJSON *item)
double valuedouble
Definition cJSON.h:119

◆ jsonIsArray()

bool SVF::jsonIsArray ( const cJSON item)

Definition at line 838 of file SVFFileSystem.cpp.

839{
840 return cJSON_IsArray(item);
841}

◆ jsonIsBool() [1/2]

bool SVF::jsonIsBool ( const cJSON item)

Definition at line 796 of file SVFFileSystem.cpp.

797{
798 return humanReadableOption()
800 : cJSON_IsNumber(item) &&
801 (item->valuedouble == 0 || item->valuedouble == 1);
802}
newitem valuedouble
Definition cJSON.cpp:2741

◆ jsonIsBool() [2/2]

bool SVF::jsonIsBool ( const cJSON item,
bool flag 
)

Definition at line 804 of file SVFFileSystem.cpp.

805{
807 {
808 if (!cJSON_IsBool(item))
809 return false;
811 return true;
812 }
813 else
814 {
815 if (!cJSON_IsNumber(item))
816 return false;
817 flag = item->valuedouble == 1;
818 return true;
819 }
820}

◆ jsonIsMap()

bool SVF::jsonIsMap ( const cJSON item)

Definition at line 843 of file SVFFileSystem.cpp.

844{
845 return cJSON_IsArray(item);
846}

◆ jsonIsNullId()

bool SVF::jsonIsNullId ( const cJSON item)

Definition at line 832 of file SVFFileSystem.cpp.

833{
834 // TODO: optimize
835 return cJSON_IsNull(item);
836}

◆ jsonIsNumber()

bool SVF::jsonIsNumber ( const cJSON item)

Definition at line 822 of file SVFFileSystem.cpp.

823{
824 return cJSON_IsNumber(item);
825}

◆ jsonIsObject()

bool SVF::jsonIsObject ( const cJSON item)

Definition at line 848 of file SVFFileSystem.cpp.

849{
851}

◆ jsonIsString()

bool SVF::jsonIsString ( const cJSON item)

Definition at line 827 of file SVFFileSystem.cpp.

828{
829 return cJSON_IsString(item);
830}

◆ jsonKeyEquals()

bool SVF::jsonKeyEquals ( const cJSON item,
const char key 
)

Definition at line 853 of file SVFFileSystem.cpp.

854{
855 return item && !(humanReadableOption() && std::strcmp(item->string, key));
856}
char * string
Definition cJSON.h:122

◆ jsonUnpackPair()

std::pair< const cJSON *, const cJSON * > SVF::jsonUnpackPair ( const cJSON item)

Definition at line 858 of file SVFFileSystem.cpp.

859{
860 ABORT_IFNOT(jsonIsArray(item), "Expected array as pair");
862 ABORT_IFNOT(child1, "Missing first child of pair");
864 ABORT_IFNOT(child2, "Missing first child of pair");
865 ABORT_IFNOT(!child2->next, "Pair has more than two children");
866 return {child1, child2};
867}
bool jsonIsArray(const cJSON *item)
struct cJSON * child
Definition cJSON.h:109
struct cJSON * next
Definition cJSON.h:106

◆ KIND_BASE() [1/8]

SVF::KIND_BASE ( CHEdge  ,
getEdgeKind   
)

◆ KIND_BASE() [2/8]

SVF::KIND_BASE ( CHNode  ,
getNodeKind   
)

◆ KIND_BASE() [3/8]

SVF::KIND_BASE ( ICFGEdge  ,
getEdgeKind   
)

◆ KIND_BASE() [4/8]

SVF::KIND_BASE ( ICFGNode  ,
getNodeKind   
)

◆ KIND_BASE() [5/8]

SVF::KIND_BASE ( SVFStmt  ,
getEdgeKind   
)

◆ KIND_BASE() [6/8]

SVF::KIND_BASE ( SVFType  ,
getKind   
)

◆ KIND_BASE() [7/8]

SVF::KIND_BASE ( SVFValue  ,
getKind   
)

◆ KIND_BASE() [8/8]

SVF::KIND_BASE ( SVFVar  ,
getNodeKind   
)

◆ make_pointee_range()

template<typename RangeT , typename WrappedIteratorT = decltype(std::begin(std::declval<RangeT>()))>
iter_range< pointee_iter< WrappedIteratorT > > SVF::make_pointee_range ( RangeT &&  Range)

Definition at line 355 of file iterator.h.

356{
358 return make_range(PointeeIteratorT(std::begin(std::forward<RangeT>(Range))),
359 PointeeIteratorT(std::end(std::forward<RangeT>(Range))));
360}

◆ make_pointer_range()

template<typename RangeT , typename WrappedIteratorT = decltype(std::begin(std::declval<RangeT>()))>
iter_range< pointer_iterator< WrappedIteratorT > > SVF::make_pointer_range ( RangeT &&  Range)

Definition at line 391 of file iterator.h.

392{
394 return make_range(PointerIteratorT(std::begin(std::forward<RangeT>(Range))),
395 PointerIteratorT(std::end(std::forward<RangeT>(Range))));
396}

◆ make_range() [1/2]

template<typename T >
iter_range< T > SVF::make_range ( std::pair< T, T p)

Definition at line 69 of file iterator_range.h.

70{
71 return iter_range<T>(std::move(p.first), std::move(p.second));
72}
cJSON * p
Definition cJSON.cpp:2559

◆ make_range() [2/2]

template<class T >
iter_range< T > SVF::make_range ( T  x,
T  y 
)

Convenience function for iterating over sub-ranges.

This provides a bit of syntactic sugar to make using sub-ranges in for loops a bit easier. Analogous to std::make_pair().

Definition at line 64 of file iterator_range.h.

65{
66 return iter_range<T>(std::move(x), std::move(y));
67}

◆ map_iter()

template<class ItTy , class FuncTy >
mapped_iter< ItTy, FuncTy > SVF::map_iter ( ItTy  I,
FuncTy  F 
)
inline

Definition at line 721 of file GenericGraph.h.

722{
723 return mapped_iter<ItTy, FuncTy>(std::move(I), std::move(F));
724}
#define F(f)

◆ nodes()

template<class GraphType >
iter_range< typename GenericGraphTraits< GraphType >::nodes_iterator > SVF::nodes ( const GraphType &  G)

◆ operator%()

Divide IntervalValues.

Definition at line 645 of file IntervalValue.h.

647{
648 if (lhs.isBottom() || rhs.isBottom())
649 {
650 return IntervalValue::bottom();
651 }
652 else if (rhs.contains(0))
653 {
654 return lhs.is_zero() ? IntervalValue(0, 0) : IntervalValue::top();
655 }
656 else if (lhs.is_numeral() && rhs.is_numeral())
657 {
658 return IntervalValue(lhs.lb() % rhs.lb(), lhs.lb() % rhs.lb());
659 }
660 else
661 {
662 BoundedInt n_ub = max(abs(lhs.lb()), abs(lhs.ub()));
663 BoundedInt d_ub = max(abs(rhs.lb()), rhs.ub()) - 1;
664 BoundedInt ub = min(n_ub, d_ub);
665
666 if (lhs.lb().getNumeral() < 0)
667 {
668 if (lhs.ub().getNumeral() > 0)
669 {
670 return IntervalValue(-ub, ub);
671 }
672 else
673 {
674 return IntervalValue(-ub, 0);
675 }
676 }
677 else
678 {
679 return IntervalValue(0, ub);
680 }
681 }
682}
s64_t getNumeral() const
Retrieves the numeral value of the BoundedInt object.
const BoundedInt & ub() const
Return the upper bound.
bool is_numeral() const
Return true if the IntervalValue is a number [num, num].
bool is_zero() const
Return true if the IntervalValue is [0, 0].
const BoundedInt & lb() const
Return the lower bound.
bool contains(int n) const
Return true if the IntervalValue contains n.

◆ operator&() [1/3]

Bitwise AND of IntervalValues.

Definition at line 962 of file IntervalValue.h.

963{
964 if (lhs.isBottom() || rhs.isBottom())
965 return IntervalValue::bottom();
966 else if (lhs.is_numeral() && rhs.is_numeral())
967 {
968 return IntervalValue(lhs.lb() & rhs.lb());
969 }
970 else if (lhs.lb().getNumeral() >= 0 && rhs.lb().getNumeral() >= 0)
971 {
972 return IntervalValue((s64_t) 0, min(lhs.ub(), rhs.ub()));
973 }
974 else if (lhs.lb().getNumeral() >= 0)
975 {
976 return IntervalValue((s64_t) 0, lhs.ub());
977 }
978 else if (rhs.lb().getNumeral() >= 0)
979 {
980 return IntervalValue((s64_t) 0, rhs.ub());
981 }
982 else
983 {
984 return IntervalValue::top();
985 }
986}

◆ operator&() [2/3]

Returns a new lhs & rhs.

Definition at line 573 of file PointsTo.cpp.

574{
575 // TODO: optimise.
577 result &= rhs;
578 return result;
579}

◆ operator&() [3/3]

template<unsigned ElementSize>
SparseBitVector< ElementSize > SVF::operator& ( const SparseBitVector< ElementSize > &  LHS,
const SparseBitVector< ElementSize > &  RHS 
)
inline

Definition at line 1213 of file SparseBitVector.h.

1215{
1217 Result &= RHS;
1218 return Result;
1219}

◆ operator&=() [1/2]

template<unsigned ElementSize>
bool SVF::operator&= ( SparseBitVector< ElementSize > &  LHS,
const SparseBitVector< ElementSize > *  RHS 
)
inline

Definition at line 1193 of file SparseBitVector.h.

1195{
1196 return LHS &= *RHS;
1197}

◆ operator&=() [2/2]

template<unsigned ElementSize>
bool SVF::operator&= ( SparseBitVector< ElementSize > *  LHS,
const SparseBitVector< ElementSize > &  RHS 
)
inline

Definition at line 1186 of file SparseBitVector.h.

1188{
1189 return LHS->operator&=(RHS);
1190}

◆ operator*()

Multiply IntervalValues.

Definition at line 583 of file IntervalValue.h.

585{
586 if (lhs.isBottom() || rhs.isBottom())
587 {
588 return IntervalValue::bottom();
589 }
590 else
591 {
592 BoundedInt ll = lhs.lb() * rhs.lb();
593 BoundedInt lu = lhs.lb() * rhs.ub();
594 BoundedInt ul = lhs.ub() * rhs.lb();
595 BoundedInt uu = lhs.ub() * rhs.ub();
596 std::vector<BoundedInt> vec{ll, lu, ul, uu};
597 return IntervalValue(BoundedInt::min(vec),
598 BoundedInt::max(vec));
599 }
600}

◆ operator+()

Add IntervalValues.

Definition at line 547 of file IntervalValue.h.

549{
550 if (lhs.isBottom() || rhs.isBottom())
551 {
552 return IntervalValue::bottom();
553 }
554 else if (lhs.isTop() || rhs.isTop())
555 {
556 return IntervalValue::top();
557 }
558 else
559 {
560 return IntervalValue(lhs.lb() + rhs.lb(), lhs.ub() + rhs.ub());
561 }
562}
bool isTop() const

◆ operator-() [1/3]

Subtract IntervalValues.

Definition at line 565 of file IntervalValue.h.

567{
568 if (lhs.isBottom() || rhs.isBottom())
569 {
570 return IntervalValue::bottom();
571 }
572 else if (lhs.isTop() || rhs.isTop())
573 {
574 return IntervalValue::top();
575 }
576 else
577 {
578 return IntervalValue(lhs.lb() - rhs.ub(), lhs.ub() - rhs.lb());
579 }
580}

◆ operator-() [2/3]

Returns a new lhs - rhs.

Definition at line 581 of file PointsTo.cpp.

582{
583 // TODO: optimise.
585 result -= rhs;
586 return result;
587}

◆ operator-() [3/3]

template<unsigned ElementSize>
SparseBitVector< ElementSize > SVF::operator- ( const SparseBitVector< ElementSize > &  LHS,
const SparseBitVector< ElementSize > &  RHS 
)
inline

Definition at line 1223 of file SparseBitVector.h.

1225{
1227 Result.intersectWithComplement(LHS, RHS);
1228 return Result;
1229}

◆ operator/()

Divide IntervalValues.

Definition at line 603 of file IntervalValue.h.

605{
606 if (lhs.isBottom() || rhs.isBottom())
607 {
608 return IntervalValue::bottom();
609 }
610 else if (rhs.contains(0))
611 {
612 IntervalValue lb = IntervalValue::create(rhs.lb(), -1);
613 IntervalValue ub = IntervalValue::create(1, rhs.ub());
614 IntervalValue l_res = lhs / lb;
615 IntervalValue r_res = lhs / ub;
616 l_res.join_with(r_res);
617 return l_res;
618 }
619 else if (lhs.contains(0))
620 {
621 IntervalValue lb = IntervalValue::create(lhs.lb(), -1);
622 IntervalValue ub = IntervalValue::create(1, lhs.ub());
623 IntervalValue l_res = lb / rhs;
624 IntervalValue r_res = ub / rhs;
625 l_res.join_with(r_res);
626 l_res.join_with(IntervalValue(0));
627 return l_res;
628 }
629 else
630 {
631 // Neither the dividend nor the divisor contains 0
632 BoundedInt ll = lhs.lb() / rhs.lb();
633 BoundedInt lu = lhs.lb() / rhs.ub();
634 BoundedInt ul = lhs.ub() / rhs.lb();
635 BoundedInt uu = lhs.ub() / rhs.ub();
636 std::vector<BoundedInt> vec{ll, lu, ul, uu};
637
638 IntervalValue res = IntervalValue(BoundedInt::min(vec),
639 BoundedInt::max(vec));
640 return res;
641 }
642}
void join_with(const IntervalValue &other)
Current IntervalValue joins with another IntervalValue.

◆ operator<()

Definition at line 736 of file IntervalValue.h.

737{
738 // If either lhs or rhs is bottom, the result is bottom
739 if (lhs.isBottom() || rhs.isBottom())
740 {
741 return IntervalValue::bottom();
742 }
743 // If either lhs or rhs is top, the result is top
744 else if (lhs.isTop() || rhs.isTop())
745 {
746 return IntervalValue::top();
747 }
748 else
749 {
750 // If both lhs and rhs are numerals (lb = ub), directly compare their values
751 if (lhs.is_numeral() && rhs.is_numeral())
752 {
753 // It means lhs.lb() < rhs.lb()? true: false
754 return lhs.lb().geq(rhs.lb()) ? IntervalValue(0, 0) : IntervalValue(1, 1);
755 }
756 else
757 {
758 // Return [1,1] means lhs is totally less than rhs
759 // When lhs.ub < rhs.lb, e.g., lhs:[1, 2] rhs:[3, 4]
760 // lhs.ub(2) < rhs.lb(3)
761 // It means lhs.ub() < rhs.lb()
762 if (!lhs.ub().geq(rhs.lb()))
763 {
764 return IntervalValue(1, 1);
765 }
766 // Return [0,0] means lhs is totally impossible to be less than rhs
767 // i.e., lhs is totally greater than or equal to rhs
768 // When lhs.lb >= rhs.ub, e.g., lhs:[4,5] rhs:[3,4]
769 // lhs.lb(4) >= rhs.ub(4)
770 else if (lhs.lb().geq(rhs.ub()))
771 {
772 return IntervalValue(0, 0);
773 }
774 // For other cases, lhs can be less than rhs or not, depending on the values
775 // e.g., lhs: [2,4], rhs: [1,3],
776 // lhs can be less than rhs if lhs is 2, rhs is 3.
777 // lhs can also not be less than rhs if lhs is 4 and rhs is 1
778 else
779 {
780 return IntervalValue(0, 1);
781 }
782 }
783 }
784}
bool geq(const BoundedInt &rhs) const

◆ operator<<() [1/5]

Left binary shift of IntervalValues.

Definition at line 888 of file IntervalValue.h.

889{
890 //TODO: implement <<
891 if (lhs.isBottom() || rhs.isBottom())
892 return IntervalValue::bottom();
893 if (lhs.isTop() && rhs.isTop())
894 return IntervalValue::top();
895 else
896 {
898 shift.meet_with(IntervalValue(0, IntervalValue::plus_infinity()));
899 if (shift.isBottom())
900 return IntervalValue::bottom();
901 BoundedInt lb = 0;
902 // If the shift is greater than 32, the result is always 0
903 if ((s32_t) shift.lb().getNumeral() >= 32 || shift.lb().is_infinity())
904 {
905 lb = IntervalValue::minus_infinity();
906 }
907 else
908 {
909 lb = (1 << (s32_t) shift.lb().getNumeral());
910 }
911 BoundedInt ub = 0;
912 if (shift.ub().is_infinity())
913 {
914 ub = IntervalValue::plus_infinity();
915 }
916 else
917 {
918 ub = (1 << (s32_t) shift.ub().getNumeral());
919 }
920 IntervalValue coeff(lb, ub);
921 return lhs * coeff;
922 }
923}
A class representing a bounded 64-bit integer.
bool is_infinity() const
void meet_with(const IntervalValue &other)
Return a intersected IntervalValue.
signed s32_t
Definition GeneralType.h:47

◆ operator<<() [2/5]

template<typename F , typename S >
OutStream & SVF::operator<< ( OutStream o,
const std::pair< F, S > &  var 
)

Definition at line 1036 of file SVFValue.h.

1037{
1038 o << "<" << var.first << ", " << var.second << ">";
1039 return o;
1040}

◆ operator<<() [3/5]

std::ostream & SVF::operator<< ( std::ostream &  o,
const IntervalValue IntervalValue 
)
inline

Write an IntervalValue on a stream.

Definition at line 1047 of file IntervalValue.h.

1049{
1051 return o;
1052}
void dump(std::ostream &o) const

◆ operator<<() [4/5]

std::ostream & SVF::operator<< ( std::ostream &  o,
const MRVer mrver 
)

Definition at line 811 of file MemRegion.cpp.

812{
813 o << "MRVERID: " << mrver.getID() <<" MemRegion: " << mrver.getMR()->dumpStr() << " MRVERSION: " << mrver.getSSAVersion() << " MSSADef: " << mrver.getDef()->getType() << ", "
814 << mrver.getDef()->getMR()->dumpStr() ;
815 return o;
816}

◆ operator<<() [5/5]

std::ostream & SVF::operator<< ( std::ostream &  os,
const SVFType type 
)

◆ operator<=()

Definition at line 838 of file IntervalValue.h.

839{
840 // If either lhs or rhs is bottom, the result is bottom
841 if (lhs.isBottom() || rhs.isBottom())
842 {
843 return IntervalValue::bottom();
844 }
845 // If either lhs or rhs is top, the result is top
846 else if (lhs.isTop() || rhs.isTop())
847 {
848 return IntervalValue::top();
849 }
850 else
851 {
852 // If both lhs and rhs are numerals (lb = ub), directly compare their values
853 if (lhs.is_numeral() && rhs.is_numeral())
854 {
855 return lhs.lb().leq(rhs.lb()) ? IntervalValue(1, 1) : IntervalValue(0, 0);
856 }
857 else
858 {
859 // Return [1,1] means lhs is totally less than or equal to rhs
860 // When lhs.ub <= rhs.lb, e.g., lhs:[1, 2] rhs:[2, 3]
861 // lhs.ub(2) <= rhs.lb(2)
862 if (lhs.ub().leq(rhs.lb()))
863 {
864 return IntervalValue(1, 1);
865 }
866 // Return [0,0] means lhs is totally impossible to be less than or equal to rhs
867 // i.e., lhs is totally greater than rhs
868 // When lhs.lb > rhs.ub, e.g., lhs:[3, 4] rhs:[1, 2]
869 // lhs.lb(3) > rhs.ub(2)
870 // It means lhs.lb() > rhs.ub()
871 else if (!lhs.lb().leq(rhs.ub()))
872 {
873 return IntervalValue(0, 0);
874 }
875 // For other cases, lhs can be less than or equal to rhs or not, depending on the values
876 // e.g., lhs: [2,4], rhs: [1,3],
877 // lhs can be less than or equal to rhs if lhs is 3, rhs is 3.
878 // lhs can also not be less than or equal to rhs if lhs is 3 and rhs is 2
879 else
880 {
881 return IntervalValue(0, 1);
882 }
883 }
884 }
885}
bool leq(const BoundedInt &rhs) const

◆ operator>()

Definition at line 685 of file IntervalValue.h.

686{
687 // If either lhs or rhs is bottom, the result is bottom
688 if (lhs.isBottom() || rhs.isBottom())
689 {
690 return IntervalValue::bottom();
691 }
692 // If either lhs or rhs is top, the result is top
693 else if (lhs.isTop() || rhs.isTop())
694 {
695 return IntervalValue::top();
696 }
697 else
698 {
699 // If both lhs and rhs are numerals (lb = ub), directly compare their values
700 if (lhs.is_numeral() && rhs.is_numeral())
701 {
702 // It means lhs.lb() > rhs.lb()? true: false
703 return lhs.lb().leq(rhs.lb()) ? IntervalValue(0, 0) : IntervalValue(1, 1);
704 }
705 else
706 {
707 // Return [1,1] means lhs is totally greater than rhs
708 // When lhs.lb > rhs.ub, e.g., lhs:[3, 4] rhs:[1, 2]
709 // lhs.lb(3) > rhs.ub(2)
710 // It means lhs.lb() > rhs.ub()
711 if (!lhs.lb().leq(rhs.ub()))
712 {
713 return IntervalValue(1, 1);
714 }
715 // Return [0,0] means lhs is totally impossible to be greater than rhs
716 // i.e., lhs is totally less than or equal to rhs
717 // When lhs.ub <= rhs.lb, e.g., lhs:[3, 4] rhs:[4,5]
718 // lhs.ub(4) <= rhs.lb(4)
719 else if (lhs.ub().leq(rhs.lb()))
720 {
721 return IntervalValue(0, 0);
722 }
723 // For other cases, lhs can be greater than or not, depending on the values
724 // e.g., lhs: [2,4], rhs: [1,3],
725 // lhs can be greater than rhs if lhs is 4 and rhs is 1.
726 // lhs can also not be greater than rhs if lhs is 2 and rhs is 3
727 else
728 {
729 return IntervalValue(0, 1);
730 }
731 }
732 }
733}

◆ operator>=()

Definition at line 788 of file IntervalValue.h.

789{
790 // If either lhs or rhs is bottom, the result is bottom
791 if (lhs.isBottom() || rhs.isBottom())
792 {
793 return IntervalValue::bottom();
794 }
795 // If either lhs or rhs is top, the result is top
796 else if (lhs.isTop() || rhs.isTop())
797 {
798 return IntervalValue::top();
799 }
800 else
801 {
802 // If both lhs and rhs are numerals (lb = ub), directly compare their values
803 if (lhs.is_numeral() && rhs.is_numeral())
804 {
805 return lhs.lb().geq(rhs.lb()) ? IntervalValue(1, 1) : IntervalValue(0, 0);
806 }
807 else
808 {
809 // Return [1,1] means lhs is totally greater than or equal to rhs
810 // When lhs.lb >= rhs.ub, e.g., lhs:[2, 3] rhs:[1, 2]
811 // lhs.lb(2) >= rhs.ub(2)
812 if (lhs.lb().geq(rhs.ub()))
813 {
814 return IntervalValue(1, 1);
815 }
816 // Return [0,0] means lhs is totally impossible to be greater than or equal to rhs
817 // i.e., lhs is totally less than rhs
818 // When lhs.ub < rhs.lb, e.g., lhs:[1, 2] rhs:[3, 4]
819 // lhs.ub(2) < rhs.lb(3)
820 // It means lhs.ub() < rhs.lb()
821 else if (!lhs.ub().geq(rhs.lb()))
822 {
823 return IntervalValue(0, 0);
824 }
825 // For other cases, lhs can be greater than or equal to rhs or not, depending on the values
826 // e.g., lhs: [2,4], rhs: [1,3],
827 // lhs can be greater than or equal to rhs if lhs is 3, rhs is 2.
828 // lhs can also not be greater than or equal to rhs if lhs is 2 and rhs is 3
829 else
830 {
831 return IntervalValue(0, 1);
832 }
833 }
834 }
835}

◆ operator>>()

Left binary shift of IntervalValues.

Definition at line 926 of file IntervalValue.h.

927{
928 //TODO: implement >>
929 if (lhs.isBottom() || rhs.isBottom())
930 return IntervalValue::bottom();
931 else if (lhs.isTop() && rhs.isTop())
932 return IntervalValue::top();
933 else
934 {
936 shift.meet_with(IntervalValue(0, IntervalValue::plus_infinity()));
937 if (shift.isBottom())
938 return IntervalValue::bottom();
939 if (lhs.contains(0))
940 {
941 IntervalValue l = IntervalValue::create(lhs.lb(), -1);
942 IntervalValue u = IntervalValue::create(1, lhs.ub());
943 IntervalValue tmp = l >> rhs;
944 tmp.join_with(u >> rhs);
945 tmp.join_with(IntervalValue(0));
946 return tmp;
947 }
948 else
949 {
950 BoundedInt ll = lhs.lb() >> shift.lb();
951 BoundedInt lu = lhs.lb() >> shift.ub();
952 BoundedInt ul = lhs.ub() >> shift.lb();
953 BoundedInt uu = lhs.ub() >> shift.ub();
954 std::vector<BoundedInt> vec{ll, lu, ul, uu};
955 return IntervalValue(BoundedInt::min(vec),
956 BoundedInt::max(vec));
957 }
958 }
959}

◆ operator^()

Bitwise XOR of IntervalValues.

Definition at line 1018 of file IntervalValue.h.

1019{
1020 auto next_power_of_2 = [](s64_t num)
1021 {
1022 int i = 1;
1023 while ((num >> i) != 0)
1024 {
1025 ++i;
1026 }
1027 return 1 << i;
1028 };
1029 if (lhs.isBottom() || rhs.isBottom())
1030 return IntervalValue::bottom();
1031 else if (lhs.is_numeral() && rhs.is_numeral())
1032 return IntervalValue(lhs.lb() ^ rhs.lb());
1033 else if (lhs.lb().getNumeral() >= 0 && !lhs.ub().is_infinity() &&
1034 rhs.lb().getNumeral() >= 0 && !rhs.ub().is_infinity())
1035 {
1036 s64_t m = std::max(lhs.ub().getNumeral(), rhs.ub().getNumeral());
1037 s64_t ub = next_power_of_2(s64_t(m)) - 1;
1038 return IntervalValue((s64_t) 0, (s64_t) ub);
1039 }
1040 else
1041 {
1042 return IntervalValue::top();
1043 }
1044}
bool isBottom() const
signed long long s64_t
Definition GeneralType.h:49

◆ operator|() [1/3]

Bitwise OR of IntervalValues.

Definition at line 989 of file IntervalValue.h.

990{
991 auto next_power_of_2 = [](s64_t num)
992 {
993 int i = 1;
994 while ((num >> i) != 0)
995 {
996 ++i;
997 }
998 return 1 << i;
999 };
1000 if (lhs.isBottom() || rhs.isBottom())
1001 return IntervalValue::bottom();
1002 else if (lhs.is_numeral() && rhs.is_numeral())
1003 return IntervalValue(lhs.lb() | rhs.lb());
1004 else if (lhs.lb().getNumeral() >= 0 && !lhs.ub().is_infinity() &&
1005 rhs.lb().getNumeral() >= 0 && !rhs.ub().is_infinity())
1006 {
1007 s64_t m = std::max(lhs.ub().getNumeral(), rhs.ub().getNumeral());
1008 s64_t ub = next_power_of_2(s64_t(m)) - 1;
1009 return IntervalValue((s64_t) 0, (s64_t) ub);
1010 }
1011 else
1012 {
1013 return IntervalValue::top();
1014 }
1015}

◆ operator|() [2/3]

Returns a new lhs | rhs.

Definition at line 565 of file PointsTo.cpp.

566{
567 // TODO: optimise.
569 result |= rhs;
570 return result;
571}

◆ operator|() [3/3]

template<unsigned ElementSize>
SparseBitVector< ElementSize > SVF::operator| ( const SparseBitVector< ElementSize > &  LHS,
const SparseBitVector< ElementSize > &  RHS 
)
inline

Definition at line 1203 of file SparseBitVector.h.

1205{
1207 Result |= RHS;
1208 return Result;
1209}

◆ operator|=() [1/2]

template<unsigned ElementSize>
bool SVF::operator|= ( SparseBitVector< ElementSize > &  LHS,
const SparseBitVector< ElementSize > *  RHS 
)
inline

Definition at line 1172 of file SparseBitVector.h.

1174{
1175 return LHS |= *RHS;
1176}

◆ operator|=() [2/2]

template<unsigned ElementSize>
bool SVF::operator|= ( SparseBitVector< ElementSize > *  LHS,
const SparseBitVector< ElementSize > &  RHS 
)
inline

Definition at line 1179 of file SparseBitVector.h.

1181{
1182 return LHS->operator|=(RHS);
1183}

◆ readBigNumber()

static void SVF::readBigNumber ( const cJSON obj,
BigNumberType val,
CStrToVal  conv 
)
inlinestatic

Definition at line 98 of file SVFFileSystem.cpp.

99{
101 "Expect (number) string JSON for " << JSON_KEY(obj));
102 val = conv(obj->valuestring);
103}
bool jsonIsString(const cJSON *item)

◆ readSmallNumber()

static void SVF::readSmallNumber ( const cJSON obj,
SmallNumberType val 
)
inlinestatic

Definition at line 92 of file SVFFileSystem.cpp.

93{
94 val = static_cast<SmallNumberType>(jsonGetNumber(obj));
95}
double jsonGetNumber(const cJSON *item)

◆ ViewGraph()

template<typename GraphType >
void SVF::ViewGraph ( const GraphType &  G,
const std::string &  name,
bool  ShortNames = false,
GraphProgram::Name  Program = GraphProgram::DOT 
)

ViewGraph - Emit a dot graph, run 'dot', run gv on the postscript file, then cleanup. For use from the debugger.

Definition at line 371 of file GraphWriter.h.

374{
376}
std::ofstream & WriteGraph(std::ofstream &O, const GraphType &G, bool ShortNames=false)

◆ WriteGraph() [1/2]

template<typename GraphType >
std::string SVF::WriteGraph ( const GraphType &  G,
bool  ShortNames = false,
std::string  Filename = "" 
)

Writes graph into a provided Filename. If Filename is empty, generates a random one.

Returns
The resulting filename, or an empty string if writing failed.

Definition at line 345 of file GraphWriter.h.

348{
349
350 std::ofstream O(Filename);
351
352 if (O.fail())
353 {
354 std::cerr << "error opening file '" << Filename << "' for writing!\n";
355 O.close();
356 return "";
357 }
358
359 SVF::WriteGraph(O, G, ShortNames);
360 O.close();
361
362 std::cerr << " done. \n";
363
364 return Filename;
365}

◆ WriteGraph() [2/2]

template<typename GraphType >
std::ofstream & SVF::WriteGraph ( std::ofstream &  O,
const GraphType &  G,
bool  ShortNames = false 
)

Definition at line 328 of file GraphWriter.h.

330{
331 // Start the graph emission process...
333
334 // Emit the graph.
335 W.writeGraph("");
336
337 return O;
338}