Static Value-Flow Analysis
Loading...
Searching...
No Matches
Public Types | Static Public Attributes | Protected Member Functions | Protected Attributes | Private Attributes | List of all members
SVF::MemSSA Class Reference

#include <MemSSA.h>

Public Types

enum  MemPartition { Distinct , IntraDisjoint , InterDisjoint }
 
typedef MemRegion::Condition Condition
 define condition here changes needed if we add new type
 
typedef MSSAMU< ConditionMU
 
typedef RetMU< ConditionRETMU
 
typedef LoadMU< ConditionLOADMU
 
typedef CallMU< ConditionCALLMU
 
typedef MSSACHI< ConditionCHI
 
typedef EntryCHI< ConditionENTRYCHI
 
typedef StoreCHI< ConditionSTORECHI
 
typedef CallCHI< ConditionCALLCHI
 
typedef MSSAPHI< ConditionPHI
 
typedef MSSADEF MDEF
 
typedef Set< MU * > MUSet
 
typedef Set< CHI * > CHISet
 
typedef Set< PHI * > PHISet
 
typedef MRGenerator::MRSet MRSet
 Define mem region set.
 
typedef std::vector< const MemRegion * > MRVector
 
typedef Map< const LoadStmt *, MUSetLoadToMUSetMap
 
typedef Map< const StoreStmt *, CHISetStoreToChiSetMap
 
typedef Map< const CallICFGNode *, MUSetCallSiteToMUSetMap
 
typedef Map< const CallICFGNode *, CHISetCallSiteToCHISetMap
 
typedef OrderedMap< const SVFBasicBlock *, PHISetBBToPhiSetMap
 
typedef Map< const FunObjVar *, CHISetFunToEntryChiSetMap
 Map from fun to its entry chi set and return mu set.
 
typedef Map< const FunObjVar *, MUSetFunToReturnMuSetMap
 
typedef std::vector< const SVFBasicBlock * > BBList
 For phi insertion.
 
typedef Map< const SVFBasicBlock *, MRSetBBToMRSetMap
 
typedef Map< const MemRegion *, BBListMemRegToBBsMap
 
typedef Map< const MemRegion *, std::vector< MRVer * > > MemRegToVerStackMap
 For SSA renaming.
 
typedef Map< const MemRegion *, MRVERSIONMemRegToCounterMap
 
typedef SVFIR::SVFStmtList SVFStmtList
 SVFIR edge list.
 

Static Public Attributes

static double timeOfGeneratingMemRegions = 0
 Statistics.
 
static double timeOfCreateMUCHI = 0
 Time for generating mu/chi for load/store/calls.
 
static double timeOfInsertingPHI = 0
 Time for inserting phis.
 
static double timeOfSSARenaming = 0
 Time for SSA rename.
 

Protected Member Functions

virtual void createMUCHI (const FunObjVar &fun)
 Create mu chi for candidate regions in a function.
 
virtual void insertPHI (const FunObjVar &fun)
 Insert phi for candidate regions in a function.
 
virtual void SSARename (const FunObjVar &fun)
 SSA rename for a function.
 
virtual void SSARenameBB (const SVFBasicBlock &bb)
 SSA rename for a basic block.
 

Protected Attributes

BVDataPTAImplpta
 
MRGeneratormrGen
 
MemSSAStatstat
 

Private Attributes

LoadToMUSetMap load2MuSetMap
 
StoreToChiSetMap store2ChiSetMap
 
CallSiteToMUSetMap callsiteToMuSetMap
 
CallSiteToCHISetMap callsiteToChiSetMap
 
BBToPhiSetMap bb2PhiSetMap
 
FunToEntryChiSetMap funToEntryChiSetMap
 
FunToReturnMuSetMap funToReturnMuSetMap
 
MemRegToVerStackMap mr2VerStackMap
 
MemRegToCounterMap mr2CounterMap
 
MRSet usedRegs
 The following three set are used for prune SSA phi insertion.
 
MemRegToBBsMap reg2BBMap
 Maps memory region to its basic block.
 
MRSet varKills
 Collect memory regions whose definition killed.
 
std::vector< std::unique_ptr< MRVer > > usedMRVers
 
void destroy ()
 Release the memory.
 
MRVernewSSAName (const MemRegion *mr, MSSADEF *def)
 Get a new SSA name of a memory region.
 
MRVergetTopStackVer (const MemRegion *mr)
 Get the last version of the SSA ver of memory region.
 
void collectRegUses (const MemRegion *mr)
 Collect region uses and region defs according to mus/chis, in order to insert phis.
 
void collectRegDefs (const SVFBasicBlock *bb, const MemRegion *mr)
 
void AddLoadMU (const SVFBasicBlock *bb, const LoadStmt *load, const MRSet &mrSet)
 Add methods for mus/chis/phis.
 
void AddStoreCHI (const SVFBasicBlock *bb, const StoreStmt *store, const MRSet &mrSet)
 
void AddCallSiteMU (const CallICFGNode *cs, const MRSet &mrSet)
 
void AddCallSiteCHI (const CallICFGNode *cs, const MRSet &mrSet)
 
void AddMSSAPHI (const SVFBasicBlock *bb, const MRSet &mrSet)
 
void AddLoadMU (const SVFBasicBlock *bb, const LoadStmt *load, const MemRegion *mr)
 
void AddStoreCHI (const SVFBasicBlock *bb, const StoreStmt *store, const MemRegion *mr)
 
void AddCallSiteMU (const CallICFGNode *cs, const MemRegion *mr)
 
void AddCallSiteCHI (const CallICFGNode *cs, const MemRegion *mr)
 
void AddMSSAPHI (const SVFBasicBlock *bb, const MemRegion *mr)
 
void RenameMuSet (const MUSet &muSet)
 Rename mus, chis and phis.
 
void RenameChiSet (const CHISet &chiSet, MRVector &memRegs)
 Rename chi set.
 
void RenamePhiRes (const PHISet &phiSet, MRVector &memRegs)
 Rename result (LHS) of phis.
 
void RenamePhiOps (const PHISet &phiSet, u32_t pos, MRVector &)
 Rename operands (RHS) of phis.
 
 MemSSA (BVDataPTAImpl *p, bool ptrOnlyMSSA)
 Constructor.
 
SVFIRgetPAG ()
 Return SVFIR.
 
BVDataPTAImplgetPTA () const
 Return PTA.
 
MRGeneratorgetMRGenerator ()
 Return MRGenerator.
 
virtual void buildMemSSA (const FunObjVar &fun)
 We start from here.
 
void performStat ()
 Perform statistics.
 
bool hasMU (const PAGEdge *inst) const
 Has mu/chi methods.
 
bool hasCHI (const PAGEdge *inst) const
 
bool hasMU (const CallICFGNode *cs) const
 
bool hasCHI (const CallICFGNode *cs) const
 
bool hasFuncEntryChi (const FunObjVar *fun) const
 Has function entry chi or return mu.
 
bool hasReturnMu (const FunObjVar *fun) const
 
CHISetgetFuncEntryChiSet (const FunObjVar *fun)
 
MUSetgetReturnMuSet (const FunObjVar *fun)
 
MUSetgetMUSet (const LoadStmt *ld)
 Get methods of mu/chi/phi.
 
CHISetgetCHISet (const StoreStmt *st)
 
MUSetgetMUSet (const CallICFGNode *cs)
 
CHISetgetCHISet (const CallICFGNode *cs)
 
PHISetgetPHISet (const SVFBasicBlock *bb)
 
bool hasPHISet (const SVFBasicBlock *bb) const
 
