Packages

c

tip.analysis.SignAnalysis.Interprocedural

WorklistSolverWithReachabilityAndPropagation

class WorklistSolverWithReachabilityAndPropagation extends InterprocValueAnalysisWorklistSolverWithReachabilityAndPropagation[SignLattice.type]

Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. WorklistSolverWithReachabilityAndPropagation
  2. InterprocValueAnalysisWorklistSolverWithReachabilityAndPropagation
  3. ForwardDependencies
  4. WorklistFixpointPropagationSolver
  5. WorklistFixpointSolverWithReachability
  6. WorklistFixpointSolver
  7. InterprocValueAnalysisFunctionsWithPropagation
  8. InterprocValueAnalysisMisc
  9. WorklistFixpointPropagationFunctions
  10. ListSetWorklist
  11. Worklist
  12. MapLiftLatticeSolver
  13. LiftedValueAnalysis
  14. ValueAnalysisMisc
  15. MapLatticeSolver
  16. Dependencies
  17. LatticeSolver
  18. FlowSensitiveAnalysis
  19. Analysis
  20. AnyRef
  21. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Instance Constructors

  1. new WorklistSolverWithReachabilityAndPropagation(cfg: InterproceduralProgramCfg)(implicit declData: DeclarationData)

Value Members

  1. def add(ns: Set[CfgNode]): Unit

    Adds a set of items to the worklist.

    Adds a set of items to the worklist.

    Definition Classes
    ListSetWorklistWorklist
  2. def add(n: CfgNode): Unit

    Adds an item to the worklist.

    Adds an item to the worklist.

    Definition Classes
    ListSetWorklistWorklist
  3. def analyze(): Element

    The analyze function.

  4. val cfg: InterproceduralProgramCfg
    Definition Classes
    LiftedValueAnalysisValueAnalysisMisc
  5. implicit val declData: DeclarationData
  6. val declaredVars: Set[ADeclaration]

    Set of declared variables, used by statelattice.

    Set of declared variables, used by statelattice.

    Definition Classes
    ValueAnalysisMisc
  7. val domain: Set[CfgNode]
    Definition Classes
    LiftedValueAnalysis
  8. def eval(exp: AExpr, env: Element)(implicit declData: DeclarationData): lattices.SignLattice.Element

    Default implementation of eval.

    Default implementation of eval.

    Definition Classes
    ValueAnalysisMisc
  9. def evalArgs(formalParams: Seq[ADeclaration], actualParams: Seq[AExpr], state: Element): Element

    Abstract evaluation of function arguments.

    Abstract evaluation of function arguments.

    Definition Classes
    InterprocValueAnalysisMisc
  10. val first: Set[CfgNode]

    Initialize worklist with the program entry point.

  11. def funsub(n: CfgNode, x: Element): Element

    Overrides funsub from tip.solvers.MapLatticeSolver, treating function entry nodes as reachable.

    Overrides funsub from tip.solvers.MapLatticeSolver, treating function entry nodes as reachable.

    n

    the current location in the map domain

    x

    the current lattice element for all locations

    returns

    the output sublattice element

    Definition Classes
    LiftedValueAnalysisMapLatticeSolver
  12. def indep(n: CfgNode): Set[CfgNode]

    Incoming dependencies.

    Incoming dependencies. Used when computing the join from predecessors.

    n

    an element from the worklist

    returns

    the elements that the given element depends on

    Definition Classes
    ForwardDependenciesDependencies
  13. def init: Element

    The initial lattice element at the start locations.

    The initial lattice element at the start locations. Default: lift(bottom).

    Definition Classes
    WorklistFixpointPropagationSolverWorklistFixpointPropagationFunctions
  14. def join(n: CfgNode, o: Element): Element

    Computes the least upper bound of the incoming elements.

    Computes the least upper bound of the incoming elements.

    Definition Classes
    MapLatticeSolver
  15. val lattice: MapLattice[CfgNode, liftedstatelattice.type]

    The analysis lattice.

    The analysis lattice.

    Definition Classes
    LiftedValueAnalysisMapLatticeSolverLatticeSolver
  16. val liftedstatelattice: LiftLattice[statelattice.type]

    Lifted state lattice, with new bottom element representing "unreachable".

    Lifted state lattice, with new bottom element representing "unreachable".

    Definition Classes
    LiftedValueAnalysis
  17. def localTransfer(n: CfgNode, s: Element): Element

    Transfer function for state lattice elements.

    Transfer function for state lattice elements.

    Definition Classes
    ValueAnalysisMisc
  18. def outdep(n: CfgNode): Set[CfgNode]

    Outgoing dependencies.

    Outgoing dependencies. Used when propagating dataflow to successors.

    n

    an element from the worklist

    returns

    the elements that depend on the given element

    Definition Classes
    ForwardDependenciesDependencies
  19. def process(n: CfgNode): Unit

    This method overrides the one from WorklistFixpointSolver.

    This method overrides the one from WorklistFixpointSolver. Called by the worklist solver when a node is visited.

    Definition Classes
    WorklistFixpointPropagationSolverWorklistFixpointSolverWorklist
  20. def propagate(y: Element, m: CfgNode): Unit

    Propagates lattice element y to node m.

    Propagates lattice element y to node m.

    Definition Classes
    WorklistFixpointPropagationFunctions
  21. def run(first: Set[CfgNode]): Unit

    Iterates until there is no more work to do.

    Iterates until there is no more work to do.

    first

    the initial contents of the worklist

    Definition Classes
    ListSetWorklistWorklist
  22. val stateAfterNode: Boolean
    Definition Classes
    FlowSensitiveAnalysis
  23. val statelattice: MapLattice[ADeclaration, valuelattice.type]

    The lattice of abstract states.

    The lattice of abstract states.

    Definition Classes
    ValueAnalysisMisc
  24. def transfer(n: CfgNode, s: Element): Element

    The transfer function.

    The transfer function.

    Definition Classes
    MapLiftLatticeSolverMapLatticeSolver
  25. def transferUnlifted(n: CfgNode, s: Element): Element

    Transfer function for state lattice elements.

    Transfer function for state lattice elements.

    Definition Classes
    InterprocValueAnalysisFunctionsWithPropagationMapLiftLatticeSolver
  26. val valuelattice: SignLattice.type

    The lattice of abstract values.

  27. val x: Element

    The current lattice element.

    The current lattice element.

    Definition Classes
    WorklistFixpointSolver