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 | f814ee600399a696f7d24db75bf0fd8e27d5b1ef (patch) | |
| tree | 5329c6f0f4aa32d68e44476a268919fa94494ab2 | |
| parent | 697f65943dc50853f0781e8d2d65eb4a4e28a51a (diff) | |
| download | bcm5719-llvm-f814ee600399a696f7d24db75bf0fd8e27d5b1ef.tar.gz bcm5719-llvm-f814ee600399a696f7d24db75bf0fd8e27d5b1ef.zip | |
Handle zero width bit fields in unions correctly (by ignoring them).
llvm-svn: 76847
| -rw-r--r-- | clang/lib/CodeGen/CGRecordLayoutBuilder.cpp | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/clang/lib/CodeGen/CGRecordLayoutBuilder.cpp b/clang/lib/CodeGen/CGRecordLayoutBuilder.cpp index 2fe7e5765de..1631c43eb99 100644 --- a/clang/lib/CodeGen/CGRecordLayoutBuilder.cpp +++ b/clang/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()); |

