1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-24 19:52:54 +01:00

In PhyRegAlloc::saveState(), dump Arguments' saved-state, and try to

make the output more compact.

Divorce state-saving from the doFinalization method; for some reason it's not
getting called when I want it to, at Reoptimizer time. Put the guts in
PhyRegAlloc::finishSavingState(). Put an abort() in it so that I can be really
really sure that it's getting called.

Update comments.

llvm-svn: 12286
This commit is contained in:
Brian Gaeke 2004-03-11 06:45:52 +00:00
parent bb3d010689
commit b3f9f99ff2
2 changed files with 32 additions and 11 deletions

View File

@ -1186,14 +1186,27 @@ void PhyRegAlloc::saveState () {
///
void PhyRegAlloc::verifySavedState () {
std::vector<AllocInfo> &state = FnAllocState[Fn];
int ArgNum = 0;
for (Function::const_aiterator i=Fn->abegin (), e=Fn->aend (); i != e; ++i) {
const Argument *Arg = &*i;
std::cerr << "Argument: " << *Arg << "\n"
<< "FnAllocState:\n";
for (unsigned i = 0; i < state.size (); ++i) {
AllocInfo &S = state[i];
if (S.Instruction == -1 && S.Operand == ArgNum)
std::cerr << " " << S << "\n";
}
std::cerr << "----------\n";
++ArgNum;
}
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);
std::cerr << "Instruction:\n" << " " << *I << "\n"
std::cerr << "Instruction: " << *I
<< "MachineCodeForInstruction:\n";
for (unsigned i = 0, n = Instrs.size (); i != n; ++i)
std::cerr << " " << *Instrs[i] << "\n";
std::cerr << " " << *Instrs[i];
std::cerr << "FnAllocState:\n";
for (unsigned i = 0; i < state.size (); ++i) {
AllocInfo &S = state[i];
@ -1206,21 +1219,29 @@ void PhyRegAlloc::verifySavedState () {
}
/// Finish the job of saveState(), by collapsing FnAllocState into an LLVM
/// Constant and stuffing it inside the Module. (NOTE: Soon, there will be
/// other, better ways of storing the saved state; this one is cumbersome and
/// does not work well with the JIT.)
///
bool PhyRegAlloc::doFinalization (Module &M) {
if (!SaveRegAllocState)
return false; // Nothing to do here, unless we're saving state.
if (SaveRegAllocState) finishSavingState (M);
return false;
}
/// Finish the job of saveState(), by collapsing FnAllocState into an LLVM
/// Constant and stuffing it inside the Module.
///
/// FIXME: There should be other, better ways of storing the saved
/// state; this one is cumbersome and does not work well with the JIT.
///
void PhyRegAlloc::finishSavingState (Module &M) {
std::cerr << "---- Saving reg. alloc state; SaveStateToModule = "
<< SaveStateToModule << " ----\n";
abort ();
// If saving state into the module, just copy new elements to the
// correct global.
if (!SaveStateToModule) {
ExportedFnAllocState = FnAllocState;
// FIXME: should ONLY copy new elements in FnAllocState
return false;
return;
}
// Convert FnAllocState to a single Constant array and add it
@ -1282,7 +1303,6 @@ bool PhyRegAlloc::doFinalization (Module &M) {
new GlobalVariable (ST2, true, GlobalValue::ExternalLinkage,
ConstantStruct::get (ST2, CV2), "_llvm_regAllocState",
&M);
return false; // No error.
}

View File

@ -129,6 +129,7 @@ private:
const Value *V, int Insn, int Opnd);
void saveState();
void verifySavedState();
void finishSavingState(Module &M);
void setCallInterferences(const MachineInstr *MI,
const ValueSet *LVSetAft);