forked from OSchip/llvm-project
Save argument list alloc state by recording it as the operands of Instruction
#-1. Other minor changes to deal with AllocInfo.Instruction becoming an int. llvm-svn: 12246
This commit is contained in:
parent
0be7ea7289
commit
f0a73a3f42
|
@ -1125,7 +1125,7 @@ void PhyRegAlloc::allocateStackSpace4SpilledLRs() {
|
|||
|
||||
|
||||
void PhyRegAlloc::saveStateForValue (std::vector<AllocInfo> &state,
|
||||
const Value *V, unsigned Insn, int Opnd) {
|
||||
const Value *V, int Insn, int Opnd) {
|
||||
LiveRangeMapType::const_iterator HMI = LRI->getLiveRangeMap ()->find (V);
|
||||
LiveRangeMapType::const_iterator HMIEnd = LRI->getLiveRangeMap ()->end ();
|
||||
AllocInfo::AllocStateTy AllocState = AllocInfo::NotAllocated;
|
||||
|
@ -1155,7 +1155,15 @@ void PhyRegAlloc::saveStateForValue (std::vector<AllocInfo> &state,
|
|||
///
|
||||
void PhyRegAlloc::saveState () {
|
||||
std::vector<AllocInfo> &state = FnAllocState[Fn];
|
||||
unsigned ArgNum = 0;
|
||||
// Arguments encoded as instruction # -1
|
||||
for (Function::const_aiterator i=Fn->abegin (), e=Fn->aend (); i != e; ++i) {
|
||||
const Argument *Arg = &*i;
|
||||
saveStateForValue (state, Arg, -1, ArgNum);
|
||||
++ArgNum;
|
||||
}
|
||||
unsigned Insn = 0;
|
||||
// Instructions themselves encoded as operand # -1
|
||||
for (const_inst_iterator II=inst_begin (Fn), IE=inst_end (Fn); II!=IE; ++II){
|
||||
saveStateForValue (state, (*II), Insn, -1);
|
||||
for (unsigned i = 0; i < (*II)->getNumOperands (); ++i) {
|
||||
|
@ -1176,7 +1184,7 @@ void PhyRegAlloc::saveState () {
|
|||
///
|
||||
void PhyRegAlloc::verifySavedState () {
|
||||
std::vector<AllocInfo> &state = FnAllocState[Fn];
|
||||
unsigned Insn = 0;
|
||||
int Insn = 0;
|
||||
for (const_inst_iterator II=inst_begin (Fn), IE=inst_end (Fn); II!=IE; ++II) {
|
||||
const Instruction *I = *II;
|
||||
MachineCodeForInstruction &Instrs = MachineCodeForInstruction::get (I);
|
||||
|
|
Loading…
Reference in New Issue