summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEli Friedman <eli.friedman@gmail.com>2012-01-13 03:58:31 +0000
committerEli Friedman <eli.friedman@gmail.com>2012-01-13 03:58:31 +0000
commit09d272d0254417df61595b83d229297ca5ec7a63 (patch)
tree100f88618883404bf2c2fcfd8fa68545f4b7b698
parentdd8fbf572ee98ef793b691dda2dc89eaf38cba2f (diff)
downloadbcm5719-llvm-09d272d0254417df61595b83d229297ca5ec7a63.tar.gz
bcm5719-llvm-09d272d0254417df61595b83d229297ca5ec7a63.zip
A base subobject type doesn't make sense for unions; don't try to compute it. Based on patch by Yin Ma. Fixes PR11751.
llvm-svn: 148093
-rw-r--r--clang/lib/CodeGen/CGRecordLayoutBuilder.cpp2
-rw-r--r--clang/test/CodeGenCXX/empty-union.cpp9
2 files changed, 4 insertions, 7 deletions
diff --git a/clang/lib/CodeGen/CGRecordLayoutBuilder.cpp b/clang/lib/CodeGen/CGRecordLayoutBuilder.cpp
index 74fd794ef11..537daf9932e 100644
--- a/clang/lib/CodeGen/CGRecordLayoutBuilder.cpp
+++ b/clang/lib/CodeGen/CGRecordLayoutBuilder.cpp
@@ -997,7 +997,7 @@ CGRecordLayout *CodeGenTypes::ComputeRecordLayout(const RecordDecl *D,
// If we're in C++, compute the base subobject type.
llvm::StructType *BaseTy = 0;
- if (isa<CXXRecordDecl>(D)) {
+ if (isa<CXXRecordDecl>(D) && !D->isUnion()) {
BaseTy = Builder.BaseSubobjectType;
if (!BaseTy) BaseTy = Ty;
}
diff --git a/clang/test/CodeGenCXX/empty-union.cpp b/clang/test/CodeGenCXX/empty-union.cpp
index 118a0d29b47..7f3e6ccf50a 100644
--- a/clang/test/CodeGenCXX/empty-union.cpp
+++ b/clang/test/CodeGenCXX/empty-union.cpp
@@ -1,10 +1,7 @@
// RUN: %clang_cc1 -emit-llvm -o - %s
union sigval { };
+union sigval Test1;
-union sigval sigev_value;
-
-int main()
-{
- return sizeof(sigev_value);
-}
+union NonPODUnion { ~NonPODUnion(); };
+union NonPODUnion Test2;
OpenPOWER on IntegriCloud