]> granicus.if.org Git - clang/commitdiff
Recommit r148056 with fixes to deal with weirdness with bitfields in unions.
authorEli Friedman <eli.friedman@gmail.com>
Thu, 12 Jan 2012 23:48:56 +0000 (23:48 +0000)
committerEli Friedman <eli.friedman@gmail.com>
Thu, 12 Jan 2012 23:48:56 +0000 (23:48 +0000)
Original message: Make sure adding a field to a struct never reduces its size.  PR11745.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@148070 91177308-0d34-0410-b5e6-96231b3b80d8

lib/AST/RecordLayoutBuilder.cpp
test/SemaCXX/empty-class-layout.cpp

index 43dee104ba364c41ba87d1916a395be9c5cc6a9c..5223219a306251503859704645a52cc0bd707398 100644 (file)
@@ -1869,12 +1869,12 @@ void RecordLayoutBuilder::LayoutField(const FieldDecl *D) {
   // Reserve space for this field.
   uint64_t FieldSizeInBits = Context.toBits(FieldSize);
   if (IsUnion)
-    setSize(std::max(getSizeInBits(), FieldSizeInBits));
+    setDataSize(std::max(getDataSizeInBits(), FieldSizeInBits));
   else
-    setSize(FieldOffset + FieldSize);
+    setDataSize(FieldOffset + FieldSize);
 
-  // Update the data size.
-  setDataSize(getSizeInBits());
+  // Update the size.
+  setSize(std::max(getSizeInBits(), getDataSizeInBits()));
 
   // Remember max struct/class alignment.
   UpdateAlignment(FieldAlign, UnpackedFieldAlign);
index 0b46bf045ac002ec26763f4d1342344abfed7b5f..c68f2bb6fb0e6f5ef2513f3668addb4d46a1e260 100644 (file)
@@ -144,3 +144,14 @@ struct B : Empty, A { };
 SA(0, sizeof(B) == 16);
 
 }
+
+namespace Test7 {
+  // Make sure we reserve enough space for both bases; PR11745.
+  struct Empty { };
+  struct Base1 : Empty { };
+  struct Base2 : Empty { };
+  struct Test : Base1, Base2 {
+    char c;
+  };
+  SA(0, sizeof(Test) == 2);
+}