summaryrefslogtreecommitdiffstats
path: root/llvm
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2006-09-30 19:40:30 +0000
committerChris Lattner <sabre@nondot.org>2006-09-30 19:40:30 +0000
commit80a01ef6f01c3f62b44988822f6731d19cf6067e (patch)
treec98abc9900c192f7d74b467456be9601d2095730 /llvm
parenteb45775347abf03b71227656f928a147320d0b5c (diff)
downloadbcm5719-llvm-80a01ef6f01c3f62b44988822f6731d19cf6067e.tar.gz
bcm5719-llvm-80a01ef6f01c3f62b44988822f6731d19cf6067e.zip
Add some ifdef'd out debug info
llvm-svn: 30676
Diffstat (limited to 'llvm')
-rw-r--r--llvm/lib/Transforms/IPO/GlobalOpt.cpp33
1 files changed, 30 insertions, 3 deletions
diff --git a/llvm/lib/Transforms/IPO/GlobalOpt.cpp b/llvm/lib/Transforms/IPO/GlobalOpt.cpp
index 37c1e40494a..27862122601 100644
--- a/llvm/lib/Transforms/IPO/GlobalOpt.cpp
+++ b/llvm/lib/Transforms/IPO/GlobalOpt.cpp
@@ -831,6 +831,10 @@ static bool OptimizeOnceStoredGlobal(GlobalVariable *GV, Value *StoredOnceVal,
if (OptimizeAwayTrappingUsesOfLoads(GV, SOVC))
return true;
} else if (MallocInst *MI = dyn_cast<MallocInst>(StoredOnceVal)) {
+ // If this is a malloc of an abstract type, don't touch it.
+ if (!MI->getAllocatedType()->isSized())
+ return false;
+
// If we have a global that is only initialized with a fixed size malloc,
// and if all users of the malloc trap, and if the malloc'd address is not
// put anywhere else, transform the program to use global memory instead
@@ -839,15 +843,15 @@ static bool OptimizeOnceStoredGlobal(GlobalVariable *GV, Value *StoredOnceVal,
// that we restrict this transformation to only working on small
// allocations (2048 bytes currently), as we don't want to introduce a 16M
// global or something.
- if (ConstantInt *NElements = dyn_cast<ConstantInt>(MI->getArraySize()))
- if (MI->getAllocatedType()->isSized() &&
- NElements->getRawValue()*
+ if (ConstantInt *NElements = dyn_cast<ConstantInt>(MI->getArraySize())) {
+ if (NElements->getRawValue()*
TD.getTypeSize(MI->getAllocatedType()) < 2048 &&
AllUsesOfLoadedValueWillTrapIfNull(GV) &&
ValueIsOnlyUsedLocallyOrStoredToOneGlobal(MI, GV)) {
GVI = OptimizeGlobalAddressOfMalloc(GV, MI);
return true;
}
+ }
}
}
@@ -938,6 +942,28 @@ bool GlobalOpt::ProcessInternalGlobal(GlobalVariable *GV,
}
if (!AnalyzeGlobal(GV, GS, PHIUsers)) {
+#if 0
+ std::cerr << "Global: " << *GV;
+ std::cerr << " isLoaded = " << GS.isLoaded << "\n";
+ std::cerr << " StoredType = ";
+ switch (GS.StoredType) {
+ case GlobalStatus::NotStored: std::cerr << "NEVER STORED\n"; break;
+ case GlobalStatus::isInitializerStored: std::cerr << "INIT STORED\n"; break;
+ case GlobalStatus::isStoredOnce: std::cerr << "STORED ONCE\n"; break;
+ case GlobalStatus::isStored: std::cerr << "stored\n"; break;
+ }
+ if (GS.StoredType == GlobalStatus::isStoredOnce && GS.StoredOnceValue)
+ std::cerr << " StoredOnceValue = " << *GS.StoredOnceValue << "\n";
+ if (GS.AccessingFunction && !GS.HasMultipleAccessingFunctions)
+ std::cerr << " AccessingFunction = " << GS.AccessingFunction->getName()
+ << "\n";
+ std::cerr << " HasMultipleAccessingFunctions = "
+ << GS.HasMultipleAccessingFunctions << "\n";
+ std::cerr << " HasNonInstructionUser = " << GS.HasNonInstructionUser<<"\n";
+ std::cerr << " isNotSuitableForSRA = " << GS.isNotSuitableForSRA << "\n";
+ std::cerr << "\n";
+#endif
+
// If this is a first class global and has only one accessing function
// and this function is main (which we know is not recursive we can make
// this global a local variable) we replace the global with a local alloca
@@ -963,6 +989,7 @@ bool GlobalOpt::ProcessInternalGlobal(GlobalVariable *GV,
++NumLocalized;
return true;
}
+
// If the global is never loaded (but may be stored to), it is dead.
// Delete it now.
if (!GS.isLoaded) {
OpenPOWER on IntegriCloud