LoadToMUSetMapgetLoadToMUSetMap ()
 
StoreToChiSetMapgetStoreToChiSetMap ()
 
FunToReturnMuSetMapgetFunToRetMuSetMap ()
 
FunToEntryChiSetMapgetFunToEntryChiSetMap ()
 
CallSiteToMUSetMapgetCallSiteToMuSetMap ()
 
CallSiteToCHISetMapgetCallSiteToChiSetMap ()
 
BBToPhiSetMapgetBBToPhiSetMap ()
 
u32_t getLoadMuNum () const
 Stat methods.
 
u32_t getStoreChiNum () const
 
u32_t getFunEntryChiNum () const
 
u32_t getFunRetMuNum () const
 
u32_t getCallSiteMuNum () const
 
u32_t getCallSiteChiNum () const
 
u32_t getBBPhiNum () const
 
void dumpMSSA (OutStream &Out=SVFUtil::outs())
 Print Memory SSA.
 

Detailed Description

Definition at line 52 of file MemSSA.h.

Member Typedef Documentation

◆ BBList

For phi insertion.

Definition at line 93 of file MemSSA.h.

◆ BBToMRSetMap

Definition at line 94 of file MemSSA.h.

◆ BBToPhiSetMap

Definition at line 84 of file MemSSA.h.

◆ CALLCHI

Definition at line 66 of file MemSSA.h.

◆ CALLMU

Definition at line 62 of file MemSSA.h.

◆ CallSiteToCHISetMap

Definition at line 83 of file MemSSA.h.

◆ CallSiteToMUSetMap

Definition at line 82 of file MemSSA.h.

◆ CHI

Definition at line 63 of file MemSSA.h.

◆ CHISet

Definition at line 71 of file MemSSA.h.

◆ Condition

define condition here changes needed if we add new type

Definition at line 58 of file MemSSA.h.

◆ ENTRYCHI

Definition at line 64 of file MemSSA.h.

◆ FunToEntryChiSetMap

Map from fun to its entry chi set and return mu set.

Definition at line 88 of file MemSSA.h.

◆ FunToReturnMuSetMap

Definition at line 89 of file MemSSA.h.

◆ LOADMU

Definition at line 61 of file MemSSA.h.

◆ LoadToMUSetMap

Map loads/stores to its mem regions, TODO:visitAtomicCmpXchgInst, visitAtomicRMWInst??

Definition at line 80 of file MemSSA.h.

◆ MDEF

Definition at line 68 of file MemSSA.h.

◆ MemRegToBBsMap

Definition at line 95 of file MemSSA.h.

◆ MemRegToCounterMap

Definition at line 100 of file MemSSA.h.

◆ MemRegToVerStackMap

For SSA renaming.

Definition at line 99 of file MemSSA.h.

◆ MRSet

Define mem region set.

Definition at line 75 of file MemSSA.h.

◆ MRVector

Definition at line 76 of file MemSSA.h.

◆ MU

Definition at line 59 of file MemSSA.h.

◆ MUSet

Definition at line 70 of file MemSSA.h.

◆ PHI

Definition at line 67 of file MemSSA.h.

◆ PHISet

Definition at line 72 of file MemSSA.h.

◆ RETMU

Definition at line 60 of file MemSSA.h.

◆ STORECHI

Definition at line 65 of file MemSSA.h.

◆ StoreToChiSetMap

Definition at line 81 of file MemSSA.h.

◆ SVFStmtList

SVFIR edge list.

Definition at line 103 of file MemSSA.h.

Member Enumeration Documentation

◆ MemPartition

Enumerator
Distinct 
IntraDisjoint 
InterDisjoint 

Definition at line 113 of file MemSSA.h.

114 {
115 Distinct,
118 };
@ InterDisjoint
Definition MemSSA.h:117
@ IntraDisjoint
Definition MemSSA.h:116

Constructor & Destructor Documentation

◆ MemSSA()

MemSSA::MemSSA ( BVDataPTAImpl p,
bool  ptrOnlyMSSA 
)

Constructor.

Constructor

Generate whole program memory regions

Definition at line 48 of file MemSSA.cpp.

49{
50 pta = p;
52 && "please specify a pointer analysis");
53
55 mrGen = new DistinctMRG(pta, ptrOnlyMSSA);
57 mrGen = new IntraDisjointMRG(pta, ptrOnlyMSSA);
59 mrGen = new InterDisjointMRG(pta, ptrOnlyMSSA);
60 else
61 assert(false && "unrecognised memory partition strategy");
62
63
64 stat = new MemSSAStat(this);
65
67 double mrStart = stat->getClk(true);
69 double mrEnd = stat->getClk(true);
71}
#define TIMEINTERVAL
Definition SVFType.h:526
cJSON * p
Definition cJSON.cpp:2559
virtual void generateMRs()
Start generating memory regions.
MRGenerator * mrGen
Definition MemSSA.h:122
static double timeOfGeneratingMemRegions
Statistics.
Definition MemSSA.h:107
BVDataPTAImpl * pta
Definition MemSSA.h:121
MemSSAStat * stat
Definition MemSSA.h:123
static const OptionMap< MemSSA::MemPartition > MemPar
Definition Options.h:145
@ Default_PTA
default pta without any analysis
PTATY getAnalysisTy() const
Type of pointer analysis.
static double getClk(bool mark=false)
Definition SVFStat.cpp:48
llvm::IRBuilder IRBuilder
Definition BasicTypes.h:74

◆ ~MemSSA()

virtual SVF::MemSSA::~MemSSA ( )
inlinevirtual

Destructor.

Definition at line 301 of file MemSSA.h.

302 {
303 destroy();
304 }
void destroy()
Release the memory.
Definition MemSSA.cpp:367

Member Function Documentation

◆ AddCallSiteCHI() [1/2]

void SVF::MemSSA::AddCallSiteCHI ( const CallICFGNode cs,
const MemRegion mr 
)
inlineprivate

Definition at line 233 of file MemSSA.h.

234 {
235 CALLCHI* chi = new CALLCHI(cs, mr);
236 callsiteToChiSetMap[cs].insert(chi);
237 collectRegUses(mr);
238 collectRegDefs(chi->getBasicBlock(),mr);
239 }
CallSiteToCHISetMap callsiteToChiSetMap
Definition MemSSA.h:137
void collectRegDefs(const SVFBasicBlock *bb, const MemRegion *mr)
Definition MemSSA.h:180
CallCHI< Condition > CALLCHI
Definition MemSSA.h:66
void collectRegUses(const MemRegion *mr)
Collect region uses and region defs according to mus/chis, in order to insert phis.
Definition MemSSA.h:175

◆ AddCallSiteCHI() [2/2]

void SVF::MemSSA::AddCallSiteCHI ( const CallICFGNode cs,
const MRSet mrSet 
)
inlineprivate

Definition at line 204 of file MemSSA.h.

205 {
206 for (MRSet::iterator iter = mrSet.begin(), eiter = mrSet.end(); iter != eiter; ++iter)
207 AddCallSiteCHI(cs,*iter);
208 }
void AddCallSiteCHI(const CallICFGNode *cs, const MRSet &mrSet)
Definition MemSSA.h:204

◆ AddCallSiteMU() [1/2]

void SVF::MemSSA::AddCallSiteMU ( const CallICFGNode cs,
const MemRegion mr 
)
inlineprivate

Definition at line 227 of file MemSSA.h.

