diff options
author | Reid Kleckner <reid@kleckner.net> | 2014-01-13 19:25:00 +0000 |
---|---|---|
committer | Reid Kleckner <reid@kleckner.net> | 2014-01-13 19:25:00 +0000 |
commit | 4f017ceedae8245e11ad803f5698ec8afeb8f446 (patch) | |
tree | b3c8940c30211d90cfefa9f50de506a336d3f42f /clang/lib | |
parent | 13ac4bd774b0904c0af700470d264e18639ce3cb (diff) | |
download | bcm5719-llvm-4f017ceedae8245e11ad803f5698ec8afeb8f446.tar.gz bcm5719-llvm-4f017ceedae8245e11ad803f5698ec8afeb8f446.zip |
[ms-abi] Quick fix layout of an array of records
This fixes llvm::SmallVector, which fixes lots of TUs in the MS ABI self
host.
llvm-svn: 199129
Diffstat (limited to 'clang/lib')
-rw-r--r-- | clang/lib/AST/RecordLayoutBuilder.cpp | 6 |
1 files changed, 2 insertions, 4 deletions
diff --git a/clang/lib/AST/RecordLayoutBuilder.cpp b/clang/lib/AST/RecordLayoutBuilder.cpp index ff6b950474d..885d4ff5fb6 100644 --- a/clang/lib/AST/RecordLayoutBuilder.cpp +++ b/clang/lib/AST/RecordLayoutBuilder.cpp @@ -2176,16 +2176,14 @@ MicrosoftRecordLayoutBuilder::getAdjustedElementInfo( Info = getAdjustedElementInfo(Layout); // Nomally getAdjustedElementInfo returns the non-virtual size, which is // correct for bases but not for fields. - Info.Size = Layout.getSize(); + Info.Size = Context.getTypeInfoInChars(FD->getType()).first; // Capture required alignment as a side-effect. RequiredAlignment = std::max(RequiredAlignment, Layout.getRequiredAlignment()); } else { - std::pair<CharUnits, CharUnits> FieldInfo = + llvm::tie(Info.Size, Info.Alignment) = Context.getTypeInfoInChars(FD->getType()); - Info.Size = FieldInfo.first; - Info.Alignment = FieldInfo.second; if (FD->isBitField() && FD->getMaxAlignment() != 0) Info.Alignment = std::max(Info.Alignment, FieldRequiredAlignment); // Respect pragma pack. |