summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDaniel Dunbar <daniel@zuster.org>2009-02-24 18:41:57 +0000
committerDaniel Dunbar <daniel@zuster.org>2009-02-24 18:41:57 +0000
commitd4ecca135a78c3b4245264c10c191452603eff2d (patch)
treee32af86133a201b903fb3688cc771d5a45bcc6d2
parentc5437ea42948f1e4cc89c0e8d944a380e6c880e7 (diff)
downloadbcm5719-llvm-d4ecca135a78c3b4245264c10c191452603eff2d.tar.gz
bcm5719-llvm-d4ecca135a78c3b4245264c10c191452603eff2d.zip
Fix IRgen of constant expressions referring to external/static
variables. - PR3657. llvm-svn: 65381
-rw-r--r--clang/lib/CodeGen/CGExprConstant.cpp13
-rw-r--r--clang/test/CodeGen/const-init.c7
2 files changed, 15 insertions, 5 deletions
diff --git a/clang/lib/CodeGen/CGExprConstant.cpp b/clang/lib/CodeGen/CGExprConstant.cpp
index fd174237c09..1141c0da8aa 100644
--- a/clang/lib/CodeGen/CGExprConstant.cpp
+++ b/clang/lib/CodeGen/CGExprConstant.cpp
@@ -384,11 +384,14 @@ public:
if (const FunctionDecl *FD = dyn_cast<FunctionDecl>(Decl))
return CGM.GetAddrOfFunction(FD);
if (const VarDecl* VD = dyn_cast<VarDecl>(Decl)) {
- if (VD->isFileVarDecl())
- return CGM.GetAddrOfGlobalVar(VD);
- else if (VD->isBlockVarDecl()) {
- assert(CGF && "Can't access static local vars without CGF");
- return CGF->GetAddrOfStaticLocalVar(VD);
+ // We can never refer to a variable with local storage.
+ if (!VD->hasLocalStorage()) {
+ if (VD->isFileVarDecl() || VD->hasExternalStorage())
+ return CGM.GetAddrOfGlobalVar(VD);
+ else if (VD->isBlockVarDecl()) {
+ assert(CGF && "Can't access static local vars without CGF");
+ return CGF->GetAddrOfStaticLocalVar(VD);
+ }
}
}
break;
diff --git a/clang/test/CodeGen/const-init.c b/clang/test/CodeGen/const-init.c
index 0ca7c24f0bf..65a59e869a7 100644
--- a/clang/test/CodeGen/const-init.c
+++ b/clang/test/CodeGen/const-init.c
@@ -79,4 +79,11 @@ long long g16 = (long long) ((void*) 0xFFFFFFFF);
// RUN: grep '@g17 = global i32\* @g15' %t &&
int *g17 = (int *) ((long) &g15);
+// RUN: grep '@g18.p = internal global \[1 x i32\*\] \[i32\* @g19\]' %t &&
+// FIXME: Should we really accept this in Sema?
+void g18(void) {
+ extern int g19;
+ static int *p[] = { &g19 };
+}
+
// RUN: true
OpenPOWER on IntegriCloud