aboutsummaryrefslogtreecommitdiff
path: root/lib/CodeGen/CodeGenModule.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2009-03-31 22:37:52 +0000
committerChris Lattner <sabre@nondot.org>2009-03-31 22:37:52 +0000
commit35f38a2c22d68c22e2dbe8e9ee84c120c8f327bb (patch)
treec7738badb0de7adc1d10fa8b5fdc09cb62d59307 /lib/CodeGen/CodeGenModule.cpp
parent481769b5dc102b0256b35581e787909ad5edfab5 (diff)
Change UsedArray to be a vector of WeakVH to fix a dangling pointer problem that occurs when
attribute(used) and asm renaming are used together. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@68155 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/CodeGenModule.cpp')
-rw-r--r--lib/CodeGen/CodeGenModule.cpp22
1 files changed, 13 insertions, 9 deletions
diff --git a/lib/CodeGen/CodeGenModule.cpp b/lib/CodeGen/CodeGenModule.cpp
index 3de8156fe5..6c0cc7ef2b 100644
--- a/lib/CodeGen/CodeGenModule.cpp
+++ b/lib/CodeGen/CodeGenModule.cpp
@@ -320,8 +320,7 @@ void CodeGenModule::SetFunctionAttributes(const FunctionDecl *FD,
void CodeGenModule::AddUsedGlobal(llvm::GlobalValue *GV) {
assert(!GV->isDeclaration() &&
"Only globals with definition can force usage.");
- llvm::Type *i8PTy = llvm::PointerType::getUnqual(llvm::Type::Int8Ty);
- LLVMUsed.push_back(llvm::ConstantExpr::getBitCast(GV, i8PTy));
+ LLVMUsed.push_back(GV);
}
void CodeGenModule::EmitLLVMUsed() {
@@ -329,12 +328,21 @@ void CodeGenModule::EmitLLVMUsed() {
if (LLVMUsed.empty())
return;
- llvm::ArrayType *ATy = llvm::ArrayType::get(LLVMUsed[0]->getType(),
- LLVMUsed.size());
+ llvm::Type *i8PTy = llvm::PointerType::getUnqual(llvm::Type::Int8Ty);
+ llvm::ArrayType *ATy = llvm::ArrayType::get(i8PTy, LLVMUsed.size());
+
+ // Convert LLVMUsed to what ConstantArray needs.
+ std::vector<llvm::Constant*> UsedArray;
+ UsedArray.resize(LLVMUsed.size());
+ for (unsigned i = 0, e = LLVMUsed.size(); i != e; ++i) {
+ UsedArray[i] =
+ llvm::ConstantExpr::getBitCast(cast<llvm::Constant>(&*LLVMUsed[i]), i8PTy);
+ }
+
llvm::GlobalVariable *GV =
new llvm::GlobalVariable(ATy, false,
llvm::GlobalValue::AppendingLinkage,
- llvm::ConstantArray::get(ATy, LLVMUsed),
+ llvm::ConstantArray::get(ATy, UsedArray),
"llvm.used", &getModule());
GV->setSection("llvm.metadata");
@@ -725,7 +733,6 @@ void CodeGenModule::EmitGlobalVarDefinition(const VarDecl *D) {
Entry->replaceAllUsesWith(NewPtrForOldDecl);
// Erase the old global, since it is no longer used.
- // FIXME: What if it was attribute used? Dangling pointer from LLVMUsed.
cast<llvm::GlobalValue>(Entry)->eraseFromParent();
}
@@ -839,8 +846,6 @@ void CodeGenModule::EmitGlobalFunctionDefinition(const FunctionDecl *D) {
Entry->replaceAllUsesWith(NewPtrForOldDecl);
// Ok, delete the old function now, which is dead.
- // FIXME: If it was attribute(used) the pointer will dangle from the
- // LLVMUsed array!
cast<llvm::GlobalValue>(Entry)->eraseFromParent();
Entry = NewFn;
@@ -905,7 +910,6 @@ void CodeGenModule::EmitAliasDefinition(const ValueDecl *D) {
Entry->replaceAllUsesWith(llvm::ConstantExpr::getBitCast(GA,
Entry->getType()));
- // FIXME: What if it was attribute used? Dangling pointer from LLVMUsed.
Entry->eraseFromParent();
}