forked from OSchip/llvm-project
Don't produce an empty llvm.compiler.used in LTO.
LTO was always creating an empty llvm.compiler.used. With this patch we now first check if there is anything to be added first. Unfortunately, there is no good way to test libLTO in isolation as it needs gold or ld64, but there are bots doing LTO builds that found this problem. llvm-svn: 180202
This commit is contained in:
parent
dcff671133
commit
cc111b2bc9
|
@ -287,9 +287,7 @@ static void findUsedValues(GlobalVariable *LLVMUsed,
|
|||
SmallPtrSet<GlobalValue*, 8> &UsedValues) {
|
||||
if (LLVMUsed == 0) return;
|
||||
|
||||
ConstantArray *Inits = dyn_cast<ConstantArray>(LLVMUsed->getInitializer());
|
||||
if (Inits == 0) return;
|
||||
|
||||
ConstantArray *Inits = cast<ConstantArray>(LLVMUsed->getInitializer());
|
||||
for (unsigned i = 0, e = Inits->getNumOperands(); i != e; ++i)
|
||||
if (GlobalValue *GV =
|
||||
dyn_cast<GlobalValue>(Inits->getOperand(i)->stripPointerCasts()))
|
||||
|
@ -326,6 +324,7 @@ void LTOCodeGenerator::applyScopeRestrictions() {
|
|||
if (LLVMCompilerUsed)
|
||||
LLVMCompilerUsed->eraseFromParent();
|
||||
|
||||
if (!asmUsed.empty()) {
|
||||
llvm::Type *i8PTy = llvm::Type::getInt8PtrTy(_context);
|
||||
std::vector<Constant*> asmUsed2;
|
||||
for (SmallPtrSet<GlobalValue*, 16>::const_iterator i = asmUsed.begin(),
|
||||
|
@ -343,6 +342,7 @@ void LTOCodeGenerator::applyScopeRestrictions() {
|
|||
"llvm.compiler.used");
|
||||
|
||||
LLVMCompilerUsed->setSection("llvm.metadata");
|
||||
}
|
||||
|
||||
passes.add(createInternalizePass(mustPreserveList));
|
||||
|
||||
|
|
Loading…
Reference in New Issue