diff options
author | Anders Carlsson <andersca@mac.com> | 2009-07-23 04:00:39 +0000 |
---|---|---|
committer | Anders Carlsson <andersca@mac.com> | 2009-07-23 04:00:39 +0000 |
commit | 2cc8f1740d88362292822e397db6085084399599 (patch) | |
tree | 97c32adede9f963083a1050db43943c79c41ac4e /lib/CodeGen/CGRecordLayoutBuilder.cpp | |
parent | 5a6e398eafa48c56e8741ad2cd36630badd98f30 (diff) |
Handle zero width bit fields in unions correctly (by ignoring them).
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@76847 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/CGRecordLayoutBuilder.cpp')
-rw-r--r-- | lib/CodeGen/CGRecordLayoutBuilder.cpp | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/lib/CodeGen/CGRecordLayoutBuilder.cpp b/lib/CodeGen/CGRecordLayoutBuilder.cpp index 2fe7e5765d..1631c43eb9 100644 --- a/lib/CodeGen/CGRecordLayoutBuilder.cpp +++ b/lib/CodeGen/CGRecordLayoutBuilder.cpp @@ -160,6 +160,15 @@ void CGRecordLayoutBuilder::LayoutUnion(const RecordDecl *D) { FieldEnd = D->field_end(); Field != FieldEnd; ++Field, ++FieldNo) { assert(Layout.getFieldOffset(FieldNo) == 0 && "Union field offset did not start at the beginning of record!"); + + if (Field->isBitField()) { + uint64_t FieldSize = + Field->getBitWidth()->EvaluateAsInt(Types.getContext()).getZExtValue(); + + // Ignore zero sized bit fields. + if (FieldSize == 0) + continue; + } const llvm::Type *FieldTy = Types.ConvertTypeForMemRecursive(Field->getType()); |