soot.jimple.infoflow.solver.IInfoflowSolver Maven / Gradle / Ivy
package soot.jimple.infoflow.solver;
import java.util.Set;
import heros.solver.Pair;
import heros.solver.PathEdge;
import soot.SootMethod;
import soot.Unit;
import soot.jimple.infoflow.data.Abstraction;
import soot.jimple.infoflow.problems.AbstractInfoflowProblem;
import soot.jimple.infoflow.solver.memory.IMemoryManager;
public interface IInfoflowSolver {
/**
* Schedules the given edge for processing in the solver
*
* @param edge The edge to schedule for processing
* @return True if the edge was scheduled, otherwise (e.g., if the edge has
* already been processed earlier) false
*/
public boolean processEdge(PathEdge edge);
/**
* Gets the end summary of the given method for the given incoming abstraction
*
* @param m The method for which to get the end summary
* @param d3 The incoming fact (context) for which to get the end summary
* @return The end summary of the given method for the given incoming
* abstraction
*/
public Set> endSummary(SootMethod m, Abstraction d3);
public void injectContext(IInfoflowSolver otherSolver, SootMethod callee, Abstraction d3, Unit callSite,
Abstraction d2, Abstraction d1);
/**
* Cleans up some unused memory. Results will still be available afterwards, but
* no intermediate computation values.
*/
public void cleanup();
/**
* Sets a handler that will be called when a followReturnsPastSeeds case
* happens, i.e., a taint leaves a method for which we have not seen any callers
*
* @param handler The handler to be called when a followReturnsPastSeeds case
* happens
*/
public void setFollowReturnsPastSeedsHandler(IFollowReturnsPastSeedsHandler handler);
/**
* Sets the memory manager that shall be used to manage the abstractions
*
* @param memoryManager The memory manager that shall be used to manage the
* abstractions
*/
public void setMemoryManager(IMemoryManager memoryManager);
/**
* Gets the memory manager used by this solver to reduce memory consumption
*
* @return The memory manager registered with this solver
*/
public IMemoryManager getMemoryManager();
/**
* Sets whether abstractions on method returns shall be connected to the
* respective call abstractions to shortcut paths.
*
* @param mode The strategy to use for shortening predecessor paths
*/
public void setPredecessorShorteningMode(PredecessorShorteningMode mode);
/**
* Gets the number of edges propagated by the solver
*
* @return The number of edges propagated by the solver
*/
public long getPropagationCount();
/**
* Solves the data flow problem
*/
public void solve();
public void setSolverId(boolean solverId);
/**
* Gets the IFDS problem solved by this solver
*
* @return The IFDS problem solved by this solver
*/
public AbstractInfoflowProblem getTabulationProblem();
/**
* Sets the maximum number of abstractions that shall be recorded per join
* point. In other words, enabling this option disables the recording of
* neighbors beyond the given count.
*
* @param maxJoinPointAbstractions The maximum number of abstractions per join
* point, or -1 to record an arbitrary number of
* join point abstractions
*/
public void setMaxJoinPointAbstractions(int maxJoinPointAbstractions);
/**
* Sets the maximum number of callees that are allowed per call site. If a call
* site has more than this number of callees, the call site is skipped and none
* of the callees are processed.
*
* @param maxCalleesPerCallSite The maximum number of callees per call site
*/
public void setMaxCalleesPerCallSite(int maxCalleesPerCallSite);
/**
* Sets the maximum length of a taint propagation path. Abstractions that run
* beyond this limit are dropped.
*
* @param maxAbstractionPathLength The maximum number of abstractions on a
* propagation path
*/
public void setMaxAbstractionPathLength(int maxAbstractionPathLength);
/**
* Sets the peer group in which this solver operates. Peer groups allow for
* synchronization between solvers
*
* @param solverPeerGroup The solver peer group
*/
public void setPeerGroup(SolverPeerGroup solverPeerGroup);
/**
* Notifies the solver that no further edges will be scheduled
*/
public void terminate();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy