diff options
author | Chris Lattner <sabre@nondot.org> | 2010-09-06 00:13:11 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2010-09-06 00:13:11 +0000 |
commit | 52bcf96384c1feaed7b9d5890093fbdf862673c8 (patch) | |
tree | 21b47394ccd61e10cfd4901477107068a32f76f6 /clang/test/CodeGen/designated-initializers.c | |
parent | f53c096813441896d7a7e3bec2546a8ddfad2d78 (diff) | |
download | bcm5719-llvm-52bcf96384c1feaed7b9d5890093fbdf862673c8.tar.gz bcm5719-llvm-52bcf96384c1feaed7b9d5890093fbdf862673c8.zip |
move the hackaround for PR6537 to catch unions as well,
fixing the ICE in PR7151
llvm-svn: 113130
Diffstat (limited to 'clang/test/CodeGen/designated-initializers.c')
-rw-r--r-- | clang/test/CodeGen/designated-initializers.c | 27 |
1 files changed, 23 insertions, 4 deletions
diff --git a/clang/test/CodeGen/designated-initializers.c b/clang/test/CodeGen/designated-initializers.c index 49f57ad062c..312d7856529 100644 --- a/clang/test/CodeGen/designated-initializers.c +++ b/clang/test/CodeGen/designated-initializers.c @@ -8,10 +8,10 @@ struct foo { // CHECK: @u = global %union.anon zeroinitializer union { int i; float f; } u = { }; -// CHECK: @u2 = global %0 { i32 0, [4 x i8] undef } +// CHECK: @u2 = global %1 { i32 0, [4 x i8] undef } union { int i; double f; } u2 = { }; -// CHECK: @u3 = global %1 zeroinitializer +// CHECK: @u3 = global %2 zeroinitializer union { double f; int i; } u3 = { }; // CHECK: @b = global [2 x i32] [i32 0, i32 22] @@ -19,7 +19,7 @@ int b[2] = { [1] = 22 }; -int main(int argc, char **argv) +void test1(int argc, char **argv) { // CHECK: internal global %struct.foo { i8* null, i32 1024 } static struct foo foo = { @@ -33,5 +33,24 @@ int main(int argc, char **argv) // CHECK-NOT: call void @llvm.memset union { int i; float f; } u3; - // CHECK: ret i32 + // CHECK: ret void +} + + +// PR7151 +struct S { + int nkeys; + int *keys; + union { + void *data; + }; +}; + +void test2() { + struct S *btkr; + + *btkr = (struct S) { + .keys = 0, + { .data = 0 }, + }; } |