summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen
diff options
context:
space:
mode:
authorBrian Gaeke <gaeke@uiuc.edu>2003-10-22 20:44:23 +0000
committerBrian Gaeke <gaeke@uiuc.edu>2003-10-22 20:44:23 +0000
commit41fe18cbaa408ffdf5b2d612fac4b0ce9342dcf7 (patch)
treecd2ae2a4dee47a374c13e23f9274cb4abbf84606 /llvm/lib/CodeGen
parentf29231ec3a57226c1a8e89b9c384d08d29ce16b8 (diff)
downloadbcm5719-llvm-41fe18cbaa408ffdf5b2d612fac4b0ce9342dcf7.tar.gz
bcm5719-llvm-41fe18cbaa408ffdf5b2d612fac4b0ce9342dcf7.zip
Don't worry about converting each function's reg. alloc. state into One Big
Constant early on, because we can do it in doFinalization. Tighten up a comment. llvm-svn: 9387
Diffstat (limited to 'llvm/lib/CodeGen')
-rw-r--r--llvm/lib/CodeGen/RegAlloc/PhyRegAlloc.cpp41
1 files changed, 21 insertions, 20 deletions
diff --git a/llvm/lib/CodeGen/RegAlloc/PhyRegAlloc.cpp b/llvm/lib/CodeGen/RegAlloc/PhyRegAlloc.cpp
index 0c27cc938aa..f23a22c6c44 100644
--- a/llvm/lib/CodeGen/RegAlloc/PhyRegAlloc.cpp
+++ b/llvm/lib/CodeGen/RegAlloc/PhyRegAlloc.cpp
@@ -1176,7 +1176,7 @@ namespace {
/// debug info").
///
void PhyRegAlloc::saveState () {
- std::vector<Constant *> state;
+ std::vector<Constant *> &state = FnAllocState[Fn];
unsigned Insn = 0;
LiveRangeMapType::const_iterator HMIEnd = LRI->getLiveRangeMap ()->end ();
for (const_inst_iterator II=inst_begin (Fn), IE=inst_end (Fn); II != IE; ++II)
@@ -1207,20 +1207,6 @@ void PhyRegAlloc::saveState () {
state.push_back (AllocInfo (Insn, i, AllocState,
Placement).toConstant ());
}
- // Convert state into an LLVM ConstantArray, and put it in a
- // ConstantStruct (named S) along with its size.
- unsigned Size = state.size ();
- ArrayType *AT = ArrayType::get (AllocInfo::getConstantType (), Size);
- std::vector<const Type *> TV;
- TV.push_back (Type::UIntTy);
- TV.push_back (AT);
- StructType *ST = StructType::get (TV);
- std::vector<Constant *> CV;
- CV.push_back (ConstantUInt::get (Type::UIntTy, Size));
- CV.push_back (ConstantArray::get (AT, state));
- Constant *S = ConstantStruct::get (ST, CV);
- // Save S in the map containing register allocator state for this module.
- FnAllocState[Fn] = S;
}
/// Check the saved state filled in by saveState(), and abort if it looks
@@ -1248,10 +1234,26 @@ bool PhyRegAlloc::doFinalization (Module &M) {
if (FnAllocState.find (F) == FnAllocState.end ()) {
allstate.push_back (ConstantPointerNull::get (PT));
} else {
+ std::vector<Constant *> &state = FnAllocState[F];
+
+ // Convert state into an LLVM ConstantArray, and put it in a
+ // ConstantStruct (named S) along with its size.
+ unsigned Size = state.size ();
+ ArrayType *AT = ArrayType::get (AllocInfo::getConstantType (), Size);
+ std::vector<const Type *> TV;
+ TV.push_back (Type::UIntTy);
+ TV.push_back (AT);
+ StructType *ST = StructType::get (TV);
+ std::vector<Constant *> CV;
+ CV.push_back (ConstantUInt::get (Type::UIntTy, Size));
+ CV.push_back (ConstantArray::get (AT, state));
+ Constant *S = ConstantStruct::get (ST, CV);
+
GlobalVariable *GV =
- new GlobalVariable (FnAllocState[F]->getType (), true,
- GlobalValue::InternalLinkage, FnAllocState[F],
+ new GlobalVariable (ST, true,
+ GlobalValue::InternalLinkage, S,
F->getName () + ".regAllocState", &M);
+
// Have: { uint, [Size x { uint, uint, uint, int }] } *
// Cast it to: { uint, [0 x { uint, uint, uint, int }] } *
Constant *CE = ConstantExpr::getCast (ConstantPointerRef::get (GV), PT);
@@ -1354,9 +1356,8 @@ bool PhyRegAlloc::runOnFunction (Function &F) {
verifySavedState ();
}
- // Now update the machine code with register names and add any
- // additional code inserted by the register allocator to the instruction
- // stream
+ // Now update the machine code with register names and add any additional
+ // code inserted by the register allocator to the instruction stream.
updateMachineCode();
if (DEBUG_RA) {
OpenPOWER on IntegriCloud