228 {
229 CALLMU* mu = new CALLMU(cs, mr);
230 callsiteToMuSetMap[cs].insert(mu);
231 collectRegUses(mr);
232 }
CallMU< Condition > CALLMU
Definition MemSSA.h:62
CallSiteToMUSetMap callsiteToMuSetMap
Definition MemSSA.h:136

◆ AddCallSiteMU() [2/2]

void SVF::MemSSA::AddCallSiteMU ( const CallICFGNode cs,
const MRSet mrSet 
)
inlineprivate

Definition at line 199 of file MemSSA.h.

200 {
201 for (MRSet::iterator iter = mrSet.begin(), eiter = mrSet.end(); iter != eiter; ++iter)
202 AddCallSiteMU(cs,*iter);
203 }
void AddCallSiteMU(const CallICFGNode *cs, const MRSet &mrSet)
Definition MemSSA.h:199

◆ AddLoadMU() [1/2]

void SVF::MemSSA::AddLoadMU ( const SVFBasicBlock bb,
const LoadStmt load,
const MemRegion mr 
)
inlineprivate

Definition at line 214 of file MemSSA.h.

215 {
216 LOADMU* mu = new LOADMU(bb,load, mr);
217 load2MuSetMap[load].insert(mu);
218 collectRegUses(mr);
219 }
LoadMU< Condition > LOADMU
Definition MemSSA.h:61
LoadToMUSetMap load2MuSetMap
Definition MemSSA.h:134

◆ AddLoadMU() [2/2]

void SVF::MemSSA::AddLoadMU ( const SVFBasicBlock bb,
const LoadStmt load,
const MRSet mrSet 
)
inlineprivate

Add methods for mus/chis/phis.

Definition at line 189 of file MemSSA.h.

190 {
191 for (MRSet::iterator iter = mrSet.begin(), eiter = mrSet.end(); iter != eiter; ++iter)
192 AddLoadMU(bb,load,*iter);
193 }
void AddLoadMU(const SVFBasicBlock *bb, const LoadStmt *load, const MRSet &mrSet)
Add methods for mus/chis/phis.
Definition MemSSA.h:189

◆ AddMSSAPHI() [1/2]

void SVF::MemSSA::AddMSSAPHI ( const SVFBasicBlock bb,
const MemRegion mr 
)
inlineprivate

Definition at line 240 of file MemSSA.h.

241 {
242 bb2PhiSetMap[bb].insert(new PHI(bb, mr));
243 }
BBToPhiSetMap bb2PhiSetMap
Definition MemSSA.h:138
MSSAPHI< Condition > PHI
Definition MemSSA.h:67

◆ AddMSSAPHI() [2/2]

void SVF::MemSSA::AddMSSAPHI ( const SVFBasicBlock bb,
const MRSet mrSet 
)
inlineprivate

Definition at line 209 of file MemSSA.h.

210 {
211 for (MRSet::iterator iter = mrSet.begin(), eiter = mrSet.end(); iter != eiter; ++iter)
212 AddMSSAPHI(bb,*iter);
213 }
void AddMSSAPHI(const SVFBasicBlock *bb, const MRSet &mrSet)
Definition MemSSA.h:209

◆ AddStoreCHI() [1/2]

void SVF::MemSSA::AddStoreCHI ( const SVFBasicBlock bb,
const StoreStmt store,
const MemRegion mr 
)
inlineprivate

Definition at line 220 of file MemSSA.h.

221 {
222 STORECHI* chi = new STORECHI(bb,store, mr);
223 store2ChiSetMap[store].insert(chi);
224 collectRegUses(mr);
225 collectRegDefs(bb,mr);
226 }
StoreCHI< Condition > STORECHI
Definition MemSSA.h:65
StoreToChiSetMap store2ChiSetMap
Definition MemSSA.h:135

◆ AddStoreCHI() [2/2]

void SVF::MemSSA::AddStoreCHI ( const SVFBasicBlock bb,
const StoreStmt store,
const MRSet mrSet 
)
inlineprivate

Definition at line 194 of file MemSSA.h.

195 {
196 for (MRSet::iterator iter = mrSet.begin(), eiter = mrSet.end(); iter != eiter; ++iter)
197 AddStoreCHI(bb,store,*iter);
198 }
void AddStoreCHI(const SVFBasicBlock *bb, const StoreStmt *store, const MRSet &mrSet)
Definition MemSSA.h:194

◆ buildMemSSA()

void MemSSA::buildMemSSA ( const FunObjVar fun)
virtual

We start from here.

Start building memory SSA

Create mus/chis for loads/stores/calls for memory regions

Insert PHI for memory regions

SSA rename for memory regions

Definition at line 81 of file MemSSA.cpp.

82{
83
84 assert(!isExtCall(&fun) && "we do not build memory ssa for external functions");
85
86 DBOUT(DMSSA, outs() << "Building Memory SSA for function " << fun.getName()
87 << " \n");
88
89 usedRegs.clear();
90 reg2BBMap.clear();
91
93 double muchiStart = stat->getClk(true);
94 createMUCHI(fun);
95 double muchiEnd = stat->getClk(true);
97
99 double phiStart = stat->getClk(true);
100 insertPHI(fun);
101 double phiEnd = stat->getClk(true);
103
105 double renameStart = stat->getClk(true);
106 SSARename(fun);
107 double renameEnd = stat->getClk(true);
109
110}
#define DBOUT(TYPE, X)
LLVM debug macros, define type of your DBUG model of each pass.
Definition SVFType.h:498
#define DMSSA
Definition SVFType.h:515
virtual void createMUCHI(const FunObjVar &fun)
Create mu chi for candidate regions in a function.
Definition MemSSA.cpp:116
static double timeOfInsertingPHI
Time for inserting phis.
Definition MemSSA.h:109
static double timeOfCreateMUCHI
Time for generating mu/chi for load/store/calls.
Definition MemSSA.h:108
virtual void insertPHI(const FunObjVar &fun)
Insert phi for candidate regions in a function.
Definition MemSSA.cpp:202
static double timeOfSSARenaming
Time for SSA rename.
Definition MemSSA.h:110
virtual void SSARename(const FunObjVar &fun)
SSA rename for a function.
Definition MemSSA.cpp:250
MRSet usedRegs
The following three set are used for prune SSA phi insertion.
Definition MemSSA.h:150
MemRegToBBsMap reg2BBMap
Maps memory region to its basic block.
Definition MemSSA.h:152
virtual const std::string & getName() const
Definition SVFValue.h:184
bool isExtCall(const FunObjVar *fun)
Definition SVFUtil.cpp:437
std::ostream & outs()
Overwrite llvm::outs()
Definition SVFUtil.h:52

◆ collectRegDefs()

void SVF::MemSSA::collectRegDefs ( const SVFBasicBlock bb,
const MemRegion mr 
)
inlineprivate

Definition at line 180 of file MemSSA.h.

181 {
182 varKills.insert(mr);
183 reg2BBMap[mr].push_back(bb);
184 }
MRSet varKills
Collect memory regions whose definition killed.
Definition MemSSA.h:154

◆ collectRegUses()

void SVF::MemSSA::collectRegUses ( const MemRegion mr)
inlineprivate

Collect region uses and region defs according to mus/chis, in order to insert phis.

Definition at line 175 of file MemSSA.h.

176 {
177 if (0 == varKills.count(mr))
178 usedRegs.insert(mr);
179 }

◆ createMUCHI()

void MemSSA::createMUCHI ( const FunObjVar fun)
protectedvirtual

Create mu chi for candidate regions in a function.

Create mu/chi according to memory regions collect used mrs in usedRegs and construction map from region to BB for prune SSA phi insertion

get all reachable basic blocks from function entry ignore dead basic blocks

