|
clang 23.0.0git
|
CoreEngine - Implements the core logic of the graph-reachability analysis. More...
#include "clang/StaticAnalyzer/Core/PathSensitive/CoreEngine.h"
Public Types | |
| using | BlocksExhausted |
| using | BlocksAborted |
Public Member Functions | |
| CoreEngine (ExprEngine &exprengine, FunctionSummariesTy *FS, AnalyzerOptions &Opts) | |
| Construct a CoreEngine object to analyze the provided CFG. | |
| CoreEngine (const CoreEngine &)=delete | |
| CoreEngine & | operator= (const CoreEngine &)=delete |
| ExplodedGraph & | getGraph () |
| getGraph - Returns the exploded graph. | |
| bool | ExecuteWorkList (const LocationContext *L, unsigned Steps, ProgramStateRef InitState) |
| ExecuteWorkList - Run the worklist algorithm for a maximum number of steps. | |
| void | dispatchWorkItem (ExplodedNode *Pred, ProgramPoint Loc, const WorkListUnit &WU) |
| Dispatch the work list item based on the given location information. | |
| bool | wasBlockAborted () const |
| bool | wasBlocksExhausted () const |
| bool | hasWorkRemaining () const |
| void | addAbortedBlock (const ExplodedNode *node, const CFGBlock *block) |
| Inform the CoreEngine that a basic block was aborted because it could not be completely analyzed. | |
| WorkList * | getWorkList () const |
| WorkList * | getCTUWorkList () const |
| auto | exhausted_blocks () const |
| auto | aborted_blocks () const |
| ExplodedNode * | makeNode (const ProgramPoint &Loc, ProgramStateRef State, ExplodedNode *Pred, bool MarkAsSink=false) const |
| void | enqueue (ExplodedNodeSet &Set) |
| Enqueue the given set of nodes onto the work list. | |
| void | enqueueStmtNodes (ExplodedNodeSet &Set, const CFGBlock *Block, unsigned Idx) |
| Enqueue nodes that were created as a result of processing a statement onto the work list. | |
| void | enqueueEndOfFunction (ExplodedNodeSet &Set, const ReturnStmt *RS) |
| enqueue the nodes corresponding to the end of function onto the end of path / work list. | |
| void | enqueueStmtNode (ExplodedNode *N, const CFGBlock *Block, unsigned Idx) |
| Enqueue a single node created as a result of statement processing. | |
| DataTag::Factory & | getDataTags () |
Friends | |
| class | ExprEngine |
| class | NodeBuilder |
| class | NodeBuilderContext |
| class | SwitchNodeBuilder |
CoreEngine - Implements the core logic of the graph-reachability analysis.
It traverses the CFG and generates the ExplodedGraph.
Definition at line 50 of file CoreEngine.h.
Definition at line 60 of file CoreEngine.h.
Definition at line 57 of file CoreEngine.h.
| CoreEngine::CoreEngine | ( | ExprEngine & | exprengine, |
| FunctionSummariesTy * | FS, | ||
| AnalyzerOptions & | Opts ) |
Construct a CoreEngine object to analyze the provided CFG.
Definition at line 74 of file CoreEngine.cpp.
References ExprEngine, generateWorkList(), and clang::nullptr.
Referenced by CoreEngine(), and operator=().
|
delete |
References CoreEngine().
|
inline |
Definition at line 169 of file CoreEngine.h.
|
inline |
Inform the CoreEngine that a basic block was aborted because it could not be completely analyzed.
Definition at line 158 of file CoreEngine.h.
| void CoreEngine::dispatchWorkItem | ( | ExplodedNode * | Pred, |
| ProgramPoint | Loc, | ||
| const WorkListUnit & | WU ) |
Dispatch the work list item based on the given location information.
Use Pred parameter as the predecessor state.
Definition at line 214 of file CoreEngine.cpp.
References clang::ProgramPoint::BlockEdgeKind, clang::ProgramPoint::BlockEntranceKind, clang::ProgramPoint::BlockExitKind, clang::ProgramPoint::CallEnterKind, clang::ProgramPoint::CallExitBeginKind, clang::ento::SVal::castAs(), dispatchWorkItem(), clang::ProgramPoint::EpsilonKind, clang::ento::SVal::getAs(), clang::ento::WorkListUnit::getBlock(), clang::ento::ExplodedNode::getFirstPred(), clang::ento::WorkListUnit::getIndex(), clang::ento::SVal::getKind(), clang::ento::ExplodedNode::getLocation(), clang::ento::ExplodedNode::getLocationContext(), clang::ento::ExplodedNode::hasSinglePred(), timeTraceMetadata(), and timeTraceScopeName().
Referenced by dispatchWorkItem(), and ExecuteWorkList().
| void CoreEngine::enqueue | ( | ExplodedNodeSet & | Set | ) |
Enqueue the given set of nodes onto the work list.
Definition at line 656 of file CoreEngine.cpp.
References clang::Set.
Referenced by ExecuteWorkList().
| void CoreEngine::enqueueEndOfFunction | ( | ExplodedNodeSet & | Set, |
| const ReturnStmt * | RS ) |
enqueue the nodes corresponding to the end of function onto the end of path / work list.
Definition at line 667 of file CoreEngine.cpp.
References clang::cast(), clang::LocationContext::getParent(), makeNode(), and clang::Set.
| void CoreEngine::enqueueStmtNode | ( | ExplodedNode * | N, |
| const CFGBlock * | Block, | ||
| unsigned | Idx ) |
Enqueue a single node created as a result of statement processing.
Definition at line 584 of file CoreEngine.cpp.
References clang::Block, clang::CFGElement::castAs(), clang::ProgramPoint::getAs(), getKind(), clang::ento::ExplodedNode::getLocation(), clang::ento::ExplodedNode::getLocationContext(), clang::ento::ExplodedNode::getState(), clang::CFGStmt::getStmt(), clang::ento::ExplodedNode::isSink(), makeNode(), clang::CFGElement::NewAllocator, and clang::ProgramPoint::withTag().
Referenced by enqueueStmtNodes().
| void CoreEngine::enqueueStmtNodes | ( | ExplodedNodeSet & | Set, |
| const CFGBlock * | Block, | ||
| unsigned | Idx ) |
Enqueue nodes that were created as a result of processing a statement onto the work list.
Definition at line 661 of file CoreEngine.cpp.
References clang::Block, enqueueStmtNode(), and clang::Set.
| bool CoreEngine::ExecuteWorkList | ( | const LocationContext * | L, |
| unsigned | Steps, | ||
| ProgramStateRef | InitState ) |
ExecuteWorkList - Run the worklist algorithm for a maximum number of steps.
Returns true if there is still simulation state on the worklist.
Definition at line 87 of file CoreEngine.cpp.
References dispatchWorkItem(), clang::CFGBlock::empty(), enqueue(), clang::ento::WorkListUnit::getBlockCounter(), clang::CFGBlock::getBlockID(), clang::LocationContext::getCFG(), clang::LocationContext::getDecl(), clang::ento::ExplodedNode::getLocation(), clang::ento::ExplodedNode::getLocationContext(), clang::ento::WorkListUnit::getNode(), clang::CFG::getNumBlockIDs(), clang::CFGBlock::succ_begin(), and clang::CFGBlock::succ_size().
|
inline |
Definition at line 165 of file CoreEngine.h.
|
inline |
Definition at line 163 of file CoreEngine.h.
Referenced by REGISTER_MAP_WITH_PROGRAMSTATE().
|
inline |
Definition at line 189 of file CoreEngine.h.
|
inline |
getGraph - Returns the exploded graph.
Definition at line 137 of file CoreEngine.h.
|
inline |
Definition at line 162 of file CoreEngine.h.
Referenced by REGISTER_MAP_WITH_PROGRAMSTATE().
|
inline |
Definition at line 152 of file CoreEngine.h.
References wasBlockAborted(), and wasBlocksExhausted().
| ExplodedNode * CoreEngine::makeNode | ( | const ProgramPoint & | Loc, |
| ProgramStateRef | State, | ||
| ExplodedNode * | Pred, | ||
| bool | MarkAsSink = false ) const |
Definition at line 572 of file CoreEngine.cpp.
References clang::ento::ExplodedNode::addPredecessor().
Referenced by enqueueEndOfFunction(), and enqueueStmtNode().
|
delete |
References CoreEngine().
|
inline |
Definition at line 150 of file CoreEngine.h.
Referenced by hasWorkRemaining().
|
inline |
Definition at line 151 of file CoreEngine.h.
Referenced by hasWorkRemaining().
|
friend |
Definition at line 51 of file CoreEngine.h.
References ExprEngine.
Referenced by CoreEngine(), and ExprEngine.
|
friend |
|
friend |
Definition at line 53 of file CoreEngine.h.
References NodeBuilderContext.
Referenced by NodeBuilderContext.
|
friend |
Definition at line 54 of file CoreEngine.h.
References SwitchNodeBuilder.
Referenced by SwitchNodeBuilder.