diff options
author | Eli Friedman <eli.friedman@gmail.com> | 2012-01-12 22:41:25 +0000 |
---|---|---|
committer | Eli Friedman <eli.friedman@gmail.com> | 2012-01-12 22:41:25 +0000 |
commit | a1796826729ba8c73c32dd49fa4945ff3cb12039 (patch) | |
tree | 9b708cdc4d1e3329c625793f4f66289ae638c839 /lib/AST/RecordLayoutBuilder.cpp | |
parent | 3d33622cf50fe8bd2f10e71b9135bc5c74b1786e (diff) |
Make sure adding a field to a struct never reduces its size. PR11745.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@148056 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/AST/RecordLayoutBuilder.cpp')
-rw-r--r-- | lib/AST/RecordLayoutBuilder.cpp | 9 |
1 files changed, 4 insertions, 5 deletions
diff --git a/lib/AST/RecordLayoutBuilder.cpp b/lib/AST/RecordLayoutBuilder.cpp index 43dee104ba..69e31a3072 100644 --- a/lib/AST/RecordLayoutBuilder.cpp +++ b/lib/AST/RecordLayoutBuilder.cpp @@ -1867,14 +1867,13 @@ void RecordLayoutBuilder::LayoutField(const FieldDecl *D) { Context.toBits(UnpackedFieldAlign), FieldPacked, D); // Reserve space for this field. - uint64_t FieldSizeInBits = Context.toBits(FieldSize); if (IsUnion) - setSize(std::max(getSizeInBits(), FieldSizeInBits)); + setDataSize(std::max(getDataSize(), FieldSize)); else - setSize(FieldOffset + FieldSize); + setDataSize(FieldOffset + FieldSize); - // Update the data size. - setDataSize(getSizeInBits()); + // Update the size. + setSize(std::max(getSize(), getDataSize())); // Remember max struct/class alignment. UpdateAlignment(FieldAlign, UnpackedFieldAlign); |