if the function does not have a reachable return instruction from function entry then we won't create return mu for it

Definition at line 116 of file MemSSA.cpp.

117{
118
119
120 DBOUT(DMSSA,
121 outs() << "\t creating mu chi for function " << fun.getName()
122 << "\n");
123 // 1. create mu/chi
124 // insert a set of mus for memory regions at each load
125 // inset a set of chis for memory regions at each store
126
127 // 2. find global names (region name before renaming) of each memory region,
128 // collect used mrs in usedRegs, and collect its def basic block in reg2BBMap
129 // in the form of mu(r) and r = chi (r)
130 // a) mu(r):
131 // if(r \not\in varKills) global = global \cup r
132 // b) r = chi(r):
133 // if(r \not\in varKills) global = global \cup r
134 // varKills = varKills \cup r
135 // block(r) = block(r) \cup bb_{chi}
136
139 BBList reachableBBs = fun.getReachableBBs();
140
141 for (BBList::const_iterator iter = reachableBBs.begin(), eiter = reachableBBs.end();
142 iter != eiter; ++iter)
143 {
144 const SVFBasicBlock* bb = *iter;
145 varKills.clear();
146 for (const auto& inst: bb->getICFGNodeList())
147 {
148 if(mrGen->hasSVFStmtList(inst))
149 {
151 for (SVFStmtList::const_iterator bit = pagEdgeList.begin(),
152 ebit = pagEdgeList.end(); bit != ebit; ++bit)
153 {
154 const PAGEdge* inst = *bit;
155 if (const LoadStmt* load = SVFUtil::dyn_cast<LoadStmt>(inst))
156 AddLoadMU(bb, load, mrGen->getLoadMRSet(load));
157 else if (const StoreStmt* store = SVFUtil::dyn_cast<StoreStmt>(inst))
158 AddStoreCHI(bb, store, mrGen->getStoreMRSet(store));
159 }
160 }
161 if (isNonInstricCallSite(inst))
162 {
163 const CallICFGNode* cs = cast<CallICFGNode>(inst);
164 if(mrGen->hasRefMRSet(cs))
166
167 if(mrGen->hasModMRSet(cs))
169 }
170 }
171 }
172
173 // create entry chi for this function including all memory regions
174 // initialize them with version 0 and 1 r_1 = chi (r_0)
175 for (MRSet::iterator iter = usedRegs.begin(), eiter = usedRegs.end();
176 iter != eiter; ++iter)
177 {
178 const MemRegion* mr = *iter;
179 // initialize mem region version and stack for renaming phase
180 mr2CounterMap[mr] = 0;
181 mr2VerStackMap[mr].clear();
182 ENTRYCHI* chi = new ENTRYCHI(&fun, mr);
183 chi->setOpVer(newSSAName(mr,chi));
184 chi->setResVer(newSSAName(mr,chi));
185 funToEntryChiSetMap[&fun].insert(chi);
186
189 if(fun.hasReturn())
190 {
191 RETMU* mu = new RETMU(&fun, mr);
192 funToReturnMuSetMap[&fun].insert(mu);
193 }
194
195 }
196
197}
const std::vector< const SVFBasicBlock * > & getReachableBBs() const
bool hasReturn() const
MRSet & getStoreMRSet(const StoreStmt *store)
Definition MemRegion.h:449
MRSet & getCallSiteRefMRSet(const CallICFGNode *cs)
Definition MemRegion.h:461
SVFStmtList & getPAGEdgesFromInst(const ICFGNode *node)
Given an instruction, get all its the PAGEdge (statement) in sequence.
bool hasModMRSet(const CallICFGNode *cs)
Definition MemRegion.h:457
bool hasSVFStmtList(const ICFGNode *icfgNode)
Whether this instruction has SVFIR Edge.
MRSet & getLoadMRSet(const LoadStmt *load)
Definition MemRegion.h:445
MRSet & getCallSiteModMRSet(const CallICFGNode *cs)
Definition MemRegion.h:465
bool hasRefMRSet(const CallICFGNode *cs)
Definition MemRegion.h:453
Memory Region class.
Definition MemRegion.h:56
std::vector< const SVFBasicBlock * > BBList
For phi insertion.
Definition MemSSA.h:93
MemRegToCounterMap mr2CounterMap
Definition MemSSA.h:144
MRVer * newSSAName(const MemRegion *mr, MSSADEF *def)
Get a new SSA name of a memory region.
Definition MemSSA.cpp:348
SVFIR::SVFStmtList SVFStmtList
SVFIR edge list.
Definition MemSSA.h:103
FunToEntryChiSetMap funToEntryChiSetMap
Definition MemSSA.h:140
EntryCHI< Condition > ENTRYCHI
Definition MemSSA.h:64
RetMU< Condition > RETMU
Definition MemSSA.h:60
FunToReturnMuSetMap funToReturnMuSetMap
Definition MemSSA.h:141
MemRegToVerStackMap mr2VerStackMap
Definition MemSSA.h:143
bool isNonInstricCallSite(const ICFGNode *inst)
Whether an instruction is a callsite in the application code, excluding llvm intrinsic calls.
Definition SVFUtil.h:182

◆ destroy()

void MemSSA::destroy ( )
private

Release the memory.

Clean up memory

Definition at line 367 of file MemSSA.cpp.

368{
369
370 for (LoadToMUSetMap::iterator iter = load2MuSetMap.begin(), eiter =
371 load2MuSetMap.end(); iter != eiter; ++iter)
372 {
373 for (MUSet::iterator it = iter->second.begin(), eit =
374 iter->second.end(); it != eit; ++it)
375 {
376 delete *it;
377 }
378 }
379
380 for (StoreToChiSetMap::iterator iter = store2ChiSetMap.begin(), eiter =
381 store2ChiSetMap.end(); iter != eiter; ++iter)
382 {
383 for (CHISet::iterator it = iter->second.begin(), eit =
384 iter->second.end(); it != eit; ++it)
385 {
386 delete *it;
387 }
388 }
389
390 for (CallSiteToMUSetMap::iterator iter = callsiteToMuSetMap.begin(),
391 eiter = callsiteToMuSetMap.end(); iter != eiter; ++iter)
392 {
393 for (MUSet::iterator it = iter->second.begin(), eit =
394 iter->second.end(); it != eit; ++it)
395 {
396 delete *it;
397 }
398 }
399
400 for (CallSiteToCHISetMap::iterator iter = callsiteToChiSetMap.begin(),
401 eiter = callsiteToChiSetMap.end(); iter != eiter; ++iter)
402 {
403 for (CHISet::iterator it = iter->second.begin(), eit =
404 iter->second.end(); it != eit; ++it)
405 {
406 delete *it;
407 }
408 }
409
410 for (FunToEntryChiSetMap::iterator iter = funToEntryChiSetMap.begin(),
411 eiter = funToEntryChiSetMap.end(); iter != eiter; ++iter)
412 {
413 for (CHISet::iterator it = iter->second.begin(), eit =
414 iter->second.end(); it != eit; ++it)
415 {
416 delete *it;
417 }
418 }
419
420 for (FunToReturnMuSetMap::iterator iter = funToReturnMuSetMap.begin(),
421 eiter = funToReturnMuSetMap.end(); iter != eiter; ++iter)
422 {
423 for (MUSet::iterator it = iter->second.begin(), eit =
424 iter->second.end(); it != eit; ++it)
425 {
426 delete *it;
427 }
428 }
429
430 for (BBToPhiSetMap::iterator iter = bb2PhiSetMap.begin(), eiter =
431 bb2PhiSetMap.end(); iter != eiter; ++iter)
432 {
433 for (PHISet::iterator it = iter->second.begin(), eit =
434 iter->second.end(); it != eit; ++it)
435 {
436 delete *it;
437 }
438 }
439
440 delete mrGen;
441 mrGen = nullptr;
442 delete stat;
443 stat = nullptr;
444 pta = nullptr;
445}

