Revert r148056 while I investigate failures.
llvm-svn: 148068
diff --git a/clang/lib/AST/RecordLayoutBuilder.cpp b/clang/lib/AST/RecordLayoutBuilder.cpp
index 69e31a3..43dee10 100644
--- a/clang/lib/AST/RecordLayoutBuilder.cpp
+++ b/clang/lib/AST/RecordLayoutBuilder.cpp
@@ -1867,13 +1867,14 @@
Context.toBits(UnpackedFieldAlign), FieldPacked, D);
// Reserve space for this field.
+ uint64_t FieldSizeInBits = Context.toBits(FieldSize);
if (IsUnion)
- setDataSize(std::max(getDataSize(), FieldSize));
+ setSize(std::max(getSizeInBits(), FieldSizeInBits));
else
- setDataSize(FieldOffset + FieldSize);
+ setSize(FieldOffset + FieldSize);
- // Update the size.
- setSize(std::max(getSize(), getDataSize()));
+ // Update the data size.
+ setDataSize(getSizeInBits());
// Remember max struct/class alignment.
UpdateAlignment(FieldAlign, UnpackedFieldAlign);