]> granicus.if.org Git - clang/commitdiff
Correct a thinko in bitfield layout code. Fixes PR4611.
authorAnders Carlsson <andersca@mac.com>
Thu, 23 Jul 2009 21:16:33 +0000 (21:16 +0000)
committerAnders Carlsson <andersca@mac.com>
Thu, 23 Jul 2009 21:16:33 +0000 (21:16 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@76898 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/CGRecordLayoutBuilder.cpp
test/CodeGen/PR4611-bitfield-layout.c [new file with mode: 0644]

index 2d10b1f030a33c30c4845e855c4713df1825b865..455b92996a96fea0859371d5b323d8ce248b4fa5 100644 (file)
@@ -88,10 +88,8 @@ void CGRecordLayoutBuilder::LayoutBitField(const FieldDecl *D,
   
   AppendBytes(NumBytesToAppend);
   
-  if (!NumBytesToAppend)
-    BitsAvailableInLastField -= FieldSize;
-  else
-    BitsAvailableInLastField = NumBytesToAppend * 8 - FieldSize;
+  BitsAvailableInLastField = 
+    getNextFieldOffsetInBytes() * 8 - (FieldOffset + FieldSize);
 }
 
 bool CGRecordLayoutBuilder::LayoutField(const FieldDecl *D,
diff --git a/test/CodeGen/PR4611-bitfield-layout.c b/test/CodeGen/PR4611-bitfield-layout.c
new file mode 100644 (file)
index 0000000..ef698d5
--- /dev/null
@@ -0,0 +1,6 @@
+// RUN: clang-cc -triple i386-unknown-unknown %s -emit-llvm -o %t &&
+// RUN: grep "struct.object_entry = type <{ i8, i8, i8, i8 }>" %t
+
+struct object_entry {
+       unsigned int type:3, pack_id:16, depth:13;
+} entries;