зеркало из https://github.com/microsoft/clang-1.git
weak globals that are const should get weak_odr linkage.
add a fixme about C++ const. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@78159 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Родитель
309457d0f1
Коммит
e78b86f320
|
@ -870,7 +870,15 @@ void CodeGenModule::EmitGlobalVarDefinition(const VarDecl *D) {
|
||||||
}
|
}
|
||||||
|
|
||||||
GV->setInitializer(Init);
|
GV->setInitializer(Init);
|
||||||
GV->setConstant(D->getType().isConstant(Context));
|
|
||||||
|
// If it is safe to mark the global 'constant', do so now.
|
||||||
|
GV->setConstant(false);
|
||||||
|
if (D->getType().isConstant(Context)) {
|
||||||
|
// FIXME: In C++, if the variable has a non-trivial ctor/dtor or any mutable
|
||||||
|
// members, it cannot be declared "LLVM const".
|
||||||
|
GV->setConstant(true);
|
||||||
|
}
|
||||||
|
|
||||||
GV->setAlignment(getContext().getDeclAlignInBytes(D));
|
GV->setAlignment(getContext().getDeclAlignInBytes(D));
|
||||||
|
|
||||||
// Set the llvm linkage type as appropriate.
|
// Set the llvm linkage type as appropriate.
|
||||||
|
@ -880,13 +888,18 @@ void CodeGenModule::EmitGlobalVarDefinition(const VarDecl *D) {
|
||||||
GV->setLinkage(llvm::Function::DLLImportLinkage);
|
GV->setLinkage(llvm::Function::DLLImportLinkage);
|
||||||
else if (D->hasAttr<DLLExportAttr>())
|
else if (D->hasAttr<DLLExportAttr>())
|
||||||
GV->setLinkage(llvm::Function::DLLExportLinkage);
|
GV->setLinkage(llvm::Function::DLLExportLinkage);
|
||||||
else if (D->hasAttr<WeakAttr>())
|
else if (D->hasAttr<WeakAttr>()) {
|
||||||
GV->setLinkage(llvm::GlobalVariable::WeakAnyLinkage);
|
if (GV->isConstant())
|
||||||
else if (!CompileOpts.NoCommon &&
|
GV->setLinkage(llvm::GlobalVariable::WeakODRLinkage);
|
||||||
|
else
|
||||||
|
GV->setLinkage(llvm::GlobalVariable::WeakAnyLinkage);
|
||||||
|
} else if (!CompileOpts.NoCommon &&
|
||||||
!D->hasExternalStorage() && !D->getInit() &&
|
!D->hasExternalStorage() && !D->getInit() &&
|
||||||
!D->getAttr<SectionAttr>())
|
!D->getAttr<SectionAttr>()) {
|
||||||
GV->setLinkage(llvm::GlobalVariable::CommonLinkage);
|
GV->setLinkage(llvm::GlobalVariable::CommonLinkage);
|
||||||
else
|
// common vars aren't constant even if declared const.
|
||||||
|
GV->setConstant(false);
|
||||||
|
} else
|
||||||
GV->setLinkage(llvm::GlobalVariable::ExternalLinkage);
|
GV->setLinkage(llvm::GlobalVariable::ExternalLinkage);
|
||||||
|
|
||||||
SetCommonAttributes(D, GV);
|
SetCommonAttributes(D, GV);
|
||||||
|
|
|
@ -7,8 +7,24 @@ int a;
|
||||||
int a = 242;
|
int a = 242;
|
||||||
// CHECK: @a = global i32 242
|
// CHECK: @a = global i32 242
|
||||||
|
|
||||||
|
// This should get normal weak linkage.
|
||||||
|
int c __attribute__((weak))= 0;
|
||||||
|
// CHECK: @c = weak global i32 0
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// Since this is marked const, it should get weak_odr linkage, since all
|
||||||
|
// definitions have to be the same.
|
||||||
|
// CHECK: @d = weak_odr constant i32 0
|
||||||
|
const int d __attribute__((weak))= 0;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// NOTE: tentative definitions are processed at the end of the translation unit.
|
||||||
|
|
||||||
// This shouldn't be emitted as common because it has an explicit section.
|
// This shouldn't be emitted as common because it has an explicit section.
|
||||||
// rdar://7119244
|
// rdar://7119244
|
||||||
int b __attribute__((section("foo")));
|
int b __attribute__((section("foo")));
|
||||||
|
|
||||||
// CHECK: @b = global i32 0, section "foo"
|
// CHECK: @b = global i32 0, section "foo"
|
||||||
|
|
||||||
|
|
Загрузка…
Ссылка в новой задаче