|
Static Value-Flow Analysis
|
#include <WPAFSSolver.h>
Public Member Functions | |
| WPAFSSolver () | |
| Constructor. | |
| virtual | ~WPAFSSolver () |
| Destructor. | |
| virtual NodeID | sccRepNode (NodeID id) const |
| SCC methods. | |
Protected Member Functions | |
| virtual NodeStack & | SCCDetect () |
| SCC detection. | |
Protected Member Functions inherited from SVF::WPASolver< GraphType > | |
| WPASolver () | |
| Constructor. | |
| virtual | ~WPASolver ()=default |
| Destructor. | |
| SCC * | getSCCDetector () const |
| Get SCC detector. | |
| const GraphType | graph () |
| Get/Set graph methods. | |
| void | setGraph (GraphType g) |
| virtual NodeStack & | SCCDetect (NodeSet &candidates) |
| virtual void | initWorklist () |
| virtual void | solveWorklist () |
| virtual void | processNode (NodeID) |
| Following methods are to be implemented in child class, in order to achieve a fully worked PTA. | |
| virtual void | collapseFields () |
| collapse positive weight cycles of a graph | |
| virtual void | propagate (GNODE *v) |
| virtual bool | propFromSrcToDst (GEDGE *) |
| Propagate information from source to destination node, to be implemented in the child class. | |
| NodeID | popFromWorklist () |
| Worklist operations. | |
| virtual void | pushIntoWorklist (NodeID id) |
| bool | isWorklistEmpty () |
| bool | isInWorklist (NodeID id) |
| GNODE * | Node (NodeID id) |
| Get node on the graph. | |
| NodeID | Node_Index (GNODE node) |
| Get node ID. | |
Protected Attributes | |
| NodeStack | nodeStack |
| stack used for processing nodes. | |
Protected Attributes inherited from SVF::WPASolver< GraphType > | |
| bool | reanalyze |
| Reanalyze if any constraint value changed. | |
| u32_t | iterationForPrintStat |
| print out statistics for i-th iteration | |
| GraphType | _graph |
| Graph. | |
| std::unique_ptr< SCC > | scc |
| SCC. | |
| WorkList | worklist |
| Worklist for resolution. | |
Additional Inherited Members | |
Public Types inherited from SVF::WPASolver< GraphType > | |
| typedef SVF::GenericGraphTraits< GraphType > | GTraits |
| Define the GTraits and node iterator for printing. | |
| typedef GTraits::NodeRef | GNODE |
| typedef GTraits::EdgeType | GEDGE |
| typedef GTraits::ChildIteratorType | child_iterator |
| typedef SCCDetection< GraphType > | SCC |
| typedef FIFOWorkList< NodeID > | WorkList |
Public Attributes inherited from SVF::WPASolver< GraphType > | |
| u32_t | numOfIteration |
| num of iterations during constraint solving | |
Flow-sensitive Solver
Definition at line 48 of file WPAFSSolver.h.
|
inline |
Constructor.
Definition at line 52 of file WPAFSSolver.h.
|
inlinevirtual |
|
inlineprotectedvirtual |
SCC detection.
SCC detection
Both rep and sub nodes need to be processed later. Collect sub nodes from SCCDetector.
restore the topological order.
Reimplemented from SVF::WPASolver< GraphType >.
Reimplemented in SVF::FlowSensitive.
Definition at line 67 of file WPAFSSolver.h.
|
inlinevirtual |
SCC methods.
Reimplemented from SVF::WPASolver< GraphType >.
Definition at line 58 of file WPAFSSolver.h.
|
protected |
stack used for processing nodes.
Definition at line 64 of file WPAFSSolver.h.