◆ dumpMSSA()

void MemSSA::dumpMSSA ( OutStream Out = SVFUtil::outs())

Print Memory SSA.

Print SSA

Definition at line 577 of file MemSSA.cpp.

578{
579
581 for (const auto& item: *svfirCallGraph)
582 {
583 const FunObjVar* fun = item.second->getFunction();
584 if(Options::MSSAFun()!="" && Options::MSSAFun()!=fun->getName())
585 continue;
586
587 Out << "==========FUNCTION: " << fun->getName() << "==========\n";
588 // dump function entry chi nodes
589 if (hasFuncEntryChi(fun))
590 {
592 for (CHISet::iterator chi_it = entry_chis.begin(); chi_it != entry_chis.end(); chi_it++)
593 {
594 (*chi_it)->dump();
595 }
596 }
597
598 for (FunObjVar::const_bb_iterator bit = fun->begin(), ebit = fun->end();
599 bit != ebit; ++bit)
600 {
601 const SVFBasicBlock* bb = bit->second;
602 Out << bb->getName() << "\n";
603 PHISet& phiSet = getPHISet(bb);
604 for(PHISet::iterator pi = phiSet.begin(), epi = phiSet.end(); pi !=epi; ++pi)
605 {
606 (*pi)->dump();
607 }
608
609 bool last_is_chi = false;
610 for (const auto& inst: bb->getICFGNodeList())
611 {
612 bool isAppCall = isNonInstricCallSite(inst) && !isExtCall(inst);
613 if (isAppCall || isHeapAllocExtCall(inst))
614 {
615 const CallICFGNode* cs = cast<CallICFGNode>(inst);
616 if(hasMU(cs))
617 {
618 if (!last_is_chi)
619 {
620 Out << "\n";
621 }
622 for (MUSet::iterator mit = getMUSet(cs).begin(), emit = getMUSet(cs).end();
623 mit != emit; ++mit)
624 {
625 (*mit)->dump();
626 }
627 }
628
629 Out << inst->toString() << "\n";
630
631 if(hasCHI(cs))
632 {
633 for (CHISet::iterator cit = getCHISet(cs).begin(), ecit = getCHISet(cs).end();
634 cit != ecit; ++cit)
635 {
636 (*cit)->dump();
637 }
638 Out << "\n";
639 last_is_chi = true;
640 }
641 else
642 last_is_chi = false;
643 }
644 else
645 {
646 bool dump_preamble = false;
648 for(SVFStmtList::const_iterator bit = pagEdgeList.begin(), ebit= pagEdgeList.end();
649 bit!=ebit; ++bit)
650 {
651 const PAGEdge* edge = *bit;
652 if (const LoadStmt* load = SVFUtil::dyn_cast<LoadStmt>(edge))
653 {
654 MUSet& muSet = getMUSet(load);
655 for(MUSet::iterator it = muSet.begin(), eit = muSet.end(); it!=eit; ++it)
656 {
657 if (!dump_preamble && !last_is_chi)
658 {
659 Out << "\n";
660 dump_preamble = true;
661 }
662 (*it)->dump();
663 }
664 }
665 }
666
667 Out << inst->toString() << "\n";
668
669 bool has_chi = false;
670 for(SVFStmtList::const_iterator bit = pagEdgeList.begin(), ebit= pagEdgeList.end();
671 bit!=ebit; ++bit)
672 {
673 const PAGEdge* edge = *bit;
674 if (const StoreStmt* store = SVFUtil::dyn_cast<StoreStmt>(edge))
675 {
676 CHISet& chiSet = getCHISet(store);
677 for(CHISet::iterator it = chiSet.begin(), eit = chiSet.end(); it!=eit; ++it)
678 {
679 has_chi = true;
680 (*it)->dump();
681 }
682 }
683 }
684 if (has_chi)
685 {
686 Out << "\n";
687 last_is_chi = true;
688 }
689 else
690 last_is_chi = false;
691 }
692 }
693 }
694
695 // dump return mu nodes
696 if (hasReturnMu(fun))
697 {
699 for (MUSet::iterator mu_it = return_mus.begin(); mu_it != return_mus.end(); mu_it++)
700 {
701 (*mu_it)->dump();
702 }
703 }
704 }
705}
cJSON * item
Definition cJSON.h:222
BasicBlockGraph::IDToNodeMapTy::const_iterator const_bb_iterator
const_bb_iterator begin() const
const_bb_iterator end() const
PHISet & getPHISet(const SVFBasicBlock *bb)
Definition MemSSA.h:397
CHISet & getCHISet(const StoreStmt *st)
Definition MemSSA.h:385
bool hasReturnMu(const FunObjVar *fun) const
Definition MemSSA.h:364
CHISet & getFuncEntryChiSet(const FunObjVar *fun)
Definition MemSSA.h:369
Set< MU * > MUSet
Definition MemSSA.h:70
Set< PHI * > PHISet
Definition MemSSA.h:72
bool hasFuncEntryChi(const FunObjVar *fun) const
Has function entry chi or return mu.
Definition MemSSA.h:360
bool hasCHI(const PAGEdge *inst) const
Definition MemSSA.h:336
MUSet & getMUSet(const LoadStmt *ld)
Get methods of mu/chi/phi.
Definition MemSSA.h:381
MUSet & getReturnMuSet(const FunObjVar *fun)
Definition MemSSA.h:373
bool hasMU(const PAGEdge *inst) const
Has mu/chi methods.
Definition MemSSA.h:325
Set< CHI * > CHISet
Definition MemSSA.h:71
static const Option< std::string > MSSAFun
Definition Options.h:143
CallGraph * getCallGraph()
Definition SVFIR.h:184
static SVFIR * getPAG(bool buildFromFile=false)
Singleton design here to make sure we only have one instance during any analysis.
Definition SVFIR.h:116
bool isHeapAllocExtCall(const ICFGNode *cs)
Definition SVFUtil.cpp:357

◆ getBBPhiNum()

u32_t MemSSA::getBBPhiNum ( ) const

Get PHI numbers

Definition at line 561 of file MemSSA.cpp.

562{
563 u32_t num = 0;
564 BBToPhiSetMap::const_iterator it = bb2PhiSetMap.begin();
565 BBToPhiSetMap::const_iterator eit = bb2PhiSetMap.end();
566 for (; it != eit; it++)
567 {
568 const PHISet & phiSet = it->second;
569 num+= phiSet.size();
570 }
571 return num;
572}
unsigned u32_t
Definition CommandLine.h:18

◆ getBBToPhiSetMap()

BBToPhiSetMap & SVF::MemSSA::getBBToPhiSetMap ( )
inline

Definition at line 429 of file MemSSA.h.

430 {
431 return bb2PhiSetMap;
432 }

◆ getCallSiteChiNum()

u32_t MemSSA::getCallSiteChiNum ( ) const

Get CallCHI numbers

Definition at line 544 of file MemSSA.cpp.

545{
546 u32_t num = 0;
547 CallSiteToCHISetMap::const_iterator it = callsiteToChiSetMap.begin();
548 CallSiteToCHISetMap::const_iterator eit = callsiteToChiSetMap.end();
549 for (; it != eit; it++)
550 {
551 const CHISet & chiSet = it->second;
552 num+= chiSet.size();
553 }
554 return num;
555}

