1 //===--- CGExprConstant.cpp - Emit LLVM Code from Constant Expressions ----===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 //
10 // This contains code to emit Constant Expr nodes as LLVM code.
11 //
12 //===----------------------------------------------------------------------===//
13 
14 #include "CodeGenFunction.h"
15 #include "CodeGenModule.h"
16 #include "CGCXXABI.h"
17 #include "CGObjCRuntime.h"
18 #include "CGRecordLayout.h"
19 #include "clang/AST/APValue.h"
20 #include "clang/AST/ASTContext.h"
21 #include "clang/AST/RecordLayout.h"
22 #include "clang/AST/StmtVisitor.h"
23 #include "clang/Basic/Builtins.h"
24 #include "llvm/Constants.h"
25 #include "llvm/Function.h"
26 #include "llvm/GlobalVariable.h"
27 #include "llvm/Target/TargetData.h"
28 using namespace clang;
29 using namespace CodeGen;
30 
31 //===----------------------------------------------------------------------===//
32 //                            ConstStructBuilder
33 //===----------------------------------------------------------------------===//
34 
35 namespace {
36 class ConstStructBuilder {
37   CodeGenModule &CGM;
38   CodeGenFunction *CGF;
39 
40   bool Packed;
41   CharUnits NextFieldOffsetInChars;
42   CharUnits LLVMStructAlignment;
43   std::vector<llvm::Constant *> Elements;
44 public:
45   static llvm::Constant *BuildStruct(CodeGenModule &CGM, CodeGenFunction *CGF,
46                                      InitListExpr *ILE);
47 
48 private:
49   ConstStructBuilder(CodeGenModule &CGM, CodeGenFunction *CGF)
50     : CGM(CGM), CGF(CGF), Packed(false),
51     NextFieldOffsetInChars(CharUnits::Zero()),
52     LLVMStructAlignment(CharUnits::One()) { }
53 
54   bool AppendField(const FieldDecl *Field, uint64_t FieldOffset,
55                    llvm::Constant *InitExpr);
56 
57   void AppendBitField(const FieldDecl *Field, uint64_t FieldOffset,
58                       llvm::ConstantInt *InitExpr);
59 
60   void AppendPadding(CharUnits PadSize);
61 
62   void AppendTailPadding(CharUnits RecordSize);
63 
64   void ConvertStructToPacked();
65 
66   bool Build(InitListExpr *ILE);
67 
68   CharUnits getAlignment(const llvm::Constant *C) const {
69     if (Packed)  return CharUnits::One();
70     return CharUnits::fromQuantity(
71         CGM.getTargetData().getABITypeAlignment(C->getType()));
72   }
73 
74   CharUnits getSizeInChars(const llvm::Constant *C) const {
75     return CharUnits::fromQuantity(
76         CGM.getTargetData().getTypeAllocSize(C->getType()));
77   }
78 };
79 
80 bool ConstStructBuilder::
81 AppendField(const FieldDecl *Field, uint64_t FieldOffset,
82             llvm::Constant *InitCst) {
83 
84   const ASTContext &Context = CGM.getContext();
85 
86   CharUnits FieldOffsetInChars = Context.toCharUnitsFromBits(FieldOffset);
87 
88   assert(NextFieldOffsetInChars <= FieldOffsetInChars
89          && "Field offset mismatch!");
90 
91   CharUnits FieldAlignment = getAlignment(InitCst);
92 
93   // Round up the field offset to the alignment of the field type.
94   CharUnits AlignedNextFieldOffsetInChars =
95     NextFieldOffsetInChars.RoundUpToAlignment(FieldAlignment);
96 
97   if (AlignedNextFieldOffsetInChars > FieldOffsetInChars) {
98     assert(!Packed && "Alignment is wrong even with a packed struct!");
99 
100     // Convert the struct to a packed struct.
101     ConvertStructToPacked();
102 
103     AlignedNextFieldOffsetInChars = NextFieldOffsetInChars;
104   }
105 
106   if (AlignedNextFieldOffsetInChars < FieldOffsetInChars) {
107     // We need to append padding.
108     AppendPadding(
109         FieldOffsetInChars - NextFieldOffsetInChars);
110 
111     assert(NextFieldOffsetInChars == FieldOffsetInChars &&
112            "Did not add enough padding!");
113 
114     AlignedNextFieldOffsetInChars = NextFieldOffsetInChars;
115   }
116 
117   // Add the field.
118   Elements.push_back(InitCst);
119   NextFieldOffsetInChars = AlignedNextFieldOffsetInChars +
120                            getSizeInChars(InitCst);
121 
122   if (Packed)
123     assert(LLVMStructAlignment == CharUnits::One() &&
124            "Packed struct not byte-aligned!");
125   else
126     LLVMStructAlignment = std::max(LLVMStructAlignment, FieldAlignment);
127 
128   return true;
129 }
130 
131 void ConstStructBuilder::AppendBitField(const FieldDecl *Field,
132                                         uint64_t FieldOffset,
133                                         llvm::ConstantInt *CI) {
134   const ASTContext &Context = CGM.getContext();
135   const uint64_t CharWidth = Context.getCharWidth();
136   uint64_t NextFieldOffsetInBits = Context.toBits(NextFieldOffsetInChars);
137   if (FieldOffset > NextFieldOffsetInBits) {
138     // We need to add padding.
139     CharUnits PadSize = Context.toCharUnitsFromBits(
140       llvm::RoundUpToAlignment(FieldOffset - NextFieldOffsetInBits,
141                                Context.Target.getCharAlign()));
142 
143     AppendPadding(PadSize);
144   }
145 
146   uint64_t FieldSize =
147     Field->getBitWidth()->EvaluateAsInt(Context).getZExtValue();
148 
149   llvm::APInt FieldValue = CI->getValue();
150 
151   // Promote the size of FieldValue if necessary
152   // FIXME: This should never occur, but currently it can because initializer
153   // constants are cast to bool, and because clang is not enforcing bitfield
154   // width limits.
155   if (FieldSize > FieldValue.getBitWidth())
156     FieldValue = FieldValue.zext(FieldSize);
157 
158   // Truncate the size of FieldValue to the bit field size.
159   if (FieldSize < FieldValue.getBitWidth())
160     FieldValue = FieldValue.trunc(FieldSize);
161 
162   NextFieldOffsetInBits = Context.toBits(NextFieldOffsetInChars);
163   if (FieldOffset < NextFieldOffsetInBits) {
164     // Either part of the field or the entire field can go into the previous
165     // byte.
166     assert(!Elements.empty() && "Elements can't be empty!");
167 
168     unsigned BitsInPreviousByte = NextFieldOffsetInBits - FieldOffset;
169 
170     bool FitsCompletelyInPreviousByte =
171       BitsInPreviousByte >= FieldValue.getBitWidth();
172 
173     llvm::APInt Tmp = FieldValue;
174 
175     if (!FitsCompletelyInPreviousByte) {
176       unsigned NewFieldWidth = FieldSize - BitsInPreviousByte;
177 
178       if (CGM.getTargetData().isBigEndian()) {
179         Tmp = Tmp.lshr(NewFieldWidth);
180         Tmp = Tmp.trunc(BitsInPreviousByte);
181 
182         // We want the remaining high bits.
183         FieldValue = FieldValue.trunc(NewFieldWidth);
184       } else {
185         Tmp = Tmp.trunc(BitsInPreviousByte);
186 
187         // We want the remaining low bits.
188         FieldValue = FieldValue.lshr(BitsInPreviousByte);
189         FieldValue = FieldValue.trunc(NewFieldWidth);
190       }
191     }
192 
193     Tmp = Tmp.zext(CharWidth);
194     if (CGM.getTargetData().isBigEndian()) {
195       if (FitsCompletelyInPreviousByte)
196         Tmp = Tmp.shl(BitsInPreviousByte - FieldValue.getBitWidth());
197     } else {
198       Tmp = Tmp.shl(CharWidth - BitsInPreviousByte);
199     }
200 
201     // 'or' in the bits that go into the previous byte.
202     llvm::Value *LastElt = Elements.back();
203     if (llvm::ConstantInt *Val = dyn_cast<llvm::ConstantInt>(LastElt))
204       Tmp |= Val->getValue();
205     else {
206       assert(isa<llvm::UndefValue>(LastElt));
207       // If there is an undef field that we're adding to, it can either be a
208       // scalar undef (in which case, we just replace it with our field) or it
209       // is an array.  If it is an array, we have to pull one byte off the
210       // array so that the other undef bytes stay around.
211       if (!isa<llvm::IntegerType>(LastElt->getType())) {
212         // The undef padding will be a multibyte array, create a new smaller
213         // padding and then an hole for our i8 to get plopped into.
214         assert(isa<llvm::ArrayType>(LastElt->getType()) &&
215                "Expected array padding of undefs");
216         const llvm::ArrayType *AT = cast<llvm::ArrayType>(LastElt->getType());
217         assert(AT->getElementType()->isIntegerTy(CharWidth) &&
218                AT->getNumElements() != 0 &&
219                "Expected non-empty array padding of undefs");
220 
221         // Remove the padding array.
222         NextFieldOffsetInChars -= CharUnits::fromQuantity(AT->getNumElements());
223         Elements.pop_back();
224 
225         // Add the padding back in two chunks.
226         AppendPadding(CharUnits::fromQuantity(AT->getNumElements()-1));
227         AppendPadding(CharUnits::One());
228         assert(isa<llvm::UndefValue>(Elements.back()) &&
229                Elements.back()->getType()->isIntegerTy(CharWidth) &&
230                "Padding addition didn't work right");
231       }
232     }
233 
234     Elements.back() = llvm::ConstantInt::get(CGM.getLLVMContext(), Tmp);
235 
236     if (FitsCompletelyInPreviousByte)
237       return;
238   }
239 
240   while (FieldValue.getBitWidth() > CharWidth) {
241     llvm::APInt Tmp;
242 
243     if (CGM.getTargetData().isBigEndian()) {
244       // We want the high bits.
245       Tmp =
246         FieldValue.lshr(FieldValue.getBitWidth() - CharWidth).trunc(CharWidth);
247     } else {
248       // We want the low bits.
249       Tmp = FieldValue.trunc(CharWidth);
250 
251       FieldValue = FieldValue.lshr(CharWidth);
252     }
253 
254     Elements.push_back(llvm::ConstantInt::get(CGM.getLLVMContext(), Tmp));
255     ++NextFieldOffsetInChars;
256 
257     FieldValue = FieldValue.trunc(FieldValue.getBitWidth() - CharWidth);
258   }
259 
260   assert(FieldValue.getBitWidth() > 0 &&
261          "Should have at least one bit left!");
262   assert(FieldValue.getBitWidth() <= CharWidth &&
263          "Should not have more than a byte left!");
264 
265   if (FieldValue.getBitWidth() < CharWidth) {
266     if (CGM.getTargetData().isBigEndian()) {
267       unsigned BitWidth = FieldValue.getBitWidth();
268 
269       FieldValue = FieldValue.zext(CharWidth) << (CharWidth - BitWidth);
270     } else
271       FieldValue = FieldValue.zext(CharWidth);
272   }
273 
274   // Append the last element.
275   Elements.push_back(llvm::ConstantInt::get(CGM.getLLVMContext(),
276                                             FieldValue));
277   ++NextFieldOffsetInChars;
278 }
279 
280 void ConstStructBuilder::AppendPadding(CharUnits PadSize) {
281   if (PadSize.isZero())
282     return;
283 
284   const llvm::Type *Ty = llvm::Type::getInt8Ty(CGM.getLLVMContext());
285   if (PadSize > CharUnits::One())
286     Ty = llvm::ArrayType::get(Ty, PadSize.getQuantity());
287 
288   llvm::Constant *C = llvm::UndefValue::get(Ty);
289   Elements.push_back(C);
290   assert(getAlignment(C) == CharUnits::One() &&
291          "Padding must have 1 byte alignment!");
292 
293   NextFieldOffsetInChars += getSizeInChars(C);
294 }
295 
296 void ConstStructBuilder::AppendTailPadding(CharUnits RecordSize) {
297   assert(NextFieldOffsetInChars <= RecordSize &&
298          "Size mismatch!");
299 
300   AppendPadding(RecordSize - NextFieldOffsetInChars);
301 }
302 
303 void ConstStructBuilder::ConvertStructToPacked() {
304   std::vector<llvm::Constant *> PackedElements;
305   CharUnits ElementOffsetInChars = CharUnits::Zero();
306 
307   for (unsigned i = 0, e = Elements.size(); i != e; ++i) {
308     llvm::Constant *C = Elements[i];
309 
310     CharUnits ElementAlign = CharUnits::fromQuantity(
311       CGM.getTargetData().getABITypeAlignment(C->getType()));
312     CharUnits AlignedElementOffsetInChars =
313       ElementOffsetInChars.RoundUpToAlignment(ElementAlign);
314 
315     if (AlignedElementOffsetInChars > ElementOffsetInChars) {
316       // We need some padding.
317       CharUnits NumChars =
318         AlignedElementOffsetInChars - ElementOffsetInChars;
319 
320       const llvm::Type *Ty = llvm::Type::getInt8Ty(CGM.getLLVMContext());
321       if (NumChars > CharUnits::One())
322         Ty = llvm::ArrayType::get(Ty, NumChars.getQuantity());
323 
324       llvm::Constant *Padding = llvm::UndefValue::get(Ty);
325       PackedElements.push_back(Padding);
326       ElementOffsetInChars += getSizeInChars(Padding);
327     }
328 
329     PackedElements.push_back(C);
330     ElementOffsetInChars += getSizeInChars(C);
331   }
332 
333   assert(ElementOffsetInChars == NextFieldOffsetInChars &&
334          "Packing the struct changed its size!");
335 
336   Elements = PackedElements;
337   LLVMStructAlignment = CharUnits::One();
338   Packed = true;
339 }
340 
341 bool ConstStructBuilder::Build(InitListExpr *ILE) {
342   RecordDecl *RD = ILE->getType()->getAs<RecordType>()->getDecl();
343   const ASTRecordLayout &Layout = CGM.getContext().getASTRecordLayout(RD);
344 
345   unsigned FieldNo = 0;
346   unsigned ElementNo = 0;
347   const FieldDecl *LastFD = 0;
348   bool IsMsStruct = RD->hasAttr<MsStructAttr>();
349 
350   for (RecordDecl::field_iterator Field = RD->field_begin(),
351        FieldEnd = RD->field_end(); Field != FieldEnd; ++Field, ++FieldNo) {
352     if (IsMsStruct) {
353       // Zero-length bitfields following non-bitfield members are
354       // ignored:
355       if (CGM.getContext().ZeroBitfieldFollowsNonBitfield((*Field), LastFD)) {
356         --FieldNo;
357         continue;
358       }
359       LastFD = (*Field);
360     }
361 
362     // If this is a union, skip all the fields that aren't being initialized.
363     if (RD->isUnion() && ILE->getInitializedFieldInUnion() != *Field)
364       continue;
365 
366     // Don't emit anonymous bitfields, they just affect layout.
367     if (Field->isBitField() && !Field->getIdentifier()) {
368       LastFD = (*Field);
369       continue;
370     }
371 
372     // Get the initializer.  A struct can include fields without initializers,
373     // we just use explicit null values for them.
374     llvm::Constant *EltInit;
375     if (ElementNo < ILE->getNumInits())
376       EltInit = CGM.EmitConstantExpr(ILE->getInit(ElementNo++),
377                                      Field->getType(), CGF);
378     else
379       EltInit = CGM.EmitNullConstant(Field->getType());
380 
381     if (!EltInit)
382       return false;
383 
384     if (!Field->isBitField()) {
385       // Handle non-bitfield members.
386       if (!AppendField(*Field, Layout.getFieldOffset(FieldNo), EltInit))
387         return false;
388     } else {
389       // Otherwise we have a bitfield.
390       AppendBitField(*Field, Layout.getFieldOffset(FieldNo),
391                      cast<llvm::ConstantInt>(EltInit));
392     }
393   }
394 
395   CharUnits LayoutSizeInChars = Layout.getSize();
396 
397   if (NextFieldOffsetInChars > LayoutSizeInChars) {
398     // If the struct is bigger than the size of the record type,
399     // we must have a flexible array member at the end.
400     assert(RD->hasFlexibleArrayMember() &&
401            "Must have flexible array member if struct is bigger than type!");
402 
403     // No tail padding is necessary.
404     return true;
405   }
406 
407   CharUnits LLVMSizeInChars =
408     NextFieldOffsetInChars.RoundUpToAlignment(LLVMStructAlignment);
409 
410   // Check if we need to convert the struct to a packed struct.
411   if (NextFieldOffsetInChars <= LayoutSizeInChars &&
412       LLVMSizeInChars > LayoutSizeInChars) {
413     assert(!Packed && "Size mismatch!");
414 
415     ConvertStructToPacked();
416     assert(NextFieldOffsetInChars <= LayoutSizeInChars &&
417            "Converting to packed did not help!");
418   }
419 
420   // Append tail padding if necessary.
421   AppendTailPadding(LayoutSizeInChars);
422 
423   assert(LayoutSizeInChars == NextFieldOffsetInChars &&
424          "Tail padding mismatch!");
425 
426   return true;
427 }
428 
429 llvm::Constant *ConstStructBuilder::
430   BuildStruct(CodeGenModule &CGM, CodeGenFunction *CGF, InitListExpr *ILE) {
431   ConstStructBuilder Builder(CGM, CGF);
432 
433   if (!Builder.Build(ILE))
434     return 0;
435 
436   // Pick the type to use.  If the type is layout identical to the ConvertType
437   // type then use it, otherwise use whatever the builder produced for us.
438   const llvm::StructType *STy =
439       llvm::ConstantStruct::getTypeForElements(CGM.getLLVMContext(),
440                                                Builder.Elements,Builder.Packed);
441   const llvm::Type *ILETy = CGM.getTypes().ConvertType(ILE->getType());
442   if (const llvm::StructType *ILESTy = dyn_cast<llvm::StructType>(ILETy)) {
443     if (ILESTy->isLayoutIdentical(STy))
444       STy = ILESTy;
445   }
446 
447   llvm::Constant *Result =
448     llvm::ConstantStruct::get(STy, Builder.Elements);
449 
450   assert(Builder.NextFieldOffsetInChars.RoundUpToAlignment(
451            Builder.getAlignment(Result)) ==
452          Builder.getSizeInChars(Result) && "Size mismatch!");
453 
454   return Result;
455 }
456 
457 
458 //===----------------------------------------------------------------------===//
459 //                             ConstExprEmitter
460 //===----------------------------------------------------------------------===//
461 
462 class ConstExprEmitter :
463   public StmtVisitor<ConstExprEmitter, llvm::Constant*> {
464   CodeGenModule &CGM;
465   CodeGenFunction *CGF;
466   llvm::LLVMContext &VMContext;
467 public:
468   ConstExprEmitter(CodeGenModule &cgm, CodeGenFunction *cgf)
469     : CGM(cgm), CGF(cgf), VMContext(cgm.getLLVMContext()) {
470   }
471 
472   //===--------------------------------------------------------------------===//
473   //                            Visitor Methods
474   //===--------------------------------------------------------------------===//
475 
476   llvm::Constant *VisitStmt(Stmt *S) {
477     return 0;
478   }
479 
480   llvm::Constant *VisitParenExpr(ParenExpr *PE) {
481     return Visit(PE->getSubExpr());
482   }
483 
484   llvm::Constant *VisitGenericSelectionExpr(GenericSelectionExpr *GE) {
485     return Visit(GE->getResultExpr());
486   }
487 
488   llvm::Constant *VisitCompoundLiteralExpr(CompoundLiteralExpr *E) {
489     return Visit(E->getInitializer());
490   }
491 
492   llvm::Constant *VisitUnaryAddrOf(UnaryOperator *E) {
493     if (E->getType()->isMemberPointerType())
494       return CGM.getMemberPointerConstant(E);
495 
496     return 0;
497   }
498 
499   llvm::Constant *VisitBinSub(BinaryOperator *E) {
500     // This must be a pointer/pointer subtraction.  This only happens for
501     // address of label.
502     if (!isa<AddrLabelExpr>(E->getLHS()->IgnoreParenNoopCasts(CGM.getContext())) ||
503        !isa<AddrLabelExpr>(E->getRHS()->IgnoreParenNoopCasts(CGM.getContext())))
504       return 0;
505 
506     llvm::Constant *LHS = CGM.EmitConstantExpr(E->getLHS(),
507                                                E->getLHS()->getType(), CGF);
508     llvm::Constant *RHS = CGM.EmitConstantExpr(E->getRHS(),
509                                                E->getRHS()->getType(), CGF);
510 
511     const llvm::Type *ResultType = ConvertType(E->getType());
512     LHS = llvm::ConstantExpr::getPtrToInt(LHS, ResultType);
513     RHS = llvm::ConstantExpr::getPtrToInt(RHS, ResultType);
514 
515     // No need to divide by element size, since addr of label is always void*,
516     // which has size 1 in GNUish.
517     return llvm::ConstantExpr::getSub(LHS, RHS);
518   }
519 
520   llvm::Constant *VisitCastExpr(CastExpr* E) {
521     Expr *subExpr = E->getSubExpr();
522     llvm::Constant *C = CGM.EmitConstantExpr(subExpr, subExpr->getType(), CGF);
523     if (!C) return 0;
524 
525     const llvm::Type *destType = ConvertType(E->getType());
526 
527     switch (E->getCastKind()) {
528     case CK_ToUnion: {
529       // GCC cast to union extension
530       assert(E->getType()->isUnionType() &&
531              "Destination type is not union type!");
532 
533       // Build a struct with the union sub-element as the first member,
534       // and padded to the appropriate size
535       std::vector<llvm::Constant*> Elts;
536       std::vector<llvm::Type*> Types;
537       Elts.push_back(C);
538       Types.push_back(C->getType());
539       unsigned CurSize = CGM.getTargetData().getTypeAllocSize(C->getType());
540       unsigned TotalSize = CGM.getTargetData().getTypeAllocSize(destType);
541 
542       assert(CurSize <= TotalSize && "Union size mismatch!");
543       if (unsigned NumPadBytes = TotalSize - CurSize) {
544         llvm::Type *Ty = llvm::Type::getInt8Ty(VMContext);
545         if (NumPadBytes > 1)
546           Ty = llvm::ArrayType::get(Ty, NumPadBytes);
547 
548         Elts.push_back(llvm::UndefValue::get(Ty));
549         Types.push_back(Ty);
550       }
551 
552       llvm::StructType* STy =
553         llvm::StructType::get(C->getType()->getContext(), Types, false);
554       return llvm::ConstantStruct::get(STy, Elts);
555     }
556     case CK_NullToMemberPointer: {
557       const MemberPointerType *MPT = E->getType()->getAs<MemberPointerType>();
558       return CGM.getCXXABI().EmitNullMemberPointer(MPT);
559     }
560 
561     case CK_DerivedToBaseMemberPointer:
562     case CK_BaseToDerivedMemberPointer:
563       return CGM.getCXXABI().EmitMemberPointerConversion(C, E);
564 
565     case CK_LValueToRValue:
566     case CK_NoOp:
567       return C;
568 
569     case CK_AnyPointerToObjCPointerCast:
570     case CK_AnyPointerToBlockPointerCast:
571     case CK_LValueBitCast:
572     case CK_BitCast:
573       if (C->getType() == destType) return C;
574       return llvm::ConstantExpr::getBitCast(C, destType);
575 
576     case CK_Dependent: llvm_unreachable("saw dependent cast!");
577 
578     // These will never be supported.
579     case CK_ObjCObjectLValueCast:
580     case CK_GetObjCProperty:
581     case CK_ToVoid:
582     case CK_Dynamic:
583     case CK_ObjCProduceObject:
584     case CK_ObjCConsumeObject:
585     case CK_ObjCReclaimReturnedObject:
586       return 0;
587 
588     // These might need to be supported for constexpr.
589     case CK_UserDefinedConversion:
590     case CK_ConstructorConversion:
591       return 0;
592 
593     // These should eventually be supported.
594     case CK_ArrayToPointerDecay:
595     case CK_FunctionToPointerDecay:
596     case CK_BaseToDerived:
597     case CK_DerivedToBase:
598     case CK_UncheckedDerivedToBase:
599     case CK_MemberPointerToBoolean:
600     case CK_VectorSplat:
601     case CK_FloatingRealToComplex:
602     case CK_FloatingComplexToReal:
603     case CK_FloatingComplexToBoolean:
604     case CK_FloatingComplexCast:
605     case CK_FloatingComplexToIntegralComplex:
606     case CK_IntegralRealToComplex:
607     case CK_IntegralComplexToReal:
608     case CK_IntegralComplexToBoolean:
609     case CK_IntegralComplexCast:
610     case CK_IntegralComplexToFloatingComplex:
611       return 0;
612 
613     case CK_PointerToIntegral:
614       if (!E->getType()->isBooleanType())
615         return llvm::ConstantExpr::getPtrToInt(C, destType);
616       // fallthrough
617 
618     case CK_PointerToBoolean:
619       return llvm::ConstantExpr::getICmp(llvm::CmpInst::ICMP_EQ, C,
620         llvm::ConstantPointerNull::get(cast<llvm::PointerType>(C->getType())));
621 
622     case CK_NullToPointer:
623       return llvm::ConstantPointerNull::get(cast<llvm::PointerType>(destType));
624 
625     case CK_IntegralCast: {
626       bool isSigned = subExpr->getType()->isSignedIntegerOrEnumerationType();
627       return llvm::ConstantExpr::getIntegerCast(C, destType, isSigned);
628     }
629 
630     case CK_IntegralToPointer: {
631       bool isSigned = subExpr->getType()->isSignedIntegerOrEnumerationType();
632       C = llvm::ConstantExpr::getIntegerCast(C, CGM.IntPtrTy, isSigned);
633       return llvm::ConstantExpr::getIntToPtr(C, destType);
634     }
635 
636     case CK_IntegralToBoolean:
637       return llvm::ConstantExpr::getICmp(llvm::CmpInst::ICMP_EQ, C,
638                              llvm::Constant::getNullValue(C->getType()));
639 
640     case CK_IntegralToFloating:
641       if (subExpr->getType()->isSignedIntegerOrEnumerationType())
642         return llvm::ConstantExpr::getSIToFP(C, destType);
643       else
644         return llvm::ConstantExpr::getUIToFP(C, destType);
645 
646     case CK_FloatingToIntegral:
647       if (E->getType()->isSignedIntegerOrEnumerationType())
648         return llvm::ConstantExpr::getFPToSI(C, destType);
649       else
650         return llvm::ConstantExpr::getFPToUI(C, destType);
651 
652     case CK_FloatingToBoolean:
653       return llvm::ConstantExpr::getFCmp(llvm::CmpInst::FCMP_UNE, C,
654                              llvm::Constant::getNullValue(C->getType()));
655 
656     case CK_FloatingCast:
657       return llvm::ConstantExpr::getFPCast(C, destType);
658     }
659     llvm_unreachable("Invalid CastKind");
660   }
661 
662   llvm::Constant *VisitCXXDefaultArgExpr(CXXDefaultArgExpr *DAE) {
663     return Visit(DAE->getExpr());
664   }
665 
666   llvm::Constant *VisitMaterializeTemporaryExpr(MaterializeTemporaryExpr *E) {
667     return Visit(E->GetTemporaryExpr());
668   }
669 
670   llvm::Constant *EmitArrayInitialization(InitListExpr *ILE) {
671     unsigned NumInitElements = ILE->getNumInits();
672     if (NumInitElements == 1 && ILE->getType() == ILE->getInit(0)->getType() &&
673         (isa<StringLiteral>(ILE->getInit(0)) ||
674          isa<ObjCEncodeExpr>(ILE->getInit(0))))
675       return Visit(ILE->getInit(0));
676 
677     std::vector<llvm::Constant*> Elts;
678     const llvm::ArrayType *AType =
679         cast<llvm::ArrayType>(ConvertType(ILE->getType()));
680     const llvm::Type *ElemTy = AType->getElementType();
681     unsigned NumElements = AType->getNumElements();
682 
683     // Initialising an array requires us to automatically
684     // initialise any elements that have not been initialised explicitly
685     unsigned NumInitableElts = std::min(NumInitElements, NumElements);
686 
687     // Copy initializer elements.
688     unsigned i = 0;
689     bool RewriteType = false;
690     for (; i < NumInitableElts; ++i) {
691       Expr *Init = ILE->getInit(i);
692       llvm::Constant *C = CGM.EmitConstantExpr(Init, Init->getType(), CGF);
693       if (!C)
694         return 0;
695       RewriteType |= (C->getType() != ElemTy);
696       Elts.push_back(C);
697     }
698 
699     // Initialize remaining array elements.
700     // FIXME: This doesn't handle member pointers correctly!
701     llvm::Constant *fillC;
702     if (Expr *filler = ILE->getArrayFiller())
703       fillC = CGM.EmitConstantExpr(filler, filler->getType(), CGF);
704     else
705       fillC = llvm::Constant::getNullValue(ElemTy);
706     if (!fillC)
707       return 0;
708     RewriteType |= (fillC->getType() != ElemTy);
709     for (; i < NumElements; ++i)
710       Elts.push_back(fillC);
711 
712     if (RewriteType) {
713       // FIXME: Try to avoid packing the array
714       std::vector<llvm::Type*> Types;
715       for (unsigned i = 0; i < Elts.size(); ++i)
716         Types.push_back(Elts[i]->getType());
717       const llvm::StructType *SType = llvm::StructType::get(AType->getContext(),
718                                                             Types, true);
719       return llvm::ConstantStruct::get(SType, Elts);
720     }
721 
722     return llvm::ConstantArray::get(AType, Elts);
723   }
724 
725   llvm::Constant *EmitStructInitialization(InitListExpr *ILE) {
726     return ConstStructBuilder::BuildStruct(CGM, CGF, ILE);
727   }
728 
729   llvm::Constant *EmitUnionInitialization(InitListExpr *ILE) {
730     return ConstStructBuilder::BuildStruct(CGM, CGF, ILE);
731   }
732 
733   llvm::Constant *VisitImplicitValueInitExpr(ImplicitValueInitExpr* E) {
734     return CGM.EmitNullConstant(E->getType());
735   }
736 
737   llvm::Constant *VisitInitListExpr(InitListExpr *ILE) {
738     if (ILE->getType()->isScalarType()) {
739       // We have a scalar in braces. Just use the first element.
740       if (ILE->getNumInits() > 0) {
741         Expr *Init = ILE->getInit(0);
742         return CGM.EmitConstantExpr(Init, Init->getType(), CGF);
743       }
744       return CGM.EmitNullConstant(ILE->getType());
745     }
746 
747     if (ILE->getType()->isArrayType())
748       return EmitArrayInitialization(ILE);
749 
750     if (ILE->getType()->isRecordType())
751       return EmitStructInitialization(ILE);
752 
753     if (ILE->getType()->isUnionType())
754       return EmitUnionInitialization(ILE);
755 
756     // If ILE was a constant vector, we would have handled it already.
757     if (ILE->getType()->isVectorType())
758       return 0;
759 
760     assert(0 && "Unable to handle InitListExpr");
761     // Get rid of control reaches end of void function warning.
762     // Not reached.
763     return 0;
764   }
765 
766   llvm::Constant *VisitCXXConstructExpr(CXXConstructExpr *E) {
767     if (!E->getConstructor()->isTrivial())
768       return 0;
769 
770     QualType Ty = E->getType();
771 
772     // FIXME: We should not have to call getBaseElementType here.
773     const RecordType *RT =
774       CGM.getContext().getBaseElementType(Ty)->getAs<RecordType>();
775     const CXXRecordDecl *RD = cast<CXXRecordDecl>(RT->getDecl());
776 
777     // If the class doesn't have a trivial destructor, we can't emit it as a
778     // constant expr.
779     if (!RD->hasTrivialDestructor())
780       return 0;
781 
782     // Only copy and default constructors can be trivial.
783 
784 
785     if (E->getNumArgs()) {
786       assert(E->getNumArgs() == 1 && "trivial ctor with > 1 argument");
787       assert(E->getConstructor()->isCopyConstructor() &&
788              "trivial ctor has argument but isn't a copy ctor");
789 
790       Expr *Arg = E->getArg(0);
791       assert(CGM.getContext().hasSameUnqualifiedType(Ty, Arg->getType()) &&
792              "argument to copy ctor is of wrong type");
793 
794       return Visit(Arg);
795     }
796 
797     return CGM.EmitNullConstant(Ty);
798   }
799 
800   llvm::Constant *VisitStringLiteral(StringLiteral *E) {
801     assert(!E->getType()->isPointerType() && "Strings are always arrays");
802 
803     // This must be a string initializing an array in a static initializer.
804     // Don't emit it as the address of the string, emit the string data itself
805     // as an inline array.
806     return llvm::ConstantArray::get(VMContext,
807                                     CGM.GetStringForStringLiteral(E), false);
808   }
809 
810   llvm::Constant *VisitObjCEncodeExpr(ObjCEncodeExpr *E) {
811     // This must be an @encode initializing an array in a static initializer.
812     // Don't emit it as the address of the string, emit the string data itself
813     // as an inline array.
814     std::string Str;
815     CGM.getContext().getObjCEncodingForType(E->getEncodedType(), Str);
816     const ConstantArrayType *CAT = cast<ConstantArrayType>(E->getType());
817 
818     // Resize the string to the right size, adding zeros at the end, or
819     // truncating as needed.
820     Str.resize(CAT->getSize().getZExtValue(), '\0');
821     return llvm::ConstantArray::get(VMContext, Str, false);
822   }
823 
824   llvm::Constant *VisitUnaryExtension(const UnaryOperator *E) {
825     return Visit(E->getSubExpr());
826   }
827 
828   // Utility methods
829   const llvm::Type *ConvertType(QualType T) {
830     return CGM.getTypes().ConvertType(T);
831   }
832 
833 public:
834   llvm::Constant *EmitLValue(Expr *E) {
835     switch (E->getStmtClass()) {
836     default: break;
837     case Expr::CompoundLiteralExprClass: {
838       // Note that due to the nature of compound literals, this is guaranteed
839       // to be the only use of the variable, so we just generate it here.
840       CompoundLiteralExpr *CLE = cast<CompoundLiteralExpr>(E);
841       llvm::Constant* C = Visit(CLE->getInitializer());
842       // FIXME: "Leaked" on failure.
843       if (C)
844         C = new llvm::GlobalVariable(CGM.getModule(), C->getType(),
845                                      E->getType().isConstant(CGM.getContext()),
846                                      llvm::GlobalValue::InternalLinkage,
847                                      C, ".compoundliteral", 0, false,
848                           CGM.getContext().getTargetAddressSpace(E->getType()));
849       return C;
850     }
851     case Expr::DeclRefExprClass: {
852       ValueDecl *Decl = cast<DeclRefExpr>(E)->getDecl();
853       if (Decl->hasAttr<WeakRefAttr>())
854         return CGM.GetWeakRefReference(Decl);
855       if (const FunctionDecl *FD = dyn_cast<FunctionDecl>(Decl))
856         return CGM.GetAddrOfFunction(FD);
857       if (const VarDecl* VD = dyn_cast<VarDecl>(Decl)) {
858         // We can never refer to a variable with local storage.
859         if (!VD->hasLocalStorage()) {
860           if (VD->isFileVarDecl() || VD->hasExternalStorage())
861             return CGM.GetAddrOfGlobalVar(VD);
862           else if (VD->isLocalVarDecl()) {
863             assert(CGF && "Can't access static local vars without CGF");
864             return CGF->GetAddrOfStaticLocalVar(VD);
865           }
866         }
867       }
868       break;
869     }
870     case Expr::StringLiteralClass:
871       return CGM.GetAddrOfConstantStringFromLiteral(cast<StringLiteral>(E));
872     case Expr::ObjCEncodeExprClass:
873       return CGM.GetAddrOfConstantStringFromObjCEncode(cast<ObjCEncodeExpr>(E));
874     case Expr::ObjCStringLiteralClass: {
875       ObjCStringLiteral* SL = cast<ObjCStringLiteral>(E);
876       llvm::Constant *C =
877           CGM.getObjCRuntime().GenerateConstantString(SL->getString());
878       return llvm::ConstantExpr::getBitCast(C, ConvertType(E->getType()));
879     }
880     case Expr::PredefinedExprClass: {
881       unsigned Type = cast<PredefinedExpr>(E)->getIdentType();
882       if (CGF) {
883         LValue Res = CGF->EmitPredefinedLValue(cast<PredefinedExpr>(E));
884         return cast<llvm::Constant>(Res.getAddress());
885       } else if (Type == PredefinedExpr::PrettyFunction) {
886         return CGM.GetAddrOfConstantCString("top level", ".tmp");
887       }
888 
889       return CGM.GetAddrOfConstantCString("", ".tmp");
890     }
891     case Expr::AddrLabelExprClass: {
892       assert(CGF && "Invalid address of label expression outside function.");
893       llvm::Constant *Ptr =
894         CGF->GetAddrOfLabel(cast<AddrLabelExpr>(E)->getLabel());
895       return llvm::ConstantExpr::getBitCast(Ptr, ConvertType(E->getType()));
896     }
897     case Expr::CallExprClass: {
898       CallExpr* CE = cast<CallExpr>(E);
899       unsigned builtin = CE->isBuiltinCall(CGM.getContext());
900       if (builtin !=
901             Builtin::BI__builtin___CFStringMakeConstantString &&
902           builtin !=
903             Builtin::BI__builtin___NSStringMakeConstantString)
904         break;
905       const Expr *Arg = CE->getArg(0)->IgnoreParenCasts();
906       const StringLiteral *Literal = cast<StringLiteral>(Arg);
907       if (builtin ==
908             Builtin::BI__builtin___NSStringMakeConstantString) {
909         return CGM.getObjCRuntime().GenerateConstantString(Literal);
910       }
911       // FIXME: need to deal with UCN conversion issues.
912       return CGM.GetAddrOfConstantCFString(Literal);
913     }
914     case Expr::BlockExprClass: {
915       std::string FunctionName;
916       if (CGF)
917         FunctionName = CGF->CurFn->getName();
918       else
919         FunctionName = "global";
920 
921       return CGM.GetAddrOfGlobalBlock(cast<BlockExpr>(E), FunctionName.c_str());
922     }
923     }
924 
925     return 0;
926   }
927 };
928 
929 }  // end anonymous namespace.
930 
931 llvm::Constant *CodeGenModule::EmitConstantExpr(const Expr *E,
932                                                 QualType DestType,
933                                                 CodeGenFunction *CGF) {
934   Expr::EvalResult Result;
935 
936   bool Success = false;
937 
938   if (DestType->isReferenceType())
939     Success = E->EvaluateAsLValue(Result, Context);
940   else
941     Success = E->Evaluate(Result, Context);
942 
943   if (Success && !Result.HasSideEffects) {
944     switch (Result.Val.getKind()) {
945     case APValue::Uninitialized:
946       assert(0 && "Constant expressions should be initialized.");
947       return 0;
948     case APValue::LValue: {
949       const llvm::Type *DestTy = getTypes().ConvertTypeForMem(DestType);
950       llvm::Constant *Offset =
951         llvm::ConstantInt::get(llvm::Type::getInt64Ty(VMContext),
952                                Result.Val.getLValueOffset().getQuantity());
953 
954       llvm::Constant *C;
955       if (const Expr *LVBase = Result.Val.getLValueBase()) {
956         C = ConstExprEmitter(*this, CGF).EmitLValue(const_cast<Expr*>(LVBase));
957 
958         // Apply offset if necessary.
959         if (!Offset->isNullValue()) {
960           const llvm::Type *Type = llvm::Type::getInt8PtrTy(VMContext);
961           llvm::Constant *Casted = llvm::ConstantExpr::getBitCast(C, Type);
962           Casted = llvm::ConstantExpr::getGetElementPtr(Casted, &Offset, 1);
963           C = llvm::ConstantExpr::getBitCast(Casted, C->getType());
964         }
965 
966         // Convert to the appropriate type; this could be an lvalue for
967         // an integer.
968         if (isa<llvm::PointerType>(DestTy))
969           return llvm::ConstantExpr::getBitCast(C, DestTy);
970 
971         return llvm::ConstantExpr::getPtrToInt(C, DestTy);
972       } else {
973         C = Offset;
974 
975         // Convert to the appropriate type; this could be an lvalue for
976         // an integer.
977         if (isa<llvm::PointerType>(DestTy))
978           return llvm::ConstantExpr::getIntToPtr(C, DestTy);
979 
980         // If the types don't match this should only be a truncate.
981         if (C->getType() != DestTy)
982           return llvm::ConstantExpr::getTrunc(C, DestTy);
983 
984         return C;
985       }
986     }
987     case APValue::Int: {
988       llvm::Constant *C = llvm::ConstantInt::get(VMContext,
989                                                  Result.Val.getInt());
990 
991       if (C->getType()->isIntegerTy(1)) {
992         const llvm::Type *BoolTy = getTypes().ConvertTypeForMem(E->getType());
993         C = llvm::ConstantExpr::getZExt(C, BoolTy);
994       }
995       return C;
996     }
997     case APValue::ComplexInt: {
998       llvm::Constant *Complex[2];
999 
1000       Complex[0] = llvm::ConstantInt::get(VMContext,
1001                                           Result.Val.getComplexIntReal());
1002       Complex[1] = llvm::ConstantInt::get(VMContext,
1003                                           Result.Val.getComplexIntImag());
1004 
1005       // FIXME: the target may want to specify that this is packed.
1006       llvm::StructType *STy = llvm::StructType::get(Complex[0]->getType(),
1007                                                     Complex[1]->getType(),
1008                                                     NULL);
1009       return llvm::ConstantStruct::get(STy, Complex);
1010     }
1011     case APValue::Float:
1012       return llvm::ConstantFP::get(VMContext, Result.Val.getFloat());
1013     case APValue::ComplexFloat: {
1014       llvm::Constant *Complex[2];
1015 
1016       Complex[0] = llvm::ConstantFP::get(VMContext,
1017                                          Result.Val.getComplexFloatReal());
1018       Complex[1] = llvm::ConstantFP::get(VMContext,
1019                                          Result.Val.getComplexFloatImag());
1020 
1021       // FIXME: the target may want to specify that this is packed.
1022       llvm::StructType *STy = llvm::StructType::get(Complex[0]->getType(),
1023                                                     Complex[1]->getType(),
1024                                                     NULL);
1025       return llvm::ConstantStruct::get(STy, Complex);
1026     }
1027     case APValue::Vector: {
1028       llvm::SmallVector<llvm::Constant *, 4> Inits;
1029       unsigned NumElts = Result.Val.getVectorLength();
1030 
1031       if (Context.getLangOptions().AltiVec &&
1032           isa<CastExpr>(E) &&
1033           cast<CastExpr>(E)->getCastKind() == CK_VectorSplat) {
1034         // AltiVec vector initialization with a single literal
1035         APValue &Elt = Result.Val.getVectorElt(0);
1036 
1037         llvm::Constant* InitValue = Elt.isInt()
1038           ? cast<llvm::Constant>
1039               (llvm::ConstantInt::get(VMContext, Elt.getInt()))
1040           : cast<llvm::Constant>
1041               (llvm::ConstantFP::get(VMContext, Elt.getFloat()));
1042 
1043         for (unsigned i = 0; i != NumElts; ++i)
1044           Inits.push_back(InitValue);
1045 
1046       } else {
1047         for (unsigned i = 0; i != NumElts; ++i) {
1048           APValue &Elt = Result.Val.getVectorElt(i);
1049           if (Elt.isInt())
1050             Inits.push_back(llvm::ConstantInt::get(VMContext, Elt.getInt()));
1051           else
1052             Inits.push_back(llvm::ConstantFP::get(VMContext, Elt.getFloat()));
1053         }
1054       }
1055       return llvm::ConstantVector::get(Inits);
1056     }
1057     }
1058   }
1059 
1060   llvm::Constant* C = ConstExprEmitter(*this, CGF).Visit(const_cast<Expr*>(E));
1061   if (C && C->getType()->isIntegerTy(1)) {
1062     const llvm::Type *BoolTy = getTypes().ConvertTypeForMem(E->getType());
1063     C = llvm::ConstantExpr::getZExt(C, BoolTy);
1064   }
1065   return C;
1066 }
1067 
1068 static uint64_t getFieldOffset(ASTContext &C, const FieldDecl *field) {
1069   const ASTRecordLayout &layout = C.getASTRecordLayout(field->getParent());
1070   return layout.getFieldOffset(field->getFieldIndex());
1071 }
1072 
1073 llvm::Constant *
1074 CodeGenModule::getMemberPointerConstant(const UnaryOperator *uo) {
1075   // Member pointer constants always have a very particular form.
1076   const MemberPointerType *type = cast<MemberPointerType>(uo->getType());
1077   const ValueDecl *decl = cast<DeclRefExpr>(uo->getSubExpr())->getDecl();
1078 
1079   // A member function pointer.
1080   if (const CXXMethodDecl *method = dyn_cast<CXXMethodDecl>(decl))
1081     return getCXXABI().EmitMemberPointer(method);
1082 
1083   // Otherwise, a member data pointer.
1084   uint64_t fieldOffset;
1085   if (const FieldDecl *field = dyn_cast<FieldDecl>(decl))
1086     fieldOffset = getFieldOffset(getContext(), field);
1087   else {
1088     const IndirectFieldDecl *ifield = cast<IndirectFieldDecl>(decl);
1089 
1090     fieldOffset = 0;
1091     for (IndirectFieldDecl::chain_iterator ci = ifield->chain_begin(),
1092            ce = ifield->chain_end(); ci != ce; ++ci)
1093       fieldOffset += getFieldOffset(getContext(), cast<FieldDecl>(*ci));
1094   }
1095 
1096   CharUnits chars = getContext().toCharUnitsFromBits((int64_t) fieldOffset);
1097   return getCXXABI().EmitMemberDataPointer(type, chars);
1098 }
1099 
1100 static void
1101 FillInNullDataMemberPointers(CodeGenModule &CGM, QualType T,
1102                              std::vector<llvm::Constant *> &Elements,
1103                              uint64_t StartOffset) {
1104   assert(StartOffset % CGM.getContext().getCharWidth() == 0 &&
1105          "StartOffset not byte aligned!");
1106 
1107   if (CGM.getTypes().isZeroInitializable(T))
1108     return;
1109 
1110   if (const ConstantArrayType *CAT =
1111         CGM.getContext().getAsConstantArrayType(T)) {
1112     QualType ElementTy = CAT->getElementType();
1113     uint64_t ElementSize = CGM.getContext().getTypeSize(ElementTy);
1114 
1115     for (uint64_t I = 0, E = CAT->getSize().getZExtValue(); I != E; ++I) {
1116       FillInNullDataMemberPointers(CGM, ElementTy, Elements,
1117                                    StartOffset + I * ElementSize);
1118     }
1119   } else if (const RecordType *RT = T->getAs<RecordType>()) {
1120     const CXXRecordDecl *RD = cast<CXXRecordDecl>(RT->getDecl());
1121     const ASTRecordLayout &Layout = CGM.getContext().getASTRecordLayout(RD);
1122 
1123     // Go through all bases and fill in any null pointer to data members.
1124     for (CXXRecordDecl::base_class_const_iterator I = RD->bases_begin(),
1125          E = RD->bases_end(); I != E; ++I) {
1126       if (I->isVirtual()) {
1127         // Ignore virtual bases.
1128         continue;
1129       }
1130 
1131       const CXXRecordDecl *BaseDecl =
1132       cast<CXXRecordDecl>(I->getType()->getAs<RecordType>()->getDecl());
1133 
1134       // Ignore empty bases.
1135       if (BaseDecl->isEmpty())
1136         continue;
1137 
1138       // Ignore bases that don't have any pointer to data members.
1139       if (CGM.getTypes().isZeroInitializable(BaseDecl))
1140         continue;
1141 
1142       uint64_t BaseOffset = Layout.getBaseClassOffsetInBits(BaseDecl);
1143       FillInNullDataMemberPointers(CGM, I->getType(),
1144                                    Elements, StartOffset + BaseOffset);
1145     }
1146 
1147     // Visit all fields.
1148     unsigned FieldNo = 0;
1149     for (RecordDecl::field_iterator I = RD->field_begin(),
1150          E = RD->field_end(); I != E; ++I, ++FieldNo) {
1151       QualType FieldType = I->getType();
1152 
1153       if (CGM.getTypes().isZeroInitializable(FieldType))
1154         continue;
1155 
1156       uint64_t FieldOffset = StartOffset + Layout.getFieldOffset(FieldNo);
1157       FillInNullDataMemberPointers(CGM, FieldType, Elements, FieldOffset);
1158     }
1159   } else {
1160     assert(T->isMemberPointerType() && "Should only see member pointers here!");
1161     assert(!T->getAs<MemberPointerType>()->getPointeeType()->isFunctionType() &&
1162            "Should only see pointers to data members here!");
1163 
1164     CharUnits StartIndex = CGM.getContext().toCharUnitsFromBits(StartOffset);
1165     CharUnits EndIndex = StartIndex + CGM.getContext().getTypeSizeInChars(T);
1166 
1167     // FIXME: hardcodes Itanium member pointer representation!
1168     llvm::Constant *NegativeOne =
1169       llvm::ConstantInt::get(llvm::Type::getInt8Ty(CGM.getLLVMContext()),
1170                              -1ULL, /*isSigned*/true);
1171 
1172     // Fill in the null data member pointer.
1173     for (CharUnits I = StartIndex; I != EndIndex; ++I)
1174       Elements[I.getQuantity()] = NegativeOne;
1175   }
1176 }
1177 
1178 static llvm::Constant *EmitNullConstantForBase(CodeGenModule &CGM,
1179                                                const llvm::Type *baseType,
1180                                                const CXXRecordDecl *base);
1181 
1182 static llvm::Constant *EmitNullConstant(CodeGenModule &CGM,
1183                                         const CXXRecordDecl *record,
1184                                         bool asCompleteObject) {
1185   const CGRecordLayout &layout = CGM.getTypes().getCGRecordLayout(record);
1186   const llvm::StructType *structure =
1187     (asCompleteObject ? layout.getLLVMType()
1188                       : layout.getBaseSubobjectLLVMType());
1189 
1190   unsigned numElements = structure->getNumElements();
1191   std::vector<llvm::Constant *> elements(numElements);
1192 
1193   // Fill in all the bases.
1194   for (CXXRecordDecl::base_class_const_iterator
1195          I = record->bases_begin(), E = record->bases_end(); I != E; ++I) {
1196     if (I->isVirtual()) {
1197       // Ignore virtual bases; if we're laying out for a complete
1198       // object, we'll lay these out later.
1199       continue;
1200     }
1201 
1202     const CXXRecordDecl *base =
1203       cast<CXXRecordDecl>(I->getType()->castAs<RecordType>()->getDecl());
1204 
1205     // Ignore empty bases.
1206     if (base->isEmpty())
1207       continue;
1208 
1209     unsigned fieldIndex = layout.getNonVirtualBaseLLVMFieldNo(base);
1210     const llvm::Type *baseType = structure->getElementType(fieldIndex);
1211     elements[fieldIndex] = EmitNullConstantForBase(CGM, baseType, base);
1212   }
1213 
1214   // Fill in all the fields.
1215   for (RecordDecl::field_iterator I = record->field_begin(),
1216          E = record->field_end(); I != E; ++I) {
1217     const FieldDecl *field = *I;
1218 
1219     // Ignore bit fields.
1220     if (field->isBitField())
1221       continue;
1222 
1223     unsigned fieldIndex = layout.getLLVMFieldNo(field);
1224     elements[fieldIndex] = CGM.EmitNullConstant(field->getType());
1225   }
1226 
1227   // Fill in the virtual bases, if we're working with the complete object.
1228   if (asCompleteObject) {
1229     for (CXXRecordDecl::base_class_const_iterator
1230            I = record->vbases_begin(), E = record->vbases_end(); I != E; ++I) {
1231       const CXXRecordDecl *base =
1232         cast<CXXRecordDecl>(I->getType()->castAs<RecordType>()->getDecl());
1233 
1234       // Ignore empty bases.
1235       if (base->isEmpty())
1236         continue;
1237 
1238       unsigned fieldIndex = layout.getVirtualBaseIndex(base);
1239 
1240       // We might have already laid this field out.
1241       if (elements[fieldIndex]) continue;
1242 
1243       const llvm::Type *baseType = structure->getElementType(fieldIndex);
1244       elements[fieldIndex] = EmitNullConstantForBase(CGM, baseType, base);
1245     }
1246   }
1247 
1248   // Now go through all other fields and zero them out.
1249   for (unsigned i = 0; i != numElements; ++i) {
1250     if (!elements[i])
1251       elements[i] = llvm::Constant::getNullValue(structure->getElementType(i));
1252   }
1253 
1254   return llvm::ConstantStruct::get(structure, elements);
1255 }
1256 
1257 /// Emit the null constant for a base subobject.
1258 static llvm::Constant *EmitNullConstantForBase(CodeGenModule &CGM,
1259                                                const llvm::Type *baseType,
1260                                                const CXXRecordDecl *base) {
1261   const CGRecordLayout &baseLayout = CGM.getTypes().getCGRecordLayout(base);
1262 
1263   // Just zero out bases that don't have any pointer to data members.
1264   if (baseLayout.isZeroInitializableAsBase())
1265     return llvm::Constant::getNullValue(baseType);
1266 
1267   // If the base type is a struct, we can just use its null constant.
1268   if (isa<llvm::StructType>(baseType)) {
1269     return EmitNullConstant(CGM, base, /*complete*/ false);
1270   }
1271 
1272   // Otherwise, some bases are represented as arrays of i8 if the size
1273   // of the base is smaller than its corresponding LLVM type.  Figure
1274   // out how many elements this base array has.
1275   const llvm::ArrayType *baseArrayType = cast<llvm::ArrayType>(baseType);
1276   unsigned numBaseElements = baseArrayType->getNumElements();
1277 
1278   // Fill in null data member pointers.
1279   std::vector<llvm::Constant *> baseElements(numBaseElements);
1280   FillInNullDataMemberPointers(CGM, CGM.getContext().getTypeDeclType(base),
1281                                baseElements, 0);
1282 
1283   // Now go through all other elements and zero them out.
1284   if (numBaseElements) {
1285     const llvm::Type *i8 = llvm::Type::getInt8Ty(CGM.getLLVMContext());
1286     llvm::Constant *i8_zero = llvm::Constant::getNullValue(i8);
1287     for (unsigned i = 0; i != numBaseElements; ++i) {
1288       if (!baseElements[i])
1289         baseElements[i] = i8_zero;
1290     }
1291   }
1292 
1293   return llvm::ConstantArray::get(baseArrayType, baseElements);
1294 }
1295 
1296 llvm::Constant *CodeGenModule::EmitNullConstant(QualType T) {
1297   if (getTypes().isZeroInitializable(T))
1298     return llvm::Constant::getNullValue(getTypes().ConvertTypeForMem(T));
1299 
1300   if (const ConstantArrayType *CAT = Context.getAsConstantArrayType(T)) {
1301 
1302     QualType ElementTy = CAT->getElementType();
1303 
1304     llvm::Constant *Element = EmitNullConstant(ElementTy);
1305     unsigned NumElements = CAT->getSize().getZExtValue();
1306     std::vector<llvm::Constant *> Array(NumElements);
1307     for (unsigned i = 0; i != NumElements; ++i)
1308       Array[i] = Element;
1309 
1310     const llvm::ArrayType *ATy =
1311       cast<llvm::ArrayType>(getTypes().ConvertTypeForMem(T));
1312     return llvm::ConstantArray::get(ATy, Array);
1313   }
1314 
1315   if (const RecordType *RT = T->getAs<RecordType>()) {
1316     const CXXRecordDecl *RD = cast<CXXRecordDecl>(RT->getDecl());
1317     return ::EmitNullConstant(*this, RD, /*complete object*/ true);
1318   }
1319 
1320   assert(T->isMemberPointerType() && "Should only see member pointers here!");
1321   assert(!T->getAs<MemberPointerType>()->getPointeeType()->isFunctionType() &&
1322          "Should only see pointers to data members here!");
1323 
1324   // Itanium C++ ABI 2.3:
1325   //   A NULL pointer is represented as -1.
1326   return getCXXABI().EmitNullMemberPointer(T->castAs<MemberPointerType>());
1327 }
1328