]> granicus.if.org Git - clang/commitdiff
Add assert for the case that is not handled.
authorDevang Patel <dpatel@apple.com>
Thu, 8 Nov 2007 00:32:12 +0000 (00:32 +0000)
committerDevang Patel <dpatel@apple.com>
Thu, 8 Nov 2007 00:32:12 +0000 (00:32 +0000)
struct { char a; short b:2; };

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@43859 91177308-0d34-0410-b5e6-96231b3b80d8

CodeGen/CodeGenTypes.cpp

index 30ef78f333ad8a3177f6a021cd44497027cad0ac..5f040bbb802fb66c88d76503f1b2416eca9ba497 100644 (file)
@@ -399,7 +399,12 @@ void RecordOrganizer::layoutStructFields(const ASTRecordLayout &RL) {
       assert (isBitField  && "Invalid BitField size expression");
       uint64_t BitFieldSize =  FieldSize.getZExtValue();
       if (ExtraBits == 0) {
+        const llvm::Type *PrevTy = LLVMFields.back();
         const llvm::Type *Ty = CGT.ConvertType(FD->getType());
+        assert (CGT.getTargetData().getTypeSizeInBits(PrevTy) >=
+                CGT.getTargetData().getTypeSizeInBits(Ty) 
+                && "FIXME Unable to handle bit field. Reuse last field");
+                
         // Calculate extra bits available in this bitfield.
         ExtraBits = CGT.getTargetData().getTypeSizeInBits(Ty) - BitFieldSize;
         addLLVMField(Ty, BitFieldSize, FD, 0, ExtraBits);