Skip to content

Commit

Permalink
weak globals that are const should get weak_odr linkage.
Browse files Browse the repository at this point in the history
add a fixme about C++ const.

llvm-svn: 78159
  • Loading branch information
lattner committed Aug 5, 2009
1 parent c0693bc commit f49573d
Show file tree
Hide file tree
Showing 2 changed files with 35 additions and 6 deletions.
25 changes: 19 additions & 6 deletions clang/lib/CodeGen/CodeGenModule.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -870,7 +870,15 @@ void CodeGenModule::EmitGlobalVarDefinition(const VarDecl *D) {
}

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));

// Set the llvm linkage type as appropriate.
Expand All @@ -880,13 +888,18 @@ void CodeGenModule::EmitGlobalVarDefinition(const VarDecl *D) {
GV->setLinkage(llvm::Function::DLLImportLinkage);
else if (D->hasAttr<DLLExportAttr>())
GV->setLinkage(llvm::Function::DLLExportLinkage);
else if (D->hasAttr<WeakAttr>())
GV->setLinkage(llvm::GlobalVariable::WeakAnyLinkage);
else if (!CompileOpts.NoCommon &&
else if (D->hasAttr<WeakAttr>()) {
if (GV->isConstant())
GV->setLinkage(llvm::GlobalVariable::WeakODRLinkage);
else
GV->setLinkage(llvm::GlobalVariable::WeakAnyLinkage);
} else if (!CompileOpts.NoCommon &&
!D->hasExternalStorage() && !D->getInit() &&
!D->getAttr<SectionAttr>())
!D->getAttr<SectionAttr>()) {
GV->setLinkage(llvm::GlobalVariable::CommonLinkage);
else
// common vars aren't constant even if declared const.
GV->setConstant(false);
} else
GV->setLinkage(llvm::GlobalVariable::ExternalLinkage);

SetCommonAttributes(D, GV);
Expand Down
16 changes: 16 additions & 0 deletions clang/test/CodeGen/global-init.c
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,24 @@ int a;
int a = 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.
// rdar://7119244
int b __attribute__((section("foo")));

// CHECK: @b = global i32 0, section "foo"

0 comments on commit f49573d

Please sign in to comment.