summaryrefslogtreecommitdiffstats
path: root/clang/lib
diff options
context:
space:
mode:
authorEli Friedman <eli.friedman@gmail.com>2012-01-12 23:48:56 +0000
committerEli Friedman <eli.friedman@gmail.com>2012-01-12 23:48:56 +0000
commit2e108376d53176fd44e32eb7c54f971b95682ec5 (patch)
tree9ec54f30ba2e59a13fdf97a0d10bf9e8b13f538d /clang/lib
parentc37917f3099480d8f5c75310543e35695ecf522f (diff)
downloadbcm5719-llvm-2e108376d53176fd44e32eb7c54f971b95682ec5.tar.gz
bcm5719-llvm-2e108376d53176fd44e32eb7c54f971b95682ec5.zip
Recommit r148056 with fixes to deal with weirdness with bitfields in unions.
Original message: Make sure adding a field to a struct never reduces its size. PR11745. llvm-svn: 148070
Diffstat (limited to 'clang/lib')
-rw-r--r--clang/lib/AST/RecordLayoutBuilder.cpp8
1 files changed, 4 insertions, 4 deletions
diff --git a/clang/lib/AST/RecordLayoutBuilder.cpp b/clang/lib/AST/RecordLayoutBuilder.cpp
index 43dee104ba3..5223219a306 100644
--- a/clang/lib/AST/RecordLayoutBuilder.cpp
+++ b/clang/lib/AST/RecordLayoutBuilder.cpp
@@ -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);
OpenPOWER on IntegriCloud