◆ getCallSiteMuNum()

u32_t MemSSA::getCallSiteMuNum ( ) const

Get CallMU numbers

Definition at line 527 of file MemSSA.cpp.

528{
529 u32_t num = 0;
530 CallSiteToMUSetMap::const_iterator it = callsiteToMuSetMap.begin();
531 CallSiteToMUSetMap::const_iterator eit = callsiteToMuSetMap.end();
532 for (; it != eit; it++)
533 {
534 const MUSet & muSet = it->second;
535 num+= muSet.size();
536 }
537 return num;
538}

◆ getCallSiteToChiSetMap()

CallSiteToCHISetMap & SVF::MemSSA::getCallSiteToChiSetMap ( )
inline

Definition at line 425 of file MemSSA.h.

426 {
427 return callsiteToChiSetMap;
428 }

◆ getCallSiteToMuSetMap()

CallSiteToMUSetMap & SVF::MemSSA::getCallSiteToMuSetMap ( )
inline

Definition at line 421 of file MemSSA.h.

422 {
423 return callsiteToMuSetMap;
424 }

◆ getCHISet() [1/2]

CHISet & SVF::MemSSA::getCHISet ( const CallICFGNode cs)
inline

Definition at line 393 of file MemSSA.h.

394 {
395 return callsiteToChiSetMap[cs];
396 }

◆ getCHISet() [2/2]

CHISet & SVF::MemSSA::getCHISet ( const StoreStmt st)
inline

Definition at line 385 of file MemSSA.h.

386 {
387 return store2ChiSetMap[st];
388 }

◆ getFuncEntryChiSet()

CHISet & SVF::MemSSA::getFuncEntryChiSet ( const FunObjVar fun)
inline

Definition at line 369 of file MemSSA.h.

370 {
371 return funToEntryChiSetMap[fun];
372 }

◆ getFunEntryChiNum()

u32_t MemSSA::getFunEntryChiNum ( ) const

Get EntryCHI numbers

Definition at line 493 of file MemSSA.cpp.

494{
495 u32_t num = 0;
496 FunToEntryChiSetMap::const_iterator it = funToEntryChiSetMap.begin();
497 FunToEntryChiSetMap::const_iterator eit = funToEntryChiSetMap.end();
498 for (; it != eit; it++)
499 {
500 const CHISet& chiSet = it->second;
501 num += chiSet.size();
502 }
503 return num;
504}

◆ getFunRetMuNum()

u32_t MemSSA::getFunRetMuNum ( ) const

Get RetMU numbers

Definition at line 510 of file MemSSA.cpp.

511{
512 u32_t num = 0;
513 FunToReturnMuSetMap::const_iterator it = funToReturnMuSetMap.begin();
514 FunToReturnMuSetMap::const_iterator eit = funToReturnMuSetMap.end();
515 for (; it != eit; it++)
516 {
517 const MUSet & muSet = it->second;
518 num+= muSet.size();
519 }
520 return num;
521}

◆ getFunToEntryChiSetMap()

FunToEntryChiSetMap & SVF::MemSSA::getFunToEntryChiSetMap ( )
inline

Definition at line 417 of file MemSSA.h.

418 {
419 return funToEntryChiSetMap;
420 }

◆ getFunToRetMuSetMap()

FunToReturnMuSetMap & SVF::MemSSA::getFunToRetMuSetMap ( )
inline

Definition at line 413 of file MemSSA.h.

414 {
415 return funToReturnMuSetMap;
416 }

◆ getLoadMuNum()

u32_t MemSSA::getLoadMuNum ( ) const

Stat methods.

Get loadMU numbers

Definition at line 459 of file MemSSA.cpp.

460{
461 u32_t num = 0;
462 LoadToMUSetMap::const_iterator it = load2MuSetMap.begin();
463 LoadToMUSetMap::const_iterator eit = load2MuSetMap.end();
464 for (; it != eit; it++)
465 {
466 const MUSet & muSet = it->second;
467 num+= muSet.size();
468 }
469 return num;
470}

◆ getLoadToMUSetMap()

LoadToMUSetMap & SVF::MemSSA::getLoadToMUSetMap ( )
inline

Definition at line 405 of file MemSSA.h.

406 {
407 return load2MuSetMap;
408 }

◆ getMRGenerator()

MRGenerator * SVF::MemSSA::getMRGenerator ( )
inline

Return MRGenerator.

Definition at line 313 of file MemSSA.h.

314 {
315 return mrGen;
316 }

◆ getMUSet() [1/2]

MUSet & SVF::MemSSA::getMUSet ( const CallICFGNode cs)
inline

Definition at line 389 of file MemSSA.h.

390 {
391 return callsiteToMuSetMap[cs];
392 }

◆ getMUSet() [2/2]

MUSet & SVF::MemSSA::getMUSet ( const LoadStmt ld)
inline

Get methods of mu/chi/phi.

Definition at line 381 of file MemSSA.h.

382 {
383 return load2MuSetMap[ld];
384 }

◆ getPAG()

SVFIR * MemSSA::getPAG ( )
inline

Return SVFIR.

Definition at line 73 of file MemSSA.cpp.

74{
75 return pta->getPAG();
76}
SVFIR * getPAG() const

◆ getPHISet()

PHISet & SVF::MemSSA::getPHISet ( const SVFBasicBlock bb)
inline

Definition at line 397 of file MemSSA.h.

398 {
399 return bb2PhiSetMap[bb];
400 }

◆ getPTA()

BVDataPTAImpl * SVF::MemSSA::getPTA ( ) const
inline

Return PTA.

Definition at line 308 of file MemSSA.h.

309 {
310 return pta;
311 }

◆ getReturnMuSet()

MUSet & SVF::MemSSA::getReturnMuSet ( const FunObjVar fun)
inline

Definition at line 373 of file MemSSA.h.

374 {
375 return funToReturnMuSetMap[fun];
376 }

◆ getStoreChiNum()

u32_t MemSSA::getStoreChiNum ( ) const

Get StoreCHI numbers

Definition at line 476 of file MemSSA.cpp.

477{
478 u32_t num = 0;
479 StoreToChiSetMap::const_iterator it = store2ChiSetMap.begin();
480 StoreToChiSetMap::const_iterator eit = store2ChiSetMap.end();
481 for (; it != eit; it++)
482 {
483 const CHISet& chiSet = it->second;
484 num += chiSet.size();
485 }
486 return num;
487}

◆ getStoreToChiSetMap()

StoreToChiSetMap & SVF::MemSSA::getStoreToChiSetMap ( )
inline

Definition at line 409 of file MemSSA.h.

410 {
411 return store2ChiSetMap;
412 }

◆ getTopStackVer()

MRVer * SVF::MemSSA::getTopStackVer ( const MemRegion mr)
inlineprivate

Get the last version of the SSA ver of memory region.

Definition at line 166 of file MemSSA.h.

167 {
168 std::vector<MRVer*> &stack = mr2VerStackMap[mr];
169 assert(!stack.empty() && "stack is empty!!");
170 return stack.back();
171 }

◆ hasCHI() [1/2]

bool SVF::MemSSA::hasCHI ( const CallICFGNode cs) const
inline

Definition at line 352 of file MemSSA.h.

353 {
354 return callsiteToChiSetMap.find(cs)!=callsiteToChiSetMap.end();
355 }

◆ hasCHI() [2/2]

bool SVF::MemSSA::hasCHI ( const PAGEdge inst) const
inline

Definition at line 336 of file MemSSA.h.

