summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAnders Carlsson <andersca@mac.com>2008-12-03 05:51:23 +0000
committerAnders Carlsson <andersca@mac.com>2008-12-03 05:51:23 +0000
commit6a113d9ddb4a4a2d19b4796e3b0f53aab7ec2d5b (patch)
tree7a75ecc65951d007287f23e66fd353acf7b3cbf9
parentcc78cdf2751a0a41efc829eb8a125300184d822e (diff)
downloadbcm5719-llvm-6a113d9ddb4a4a2d19b4796e3b0f53aab7ec2d5b.tar.gz
bcm5719-llvm-6a113d9ddb4a4a2d19b4796e3b0f53aab7ec2d5b.zip
If a global var decl has an initializer, make sure to always set its linkage to external.
llvm-svn: 60462
-rw-r--r--clang/lib/CodeGen/CodeGenModule.cpp2
-rw-r--r--clang/test/CodeGen/global-init.c7
2 files changed, 9 insertions, 0 deletions
diff --git a/clang/lib/CodeGen/CodeGenModule.cpp b/clang/lib/CodeGen/CodeGenModule.cpp
index f0aa8b7d141..80ef53f5f9c 100644
--- a/clang/lib/CodeGen/CodeGenModule.cpp
+++ b/clang/lib/CodeGen/CodeGenModule.cpp
@@ -607,6 +607,8 @@ void CodeGenModule::EmitGlobalVarDefinition(const VarDecl *D) {
case VarDecl::None:
if (!D->getInit())
GV->setLinkage(llvm::GlobalVariable::CommonLinkage);
+ else
+ GV->setLinkage(llvm::GlobalVariable::ExternalLinkage);
break;
case VarDecl::Extern:
case VarDecl::PrivateExtern:
diff --git a/clang/test/CodeGen/global-init.c b/clang/test/CodeGen/global-init.c
new file mode 100644
index 00000000000..133a3b5373f
--- /dev/null
+++ b/clang/test/CodeGen/global-init.c
@@ -0,0 +1,7 @@
+// RUN: clang -emit-llvm -o - %s | not grep "common"
+
+// This checks that the global won't be marked as common.
+// (It shouldn't because it's being initialized).
+
+int a;
+int a = 242;
OpenPOWER on IntegriCloud