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:
parent
bb3d010689
commit
b3f9f99ff2
@ -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.
|
||||
}
|
||||
|
||||
|
||||
|
@ -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);
|
||||
|
Loading…
Reference in New Issue
Block a user