337 {
338 if (const StoreStmt* store = SVFUtil::dyn_cast<StoreStmt>(
339 inst))
340 {
341 bool has_store = store2ChiSetMap.count(store) != 0;
342 assert(has_store && "not associated with mem region!");
343 return has_store;
344 }
345 else
346 return false;
347 }

◆ hasFuncEntryChi()

bool SVF::MemSSA::hasFuncEntryChi ( const FunObjVar fun) const
inline

Has function entry chi or return mu.

Definition at line 360 of file MemSSA.h.

361 {
362 return (funToEntryChiSetMap.find(fun) != funToEntryChiSetMap.end());
363 }

◆ hasMU() [1/2]

bool SVF::MemSSA::hasMU ( const CallICFGNode cs) const
inline

Definition at line 348 of file MemSSA.h.

349 {
350 return callsiteToMuSetMap.find(cs)!=callsiteToMuSetMap.end();
351 }

◆ hasMU() [2/2]

bool SVF::MemSSA::hasMU ( const PAGEdge inst) const
inline

Has mu/chi methods.

Definition at line 325 of file MemSSA.h.

326 {
327 if (const LoadStmt* load = SVFUtil::dyn_cast<LoadStmt>(inst))
328 {
329 bool hasMu = load2MuSetMap.count(load) != 0;
330 assert(hasMu && "not associated with mem region!");
331 return hasMu;
332 }
333 else
334 return false;
335 }

◆ hasPHISet()

bool SVF::MemSSA::hasPHISet ( const SVFBasicBlock bb) const
inline

Definition at line 401 of file MemSSA.h.

402 {
403 return bb2PhiSetMap.find(bb)!=bb2PhiSetMap.end();
404 }

◆ hasReturnMu()

bool SVF::MemSSA::hasReturnMu ( const FunObjVar fun) const
inline

Definition at line 364 of file MemSSA.h.

365 {
366 return (funToReturnMuSetMap.find(fun) != funToReturnMuSetMap.end());
367 }

◆ insertPHI()

void MemSSA::insertPHI ( const FunObjVar fun)
protectedvirtual

Insert phi for candidate regions in a function.

Definition at line 202 of file MemSSA.cpp.

203{
204
205 DBOUT(DMSSA,
206 outs() << "\t insert phi for function " << fun.getName() << "\n");
207
209 // record whether a phi of mr has already been inserted into the bb.
211
212 // start inserting phi node
213 for (MRSet::iterator iter = usedRegs.begin(), eiter = usedRegs.end();
214 iter != eiter; ++iter)
215 {
216 const MemRegion* mr = *iter;
217
218 BBList bbs = reg2BBMap[mr];
219 while (!bbs.empty())
220 {
221 const SVFBasicBlock* bb = bbs.back();
222 bbs.pop_back();
223 Map<const SVFBasicBlock*,Set<const SVFBasicBlock*>>::const_iterator it = df.find(bb);
224 if(it == df.end())
225 {
226 writeWrnMsg("bb not in the dominance frontier map??");
227 continue;
228 }
229 const Set<const SVFBasicBlock*>& domSet = it->second;
230 for (const SVFBasicBlock* pbb : domSet)
231 {
232 // if we never insert this phi node before
233 if (0 == bb2MRSetMap[pbb].count(mr))
234 {
235 bb2MRSetMap[pbb].insert(mr);
236 // insert phi node
237 AddMSSAPHI(pbb,mr);
238 // continue to insert phi in its iterative dominate frontiers
239 bbs.push_back(pbb);
240 }
241 }
242 }
243 }
244
245}
int count
Definition cJSON.h:216
const Map< const SVFBasicBlock *, BBSet > & getDomFrontierMap() const
Map< const SVFBasicBlock *, MRSet > BBToMRSetMap
Definition MemSSA.h:94
const ICFGNode * back() const
void writeWrnMsg(const std::string &msg)
Writes a message run through wrnMsg.
Definition SVFUtil.cpp:68

◆ newSSAName()

MRVer * MemSSA::newSSAName ( const MemRegion mr,
MSSADEF def 
)
private

Get a new SSA name of a memory region.

Definition at line 348 of file MemSSA.cpp.

349{
350 assert(0 != mr2CounterMap.count(mr)
351 && "did not find initial version in map? ");
352 assert(0 != mr2VerStackMap.count(mr)
353 && "did not find initial stack in map? ");
354
355 MRVERSION version = mr2CounterMap[mr];
356 mr2CounterMap[mr] = version + 1;
357 auto mrVer = std::make_unique<MRVer>(mr, version, def);
358 auto mrVerPtr = mrVer.get();
359 mr2VerStackMap[mr].push_back(mrVerPtr);
360 usedMRVers.push_back(std::move(mrVer));
361 return mrVerPtr;
362}
std::vector< std::unique_ptr< MRVer > > usedMRVers
Definition MemSSA.h:157
NodeID MRVERSION
Definition MemRegion.h:52

◆ performStat()

void MemSSA::performStat ( )

Perform statistics.

Perform statistics

Definition at line 450 of file MemSSA.cpp.

451{
452 if(pta->printStat())
453 stat->performStat();
454}
virtual void performStat() override
Definition SVFGStat.cpp:74
bool printStat()
Whether print statistics.

◆ RenameChiSet()

void SVF::MemSSA::RenameChiSet ( const CHISet chiSet,
MRVector memRegs 
)
inlineprivate

Rename chi set.

Definition at line 260 of file MemSSA.h.

261 {
262 for (CHISet::const_iterator cit = chiSet.begin(), ecit = chiSet.end();
263 cit != ecit; ++cit)
264 {
265 CHI* chi = (*cit);
266 chi->setOpVer(getTopStackVer(chi->getMR()));
267 chi->setResVer(newSSAName(chi->getMR(),chi));
268 memRegs.push_back(chi->getMR());
269 }
270 }
MSSACHI< Condition > CHI
Definition MemSSA.h:63
MRVer * getTopStackVer(const MemRegion *mr)
Get the last version of the SSA ver of memory region.
Definition MemSSA.h:166

◆ RenameMuSet()

void SVF::MemSSA::RenameMuSet ( const MUSet muSet)
inlineprivate

Rename mus, chis and phis.

Rename mu set

Definition at line 249 of file MemSSA.h.

250 {
251 for (MUSet::const_iterator mit = muSet.begin(), emit = muSet.end();
252 mit != emit; ++mit)
253 {
254 MU* mu = (*mit);
255 mu->setVer(getTopStackVer(mu->getMR()));
256 }
257 }
MSSAMU< Condition > MU
Definition MemSSA.h:59

◆ RenamePhiOps()

void SVF::MemSSA::RenamePhiOps ( const PHISet phiSet,
u32_t  pos,
MRVector  
)
inlineprivate

Rename operands (RHS) of phis.

Definition at line 285 of file MemSSA.h.

286 {
287 for (PHISet::const_iterator iter = phiSet.begin(), eiter = phiSet.end();
288 iter != eiter; ++iter)
289 {
290 PHI* phi = *iter;
291 phi->setOpVer(getTopStackVer(phi->getMR()), pos);
292 }
293 }

◆ RenamePhiRes()

void SVF::MemSSA::RenamePhiRes ( const PHISet phiSet,
MRVector memRegs 
)
inlineprivate

Rename result (LHS) of phis.

Definition at line 273 of file MemSSA.h.

274 {
275 for (PHISet::const_iterator iter = phiSet.begin(), eiter = phiSet.end();
276 iter != eiter; ++iter)
277 {
278 PHI* phi = *iter;
279 phi->setResVer(newSSAName(phi->getMR(),phi));
280 memRegs.push_back(phi->getMR());
281 }
282 }

