summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAnders Carlsson <andersca@mac.com>2010-01-26 04:02:23 +0000
committerAnders Carlsson <andersca@mac.com>2010-01-26 04:02:23 +0000
commit20bbbd489bf1b66e079f39708406148bcbb65b06 (patch)
tree8c6ab473066e1a0cfb818518ae1eee6e52a5092c
parent19afd61201b121ee878a2eac6e03a8887cf68b1b (diff)
downloadbcm5719-llvm-20bbbd489bf1b66e079f39708406148bcbb65b06.tar.gz
bcm5719-llvm-20bbbd489bf1b66e079f39708406148bcbb65b06.zip
Make sure to always mark a global variable as not being constant if it has a C++ initializer.
llvm-svn: 94504
-rw-r--r--clang/lib/CodeGen/CGDecl.cpp7
-rw-r--r--clang/test/CodeGenCXX/static-init.cpp7
2 files changed, 13 insertions, 1 deletions
diff --git a/clang/lib/CodeGen/CGDecl.cpp b/clang/lib/CodeGen/CGDecl.cpp
index 9606a71527a..23b4ff26a2e 100644
--- a/clang/lib/CodeGen/CGDecl.cpp
+++ b/clang/lib/CodeGen/CGDecl.cpp
@@ -138,8 +138,13 @@ CodeGenFunction::AddInitializerToGlobalBlockVarDecl(const VarDecl &D,
if (!Init) {
if (!getContext().getLangOptions().CPlusPlus)
CGM.ErrorUnsupported(D.getInit(), "constant l-value expression");
- else
+ else {
+ // Since we have a static initializer, this global variable can't
+ // be constant.
+ GV->setConstant(false);
+
EmitStaticCXXBlockVarDeclInit(D, GV);
+ }
return GV;
}
diff --git a/clang/test/CodeGenCXX/static-init.cpp b/clang/test/CodeGenCXX/static-init.cpp
index cbd90e78940..33d92d68536 100644
--- a/clang/test/CodeGenCXX/static-init.cpp
+++ b/clang/test/CodeGenCXX/static-init.cpp
@@ -1,4 +1,6 @@
// RUN: %clang_cc1 %s -triple=x86_64-apple-darwin10 -emit-llvm -o - | FileCheck %s
+
+// CHECK: @_ZZ1hvE1i = internal global i32 0, align 4
struct A {
A();
~A();
@@ -15,3 +17,8 @@ void g() {
// CHECK: call void @_ZN1AC1Ev(
static A& a = *new A;
}
+
+int a();
+void h() {
+ static const int i = a();
+}
OpenPOWER on IntegriCloud