summaryrefslogtreecommitdiffstats
path: root/clang/test/CodeGenCXX/global-init.cpp
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2011-07-01 21:54:36 +0000
committerDouglas Gregor <dgregor@apple.com>2011-07-01 21:54:36 +0000
commitfa918f69f67d19bc55a4eac8d2304c42d28cdfc9 (patch)
treec684da82f8c4d59f16fc1b22c0968d70ac413ce0 /clang/test/CodeGenCXX/global-init.cpp
parent2f37bdc39223dcfc129a92accd17cc0b7fd6e7f1 (diff)
downloadbcm5719-llvm-fa918f69f67d19bc55a4eac8d2304c42d28cdfc9.tar.gz
bcm5719-llvm-fa918f69f67d19bc55a4eac8d2304c42d28cdfc9.zip
Emit guard variables for any weak global that has a run-time
initializer. Previously, we only used guard variables for weak static data members. Fixes <rdar://problem/9692249>. llvm-svn: 134266
Diffstat (limited to 'clang/test/CodeGenCXX/global-init.cpp')
-rw-r--r--clang/test/CodeGenCXX/global-init.cpp23
1 files changed, 14 insertions, 9 deletions
diff --git a/clang/test/CodeGenCXX/global-init.cpp b/clang/test/CodeGenCXX/global-init.cpp
index 9bd7390d076..fd8734c5fad 100644
--- a/clang/test/CodeGenCXX/global-init.cpp
+++ b/clang/test/CodeGenCXX/global-init.cpp
@@ -70,6 +70,20 @@ namespace test3 {
const char *test() { return var; }
}
+namespace test6 {
+ struct A {
+ A();
+ };
+ extern int foo();
+
+ // This needs an initialization function and guard variables.
+ // CHECK: load i8* bitcast (i64* @_ZGVN5test61xE
+ // CHECK: [[CALL:%.*]] = call i32 @_ZN5test63fooEv
+ // CHECK-NEXT: store i32 [[CALL]], i32* @_ZN5test61xE
+ // CHECK-NEXT: store i64 1, i64* @_ZGVN5test61xE
+ __attribute__((weak)) int x = foo();
+}
+
namespace PR5974 {
struct A { int a; };
struct B { int b; };
@@ -97,15 +111,6 @@ 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.
OpenPOWER on IntegriCloud