◆ SSARename()

void MemSSA::SSARename ( const FunObjVar fun)
protectedvirtual

SSA rename for a function.

SSA construction algorithm

Definition at line 250 of file MemSSA.cpp.

251{
252
253 DBOUT(DMSSA,
254 outs() << "\t ssa rename for function " << fun.getName() << "\n");
255
257}
const SVFBasicBlock * getEntryBlock() const
virtual void SSARenameBB(const SVFBasicBlock &bb)
SSA rename for a basic block.
Definition MemSSA.cpp:263

◆ SSARenameBB()

void MemSSA::SSARenameBB ( const SVFBasicBlock bb)
protectedvirtual

SSA rename for a basic block.

Renaming for each memory regions See the renaming algorithm in book Engineering A Compiler (Figure 9.12)

Definition at line 263 of file MemSSA.cpp.

264{
265
266 // record which mem region needs to pop stack
268
269 // rename phi result op
270 // for each r = phi (...)
271 // rewrite r as new name
272 if (hasPHISet(&bb))
274
275
276 // process mu and chi
277 // for each mu(r)
278 // rewrite r with top mrver of stack(r)
279 // for each r = chi(r')
280 // rewrite r' with top mrver of stack(r)
281 // rewrite r with new name
282
283 for (const auto& pNode: bb.getICFGNodeList())
284 {
286 {
288 for(SVFStmtList::const_iterator bit = pagEdgeList.begin(), ebit= pagEdgeList.end();
289 bit!=ebit; ++bit)
290 {
291 const PAGEdge* inst = *bit;
292 if (const LoadStmt* load = SVFUtil::dyn_cast<LoadStmt>(inst))
293 RenameMuSet(getMUSet(load));
294
295 else if (const StoreStmt* store = SVFUtil::dyn_cast<StoreStmt>(inst))
297
298 }
299 }
301 {
303 if(mrGen->hasRefMRSet(cs))
305
306 if(mrGen->hasModMRSet(cs))
308 }
309 else if(isRetInstNode(pNode))
310 {
311 const FunObjVar* fun = bb.getParent();
313 }
314 }
315
316
317 // fill phi operands of succ basic blocks
318 for (const SVFBasicBlock* succ : bb.getSuccessors())
319 {
321 if (hasPHISet(succ))
323 }
324
325 // for succ basic block in dominator tree
326 const FunObjVar* fun = bb.getParent();
328 Map<const SVFBasicBlock*,Set<const SVFBasicBlock*>>::const_iterator mapIter = dtBBsMap.find(&bb);
329 if (mapIter != dtBBsMap.end())
330 {
331 const Set<const SVFBasicBlock*>& dtBBs = mapIter->second;
332 for (const SVFBasicBlock* dtbb : dtBBs)
333 {
335 }
336 }
337 // for each r = chi(..), and r = phi(..)
338 // pop ver stack(r)
339 while (!memRegs.empty())
340 {
341 const MemRegion* mr = memRegs.back();
342 memRegs.pop_back();
343 mr2VerStackMap[mr].pop_back();
344 }
345
346}
const Map< const SVFBasicBlock *, BBSet > & getDomTreeMap() const
void RenamePhiOps(const PHISet &phiSet, u32_t pos, MRVector &)
Rename operands (RHS) of phis.
Definition MemSSA.h:285
void RenameMuSet(const MUSet &muSet)
Rename mus, chis and phis.
Definition MemSSA.h:249
bool hasPHISet(const SVFBasicBlock *bb) const
Definition MemSSA.h:401
void RenameChiSet(const CHISet &chiSet, MRVector &memRegs)
Rename chi set.
Definition MemSSA.h:260
void RenamePhiRes(const PHISet &phiSet, MRVector &memRegs)
Rename result (LHS) of phis.
Definition MemSSA.h:273
std::vector< const MemRegion * > MRVector
Definition MemSSA.h:76
const FunObjVar * getParent() const
u32_t getBBPredecessorPos(const SVFBasicBlock *succbb)
bool isRetInstNode(const ICFGNode *node)
Definition SVFUtil.cpp:376

Member Data Documentation

◆ bb2PhiSetMap

BBToPhiSetMap SVF::MemSSA::bb2PhiSetMap
private

Definition at line 138 of file MemSSA.h.

◆ callsiteToChiSetMap

CallSiteToCHISetMap SVF::MemSSA::callsiteToChiSetMap
private

Definition at line 137 of file MemSSA.h.

◆ callsiteToMuSetMap

CallSiteToMUSetMap SVF::MemSSA::callsiteToMuSetMap
private

Definition at line 136 of file MemSSA.h.

◆ funToEntryChiSetMap

FunToEntryChiSetMap SVF::MemSSA::funToEntryChiSetMap
private

Definition at line 140 of file MemSSA.h.

◆ funToReturnMuSetMap

FunToReturnMuSetMap SVF::MemSSA::funToReturnMuSetMap
private

Definition at line 141 of file MemSSA.h.

◆ load2MuSetMap

LoadToMUSetMap SVF::MemSSA::load2MuSetMap
private

Definition at line 134 of file MemSSA.h.

◆ mr2CounterMap

MemRegToCounterMap SVF::MemSSA::mr2CounterMap
private

Definition at line 144 of file MemSSA.h.

◆ mr2VerStackMap

MemRegToVerStackMap SVF::MemSSA::mr2VerStackMap
private

Definition at line 143 of file MemSSA.h.

◆ mrGen

MRGenerator* SVF::MemSSA::mrGen
protected

Definition at line 122 of file MemSSA.h.

◆ pta

BVDataPTAImpl* SVF::MemSSA::pta
protected

Definition at line 121 of file MemSSA.h.

◆ reg2BBMap

MemRegToBBsMap SVF::MemSSA::reg2BBMap
private

Maps memory region to its basic block.

Definition at line 152 of file MemSSA.h.

◆ stat

MemSSAStat* SVF::MemSSA::stat
protected

Definition at line 123 of file MemSSA.h.

◆ store2ChiSetMap

StoreToChiSetMap SVF::MemSSA::store2ChiSetMap
private

Definition at line 135 of file MemSSA.h.

◆ timeOfCreateMUCHI

double MemSSA::timeOfCreateMUCHI = 0
static

Time for generating mu/chi for load/store/calls.

Definition at line 108 of file MemSSA.h.

◆ timeOfGeneratingMemRegions

double MemSSA::timeOfGeneratingMemRegions = 0
static

Statistics.

Time for allocating regions.

Time for allocating regions

Definition at line 107 of file MemSSA.h.

◆ timeOfInsertingPHI

double MemSSA::timeOfInsertingPHI = 0
static

Time for inserting phis.

Definition at line 109 of file MemSSA.h.

◆ timeOfSSARenaming

double MemSSA::timeOfSSARenaming = 0
static

Time for SSA rename.

Definition at line 110 of file MemSSA.h.

◆ usedMRVers

std::vector<std::unique_ptr<MRVer> > SVF::MemSSA::usedMRVers
private

Definition at line 157 of file MemSSA.h.

◆ usedRegs

MRSet SVF::MemSSA::usedRegs
private

The following three set are used for prune SSA phi insertion.

Collects used memory regions

Definition at line 150 of file MemSSA.h.

◆ varKills

MRSet SVF::MemSSA::varKills
private

Collect memory regions whose definition killed.

Definition at line 154 of file MemSSA.h.


The documentation for this class was generated from the following files: