36#ifndef DISNCTMRGENERATOR_H_
37#define DISNCTMRGENERATOR_H_
virtual void partitionMRs()
Partition regions.
virtual void getMRsForCallSiteRef(MRSet &aliasMRs, const NodeBS &cpts, const FunObjVar *fun)
Get memory regions to be inserted at a load statement.
void createDistinctMR(const FunObjVar *func, const NodeBS &cpts)
Create memory regions for each points-to target.
virtual void getMRsForLoad(MRSet &aliasMRs, const NodeBS &cpts, const FunObjVar *fun)
Get memory region at a load.
DistinctMRG(BVDataPTAImpl *p, bool ptrOnly)
virtual void getMRsForLoad(MRSet &aliasMRs, const NodeBS &cpts, const FunObjVar *)
virtual void partitionMRs()
Partition regions.
InterDisjointMRG(BVDataPTAImpl *p, bool ptrOnly)
Map< const FunObjVar *, PtsToSubPtsMap > FunToPtsMap
OrderedMap< NodeBS, PointsToList > PtsToSubPtsMap
virtual void partitionMRs()
Partition regions.
PointsToList & getIntersList(const FunObjVar *func)
void getMRsForLoadFromInterList(MRSet &mrs, const NodeBS &cpts, const PointsToList &inters)
Map< const FunObjVar *, PointsToList > FunToInterMap
void createDisjointMR(const FunObjVar *func, const NodeBS &cpts)
Create disjoint memory region.
FunToInterMap funcToInterMap
virtual void getMRsForLoad(MRSet &aliasMRs, const NodeBS &cpts, const FunObjVar *fun)
void computeIntersections(const NodeBS &cpts, PointsToList &inters)
Compute intersections between cpts and computed cpts intersections before.
IntraDisjointMRG(BVDataPTAImpl *p, bool ptrOnly)
PtsToSubPtsMap & getPtsSubSetMap(const FunObjVar *func)
virtual void getMRsForCallSiteRef(MRSet &aliasMRs, const NodeBS &cpts, const FunObjVar *fun)
Get memory regions to be inserted at a load statement.
const PtsToSubPtsMap & getPtsSubSetMap(const FunObjVar *func) const
OrderedSet< NodeBS, SVFUtil::equalNodeBS > PointsToList
OrderedSet< const MemRegion *, MemRegion::equalMemRegion > MRSet
Get typedef from Pointer Analysis.
llvm::IRBuilder IRBuilder