2001-10-01 13:19:53 +00:00
|
|
|
/* Title: MethodLiveVarInfo.h -*- C++ -*-
|
2001-07-24 17:14:13 +00:00
|
|
|
Author: Ruchira Sasanka
|
|
|
|
Date: Jun 30, 01
|
|
|
|
Purpose:
|
|
|
|
|
2001-08-20 21:11:01 +00:00
|
|
|
This is the interface for live variable info of a method that is required
|
|
|
|
by any other part of the compiler
|
2001-07-24 17:14:13 +00:00
|
|
|
|
2001-08-20 21:11:01 +00:00
|
|
|
It must be called like:
|
2001-07-24 17:14:13 +00:00
|
|
|
|
|
|
|
MethodLiveVarInfo MLVI( Mehtod *); // initializes data structures
|
2001-08-20 21:11:01 +00:00
|
|
|
MLVI.analyze(); // do the actural live variable anal
|
2001-07-24 17:14:13 +00:00
|
|
|
|
|
|
|
After the analysis, getInSetOfBB or getOutSetofBB can be called to get
|
2001-08-20 21:11:01 +00:00
|
|
|
live var info of a BB.
|
2001-07-24 17:14:13 +00:00
|
|
|
|
2001-08-20 21:11:01 +00:00
|
|
|
The live var set before an instruction can be obtained in 2 ways:
|
2001-07-24 17:14:13 +00:00
|
|
|
|
2001-08-20 21:11:01 +00:00
|
|
|
1. Use the method getLiveVarSetAfterInst(Instruction *) to get the LV Info
|
|
|
|
just after an instruction. (also exists getLiveVarSetBeforeInst(..))
|
|
|
|
|
|
|
|
This function caluclates the LV info for a BB only once and caches that
|
|
|
|
info. If the cache does not contain the LV info of the instruction, it
|
|
|
|
calculates the LV info for the whole BB and caches them.
|
|
|
|
|
|
|
|
Getting liveVar info this way uses more memory since, LV info should be
|
|
|
|
cached. However, if you need LV info of nearly all the instructions of a
|
|
|
|
BB, this is the best and simplest interfrace.
|
|
|
|
|
|
|
|
|
|
|
|
2. Use the OutSet and applyTranferFuncForInst(const Instruction *const Inst)
|
2001-07-24 17:14:13 +00:00
|
|
|
declared in LiveVarSet and traverse the instructions of a basic block in
|
|
|
|
reverse (using const_reverse_iterator in the BB class).
|
|
|
|
|
2001-08-20 21:11:01 +00:00
|
|
|
This is the most memory efficient method if you need LV info for
|
|
|
|
only several instructions in a BasicBlock. An example is given below:
|
2001-07-24 17:14:13 +00:00
|
|
|
|
|
|
|
|
|
|
|
LiveVarSet LVSet; // this will be the set used to traverse through each BB
|
|
|
|
|
2001-08-20 21:11:01 +00:00
|
|
|
// Initialize LVSet so that it is the same as OutSet of the BB
|
2001-07-24 17:14:13 +00:00
|
|
|
LVSet.setUnion( LVI->getOutSetOfBB( *BBI ) );
|
|
|
|
|
|
|
|
BasicBlock::InstListType::const_reverse_iterator
|
2001-08-20 21:11:01 +00:00
|
|
|
InstIterator = InstListInBB.rbegin(); // get the rev iter for inst in BB
|
2001-07-24 17:14:13 +00:00
|
|
|
|
2001-08-20 21:11:01 +00:00
|
|
|
// iterate over all the instructions in BB in reverse
|
2001-07-24 17:14:13 +00:00
|
|
|
for( ; InstIterator != InstListInBB.rend(); InstIterator++) {
|
|
|
|
|
|
|
|
//...... all code here which uses LVSet ........
|
|
|
|
|
|
|
|
LVSet.applyTranferFuncForInst(*InstIterator);
|
|
|
|
|
|
|
|
// Now LVSet contains live vars ABOVE the current instrution
|
|
|
|
}
|
|
|
|
|
|
|
|
See buildInterferenceGraph() for the above example.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef METH_LIVE_VAR_INFO_H
|
|
|
|
#define METH_LIVE_VAR_INFO_H
|
|
|
|
|
2001-08-20 21:11:01 +00:00
|
|
|
// set DEBUG_LV for printing out debug messages
|
|
|
|
// if DEBUG_LV is 1 normal output messages
|
|
|
|
// if DEBUG_LV is 2 extensive debug info for each instr
|
|
|
|
|
2001-08-28 21:35:26 +00:00
|
|
|
static const int DEBUG_LV = 0;
|
2001-07-24 17:14:13 +00:00
|
|
|
|
2002-02-04 20:00:08 +00:00
|
|
|
#include "llvm/Pass.h"
|
2002-02-05 02:51:01 +00:00
|
|
|
#include "llvm/Analysis/LiveVar/ValueSet.h"
|
2002-02-05 00:33:19 +00:00
|
|
|
class BBLiveVar;
|
|
|
|
class MachineInstr;
|
2001-07-24 17:14:13 +00:00
|
|
|
|
2002-02-04 20:00:08 +00:00
|
|
|
class MethodLiveVarInfo : public MethodPass {
|
2001-08-20 21:11:01 +00:00
|
|
|
// Machine Instr to LiveVarSet Map for providing LVset BEFORE each inst
|
2002-02-05 02:51:01 +00:00
|
|
|
std::map<const MachineInstr *, const ValueSet *> MInst2LVSetBI;
|
2001-08-20 21:11:01 +00:00
|
|
|
|
|
|
|
// Machine Instr to LiveVarSet Map for providing LVset AFTER each inst
|
2002-02-05 02:51:01 +00:00
|
|
|
std::map<const MachineInstr *, const ValueSet *> MInst2LVSetAI;
|
2001-07-24 17:14:13 +00:00
|
|
|
|
2002-02-05 06:52:25 +00:00
|
|
|
// Stored Method that the data is computed with respect to
|
|
|
|
const Method *M;
|
2001-07-24 17:14:13 +00:00
|
|
|
|
2001-08-20 21:11:01 +00:00
|
|
|
// --------- private methods -----------------------------------------
|
|
|
|
|
|
|
|
// constructs BBLiveVars and init Def and In sets
|
2002-02-04 20:49:04 +00:00
|
|
|
void constructBBs(const Method *M);
|
2001-08-20 21:11:01 +00:00
|
|
|
|
|
|
|
// do one backward pass over the CFG
|
2002-02-05 06:52:25 +00:00
|
|
|
bool doSingleBackwardPass(const Method *M);
|
2001-08-20 21:11:01 +00:00
|
|
|
|
|
|
|
// calculates live var sets for instructions in a BB
|
2002-02-04 16:32:40 +00:00
|
|
|
void calcLiveVarSetsForBB(const BasicBlock *BB);
|
2001-07-24 17:14:13 +00:00
|
|
|
|
2002-02-04 20:00:08 +00:00
|
|
|
public:
|
|
|
|
static AnalysisID ID; // We are an analysis, we must have an ID
|
|
|
|
|
2002-02-04 20:49:04 +00:00
|
|
|
MethodLiveVarInfo(AnalysisID id = ID) { assert(id == ID); }
|
2002-02-04 20:00:08 +00:00
|
|
|
|
|
|
|
// --------- Implement the MethodPass interface ----------------------
|
|
|
|
|
|
|
|
// runOnMethod - Perform analysis, update internal data structures.
|
|
|
|
virtual bool runOnMethod(Method *M);
|
2001-07-24 17:14:13 +00:00
|
|
|
|
2002-02-04 20:00:08 +00:00
|
|
|
// releaseMemory - After LiveVariable analysis has been used, forget!
|
|
|
|
virtual void releaseMemory();
|
|
|
|
|
|
|
|
// getAnalysisUsageInfo - Provide self!
|
|
|
|
virtual void getAnalysisUsageInfo(AnalysisSet &Required,
|
|
|
|
AnalysisSet &Destroyed,
|
|
|
|
AnalysisSet &Provided) {
|
|
|
|
Provided.push_back(ID);
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------- Functions to access analysis results -------------------
|
2001-07-24 17:14:13 +00:00
|
|
|
|
2001-08-20 21:11:01 +00:00
|
|
|
// gets OutSet of a BB
|
2002-02-05 04:20:12 +00:00
|
|
|
const ValueSet &getOutSetOfBB(const BasicBlock *BB) const;
|
2001-07-24 17:14:13 +00:00
|
|
|
|
2001-08-20 21:11:01 +00:00
|
|
|
// gets InSet of a BB
|
2002-02-05 04:20:12 +00:00
|
|
|
const ValueSet &getInSetOfBB(const BasicBlock *BB) const;
|
2001-08-20 21:11:01 +00:00
|
|
|
|
|
|
|
// gets the Live var set BEFORE an instruction
|
2002-02-05 04:20:12 +00:00
|
|
|
const ValueSet &getLiveVarSetBeforeMInst(const MachineInstr *MI,
|
2002-02-05 02:51:01 +00:00
|
|
|
const BasicBlock *BB);
|
2001-08-20 21:11:01 +00:00
|
|
|
|
|
|
|
// gets the Live var set AFTER an instruction
|
2002-02-05 04:20:12 +00:00
|
|
|
const ValueSet &getLiveVarSetAfterMInst(const MachineInstr *MI,
|
2002-02-05 02:51:01 +00:00
|
|
|
const BasicBlock *BB);
|
2001-07-24 17:14:13 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|