summaryrefslogtreecommitdiffstats
path: root/clang/test/CodeGenCXX/global-init.cpp
diff options
context:
space:
mode:
authorJohn McCall <rjmccall@apple.com>2011-04-12 01:46:54 +0000
committerJohn McCall <rjmccall@apple.com>2011-04-12 01:46:54 +0000
commita97f32986913c07cac9c49b0b6b755b7190812b1 (patch)
treeb186fabf5c2070c3ece88e6c820f55895b510e40 /clang/test/CodeGenCXX/global-init.cpp
parentb4744a3f4d9bffebc671201b6c133f7464fb1c8e (diff)
downloadbcm5719-llvm-a97f32986913c07cac9c49b0b6b755b7190812b1.tar.gz
bcm5719-llvm-a97f32986913c07cac9c49b0b6b755b7190812b1.zip
Template static data members can have weak_odr linkage, not just
weak linkage. Also, fix a problem where global weak variables with non-trivial initializers were getting guard variables, or at least were checking for them and then crashing. llvm-svn: 129342
Diffstat (limited to 'clang/test/CodeGenCXX/global-init.cpp')
-rw-r--r--clang/test/CodeGenCXX/global-init.cpp10
1 files changed, 10 insertions, 0 deletions
diff --git a/clang/test/CodeGenCXX/global-init.cpp b/clang/test/CodeGenCXX/global-init.cpp
index 53cfe05fd77..f9eeb59145f 100644
--- a/clang/test/CodeGenCXX/global-init.cpp
+++ b/clang/test/CodeGenCXX/global-init.cpp
@@ -97,6 +97,16 @@ namespace test5 {
};
}
+namespace test6 {
+ struct A {
+ A();
+ };
+ extern int foo();
+
+ // This needs an initialization function but not guard variables.
+ __attribute__((weak)) int x = foo();
+}
+
// At the end of the file, we check that y is initialized before z.
// CHECK: define internal void @_GLOBAL__I_a() section "__TEXT,__StaticInit,regular,pure_instructions" {
OpenPOWER on IntegriCloud