Fix link of libxul with LTO and the linker in xcode4. It is not clear if this

is working around a bug in ld or if the new linker has a reasonable reason
for wanting the string constant to be linker visible.

llvm-svn: 127594
This commit is contained in:
Rafael Espindola
2011-03-14 17:55:00 +00:00
parent e92dcceab7
commit 7a6cf01895
2 changed files with 6 additions and 3 deletions

View File

@@ -1669,7 +1669,10 @@ CodeGenModule::GetAddrOfConstantCFString(const StringLiteral *Literal) {
// does make plain ascii ones writable.
isConstant = true;
} else {
Linkage = llvm::GlobalValue::PrivateLinkage;
// FIXME: With OS X ld 123.2 (xcode 4) and LTO we would get a linker error
// when using private linkage. It is not clear if this is a bug in ld
// or a reasonable new restriction.
Linkage = llvm::GlobalValue::InternalLinkage;
isConstant = !Features.WritableStrings;
}