1 //===--- CGExpr.cpp - Emit LLVM Code from 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 Expr nodes as LLVM code.
11 //
12 //===----------------------------------------------------------------------===//
13 
14 #include "CodeGenFunction.h"
15 #include "CodeGenModule.h"
16 #include "CGCall.h"
17 #include "CGCXXABI.h"
18 #include "CGDebugInfo.h"
19 #include "CGRecordLayout.h"
20 #include "CGObjCRuntime.h"
21 #include "TargetInfo.h"
22 #include "clang/AST/ASTContext.h"
23 #include "clang/AST/DeclObjC.h"
24 #include "clang/Basic/ConvertUTF.h"
25 #include "clang/Frontend/CodeGenOptions.h"
26 #include "llvm/Intrinsics.h"
27 #include "llvm/LLVMContext.h"
28 #include "llvm/Support/MDBuilder.h"
29 #include "llvm/Target/TargetData.h"
30 using namespace clang;
31 using namespace CodeGen;
32 
33 //===--------------------------------------------------------------------===//
34 //                        Miscellaneous Helper Methods
35 //===--------------------------------------------------------------------===//
36 
37 llvm::Value *CodeGenFunction::EmitCastToVoidPtr(llvm::Value *value) {
38   unsigned addressSpace =
39     cast<llvm::PointerType>(value->getType())->getAddressSpace();
40 
41   llvm::PointerType *destType = Int8PtrTy;
42   if (addressSpace)
43     destType = llvm::Type::getInt8PtrTy(getLLVMContext(), addressSpace);
44 
45   if (value->getType() == destType) return value;
46   return Builder.CreateBitCast(value, destType);
47 }
48 
49 /// CreateTempAlloca - This creates a alloca and inserts it into the entry
50 /// block.
51 llvm::AllocaInst *CodeGenFunction::CreateTempAlloca(llvm::Type *Ty,
52                                                     const Twine &Name) {
53   if (!Builder.isNamePreserving())
54     return new llvm::AllocaInst(Ty, 0, "", AllocaInsertPt);
55   return new llvm::AllocaInst(Ty, 0, Name, AllocaInsertPt);
56 }
57 
58 void CodeGenFunction::InitTempAlloca(llvm::AllocaInst *Var,
59                                      llvm::Value *Init) {
60   llvm::StoreInst *Store = new llvm::StoreInst(Init, Var);
61   llvm::BasicBlock *Block = AllocaInsertPt->getParent();
62   Block->getInstList().insertAfter(&*AllocaInsertPt, Store);
63 }
64 
65 llvm::AllocaInst *CodeGenFunction::CreateIRTemp(QualType Ty,
66                                                 const Twine &Name) {
67   llvm::AllocaInst *Alloc = CreateTempAlloca(ConvertType(Ty), Name);
68   // FIXME: Should we prefer the preferred type alignment here?
69   CharUnits Align = getContext().getTypeAlignInChars(Ty);
70   Alloc->setAlignment(Align.getQuantity());
71   return Alloc;
72 }
73 
74 llvm::AllocaInst *CodeGenFunction::CreateMemTemp(QualType Ty,
75                                                  const Twine &Name) {
76   llvm::AllocaInst *Alloc = CreateTempAlloca(ConvertTypeForMem(Ty), Name);
77   // FIXME: Should we prefer the preferred type alignment here?
78   CharUnits Align = getContext().getTypeAlignInChars(Ty);
79   Alloc->setAlignment(Align.getQuantity());
80   return Alloc;
81 }
82 
83 /// EvaluateExprAsBool - Perform the usual unary conversions on the specified
84 /// expression and compare the result against zero, returning an Int1Ty value.
85 llvm::Value *CodeGenFunction::EvaluateExprAsBool(const Expr *E) {
86   if (const MemberPointerType *MPT = E->getType()->getAs<MemberPointerType>()) {
87     llvm::Value *MemPtr = EmitScalarExpr(E);
88     return CGM.getCXXABI().EmitMemberPointerIsNotNull(*this, MemPtr, MPT);
89   }
90 
91   QualType BoolTy = getContext().BoolTy;
92   if (!E->getType()->isAnyComplexType())
93     return EmitScalarConversion(EmitScalarExpr(E), E->getType(), BoolTy);
94 
95   return EmitComplexToScalarConversion(EmitComplexExpr(E), E->getType(),BoolTy);
96 }
97 
98 /// EmitIgnoredExpr - Emit code to compute the specified expression,
99 /// ignoring the result.
100 void CodeGenFunction::EmitIgnoredExpr(const Expr *E) {
101   if (E->isRValue())
102     return (void) EmitAnyExpr(E, AggValueSlot::ignored(), true);
103 
104   // Just emit it as an l-value and drop the result.
105   EmitLValue(E);
106 }
107 
108 /// EmitAnyExpr - Emit code to compute the specified expression which
109 /// can have any type.  The result is returned as an RValue struct.
110 /// If this is an aggregate expression, AggSlot indicates where the
111 /// result should be returned.
112 RValue CodeGenFunction::EmitAnyExpr(const Expr *E, AggValueSlot AggSlot,
113                                     bool IgnoreResult) {
114   if (!hasAggregateLLVMType(E->getType()))
115     return RValue::get(EmitScalarExpr(E, IgnoreResult));
116   else if (E->getType()->isAnyComplexType())
117     return RValue::getComplex(EmitComplexExpr(E, IgnoreResult, IgnoreResult));
118 
119   EmitAggExpr(E, AggSlot, IgnoreResult);
120   return AggSlot.asRValue();
121 }
122 
123 /// EmitAnyExprToTemp - Similary to EmitAnyExpr(), however, the result will
124 /// always be accessible even if no aggregate location is provided.
125 RValue CodeGenFunction::EmitAnyExprToTemp(const Expr *E) {
126   AggValueSlot AggSlot = AggValueSlot::ignored();
127 
128   if (hasAggregateLLVMType(E->getType()) &&
129       !E->getType()->isAnyComplexType())
130     AggSlot = CreateAggTemp(E->getType(), "agg.tmp");
131   return EmitAnyExpr(E, AggSlot);
132 }
133 
134 /// EmitAnyExprToMem - Evaluate an expression into a given memory
135 /// location.
136 void CodeGenFunction::EmitAnyExprToMem(const Expr *E,
137                                        llvm::Value *Location,
138                                        Qualifiers Quals,
139                                        bool IsInit) {
140   // FIXME: This function should take an LValue as an argument.
141   if (E->getType()->isAnyComplexType()) {
142     EmitComplexExprIntoAddr(E, Location, Quals.hasVolatile());
143   } else if (hasAggregateLLVMType(E->getType())) {
144     CharUnits Alignment = getContext().getTypeAlignInChars(E->getType());
145     EmitAggExpr(E, AggValueSlot::forAddr(Location, Alignment, Quals,
146                                          AggValueSlot::IsDestructed_t(IsInit),
147                                          AggValueSlot::DoesNotNeedGCBarriers,
148                                          AggValueSlot::IsAliased_t(!IsInit)));
149   } else {
150     RValue RV = RValue::get(EmitScalarExpr(E, /*Ignore*/ false));
151     LValue LV = MakeAddrLValue(Location, E->getType());
152     EmitStoreThroughLValue(RV, LV);
153   }
154 }
155 
156 namespace {
157 /// \brief An adjustment to be made to the temporary created when emitting a
158 /// reference binding, which accesses a particular subobject of that temporary.
159   struct SubobjectAdjustment {
160     enum {
161       DerivedToBaseAdjustment,
162       FieldAdjustment,
163       MemberPointerAdjustment
164     } Kind;
165 
166     union {
167       struct {
168         const CastExpr *BasePath;
169         const CXXRecordDecl *DerivedClass;
170       } DerivedToBase;
171 
172       FieldDecl *Field;
173 
174       struct {
175         const MemberPointerType *MPT;
176         llvm::Value *Ptr;
177       } Ptr;
178     };
179 
180     SubobjectAdjustment(const CastExpr *BasePath,
181                         const CXXRecordDecl *DerivedClass)
182       : Kind(DerivedToBaseAdjustment) {
183       DerivedToBase.BasePath = BasePath;
184       DerivedToBase.DerivedClass = DerivedClass;
185     }
186 
187     SubobjectAdjustment(FieldDecl *Field)
188       : Kind(FieldAdjustment) {
189       this->Field = Field;
190     }
191 
192     SubobjectAdjustment(const MemberPointerType *MPT, llvm::Value *Ptr)
193       : Kind(MemberPointerAdjustment) {
194       this->Ptr.MPT = MPT;
195       this->Ptr.Ptr = Ptr;
196     }
197   };
198 }
199 
200 static llvm::Value *
201 CreateReferenceTemporary(CodeGenFunction &CGF, QualType Type,
202                          const NamedDecl *InitializedDecl) {
203   if (const VarDecl *VD = dyn_cast_or_null<VarDecl>(InitializedDecl)) {
204     if (VD->hasGlobalStorage()) {
205       SmallString<256> Name;
206       llvm::raw_svector_ostream Out(Name);
207       CGF.CGM.getCXXABI().getMangleContext().mangleReferenceTemporary(VD, Out);
208       Out.flush();
209 
210       llvm::Type *RefTempTy = CGF.ConvertTypeForMem(Type);
211 
212       // Create the reference temporary.
213       llvm::GlobalValue *RefTemp =
214         new llvm::GlobalVariable(CGF.CGM.getModule(),
215                                  RefTempTy, /*isConstant=*/false,
216                                  llvm::GlobalValue::InternalLinkage,
217                                  llvm::Constant::getNullValue(RefTempTy),
218                                  Name.str());
219       return RefTemp;
220     }
221   }
222 
223   return CGF.CreateMemTemp(Type, "ref.tmp");
224 }
225 
226 static llvm::Value *
227 EmitExprForReferenceBinding(CodeGenFunction &CGF, const Expr *E,
228                             llvm::Value *&ReferenceTemporary,
229                             const CXXDestructorDecl *&ReferenceTemporaryDtor,
230                             QualType &ObjCARCReferenceLifetimeType,
231                             const NamedDecl *InitializedDecl) {
232   // Look through single-element init lists that claim to be lvalues. They're
233   // just syntactic wrappers in this case.
234   if (const InitListExpr *ILE = dyn_cast<InitListExpr>(E)) {
235     if (ILE->getNumInits() == 1 && ILE->isGLValue())
236       E = ILE->getInit(0);
237   }
238 
239   // Look through expressions for materialized temporaries (for now).
240   if (const MaterializeTemporaryExpr *M
241                                       = dyn_cast<MaterializeTemporaryExpr>(E)) {
242     // Objective-C++ ARC:
243     //   If we are binding a reference to a temporary that has ownership, we
244     //   need to perform retain/release operations on the temporary.
245     if (CGF.getContext().getLangOpts().ObjCAutoRefCount &&
246         E->getType()->isObjCLifetimeType() &&
247         (E->getType().getObjCLifetime() == Qualifiers::OCL_Strong ||
248          E->getType().getObjCLifetime() == Qualifiers::OCL_Weak ||
249          E->getType().getObjCLifetime() == Qualifiers::OCL_Autoreleasing))
250       ObjCARCReferenceLifetimeType = E->getType();
251 
252     E = M->GetTemporaryExpr();
253   }
254 
255   if (const CXXDefaultArgExpr *DAE = dyn_cast<CXXDefaultArgExpr>(E))
256     E = DAE->getExpr();
257 
258   if (const ExprWithCleanups *EWC = dyn_cast<ExprWithCleanups>(E)) {
259     CGF.enterFullExpression(EWC);
260     CodeGenFunction::RunCleanupsScope Scope(CGF);
261 
262     return EmitExprForReferenceBinding(CGF, EWC->getSubExpr(),
263                                        ReferenceTemporary,
264                                        ReferenceTemporaryDtor,
265                                        ObjCARCReferenceLifetimeType,
266                                        InitializedDecl);
267   }
268 
269   RValue RV;
270   if (E->isGLValue()) {
271     // Emit the expression as an lvalue.
272     LValue LV = CGF.EmitLValue(E);
273 
274     if (LV.isSimple())
275       return LV.getAddress();
276 
277     // We have to load the lvalue.
278     RV = CGF.EmitLoadOfLValue(LV);
279   } else {
280     if (!ObjCARCReferenceLifetimeType.isNull()) {
281       ReferenceTemporary = CreateReferenceTemporary(CGF,
282                                                   ObjCARCReferenceLifetimeType,
283                                                     InitializedDecl);
284 
285 
286       LValue RefTempDst = CGF.MakeAddrLValue(ReferenceTemporary,
287                                              ObjCARCReferenceLifetimeType);
288 
289       CGF.EmitScalarInit(E, dyn_cast_or_null<ValueDecl>(InitializedDecl),
290                          RefTempDst, false);
291 
292       bool ExtendsLifeOfTemporary = false;
293       if (const VarDecl *Var = dyn_cast_or_null<VarDecl>(InitializedDecl)) {
294         if (Var->extendsLifetimeOfTemporary())
295           ExtendsLifeOfTemporary = true;
296       } else if (InitializedDecl && isa<FieldDecl>(InitializedDecl)) {
297         ExtendsLifeOfTemporary = true;
298       }
299 
300       if (!ExtendsLifeOfTemporary) {
301         // Since the lifetime of this temporary isn't going to be extended,
302         // we need to clean it up ourselves at the end of the full expression.
303         switch (ObjCARCReferenceLifetimeType.getObjCLifetime()) {
304         case Qualifiers::OCL_None:
305         case Qualifiers::OCL_ExplicitNone:
306         case Qualifiers::OCL_Autoreleasing:
307           break;
308 
309         case Qualifiers::OCL_Strong: {
310           assert(!ObjCARCReferenceLifetimeType->isArrayType());
311           CleanupKind cleanupKind = CGF.getARCCleanupKind();
312           CGF.pushDestroy(cleanupKind,
313                           ReferenceTemporary,
314                           ObjCARCReferenceLifetimeType,
315                           CodeGenFunction::destroyARCStrongImprecise,
316                           cleanupKind & EHCleanup);
317           break;
318         }
319 
320         case Qualifiers::OCL_Weak:
321           assert(!ObjCARCReferenceLifetimeType->isArrayType());
322           CGF.pushDestroy(NormalAndEHCleanup,
323                           ReferenceTemporary,
324                           ObjCARCReferenceLifetimeType,
325                           CodeGenFunction::destroyARCWeak,
326                           /*useEHCleanupForArray*/ true);
327           break;
328         }
329 
330         ObjCARCReferenceLifetimeType = QualType();
331       }
332 
333       return ReferenceTemporary;
334     }
335 
336     SmallVector<SubobjectAdjustment, 2> Adjustments;
337     while (true) {
338       E = E->IgnoreParens();
339 
340       if (const CastExpr *CE = dyn_cast<CastExpr>(E)) {
341         if ((CE->getCastKind() == CK_DerivedToBase ||
342              CE->getCastKind() == CK_UncheckedDerivedToBase) &&
343             E->getType()->isRecordType()) {
344           E = CE->getSubExpr();
345           CXXRecordDecl *Derived
346             = cast<CXXRecordDecl>(E->getType()->getAs<RecordType>()->getDecl());
347           Adjustments.push_back(SubobjectAdjustment(CE, Derived));
348           continue;
349         }
350 
351         if (CE->getCastKind() == CK_NoOp) {
352           E = CE->getSubExpr();
353           continue;
354         }
355       } else if (const MemberExpr *ME = dyn_cast<MemberExpr>(E)) {
356         if (!ME->isArrow() && ME->getBase()->isRValue()) {
357           assert(ME->getBase()->getType()->isRecordType());
358           if (FieldDecl *Field = dyn_cast<FieldDecl>(ME->getMemberDecl())) {
359             E = ME->getBase();
360             Adjustments.push_back(SubobjectAdjustment(Field));
361             continue;
362           }
363         }
364       } else if (const BinaryOperator *BO = dyn_cast<BinaryOperator>(E)) {
365         if (BO->isPtrMemOp()) {
366           assert(BO->getLHS()->isRValue());
367           E = BO->getLHS();
368           const MemberPointerType *MPT =
369               BO->getRHS()->getType()->getAs<MemberPointerType>();
370           llvm::Value *Ptr = CGF.EmitScalarExpr(BO->getRHS());
371           Adjustments.push_back(SubobjectAdjustment(MPT, Ptr));
372         }
373       }
374 
375       if (const OpaqueValueExpr *opaque = dyn_cast<OpaqueValueExpr>(E))
376         if (opaque->getType()->isRecordType())
377           return CGF.EmitOpaqueValueLValue(opaque).getAddress();
378 
379       // Nothing changed.
380       break;
381     }
382 
383     // Create a reference temporary if necessary.
384     AggValueSlot AggSlot = AggValueSlot::ignored();
385     if (CGF.hasAggregateLLVMType(E->getType()) &&
386         !E->getType()->isAnyComplexType()) {
387       ReferenceTemporary = CreateReferenceTemporary(CGF, E->getType(),
388                                                     InitializedDecl);
389       CharUnits Alignment = CGF.getContext().getTypeAlignInChars(E->getType());
390       AggValueSlot::IsDestructed_t isDestructed
391         = AggValueSlot::IsDestructed_t(InitializedDecl != 0);
392       AggSlot = AggValueSlot::forAddr(ReferenceTemporary, Alignment,
393                                       Qualifiers(), isDestructed,
394                                       AggValueSlot::DoesNotNeedGCBarriers,
395                                       AggValueSlot::IsNotAliased);
396     }
397 
398     if (InitializedDecl) {
399       // Get the destructor for the reference temporary.
400       if (const RecordType *RT = E->getType()->getAs<RecordType>()) {
401         CXXRecordDecl *ClassDecl = cast<CXXRecordDecl>(RT->getDecl());
402         if (!ClassDecl->hasTrivialDestructor())
403           ReferenceTemporaryDtor = ClassDecl->getDestructor();
404       }
405     }
406 
407     RV = CGF.EmitAnyExpr(E, AggSlot);
408 
409     // Check if need to perform derived-to-base casts and/or field accesses, to
410     // get from the temporary object we created (and, potentially, for which we
411     // extended the lifetime) to the subobject we're binding the reference to.
412     if (!Adjustments.empty()) {
413       llvm::Value *Object = RV.getAggregateAddr();
414       for (unsigned I = Adjustments.size(); I != 0; --I) {
415         SubobjectAdjustment &Adjustment = Adjustments[I-1];
416         switch (Adjustment.Kind) {
417         case SubobjectAdjustment::DerivedToBaseAdjustment:
418           Object =
419               CGF.GetAddressOfBaseClass(Object,
420                                         Adjustment.DerivedToBase.DerivedClass,
421                               Adjustment.DerivedToBase.BasePath->path_begin(),
422                               Adjustment.DerivedToBase.BasePath->path_end(),
423                                         /*NullCheckValue=*/false);
424           break;
425 
426         case SubobjectAdjustment::FieldAdjustment: {
427           LValue LV = CGF.MakeAddrLValue(Object, E->getType());
428           LV = CGF.EmitLValueForField(LV, Adjustment.Field);
429           if (LV.isSimple()) {
430             Object = LV.getAddress();
431             break;
432           }
433 
434           // For non-simple lvalues, we actually have to create a copy of
435           // the object we're binding to.
436           QualType T = Adjustment.Field->getType().getNonReferenceType()
437                                                   .getUnqualifiedType();
438           Object = CreateReferenceTemporary(CGF, T, InitializedDecl);
439           LValue TempLV = CGF.MakeAddrLValue(Object,
440                                              Adjustment.Field->getType());
441           CGF.EmitStoreThroughLValue(CGF.EmitLoadOfLValue(LV), TempLV);
442           break;
443         }
444 
445         case SubobjectAdjustment::MemberPointerAdjustment: {
446           Object = CGF.CGM.getCXXABI().EmitMemberDataPointerAddress(
447                         CGF, Object, Adjustment.Ptr.Ptr, Adjustment.Ptr.MPT);
448           break;
449         }
450         }
451       }
452 
453       return Object;
454     }
455   }
456 
457   if (RV.isAggregate())
458     return RV.getAggregateAddr();
459 
460   // Create a temporary variable that we can bind the reference to.
461   ReferenceTemporary = CreateReferenceTemporary(CGF, E->getType(),
462                                                 InitializedDecl);
463 
464 
465   unsigned Alignment =
466     CGF.getContext().getTypeAlignInChars(E->getType()).getQuantity();
467   if (RV.isScalar())
468     CGF.EmitStoreOfScalar(RV.getScalarVal(), ReferenceTemporary,
469                           /*Volatile=*/false, Alignment, E->getType());
470   else
471     CGF.StoreComplexToAddr(RV.getComplexVal(), ReferenceTemporary,
472                            /*Volatile=*/false);
473   return ReferenceTemporary;
474 }
475 
476 RValue
477 CodeGenFunction::EmitReferenceBindingToExpr(const Expr *E,
478                                             const NamedDecl *InitializedDecl) {
479   llvm::Value *ReferenceTemporary = 0;
480   const CXXDestructorDecl *ReferenceTemporaryDtor = 0;
481   QualType ObjCARCReferenceLifetimeType;
482   llvm::Value *Value = EmitExprForReferenceBinding(*this, E, ReferenceTemporary,
483                                                    ReferenceTemporaryDtor,
484                                                    ObjCARCReferenceLifetimeType,
485                                                    InitializedDecl);
486   if (!ReferenceTemporaryDtor && ObjCARCReferenceLifetimeType.isNull())
487     return RValue::get(Value);
488 
489   // Make sure to call the destructor for the reference temporary.
490   const VarDecl *VD = dyn_cast_or_null<VarDecl>(InitializedDecl);
491   if (VD && VD->hasGlobalStorage()) {
492     if (ReferenceTemporaryDtor) {
493       llvm::Constant *DtorFn =
494         CGM.GetAddrOfCXXDestructor(ReferenceTemporaryDtor, Dtor_Complete);
495       CGM.getCXXABI().registerGlobalDtor(*this, DtorFn,
496                                     cast<llvm::Constant>(ReferenceTemporary));
497     } else {
498       assert(!ObjCARCReferenceLifetimeType.isNull());
499       // Note: We intentionally do not register a global "destructor" to
500       // release the object.
501     }
502 
503     return RValue::get(Value);
504   }
505 
506   if (ReferenceTemporaryDtor)
507     PushDestructorCleanup(ReferenceTemporaryDtor, ReferenceTemporary);
508   else {
509     switch (ObjCARCReferenceLifetimeType.getObjCLifetime()) {
510     case Qualifiers::OCL_None:
511       llvm_unreachable(
512                       "Not a reference temporary that needs to be deallocated");
513     case Qualifiers::OCL_ExplicitNone:
514     case Qualifiers::OCL_Autoreleasing:
515       // Nothing to do.
516       break;
517 
518     case Qualifiers::OCL_Strong: {
519       bool precise = VD && VD->hasAttr<ObjCPreciseLifetimeAttr>();
520       CleanupKind cleanupKind = getARCCleanupKind();
521       pushDestroy(cleanupKind, ReferenceTemporary, ObjCARCReferenceLifetimeType,
522                   precise ? destroyARCStrongPrecise : destroyARCStrongImprecise,
523                   cleanupKind & EHCleanup);
524       break;
525     }
526 
527     case Qualifiers::OCL_Weak: {
528       // __weak objects always get EH cleanups; otherwise, exceptions
529       // could cause really nasty crashes instead of mere leaks.
530       pushDestroy(NormalAndEHCleanup, ReferenceTemporary,
531                   ObjCARCReferenceLifetimeType, destroyARCWeak, true);
532       break;
533     }
534     }
535   }
536 
537   return RValue::get(Value);
538 }
539 
540 
541 /// getAccessedFieldNo - Given an encoded value and a result number, return the
542 /// input field number being accessed.
543 unsigned CodeGenFunction::getAccessedFieldNo(unsigned Idx,
544                                              const llvm::Constant *Elts) {
545   return cast<llvm::ConstantInt>(Elts->getAggregateElement(Idx))
546       ->getZExtValue();
547 }
548 
549 void CodeGenFunction::EmitCheck(llvm::Value *Address, unsigned Size) {
550   if (!CatchUndefined)
551     return;
552 
553   // This needs to be to the standard address space.
554   Address = Builder.CreateBitCast(Address, Int8PtrTy);
555 
556   llvm::Value *F = CGM.getIntrinsic(llvm::Intrinsic::objectsize, IntPtrTy);
557 
558   llvm::Value *Min = Builder.getFalse();
559   llvm::Value *C = Builder.CreateCall2(F, Address, Min);
560   llvm::BasicBlock *Cont = createBasicBlock();
561   Builder.CreateCondBr(Builder.CreateICmpUGE(C,
562                                         llvm::ConstantInt::get(IntPtrTy, Size)),
563                        Cont, getTrapBB());
564   EmitBlock(Cont);
565 }
566 
567 
568 CodeGenFunction::ComplexPairTy CodeGenFunction::
569 EmitComplexPrePostIncDec(const UnaryOperator *E, LValue LV,
570                          bool isInc, bool isPre) {
571   ComplexPairTy InVal = LoadComplexFromAddr(LV.getAddress(),
572                                             LV.isVolatileQualified());
573 
574   llvm::Value *NextVal;
575   if (isa<llvm::IntegerType>(InVal.first->getType())) {
576     uint64_t AmountVal = isInc ? 1 : -1;
577     NextVal = llvm::ConstantInt::get(InVal.first->getType(), AmountVal, true);
578 
579     // Add the inc/dec to the real part.
580     NextVal = Builder.CreateAdd(InVal.first, NextVal, isInc ? "inc" : "dec");
581   } else {
582     QualType ElemTy = E->getType()->getAs<ComplexType>()->getElementType();
583     llvm::APFloat FVal(getContext().getFloatTypeSemantics(ElemTy), 1);
584     if (!isInc)
585       FVal.changeSign();
586     NextVal = llvm::ConstantFP::get(getLLVMContext(), FVal);
587 
588     // Add the inc/dec to the real part.
589     NextVal = Builder.CreateFAdd(InVal.first, NextVal, isInc ? "inc" : "dec");
590   }
591 
592   ComplexPairTy IncVal(NextVal, InVal.second);
593 
594   // Store the updated result through the lvalue.
595   StoreComplexToAddr(IncVal, LV.getAddress(), LV.isVolatileQualified());
596 
597   // If this is a postinc, return the value read from memory, otherwise use the
598   // updated value.
599   return isPre ? IncVal : InVal;
600 }
601 
602 
603 //===----------------------------------------------------------------------===//
604 //                         LValue Expression Emission
605 //===----------------------------------------------------------------------===//
606 
607 RValue CodeGenFunction::GetUndefRValue(QualType Ty) {
608   if (Ty->isVoidType())
609     return RValue::get(0);
610 
611   if (const ComplexType *CTy = Ty->getAs<ComplexType>()) {
612     llvm::Type *EltTy = ConvertType(CTy->getElementType());
613     llvm::Value *U = llvm::UndefValue::get(EltTy);
614     return RValue::getComplex(std::make_pair(U, U));
615   }
616 
617   // If this is a use of an undefined aggregate type, the aggregate must have an
618   // identifiable address.  Just because the contents of the value are undefined
619   // doesn't mean that the address can't be taken and compared.
620   if (hasAggregateLLVMType(Ty)) {
621     llvm::Value *DestPtr = CreateMemTemp(Ty, "undef.agg.tmp");
622     return RValue::getAggregate(DestPtr);
623   }
624 
625   return RValue::get(llvm::UndefValue::get(ConvertType(Ty)));
626 }
627 
628 RValue CodeGenFunction::EmitUnsupportedRValue(const Expr *E,
629                                               const char *Name) {
630   ErrorUnsupported(E, Name);
631   return GetUndefRValue(E->getType());
632 }
633 
634 LValue CodeGenFunction::EmitUnsupportedLValue(const Expr *E,
635                                               const char *Name) {
636   ErrorUnsupported(E, Name);
637   llvm::Type *Ty = llvm::PointerType::getUnqual(ConvertType(E->getType()));
638   return MakeAddrLValue(llvm::UndefValue::get(Ty), E->getType());
639 }
640 
641 LValue CodeGenFunction::EmitCheckedLValue(const Expr *E) {
642   LValue LV = EmitLValue(E);
643   if (!isa<DeclRefExpr>(E) && !LV.isBitField() && LV.isSimple())
644     EmitCheck(LV.getAddress(),
645               getContext().getTypeSizeInChars(E->getType()).getQuantity());
646   return LV;
647 }
648 
649 /// EmitLValue - Emit code to compute a designator that specifies the location
650 /// of the expression.
651 ///
652 /// This can return one of two things: a simple address or a bitfield reference.
653 /// In either case, the LLVM Value* in the LValue structure is guaranteed to be
654 /// an LLVM pointer type.
655 ///
656 /// If this returns a bitfield reference, nothing about the pointee type of the
657 /// LLVM value is known: For example, it may not be a pointer to an integer.
658 ///
659 /// If this returns a normal address, and if the lvalue's C type is fixed size,
660 /// this method guarantees that the returned pointer type will point to an LLVM
661 /// type of the same size of the lvalue's type.  If the lvalue has a variable
662 /// length type, this is not possible.
663 ///
664 LValue CodeGenFunction::EmitLValue(const Expr *E) {
665   switch (E->getStmtClass()) {
666   default: return EmitUnsupportedLValue(E, "l-value expression");
667 
668   case Expr::ObjCPropertyRefExprClass:
669     llvm_unreachable("cannot emit a property reference directly");
670 
671   case Expr::ObjCSelectorExprClass:
672   return EmitObjCSelectorLValue(cast<ObjCSelectorExpr>(E));
673   case Expr::ObjCIsaExprClass:
674     return EmitObjCIsaExpr(cast<ObjCIsaExpr>(E));
675   case Expr::BinaryOperatorClass:
676     return EmitBinaryOperatorLValue(cast<BinaryOperator>(E));
677   case Expr::CompoundAssignOperatorClass:
678     if (!E->getType()->isAnyComplexType())
679       return EmitCompoundAssignmentLValue(cast<CompoundAssignOperator>(E));
680     return EmitComplexCompoundAssignmentLValue(cast<CompoundAssignOperator>(E));
681   case Expr::CallExprClass:
682   case Expr::CXXMemberCallExprClass:
683   case Expr::CXXOperatorCallExprClass:
684   case Expr::UserDefinedLiteralClass:
685     return EmitCallExprLValue(cast<CallExpr>(E));
686   case Expr::VAArgExprClass:
687     return EmitVAArgExprLValue(cast<VAArgExpr>(E));
688   case Expr::DeclRefExprClass:
689     return EmitDeclRefLValue(cast<DeclRefExpr>(E));
690   case Expr::ParenExprClass:
691     return EmitLValue(cast<ParenExpr>(E)->getSubExpr());
692   case Expr::GenericSelectionExprClass:
693     return EmitLValue(cast<GenericSelectionExpr>(E)->getResultExpr());
694   case Expr::PredefinedExprClass:
695     return EmitPredefinedLValue(cast<PredefinedExpr>(E));
696   case Expr::StringLiteralClass:
697     return EmitStringLiteralLValue(cast<StringLiteral>(E));
698   case Expr::ObjCEncodeExprClass:
699     return EmitObjCEncodeExprLValue(cast<ObjCEncodeExpr>(E));
700   case Expr::PseudoObjectExprClass:
701     return EmitPseudoObjectLValue(cast<PseudoObjectExpr>(E));
702   case Expr::InitListExprClass:
703     return EmitInitListLValue(cast<InitListExpr>(E));
704   case Expr::CXXTemporaryObjectExprClass:
705   case Expr::CXXConstructExprClass:
706     return EmitCXXConstructLValue(cast<CXXConstructExpr>(E));
707   case Expr::CXXBindTemporaryExprClass:
708     return EmitCXXBindTemporaryLValue(cast<CXXBindTemporaryExpr>(E));
709   case Expr::LambdaExprClass:
710     return EmitLambdaLValue(cast<LambdaExpr>(E));
711 
712   case Expr::ExprWithCleanupsClass: {
713     const ExprWithCleanups *cleanups = cast<ExprWithCleanups>(E);
714     enterFullExpression(cleanups);
715     RunCleanupsScope Scope(*this);
716     return EmitLValue(cleanups->getSubExpr());
717   }
718 
719   case Expr::CXXScalarValueInitExprClass:
720     return EmitNullInitializationLValue(cast<CXXScalarValueInitExpr>(E));
721   case Expr::CXXDefaultArgExprClass:
722     return EmitLValue(cast<CXXDefaultArgExpr>(E)->getExpr());
723   case Expr::CXXTypeidExprClass:
724     return EmitCXXTypeidLValue(cast<CXXTypeidExpr>(E));
725 
726   case Expr::ObjCMessageExprClass:
727     return EmitObjCMessageExprLValue(cast<ObjCMessageExpr>(E));
728   case Expr::ObjCIvarRefExprClass:
729     return EmitObjCIvarRefLValue(cast<ObjCIvarRefExpr>(E));
730   case Expr::StmtExprClass:
731     return EmitStmtExprLValue(cast<StmtExpr>(E));
732   case Expr::UnaryOperatorClass:
733     return EmitUnaryOpLValue(cast<UnaryOperator>(E));
734   case Expr::ArraySubscriptExprClass:
735     return EmitArraySubscriptExpr(cast<ArraySubscriptExpr>(E));
736   case Expr::ExtVectorElementExprClass:
737     return EmitExtVectorElementExpr(cast<ExtVectorElementExpr>(E));
738   case Expr::MemberExprClass:
739     return EmitMemberExpr(cast<MemberExpr>(E));
740   case Expr::CompoundLiteralExprClass:
741     return EmitCompoundLiteralLValue(cast<CompoundLiteralExpr>(E));
742   case Expr::ConditionalOperatorClass:
743     return EmitConditionalOperatorLValue(cast<ConditionalOperator>(E));
744   case Expr::BinaryConditionalOperatorClass:
745     return EmitConditionalOperatorLValue(cast<BinaryConditionalOperator>(E));
746   case Expr::ChooseExprClass:
747     return EmitLValue(cast<ChooseExpr>(E)->getChosenSubExpr(getContext()));
748   case Expr::OpaqueValueExprClass:
749     return EmitOpaqueValueLValue(cast<OpaqueValueExpr>(E));
750   case Expr::SubstNonTypeTemplateParmExprClass:
751     return EmitLValue(cast<SubstNonTypeTemplateParmExpr>(E)->getReplacement());
752   case Expr::ImplicitCastExprClass:
753   case Expr::CStyleCastExprClass:
754   case Expr::CXXFunctionalCastExprClass:
755   case Expr::CXXStaticCastExprClass:
756   case Expr::CXXDynamicCastExprClass:
757   case Expr::CXXReinterpretCastExprClass:
758   case Expr::CXXConstCastExprClass:
759   case Expr::ObjCBridgedCastExprClass:
760     return EmitCastLValue(cast<CastExpr>(E));
761 
762   case Expr::MaterializeTemporaryExprClass:
763     return EmitMaterializeTemporaryExpr(cast<MaterializeTemporaryExpr>(E));
764   }
765 }
766 
767 /// Given an object of the given canonical type, can we safely copy a
768 /// value out of it based on its initializer?
769 static bool isConstantEmittableObjectType(QualType type) {
770   assert(type.isCanonical());
771   assert(!type->isReferenceType());
772 
773   // Must be const-qualified but non-volatile.
774   Qualifiers qs = type.getLocalQualifiers();
775   if (!qs.hasConst() || qs.hasVolatile()) return false;
776 
777   // Otherwise, all object types satisfy this except C++ classes with
778   // mutable subobjects or non-trivial copy/destroy behavior.
779   if (const RecordType *RT = dyn_cast<RecordType>(type))
780     if (const CXXRecordDecl *RD = dyn_cast<CXXRecordDecl>(RT->getDecl()))
781       if (RD->hasMutableFields() || !RD->isTrivial())
782         return false;
783 
784   return true;
785 }
786 
787 /// Can we constant-emit a load of a reference to a variable of the
788 /// given type?  This is different from predicates like
789 /// Decl::isUsableInConstantExpressions because we do want it to apply
790 /// in situations that don't necessarily satisfy the language's rules
791 /// for this (e.g. C++'s ODR-use rules).  For example, we want to able
792 /// to do this with const float variables even if those variables
793 /// aren't marked 'constexpr'.
794 enum ConstantEmissionKind {
795   CEK_None,
796   CEK_AsReferenceOnly,
797   CEK_AsValueOrReference,
798   CEK_AsValueOnly
799 };
800 static ConstantEmissionKind checkVarTypeForConstantEmission(QualType type) {
801   type = type.getCanonicalType();
802   if (const ReferenceType *ref = dyn_cast<ReferenceType>(type)) {
803     if (isConstantEmittableObjectType(ref->getPointeeType()))
804       return CEK_AsValueOrReference;
805     return CEK_AsReferenceOnly;
806   }
807   if (isConstantEmittableObjectType(type))
808     return CEK_AsValueOnly;
809   return CEK_None;
810 }
811 
812 /// Try to emit a reference to the given value without producing it as
813 /// an l-value.  This is actually more than an optimization: we can't
814 /// produce an l-value for variables that we never actually captured
815 /// in a block or lambda, which means const int variables or constexpr
816 /// literals or similar.
817 CodeGenFunction::ConstantEmission
818 CodeGenFunction::tryEmitAsConstant(DeclRefExpr *refExpr) {
819   ValueDecl *value = refExpr->getDecl();
820 
821   // The value needs to be an enum constant or a constant variable.
822   ConstantEmissionKind CEK;
823   if (isa<ParmVarDecl>(value)) {
824     CEK = CEK_None;
825   } else if (VarDecl *var = dyn_cast<VarDecl>(value)) {
826     CEK = checkVarTypeForConstantEmission(var->getType());
827   } else if (isa<EnumConstantDecl>(value)) {
828     CEK = CEK_AsValueOnly;
829   } else {
830     CEK = CEK_None;
831   }
832   if (CEK == CEK_None) return ConstantEmission();
833 
834   Expr::EvalResult result;
835   bool resultIsReference;
836   QualType resultType;
837 
838   // It's best to evaluate all the way as an r-value if that's permitted.
839   if (CEK != CEK_AsReferenceOnly &&
840       refExpr->EvaluateAsRValue(result, getContext())) {
841     resultIsReference = false;
842     resultType = refExpr->getType();
843 
844   // Otherwise, try to evaluate as an l-value.
845   } else if (CEK != CEK_AsValueOnly &&
846              refExpr->EvaluateAsLValue(result, getContext())) {
847     resultIsReference = true;
848     resultType = value->getType();
849 
850   // Failure.
851   } else {
852     return ConstantEmission();
853   }
854 
855   // In any case, if the initializer has side-effects, abandon ship.
856   if (result.HasSideEffects)
857     return ConstantEmission();
858 
859   // Emit as a constant.
860   llvm::Constant *C = CGM.EmitConstantValue(result.Val, resultType, this);
861 
862   // Make sure we emit a debug reference to the global variable.
863   // This should probably fire even for
864   if (isa<VarDecl>(value)) {
865     if (!getContext().DeclMustBeEmitted(cast<VarDecl>(value)))
866       EmitDeclRefExprDbgValue(refExpr, C);
867   } else {
868     assert(isa<EnumConstantDecl>(value));
869     EmitDeclRefExprDbgValue(refExpr, C);
870   }
871 
872   // If we emitted a reference constant, we need to dereference that.
873   if (resultIsReference)
874     return ConstantEmission::forReference(C);
875 
876   return ConstantEmission::forValue(C);
877 }
878 
879 llvm::Value *CodeGenFunction::EmitLoadOfScalar(LValue lvalue) {
880   return EmitLoadOfScalar(lvalue.getAddress(), lvalue.isVolatile(),
881                           lvalue.getAlignment().getQuantity(),
882                           lvalue.getType(), lvalue.getTBAAInfo());
883 }
884 
885 static bool hasBooleanRepresentation(QualType Ty) {
886   if (Ty->isBooleanType())
887     return true;
888 
889   if (const EnumType *ET = Ty->getAs<EnumType>())
890     return ET->getDecl()->getIntegerType()->isBooleanType();
891 
892   if (const AtomicType *AT = Ty->getAs<AtomicType>())
893     return hasBooleanRepresentation(AT->getValueType());
894 
895   return false;
896 }
897 
898 llvm::MDNode *CodeGenFunction::getRangeForLoadFromType(QualType Ty) {
899   const EnumType *ET = Ty->getAs<EnumType>();
900   bool IsRegularCPlusPlusEnum = (getLangOpts().CPlusPlus && ET &&
901                                  CGM.getCodeGenOpts().StrictEnums &&
902                                  !ET->getDecl()->isFixed());
903   bool IsBool = hasBooleanRepresentation(Ty);
904   if (!IsBool && !IsRegularCPlusPlusEnum)
905     return NULL;
906 
907   llvm::APInt Min;
908   llvm::APInt End;
909   if (IsBool) {
910     Min = llvm::APInt(8, 0);
911     End = llvm::APInt(8, 2);
912   } else {
913     const EnumDecl *ED = ET->getDecl();
914     llvm::Type *LTy = ConvertTypeForMem(ED->getIntegerType());
915     unsigned Bitwidth = LTy->getScalarSizeInBits();
916     unsigned NumNegativeBits = ED->getNumNegativeBits();
917     unsigned NumPositiveBits = ED->getNumPositiveBits();
918 
919     if (NumNegativeBits) {
920       unsigned NumBits = std::max(NumNegativeBits, NumPositiveBits + 1);
921       assert(NumBits <= Bitwidth);
922       End = llvm::APInt(Bitwidth, 1) << (NumBits - 1);
923       Min = -End;
924     } else {
925       assert(NumPositiveBits <= Bitwidth);
926       End = llvm::APInt(Bitwidth, 1) << NumPositiveBits;
927       Min = llvm::APInt(Bitwidth, 0);
928     }
929   }
930 
931   llvm::MDBuilder MDHelper(getLLVMContext());
932   return MDHelper.createRange(Min, End);
933 }
934 
935 llvm::Value *CodeGenFunction::EmitLoadOfScalar(llvm::Value *Addr, bool Volatile,
936                                               unsigned Alignment, QualType Ty,
937                                               llvm::MDNode *TBAAInfo) {
938   llvm::LoadInst *Load = Builder.CreateLoad(Addr);
939   if (Volatile)
940     Load->setVolatile(true);
941   if (Alignment)
942     Load->setAlignment(Alignment);
943   if (TBAAInfo)
944     CGM.DecorateInstruction(Load, TBAAInfo);
945   // If this is an atomic type, all normal reads must be atomic
946   if (Ty->isAtomicType())
947     Load->setAtomic(llvm::SequentiallyConsistent);
948 
949   if (CGM.getCodeGenOpts().OptimizationLevel > 0)
950     if (llvm::MDNode *RangeInfo = getRangeForLoadFromType(Ty))
951       Load->setMetadata(llvm::LLVMContext::MD_range, RangeInfo);
952 
953   return EmitFromMemory(Load, Ty);
954 }
955 
956 llvm::Value *CodeGenFunction::EmitToMemory(llvm::Value *Value, QualType Ty) {
957   // Bool has a different representation in memory than in registers.
958   if (hasBooleanRepresentation(Ty)) {
959     // This should really always be an i1, but sometimes it's already
960     // an i8, and it's awkward to track those cases down.
961     if (Value->getType()->isIntegerTy(1))
962       return Builder.CreateZExt(Value, Builder.getInt8Ty(), "frombool");
963     assert(Value->getType()->isIntegerTy(8) && "value rep of bool not i1/i8");
964   }
965 
966   return Value;
967 }
968 
969 llvm::Value *CodeGenFunction::EmitFromMemory(llvm::Value *Value, QualType Ty) {
970   // Bool has a different representation in memory than in registers.
971   if (hasBooleanRepresentation(Ty)) {
972     assert(Value->getType()->isIntegerTy(8) && "memory rep of bool not i8");
973     return Builder.CreateTrunc(Value, Builder.getInt1Ty(), "tobool");
974   }
975 
976   return Value;
977 }
978 
979 void CodeGenFunction::EmitStoreOfScalar(llvm::Value *Value, llvm::Value *Addr,
980                                         bool Volatile, unsigned Alignment,
981                                         QualType Ty,
982                                         llvm::MDNode *TBAAInfo,
983                                         bool isInit) {
984   Value = EmitToMemory(Value, Ty);
985 
986   llvm::StoreInst *Store = Builder.CreateStore(Value, Addr, Volatile);
987   if (Alignment)
988     Store->setAlignment(Alignment);
989   if (TBAAInfo)
990     CGM.DecorateInstruction(Store, TBAAInfo);
991   if (!isInit && Ty->isAtomicType())
992     Store->setAtomic(llvm::SequentiallyConsistent);
993 }
994 
995 void CodeGenFunction::EmitStoreOfScalar(llvm::Value *value, LValue lvalue,
996     bool isInit) {
997   EmitStoreOfScalar(value, lvalue.getAddress(), lvalue.isVolatile(),
998                     lvalue.getAlignment().getQuantity(), lvalue.getType(),
999                     lvalue.getTBAAInfo(), isInit);
1000 }
1001 
1002 /// EmitLoadOfLValue - Given an expression that represents a value lvalue, this
1003 /// method emits the address of the lvalue, then loads the result as an rvalue,
1004 /// returning the rvalue.
1005 RValue CodeGenFunction::EmitLoadOfLValue(LValue LV) {
1006   if (LV.isObjCWeak()) {
1007     // load of a __weak object.
1008     llvm::Value *AddrWeakObj = LV.getAddress();
1009     return RValue::get(CGM.getObjCRuntime().EmitObjCWeakRead(*this,
1010                                                              AddrWeakObj));
1011   }
1012   if (LV.getQuals().getObjCLifetime() == Qualifiers::OCL_Weak)
1013     return RValue::get(EmitARCLoadWeak(LV.getAddress()));
1014 
1015   if (LV.isSimple()) {
1016     assert(!LV.getType()->isFunctionType());
1017 
1018     // Everything needs a load.
1019     return RValue::get(EmitLoadOfScalar(LV));
1020   }
1021 
1022   if (LV.isVectorElt()) {
1023     llvm::LoadInst *Load = Builder.CreateLoad(LV.getVectorAddr(),
1024                                               LV.isVolatileQualified());
1025     Load->setAlignment(LV.getAlignment().getQuantity());
1026     return RValue::get(Builder.CreateExtractElement(Load, LV.getVectorIdx(),
1027                                                     "vecext"));
1028   }
1029 
1030   // If this is a reference to a subset of the elements of a vector, either
1031   // shuffle the input or extract/insert them as appropriate.
1032   if (LV.isExtVectorElt())
1033     return EmitLoadOfExtVectorElementLValue(LV);
1034 
1035   assert(LV.isBitField() && "Unknown LValue type!");
1036   return EmitLoadOfBitfieldLValue(LV);
1037 }
1038 
1039 RValue CodeGenFunction::EmitLoadOfBitfieldLValue(LValue LV) {
1040   const CGBitFieldInfo &Info = LV.getBitFieldInfo();
1041 
1042   // Get the output type.
1043   llvm::Type *ResLTy = ConvertType(LV.getType());
1044   unsigned ResSizeInBits = CGM.getTargetData().getTypeSizeInBits(ResLTy);
1045 
1046   // Compute the result as an OR of all of the individual component accesses.
1047   llvm::Value *Res = 0;
1048   for (unsigned i = 0, e = Info.getNumComponents(); i != e; ++i) {
1049     const CGBitFieldInfo::AccessInfo &AI = Info.getComponent(i);
1050     CharUnits AccessAlignment = AI.AccessAlignment;
1051     if (!LV.getAlignment().isZero())
1052       AccessAlignment = std::min(AccessAlignment, LV.getAlignment());
1053 
1054     // Get the field pointer.
1055     llvm::Value *Ptr = LV.getBitFieldBaseAddr();
1056 
1057     // Only offset by the field index if used, so that incoming values are not
1058     // required to be structures.
1059     if (AI.FieldIndex)
1060       Ptr = Builder.CreateStructGEP(Ptr, AI.FieldIndex, "bf.field");
1061 
1062     // Offset by the byte offset, if used.
1063     if (!AI.FieldByteOffset.isZero()) {
1064       Ptr = EmitCastToVoidPtr(Ptr);
1065       Ptr = Builder.CreateConstGEP1_32(Ptr, AI.FieldByteOffset.getQuantity(),
1066                                        "bf.field.offs");
1067     }
1068 
1069     // Cast to the access type.
1070     llvm::Type *PTy = llvm::Type::getIntNPtrTy(getLLVMContext(), AI.AccessWidth,
1071                        CGM.getContext().getTargetAddressSpace(LV.getType()));
1072     Ptr = Builder.CreateBitCast(Ptr, PTy);
1073 
1074     // Perform the load.
1075     llvm::LoadInst *Load = Builder.CreateLoad(Ptr, LV.isVolatileQualified());
1076     Load->setAlignment(AccessAlignment.getQuantity());
1077 
1078     // Shift out unused low bits and mask out unused high bits.
1079     llvm::Value *Val = Load;
1080     if (AI.FieldBitStart)
1081       Val = Builder.CreateLShr(Load, AI.FieldBitStart);
1082     Val = Builder.CreateAnd(Val, llvm::APInt::getLowBitsSet(AI.AccessWidth,
1083                                                             AI.TargetBitWidth),
1084                             "bf.clear");
1085 
1086     // Extend or truncate to the target size.
1087     if (AI.AccessWidth < ResSizeInBits)
1088       Val = Builder.CreateZExt(Val, ResLTy);
1089     else if (AI.AccessWidth > ResSizeInBits)
1090       Val = Builder.CreateTrunc(Val, ResLTy);
1091 
1092     // Shift into place, and OR into the result.
1093     if (AI.TargetBitOffset)
1094       Val = Builder.CreateShl(Val, AI.TargetBitOffset);
1095     Res = Res ? Builder.CreateOr(Res, Val) : Val;
1096   }
1097 
1098   // If the bit-field is signed, perform the sign-extension.
1099   //
1100   // FIXME: This can easily be folded into the load of the high bits, which
1101   // could also eliminate the mask of high bits in some situations.
1102   if (Info.isSigned()) {
1103     unsigned ExtraBits = ResSizeInBits - Info.getSize();
1104     if (ExtraBits)
1105       Res = Builder.CreateAShr(Builder.CreateShl(Res, ExtraBits),
1106                                ExtraBits, "bf.val.sext");
1107   }
1108 
1109   return RValue::get(Res);
1110 }
1111 
1112 // If this is a reference to a subset of the elements of a vector, create an
1113 // appropriate shufflevector.
1114 RValue CodeGenFunction::EmitLoadOfExtVectorElementLValue(LValue LV) {
1115   llvm::LoadInst *Load = Builder.CreateLoad(LV.getExtVectorAddr(),
1116                                             LV.isVolatileQualified());
1117   Load->setAlignment(LV.getAlignment().getQuantity());
1118   llvm::Value *Vec = Load;
1119 
1120   const llvm::Constant *Elts = LV.getExtVectorElts();
1121 
1122   // If the result of the expression is a non-vector type, we must be extracting
1123   // a single element.  Just codegen as an extractelement.
1124   const VectorType *ExprVT = LV.getType()->getAs<VectorType>();
1125   if (!ExprVT) {
1126     unsigned InIdx = getAccessedFieldNo(0, Elts);
1127     llvm::Value *Elt = llvm::ConstantInt::get(Int32Ty, InIdx);
1128     return RValue::get(Builder.CreateExtractElement(Vec, Elt));
1129   }
1130 
1131   // Always use shuffle vector to try to retain the original program structure
1132   unsigned NumResultElts = ExprVT->getNumElements();
1133 
1134   SmallVector<llvm::Constant*, 4> Mask;
1135   for (unsigned i = 0; i != NumResultElts; ++i)
1136     Mask.push_back(Builder.getInt32(getAccessedFieldNo(i, Elts)));
1137 
1138   llvm::Value *MaskV = llvm::ConstantVector::get(Mask);
1139   Vec = Builder.CreateShuffleVector(Vec, llvm::UndefValue::get(Vec->getType()),
1140                                     MaskV);
1141   return RValue::get(Vec);
1142 }
1143 
1144 
1145 
1146 /// EmitStoreThroughLValue - Store the specified rvalue into the specified
1147 /// lvalue, where both are guaranteed to the have the same type, and that type
1148 /// is 'Ty'.
1149 void CodeGenFunction::EmitStoreThroughLValue(RValue Src, LValue Dst, bool isInit) {
1150   if (!Dst.isSimple()) {
1151     if (Dst.isVectorElt()) {
1152       // Read/modify/write the vector, inserting the new element.
1153       llvm::LoadInst *Load = Builder.CreateLoad(Dst.getVectorAddr(),
1154                                                 Dst.isVolatileQualified());
1155       Load->setAlignment(Dst.getAlignment().getQuantity());
1156       llvm::Value *Vec = Load;
1157       Vec = Builder.CreateInsertElement(Vec, Src.getScalarVal(),
1158                                         Dst.getVectorIdx(), "vecins");
1159       llvm::StoreInst *Store = Builder.CreateStore(Vec, Dst.getVectorAddr(),
1160                                                    Dst.isVolatileQualified());
1161       Store->setAlignment(Dst.getAlignment().getQuantity());
1162       return;
1163     }
1164 
1165     // If this is an update of extended vector elements, insert them as
1166     // appropriate.
1167     if (Dst.isExtVectorElt())
1168       return EmitStoreThroughExtVectorComponentLValue(Src, Dst);
1169 
1170     assert(Dst.isBitField() && "Unknown LValue type");
1171     return EmitStoreThroughBitfieldLValue(Src, Dst);
1172   }
1173 
1174   // There's special magic for assigning into an ARC-qualified l-value.
1175   if (Qualifiers::ObjCLifetime Lifetime = Dst.getQuals().getObjCLifetime()) {
1176     switch (Lifetime) {
1177     case Qualifiers::OCL_None:
1178       llvm_unreachable("present but none");
1179 
1180     case Qualifiers::OCL_ExplicitNone:
1181       // nothing special
1182       break;
1183 
1184     case Qualifiers::OCL_Strong:
1185       EmitARCStoreStrong(Dst, Src.getScalarVal(), /*ignore*/ true);
1186       return;
1187 
1188     case Qualifiers::OCL_Weak:
1189       EmitARCStoreWeak(Dst.getAddress(), Src.getScalarVal(), /*ignore*/ true);
1190       return;
1191 
1192     case Qualifiers::OCL_Autoreleasing:
1193       Src = RValue::get(EmitObjCExtendObjectLifetime(Dst.getType(),
1194                                                      Src.getScalarVal()));
1195       // fall into the normal path
1196       break;
1197     }
1198   }
1199 
1200   if (Dst.isObjCWeak() && !Dst.isNonGC()) {
1201     // load of a __weak object.
1202     llvm::Value *LvalueDst = Dst.getAddress();
1203     llvm::Value *src = Src.getScalarVal();
1204      CGM.getObjCRuntime().EmitObjCWeakAssign(*this, src, LvalueDst);
1205     return;
1206   }
1207 
1208   if (Dst.isObjCStrong() && !Dst.isNonGC()) {
1209     // load of a __strong object.
1210     llvm::Value *LvalueDst = Dst.getAddress();
1211     llvm::Value *src = Src.getScalarVal();
1212     if (Dst.isObjCIvar()) {
1213       assert(Dst.getBaseIvarExp() && "BaseIvarExp is NULL");
1214       llvm::Type *ResultType = ConvertType(getContext().LongTy);
1215       llvm::Value *RHS = EmitScalarExpr(Dst.getBaseIvarExp());
1216       llvm::Value *dst = RHS;
1217       RHS = Builder.CreatePtrToInt(RHS, ResultType, "sub.ptr.rhs.cast");
1218       llvm::Value *LHS =
1219         Builder.CreatePtrToInt(LvalueDst, ResultType, "sub.ptr.lhs.cast");
1220       llvm::Value *BytesBetween = Builder.CreateSub(LHS, RHS, "ivar.offset");
1221       CGM.getObjCRuntime().EmitObjCIvarAssign(*this, src, dst,
1222                                               BytesBetween);
1223     } else if (Dst.isGlobalObjCRef()) {
1224       CGM.getObjCRuntime().EmitObjCGlobalAssign(*this, src, LvalueDst,
1225                                                 Dst.isThreadLocalRef());
1226     }
1227     else
1228       CGM.getObjCRuntime().EmitObjCStrongCastAssign(*this, src, LvalueDst);
1229     return;
1230   }
1231 
1232   assert(Src.isScalar() && "Can't emit an agg store with this method");
1233   EmitStoreOfScalar(Src.getScalarVal(), Dst, isInit);
1234 }
1235 
1236 void CodeGenFunction::EmitStoreThroughBitfieldLValue(RValue Src, LValue Dst,
1237                                                      llvm::Value **Result) {
1238   const CGBitFieldInfo &Info = Dst.getBitFieldInfo();
1239 
1240   // Get the output type.
1241   llvm::Type *ResLTy = ConvertTypeForMem(Dst.getType());
1242   unsigned ResSizeInBits = CGM.getTargetData().getTypeSizeInBits(ResLTy);
1243 
1244   // Get the source value, truncated to the width of the bit-field.
1245   llvm::Value *SrcVal = Src.getScalarVal();
1246 
1247   if (hasBooleanRepresentation(Dst.getType()))
1248     SrcVal = Builder.CreateIntCast(SrcVal, ResLTy, /*IsSigned=*/false);
1249 
1250   SrcVal = Builder.CreateAnd(SrcVal, llvm::APInt::getLowBitsSet(ResSizeInBits,
1251                                                                 Info.getSize()),
1252                              "bf.value");
1253 
1254   // Return the new value of the bit-field, if requested.
1255   if (Result) {
1256     // Cast back to the proper type for result.
1257     llvm::Type *SrcTy = Src.getScalarVal()->getType();
1258     llvm::Value *ReloadVal = Builder.CreateIntCast(SrcVal, SrcTy, false,
1259                                                    "bf.reload.val");
1260 
1261     // Sign extend if necessary.
1262     if (Info.isSigned()) {
1263       unsigned ExtraBits = ResSizeInBits - Info.getSize();
1264       if (ExtraBits)
1265         ReloadVal = Builder.CreateAShr(Builder.CreateShl(ReloadVal, ExtraBits),
1266                                        ExtraBits, "bf.reload.sext");
1267     }
1268 
1269     *Result = ReloadVal;
1270   }
1271 
1272   // Iterate over the components, writing each piece to memory.
1273   for (unsigned i = 0, e = Info.getNumComponents(); i != e; ++i) {
1274     const CGBitFieldInfo::AccessInfo &AI = Info.getComponent(i);
1275     CharUnits AccessAlignment = AI.AccessAlignment;
1276     if (!Dst.getAlignment().isZero())
1277       AccessAlignment = std::min(AccessAlignment, Dst.getAlignment());
1278 
1279     // Get the field pointer.
1280     llvm::Value *Ptr = Dst.getBitFieldBaseAddr();
1281     unsigned addressSpace =
1282       cast<llvm::PointerType>(Ptr->getType())->getAddressSpace();
1283 
1284     // Only offset by the field index if used, so that incoming values are not
1285     // required to be structures.
1286     if (AI.FieldIndex)
1287       Ptr = Builder.CreateStructGEP(Ptr, AI.FieldIndex, "bf.field");
1288 
1289     // Offset by the byte offset, if used.
1290     if (!AI.FieldByteOffset.isZero()) {
1291       Ptr = EmitCastToVoidPtr(Ptr);
1292       Ptr = Builder.CreateConstGEP1_32(Ptr, AI.FieldByteOffset.getQuantity(),
1293                                        "bf.field.offs");
1294     }
1295 
1296     // Cast to the access type.
1297     llvm::Type *AccessLTy =
1298       llvm::Type::getIntNTy(getLLVMContext(), AI.AccessWidth);
1299 
1300     llvm::Type *PTy = AccessLTy->getPointerTo(addressSpace);
1301     Ptr = Builder.CreateBitCast(Ptr, PTy);
1302 
1303     // Extract the piece of the bit-field value to write in this access, limited
1304     // to the values that are part of this access.
1305     llvm::Value *Val = SrcVal;
1306     if (AI.TargetBitOffset)
1307       Val = Builder.CreateLShr(Val, AI.TargetBitOffset);
1308     Val = Builder.CreateAnd(Val, llvm::APInt::getLowBitsSet(ResSizeInBits,
1309                                                             AI.TargetBitWidth));
1310 
1311     // Extend or truncate to the access size.
1312     if (ResSizeInBits < AI.AccessWidth)
1313       Val = Builder.CreateZExt(Val, AccessLTy);
1314     else if (ResSizeInBits > AI.AccessWidth)
1315       Val = Builder.CreateTrunc(Val, AccessLTy);
1316 
1317     // Shift into the position in memory.
1318     if (AI.FieldBitStart)
1319       Val = Builder.CreateShl(Val, AI.FieldBitStart);
1320 
1321     // If necessary, load and OR in bits that are outside of the bit-field.
1322     if (AI.TargetBitWidth != AI.AccessWidth) {
1323       llvm::LoadInst *Load = Builder.CreateLoad(Ptr, Dst.isVolatileQualified());
1324       Load->setAlignment(AccessAlignment.getQuantity());
1325 
1326       // Compute the mask for zeroing the bits that are part of the bit-field.
1327       llvm::APInt InvMask =
1328         ~llvm::APInt::getBitsSet(AI.AccessWidth, AI.FieldBitStart,
1329                                  AI.FieldBitStart + AI.TargetBitWidth);
1330 
1331       // Apply the mask and OR in to the value to write.
1332       Val = Builder.CreateOr(Builder.CreateAnd(Load, InvMask), Val);
1333     }
1334 
1335     // Write the value.
1336     llvm::StoreInst *Store = Builder.CreateStore(Val, Ptr,
1337                                                  Dst.isVolatileQualified());
1338     Store->setAlignment(AccessAlignment.getQuantity());
1339   }
1340 }
1341 
1342 void CodeGenFunction::EmitStoreThroughExtVectorComponentLValue(RValue Src,
1343                                                                LValue Dst) {
1344   // This access turns into a read/modify/write of the vector.  Load the input
1345   // value now.
1346   llvm::LoadInst *Load = Builder.CreateLoad(Dst.getExtVectorAddr(),
1347                                             Dst.isVolatileQualified());
1348   Load->setAlignment(Dst.getAlignment().getQuantity());
1349   llvm::Value *Vec = Load;
1350   const llvm::Constant *Elts = Dst.getExtVectorElts();
1351 
1352   llvm::Value *SrcVal = Src.getScalarVal();
1353 
1354   if (const VectorType *VTy = Dst.getType()->getAs<VectorType>()) {
1355     unsigned NumSrcElts = VTy->getNumElements();
1356     unsigned NumDstElts =
1357        cast<llvm::VectorType>(Vec->getType())->getNumElements();
1358     if (NumDstElts == NumSrcElts) {
1359       // Use shuffle vector is the src and destination are the same number of
1360       // elements and restore the vector mask since it is on the side it will be
1361       // stored.
1362       SmallVector<llvm::Constant*, 4> Mask(NumDstElts);
1363       for (unsigned i = 0; i != NumSrcElts; ++i)
1364         Mask[getAccessedFieldNo(i, Elts)] = Builder.getInt32(i);
1365 
1366       llvm::Value *MaskV = llvm::ConstantVector::get(Mask);
1367       Vec = Builder.CreateShuffleVector(SrcVal,
1368                                         llvm::UndefValue::get(Vec->getType()),
1369                                         MaskV);
1370     } else if (NumDstElts > NumSrcElts) {
1371       // Extended the source vector to the same length and then shuffle it
1372       // into the destination.
1373       // FIXME: since we're shuffling with undef, can we just use the indices
1374       //        into that?  This could be simpler.
1375       SmallVector<llvm::Constant*, 4> ExtMask;
1376       for (unsigned i = 0; i != NumSrcElts; ++i)
1377         ExtMask.push_back(Builder.getInt32(i));
1378       ExtMask.resize(NumDstElts, llvm::UndefValue::get(Int32Ty));
1379       llvm::Value *ExtMaskV = llvm::ConstantVector::get(ExtMask);
1380       llvm::Value *ExtSrcVal =
1381         Builder.CreateShuffleVector(SrcVal,
1382                                     llvm::UndefValue::get(SrcVal->getType()),
1383                                     ExtMaskV);
1384       // build identity
1385       SmallVector<llvm::Constant*, 4> Mask;
1386       for (unsigned i = 0; i != NumDstElts; ++i)
1387         Mask.push_back(Builder.getInt32(i));
1388 
1389       // modify when what gets shuffled in
1390       for (unsigned i = 0; i != NumSrcElts; ++i)
1391         Mask[getAccessedFieldNo(i, Elts)] = Builder.getInt32(i+NumDstElts);
1392       llvm::Value *MaskV = llvm::ConstantVector::get(Mask);
1393       Vec = Builder.CreateShuffleVector(Vec, ExtSrcVal, MaskV);
1394     } else {
1395       // We should never shorten the vector
1396       llvm_unreachable("unexpected shorten vector length");
1397     }
1398   } else {
1399     // If the Src is a scalar (not a vector) it must be updating one element.
1400     unsigned InIdx = getAccessedFieldNo(0, Elts);
1401     llvm::Value *Elt = llvm::ConstantInt::get(Int32Ty, InIdx);
1402     Vec = Builder.CreateInsertElement(Vec, SrcVal, Elt);
1403   }
1404 
1405   llvm::StoreInst *Store = Builder.CreateStore(Vec, Dst.getExtVectorAddr(),
1406                                                Dst.isVolatileQualified());
1407   Store->setAlignment(Dst.getAlignment().getQuantity());
1408 }
1409 
1410 // setObjCGCLValueClass - sets class of he lvalue for the purpose of
1411 // generating write-barries API. It is currently a global, ivar,
1412 // or neither.
1413 static void setObjCGCLValueClass(const ASTContext &Ctx, const Expr *E,
1414                                  LValue &LV,
1415                                  bool IsMemberAccess=false) {
1416   if (Ctx.getLangOpts().getGC() == LangOptions::NonGC)
1417     return;
1418 
1419   if (isa<ObjCIvarRefExpr>(E)) {
1420     QualType ExpTy = E->getType();
1421     if (IsMemberAccess && ExpTy->isPointerType()) {
1422       // If ivar is a structure pointer, assigning to field of
1423       // this struct follows gcc's behavior and makes it a non-ivar
1424       // writer-barrier conservatively.
1425       ExpTy = ExpTy->getAs<PointerType>()->getPointeeType();
1426       if (ExpTy->isRecordType()) {
1427         LV.setObjCIvar(false);
1428         return;
1429       }
1430     }
1431     LV.setObjCIvar(true);
1432     ObjCIvarRefExpr *Exp = cast<ObjCIvarRefExpr>(const_cast<Expr*>(E));
1433     LV.setBaseIvarExp(Exp->getBase());
1434     LV.setObjCArray(E->getType()->isArrayType());
1435     return;
1436   }
1437 
1438   if (const DeclRefExpr *Exp = dyn_cast<DeclRefExpr>(E)) {
1439     if (const VarDecl *VD = dyn_cast<VarDecl>(Exp->getDecl())) {
1440       if (VD->hasGlobalStorage()) {
1441         LV.setGlobalObjCRef(true);
1442         LV.setThreadLocalRef(VD->isThreadSpecified());
1443       }
1444     }
1445     LV.setObjCArray(E->getType()->isArrayType());
1446     return;
1447   }
1448 
1449   if (const UnaryOperator *Exp = dyn_cast<UnaryOperator>(E)) {
1450     setObjCGCLValueClass(Ctx, Exp->getSubExpr(), LV, IsMemberAccess);
1451     return;
1452   }
1453 
1454   if (const ParenExpr *Exp = dyn_cast<ParenExpr>(E)) {
1455     setObjCGCLValueClass(Ctx, Exp->getSubExpr(), LV, IsMemberAccess);
1456     if (LV.isObjCIvar()) {
1457       // If cast is to a structure pointer, follow gcc's behavior and make it
1458       // a non-ivar write-barrier.
1459       QualType ExpTy = E->getType();
1460       if (ExpTy->isPointerType())
1461         ExpTy = ExpTy->getAs<PointerType>()->getPointeeType();
1462       if (ExpTy->isRecordType())
1463         LV.setObjCIvar(false);
1464     }
1465     return;
1466   }
1467 
1468   if (const GenericSelectionExpr *Exp = dyn_cast<GenericSelectionExpr>(E)) {
1469     setObjCGCLValueClass(Ctx, Exp->getResultExpr(), LV);
1470     return;
1471   }
1472 
1473   if (const ImplicitCastExpr *Exp = dyn_cast<ImplicitCastExpr>(E)) {
1474     setObjCGCLValueClass(Ctx, Exp->getSubExpr(), LV, IsMemberAccess);
1475     return;
1476   }
1477 
1478   if (const CStyleCastExpr *Exp = dyn_cast<CStyleCastExpr>(E)) {
1479     setObjCGCLValueClass(Ctx, Exp->getSubExpr(), LV, IsMemberAccess);
1480     return;
1481   }
1482 
1483   if (const ObjCBridgedCastExpr *Exp = dyn_cast<ObjCBridgedCastExpr>(E)) {
1484     setObjCGCLValueClass(Ctx, Exp->getSubExpr(), LV, IsMemberAccess);
1485     return;
1486   }
1487 
1488   if (const ArraySubscriptExpr *Exp = dyn_cast<ArraySubscriptExpr>(E)) {
1489     setObjCGCLValueClass(Ctx, Exp->getBase(), LV);
1490     if (LV.isObjCIvar() && !LV.isObjCArray())
1491       // Using array syntax to assigning to what an ivar points to is not
1492       // same as assigning to the ivar itself. {id *Names;} Names[i] = 0;
1493       LV.setObjCIvar(false);
1494     else if (LV.isGlobalObjCRef() && !LV.isObjCArray())
1495       // Using array syntax to assigning to what global points to is not
1496       // same as assigning to the global itself. {id *G;} G[i] = 0;
1497       LV.setGlobalObjCRef(false);
1498     return;
1499   }
1500 
1501   if (const MemberExpr *Exp = dyn_cast<MemberExpr>(E)) {
1502     setObjCGCLValueClass(Ctx, Exp->getBase(), LV, true);
1503     // We don't know if member is an 'ivar', but this flag is looked at
1504     // only in the context of LV.isObjCIvar().
1505     LV.setObjCArray(E->getType()->isArrayType());
1506     return;
1507   }
1508 }
1509 
1510 static llvm::Value *
1511 EmitBitCastOfLValueToProperType(CodeGenFunction &CGF,
1512                                 llvm::Value *V, llvm::Type *IRType,
1513                                 StringRef Name = StringRef()) {
1514   unsigned AS = cast<llvm::PointerType>(V->getType())->getAddressSpace();
1515   return CGF.Builder.CreateBitCast(V, IRType->getPointerTo(AS), Name);
1516 }
1517 
1518 static LValue EmitGlobalVarDeclLValue(CodeGenFunction &CGF,
1519                                       const Expr *E, const VarDecl *VD) {
1520   assert((VD->hasExternalStorage() || VD->isFileVarDecl()) &&
1521          "Var decl must have external storage or be a file var decl!");
1522 
1523   llvm::Value *V = CGF.CGM.GetAddrOfGlobalVar(VD);
1524   llvm::Type *RealVarTy = CGF.getTypes().ConvertTypeForMem(VD->getType());
1525   V = EmitBitCastOfLValueToProperType(CGF, V, RealVarTy);
1526   CharUnits Alignment = CGF.getContext().getDeclAlign(VD);
1527   QualType T = E->getType();
1528   LValue LV;
1529   if (VD->getType()->isReferenceType()) {
1530     llvm::LoadInst *LI = CGF.Builder.CreateLoad(V);
1531     LI->setAlignment(Alignment.getQuantity());
1532     V = LI;
1533     LV = CGF.MakeNaturalAlignAddrLValue(V, T);
1534   } else {
1535     LV = CGF.MakeAddrLValue(V, E->getType(), Alignment);
1536   }
1537   setObjCGCLValueClass(CGF.getContext(), E, LV);
1538   return LV;
1539 }
1540 
1541 static LValue EmitFunctionDeclLValue(CodeGenFunction &CGF,
1542                                      const Expr *E, const FunctionDecl *FD) {
1543   llvm::Value *V = CGF.CGM.GetAddrOfFunction(FD);
1544   if (!FD->hasPrototype()) {
1545     if (const FunctionProtoType *Proto =
1546             FD->getType()->getAs<FunctionProtoType>()) {
1547       // Ugly case: for a K&R-style definition, the type of the definition
1548       // isn't the same as the type of a use.  Correct for this with a
1549       // bitcast.
1550       QualType NoProtoType =
1551           CGF.getContext().getFunctionNoProtoType(Proto->getResultType());
1552       NoProtoType = CGF.getContext().getPointerType(NoProtoType);
1553       V = CGF.Builder.CreateBitCast(V, CGF.ConvertType(NoProtoType));
1554     }
1555   }
1556   CharUnits Alignment = CGF.getContext().getDeclAlign(FD);
1557   return CGF.MakeAddrLValue(V, E->getType(), Alignment);
1558 }
1559 
1560 LValue CodeGenFunction::EmitDeclRefLValue(const DeclRefExpr *E) {
1561   const NamedDecl *ND = E->getDecl();
1562   CharUnits Alignment = getContext().getDeclAlign(ND);
1563   QualType T = E->getType();
1564 
1565   // FIXME: We should be able to assert this for FunctionDecls as well!
1566   // FIXME: We should be able to assert this for all DeclRefExprs, not just
1567   // those with a valid source location.
1568   assert((ND->isUsed(false) || !isa<VarDecl>(ND) ||
1569           !E->getLocation().isValid()) &&
1570          "Should not use decl without marking it used!");
1571 
1572   if (ND->hasAttr<WeakRefAttr>()) {
1573     const ValueDecl *VD = cast<ValueDecl>(ND);
1574     llvm::Constant *Aliasee = CGM.GetWeakRefReference(VD);
1575     return MakeAddrLValue(Aliasee, E->getType(), Alignment);
1576   }
1577 
1578   if (const VarDecl *VD = dyn_cast<VarDecl>(ND)) {
1579     // Check if this is a global variable.
1580     if (VD->hasExternalStorage() || VD->isFileVarDecl())
1581       return EmitGlobalVarDeclLValue(*this, E, VD);
1582 
1583     bool isBlockVariable = VD->hasAttr<BlocksAttr>();
1584 
1585     bool NonGCable = VD->hasLocalStorage() &&
1586                      !VD->getType()->isReferenceType() &&
1587                      !isBlockVariable;
1588 
1589     llvm::Value *V = LocalDeclMap[VD];
1590     if (!V && VD->isStaticLocal())
1591       V = CGM.getStaticLocalDeclAddress(VD);
1592 
1593     // Use special handling for lambdas.
1594     if (!V) {
1595       if (FieldDecl *FD = LambdaCaptureFields.lookup(VD)) {
1596         QualType LambdaTagType = getContext().getTagDeclType(FD->getParent());
1597         LValue LambdaLV = MakeNaturalAlignAddrLValue(CXXABIThisValue,
1598                                                      LambdaTagType);
1599         return EmitLValueForField(LambdaLV, FD);
1600       }
1601 
1602       assert(isa<BlockDecl>(CurCodeDecl) && E->refersToEnclosingLocal());
1603       CharUnits alignment = getContext().getDeclAlign(VD);
1604       return MakeAddrLValue(GetAddrOfBlockDecl(VD, isBlockVariable),
1605                             E->getType(), alignment);
1606     }
1607 
1608     assert(V && "DeclRefExpr not entered in LocalDeclMap?");
1609 
1610     if (isBlockVariable)
1611       V = BuildBlockByrefAddress(V, VD);
1612 
1613     LValue LV;
1614     if (VD->getType()->isReferenceType()) {
1615       llvm::LoadInst *LI = Builder.CreateLoad(V);
1616       LI->setAlignment(Alignment.getQuantity());
1617       V = LI;
1618       LV = MakeNaturalAlignAddrLValue(V, T);
1619     } else {
1620       LV = MakeAddrLValue(V, T, Alignment);
1621     }
1622 
1623     if (NonGCable) {
1624       LV.getQuals().removeObjCGCAttr();
1625       LV.setNonGC(true);
1626     }
1627     setObjCGCLValueClass(getContext(), E, LV);
1628     return LV;
1629   }
1630 
1631   if (const FunctionDecl *fn = dyn_cast<FunctionDecl>(ND))
1632     return EmitFunctionDeclLValue(*this, E, fn);
1633 
1634   llvm_unreachable("Unhandled DeclRefExpr");
1635 }
1636 
1637 LValue CodeGenFunction::EmitUnaryOpLValue(const UnaryOperator *E) {
1638   // __extension__ doesn't affect lvalue-ness.
1639   if (E->getOpcode() == UO_Extension)
1640     return EmitLValue(E->getSubExpr());
1641 
1642   QualType ExprTy = getContext().getCanonicalType(E->getSubExpr()->getType());
1643   switch (E->getOpcode()) {
1644   default: llvm_unreachable("Unknown unary operator lvalue!");
1645   case UO_Deref: {
1646     QualType T = E->getSubExpr()->getType()->getPointeeType();
1647     assert(!T.isNull() && "CodeGenFunction::EmitUnaryOpLValue: Illegal type");
1648 
1649     LValue LV = MakeNaturalAlignAddrLValue(EmitScalarExpr(E->getSubExpr()), T);
1650     LV.getQuals().setAddressSpace(ExprTy.getAddressSpace());
1651 
1652     // We should not generate __weak write barrier on indirect reference
1653     // of a pointer to object; as in void foo (__weak id *param); *param = 0;
1654     // But, we continue to generate __strong write barrier on indirect write
1655     // into a pointer to object.
1656     if (getContext().getLangOpts().ObjC1 &&
1657         getContext().getLangOpts().getGC() != LangOptions::NonGC &&
1658         LV.isObjCWeak())
1659       LV.setNonGC(!E->isOBJCGCCandidate(getContext()));
1660     return LV;
1661   }
1662   case UO_Real:
1663   case UO_Imag: {
1664     LValue LV = EmitLValue(E->getSubExpr());
1665     assert(LV.isSimple() && "real/imag on non-ordinary l-value");
1666     llvm::Value *Addr = LV.getAddress();
1667 
1668     // __real is valid on scalars.  This is a faster way of testing that.
1669     // __imag can only produce an rvalue on scalars.
1670     if (E->getOpcode() == UO_Real &&
1671         !cast<llvm::PointerType>(Addr->getType())
1672            ->getElementType()->isStructTy()) {
1673       assert(E->getSubExpr()->getType()->isArithmeticType());
1674       return LV;
1675     }
1676 
1677     assert(E->getSubExpr()->getType()->isAnyComplexType());
1678 
1679     unsigned Idx = E->getOpcode() == UO_Imag;
1680     return MakeAddrLValue(Builder.CreateStructGEP(LV.getAddress(),
1681                                                   Idx, "idx"),
1682                           ExprTy);
1683   }
1684   case UO_PreInc:
1685   case UO_PreDec: {
1686     LValue LV = EmitLValue(E->getSubExpr());
1687     bool isInc = E->getOpcode() == UO_PreInc;
1688 
1689     if (E->getType()->isAnyComplexType())
1690       EmitComplexPrePostIncDec(E, LV, isInc, true/*isPre*/);
1691     else
1692       EmitScalarPrePostIncDec(E, LV, isInc, true/*isPre*/);
1693     return LV;
1694   }
1695   }
1696 }
1697 
1698 LValue CodeGenFunction::EmitStringLiteralLValue(const StringLiteral *E) {
1699   return MakeAddrLValue(CGM.GetAddrOfConstantStringFromLiteral(E),
1700                         E->getType());
1701 }
1702 
1703 LValue CodeGenFunction::EmitObjCEncodeExprLValue(const ObjCEncodeExpr *E) {
1704   return MakeAddrLValue(CGM.GetAddrOfConstantStringFromObjCEncode(E),
1705                         E->getType());
1706 }
1707 
1708 static llvm::Constant*
1709 GetAddrOfConstantWideString(StringRef Str,
1710                             const char *GlobalName,
1711                             ASTContext &Context,
1712                             QualType Ty, SourceLocation Loc,
1713                             CodeGenModule &CGM) {
1714 
1715   StringLiteral *SL = StringLiteral::Create(Context,
1716                                             Str,
1717                                             StringLiteral::Wide,
1718                                             /*Pascal = */false,
1719                                             Ty, Loc);
1720   llvm::Constant *C = CGM.GetConstantArrayFromStringLiteral(SL);
1721   llvm::GlobalVariable *GV =
1722     new llvm::GlobalVariable(CGM.getModule(), C->getType(),
1723                              !CGM.getLangOpts().WritableStrings,
1724                              llvm::GlobalValue::PrivateLinkage,
1725                              C, GlobalName);
1726   const unsigned WideAlignment =
1727     Context.getTypeAlignInChars(Ty).getQuantity();
1728   GV->setAlignment(WideAlignment);
1729   return GV;
1730 }
1731 
1732 // FIXME: Mostly copied from StringLiteralParser::CopyStringFragment
1733 static void ConvertUTF8ToWideString(unsigned CharByteWidth, StringRef Source,
1734                                     SmallString<32>& Target) {
1735   Target.resize(CharByteWidth * (Source.size() + 1));
1736   char* ResultPtr = &Target[0];
1737 
1738   assert(CharByteWidth==1 || CharByteWidth==2 || CharByteWidth==4);
1739   ConversionResult result = conversionOK;
1740   // Copy the character span over.
1741   if (CharByteWidth == 1) {
1742     if (!isLegalUTF8String(reinterpret_cast<const UTF8*>(&*Source.begin()),
1743                            reinterpret_cast<const UTF8*>(&*Source.end())))
1744       result = sourceIllegal;
1745     memcpy(ResultPtr, Source.data(), Source.size());
1746     ResultPtr += Source.size();
1747   } else if (CharByteWidth == 2) {
1748     UTF8 const *sourceStart = (UTF8 const *)Source.data();
1749     // FIXME: Make the type of the result buffer correct instead of
1750     // using reinterpret_cast.
1751     UTF16 *targetStart = reinterpret_cast<UTF16*>(ResultPtr);
1752     ConversionFlags flags = strictConversion;
1753     result = ConvertUTF8toUTF16(
1754       &sourceStart,sourceStart + Source.size(),
1755         &targetStart,targetStart + 2*Source.size(),flags);
1756     if (result==conversionOK)
1757       ResultPtr = reinterpret_cast<char*>(targetStart);
1758   } else if (CharByteWidth == 4) {
1759     UTF8 const *sourceStart = (UTF8 const *)Source.data();
1760     // FIXME: Make the type of the result buffer correct instead of
1761     // using reinterpret_cast.
1762     UTF32 *targetStart = reinterpret_cast<UTF32*>(ResultPtr);
1763     ConversionFlags flags = strictConversion;
1764     result = ConvertUTF8toUTF32(
1765         &sourceStart,sourceStart + Source.size(),
1766         &targetStart,targetStart + 4*Source.size(),flags);
1767     if (result==conversionOK)
1768       ResultPtr = reinterpret_cast<char*>(targetStart);
1769   }
1770   assert((result != targetExhausted)
1771          && "ConvertUTF8toUTFXX exhausted target buffer");
1772   assert(result == conversionOK);
1773   Target.resize(ResultPtr - &Target[0]);
1774 }
1775 
1776 LValue CodeGenFunction::EmitPredefinedLValue(const PredefinedExpr *E) {
1777   switch (E->getIdentType()) {
1778   default:
1779     return EmitUnsupportedLValue(E, "predefined expression");
1780 
1781   case PredefinedExpr::Func:
1782   case PredefinedExpr::Function:
1783   case PredefinedExpr::LFunction:
1784   case PredefinedExpr::PrettyFunction: {
1785     unsigned IdentType = E->getIdentType();
1786     std::string GlobalVarName;
1787 
1788     switch (IdentType) {
1789     default: llvm_unreachable("Invalid type");
1790     case PredefinedExpr::Func:
1791       GlobalVarName = "__func__.";
1792       break;
1793     case PredefinedExpr::Function:
1794       GlobalVarName = "__FUNCTION__.";
1795       break;
1796     case PredefinedExpr::LFunction:
1797       GlobalVarName = "L__FUNCTION__.";
1798       break;
1799     case PredefinedExpr::PrettyFunction:
1800       GlobalVarName = "__PRETTY_FUNCTION__.";
1801       break;
1802     }
1803 
1804     StringRef FnName = CurFn->getName();
1805     if (FnName.startswith("\01"))
1806       FnName = FnName.substr(1);
1807     GlobalVarName += FnName;
1808 
1809     const Decl *CurDecl = CurCodeDecl;
1810     if (CurDecl == 0)
1811       CurDecl = getContext().getTranslationUnitDecl();
1812 
1813     std::string FunctionName =
1814         (isa<BlockDecl>(CurDecl)
1815          ? FnName.str()
1816          : PredefinedExpr::ComputeName((PredefinedExpr::IdentType)IdentType,
1817                                        CurDecl));
1818 
1819     const Type* ElemType = E->getType()->getArrayElementTypeNoTypeQual();
1820     llvm::Constant *C;
1821     if (ElemType->isWideCharType()) {
1822       SmallString<32> RawChars;
1823       ConvertUTF8ToWideString(
1824           getContext().getTypeSizeInChars(ElemType).getQuantity(),
1825           FunctionName, RawChars);
1826       C = GetAddrOfConstantWideString(RawChars,
1827                                       GlobalVarName.c_str(),
1828                                       getContext(),
1829                                       E->getType(),
1830                                       E->getLocation(),
1831                                       CGM);
1832     } else {
1833       C = CGM.GetAddrOfConstantCString(FunctionName,
1834                                        GlobalVarName.c_str(),
1835                                        1);
1836     }
1837     return MakeAddrLValue(C, E->getType());
1838   }
1839   }
1840 }
1841 
1842 llvm::BasicBlock *CodeGenFunction::getTrapBB() {
1843   const CodeGenOptions &GCO = CGM.getCodeGenOpts();
1844 
1845   // If we are not optimzing, don't collapse all calls to trap in the function
1846   // to the same call, that way, in the debugger they can see which operation
1847   // did in fact fail.  If we are optimizing, we collapse all calls to trap down
1848   // to just one per function to save on codesize.
1849   if (GCO.OptimizationLevel && TrapBB)
1850     return TrapBB;
1851 
1852   llvm::BasicBlock *Cont = 0;
1853   if (HaveInsertPoint()) {
1854     Cont = createBasicBlock("cont");
1855     EmitBranch(Cont);
1856   }
1857   TrapBB = createBasicBlock("trap");
1858   EmitBlock(TrapBB);
1859 
1860   llvm::Value *F = CGM.getIntrinsic(llvm::Intrinsic::trap);
1861   llvm::CallInst *TrapCall = Builder.CreateCall(F);
1862   TrapCall->setDoesNotReturn();
1863   TrapCall->setDoesNotThrow();
1864   Builder.CreateUnreachable();
1865 
1866   if (Cont)
1867     EmitBlock(Cont);
1868   return TrapBB;
1869 }
1870 
1871 /// isSimpleArrayDecayOperand - If the specified expr is a simple decay from an
1872 /// array to pointer, return the array subexpression.
1873 static const Expr *isSimpleArrayDecayOperand(const Expr *E) {
1874   // If this isn't just an array->pointer decay, bail out.
1875   const CastExpr *CE = dyn_cast<CastExpr>(E);
1876   if (CE == 0 || CE->getCastKind() != CK_ArrayToPointerDecay)
1877     return 0;
1878 
1879   // If this is a decay from variable width array, bail out.
1880   const Expr *SubExpr = CE->getSubExpr();
1881   if (SubExpr->getType()->isVariableArrayType())
1882     return 0;
1883 
1884   return SubExpr;
1885 }
1886 
1887 LValue CodeGenFunction::EmitArraySubscriptExpr(const ArraySubscriptExpr *E) {
1888   // The index must always be an integer, which is not an aggregate.  Emit it.
1889   llvm::Value *Idx = EmitScalarExpr(E->getIdx());
1890   QualType IdxTy  = E->getIdx()->getType();
1891   bool IdxSigned = IdxTy->isSignedIntegerOrEnumerationType();
1892 
1893   // If the base is a vector type, then we are forming a vector element lvalue
1894   // with this subscript.
1895   if (E->getBase()->getType()->isVectorType()) {
1896     // Emit the vector as an lvalue to get its address.
1897     LValue LHS = EmitLValue(E->getBase());
1898     assert(LHS.isSimple() && "Can only subscript lvalue vectors here!");
1899     Idx = Builder.CreateIntCast(Idx, Int32Ty, IdxSigned, "vidx");
1900     return LValue::MakeVectorElt(LHS.getAddress(), Idx,
1901                                  E->getBase()->getType(), LHS.getAlignment());
1902   }
1903 
1904   // Extend or truncate the index type to 32 or 64-bits.
1905   if (Idx->getType() != IntPtrTy)
1906     Idx = Builder.CreateIntCast(Idx, IntPtrTy, IdxSigned, "idxprom");
1907 
1908   // We know that the pointer points to a type of the correct size, unless the
1909   // size is a VLA or Objective-C interface.
1910   llvm::Value *Address = 0;
1911   CharUnits ArrayAlignment;
1912   if (const VariableArrayType *vla =
1913         getContext().getAsVariableArrayType(E->getType())) {
1914     // The base must be a pointer, which is not an aggregate.  Emit
1915     // it.  It needs to be emitted first in case it's what captures
1916     // the VLA bounds.
1917     Address = EmitScalarExpr(E->getBase());
1918 
1919     // The element count here is the total number of non-VLA elements.
1920     llvm::Value *numElements = getVLASize(vla).first;
1921 
1922     // Effectively, the multiply by the VLA size is part of the GEP.
1923     // GEP indexes are signed, and scaling an index isn't permitted to
1924     // signed-overflow, so we use the same semantics for our explicit
1925     // multiply.  We suppress this if overflow is not undefined behavior.
1926     if (getLangOpts().isSignedOverflowDefined()) {
1927       Idx = Builder.CreateMul(Idx, numElements);
1928       Address = Builder.CreateGEP(Address, Idx, "arrayidx");
1929     } else {
1930       Idx = Builder.CreateNSWMul(Idx, numElements);
1931       Address = Builder.CreateInBoundsGEP(Address, Idx, "arrayidx");
1932     }
1933   } else if (const ObjCObjectType *OIT = E->getType()->getAs<ObjCObjectType>()){
1934     // Indexing over an interface, as in "NSString *P; P[4];"
1935     llvm::Value *InterfaceSize =
1936       llvm::ConstantInt::get(Idx->getType(),
1937           getContext().getTypeSizeInChars(OIT).getQuantity());
1938 
1939     Idx = Builder.CreateMul(Idx, InterfaceSize);
1940 
1941     // The base must be a pointer, which is not an aggregate.  Emit it.
1942     llvm::Value *Base = EmitScalarExpr(E->getBase());
1943     Address = EmitCastToVoidPtr(Base);
1944     Address = Builder.CreateGEP(Address, Idx, "arrayidx");
1945     Address = Builder.CreateBitCast(Address, Base->getType());
1946   } else if (const Expr *Array = isSimpleArrayDecayOperand(E->getBase())) {
1947     // If this is A[i] where A is an array, the frontend will have decayed the
1948     // base to be a ArrayToPointerDecay implicit cast.  While correct, it is
1949     // inefficient at -O0 to emit a "gep A, 0, 0" when codegen'ing it, then a
1950     // "gep x, i" here.  Emit one "gep A, 0, i".
1951     assert(Array->getType()->isArrayType() &&
1952            "Array to pointer decay must have array source type!");
1953     LValue ArrayLV = EmitLValue(Array);
1954     llvm::Value *ArrayPtr = ArrayLV.getAddress();
1955     llvm::Value *Zero = llvm::ConstantInt::get(Int32Ty, 0);
1956     llvm::Value *Args[] = { Zero, Idx };
1957 
1958     // Propagate the alignment from the array itself to the result.
1959     ArrayAlignment = ArrayLV.getAlignment();
1960 
1961     if (getContext().getLangOpts().isSignedOverflowDefined())
1962       Address = Builder.CreateGEP(ArrayPtr, Args, "arrayidx");
1963     else
1964       Address = Builder.CreateInBoundsGEP(ArrayPtr, Args, "arrayidx");
1965   } else {
1966     // The base must be a pointer, which is not an aggregate.  Emit it.
1967     llvm::Value *Base = EmitScalarExpr(E->getBase());
1968     if (getContext().getLangOpts().isSignedOverflowDefined())
1969       Address = Builder.CreateGEP(Base, Idx, "arrayidx");
1970     else
1971       Address = Builder.CreateInBoundsGEP(Base, Idx, "arrayidx");
1972   }
1973 
1974   QualType T = E->getBase()->getType()->getPointeeType();
1975   assert(!T.isNull() &&
1976          "CodeGenFunction::EmitArraySubscriptExpr(): Illegal base type");
1977 
1978 
1979   // Limit the alignment to that of the result type.
1980   LValue LV;
1981   if (!ArrayAlignment.isZero()) {
1982     CharUnits Align = getContext().getTypeAlignInChars(T);
1983     ArrayAlignment = std::min(Align, ArrayAlignment);
1984     LV = MakeAddrLValue(Address, T, ArrayAlignment);
1985   } else {
1986     LV = MakeNaturalAlignAddrLValue(Address, T);
1987   }
1988 
1989   LV.getQuals().setAddressSpace(E->getBase()->getType().getAddressSpace());
1990 
1991   if (getContext().getLangOpts().ObjC1 &&
1992       getContext().getLangOpts().getGC() != LangOptions::NonGC) {
1993     LV.setNonGC(!E->isOBJCGCCandidate(getContext()));
1994     setObjCGCLValueClass(getContext(), E, LV);
1995   }
1996   return LV;
1997 }
1998 
1999 static
2000 llvm::Constant *GenerateConstantVector(CGBuilderTy &Builder,
2001                                        SmallVector<unsigned, 4> &Elts) {
2002   SmallVector<llvm::Constant*, 4> CElts;
2003   for (unsigned i = 0, e = Elts.size(); i != e; ++i)
2004     CElts.push_back(Builder.getInt32(Elts[i]));
2005 
2006   return llvm::ConstantVector::get(CElts);
2007 }
2008 
2009 LValue CodeGenFunction::
2010 EmitExtVectorElementExpr(const ExtVectorElementExpr *E) {
2011   // Emit the base vector as an l-value.
2012   LValue Base;
2013 
2014   // ExtVectorElementExpr's base can either be a vector or pointer to vector.
2015   if (E->isArrow()) {
2016     // If it is a pointer to a vector, emit the address and form an lvalue with
2017     // it.
2018     llvm::Value *Ptr = EmitScalarExpr(E->getBase());
2019     const PointerType *PT = E->getBase()->getType()->getAs<PointerType>();
2020     Base = MakeAddrLValue(Ptr, PT->getPointeeType());
2021     Base.getQuals().removeObjCGCAttr();
2022   } else if (E->getBase()->isGLValue()) {
2023     // Otherwise, if the base is an lvalue ( as in the case of foo.x.x),
2024     // emit the base as an lvalue.
2025     assert(E->getBase()->getType()->isVectorType());
2026     Base = EmitLValue(E->getBase());
2027   } else {
2028     // Otherwise, the base is a normal rvalue (as in (V+V).x), emit it as such.
2029     assert(E->getBase()->getType()->isVectorType() &&
2030            "Result must be a vector");
2031     llvm::Value *Vec = EmitScalarExpr(E->getBase());
2032 
2033     // Store the vector to memory (because LValue wants an address).
2034     llvm::Value *VecMem = CreateMemTemp(E->getBase()->getType());
2035     Builder.CreateStore(Vec, VecMem);
2036     Base = MakeAddrLValue(VecMem, E->getBase()->getType());
2037   }
2038 
2039   QualType type =
2040     E->getType().withCVRQualifiers(Base.getQuals().getCVRQualifiers());
2041 
2042   // Encode the element access list into a vector of unsigned indices.
2043   SmallVector<unsigned, 4> Indices;
2044   E->getEncodedElementAccess(Indices);
2045 
2046   if (Base.isSimple()) {
2047     llvm::Constant *CV = GenerateConstantVector(Builder, Indices);
2048     return LValue::MakeExtVectorElt(Base.getAddress(), CV, type,
2049                                     Base.getAlignment());
2050   }
2051   assert(Base.isExtVectorElt() && "Can only subscript lvalue vec elts here!");
2052 
2053   llvm::Constant *BaseElts = Base.getExtVectorElts();
2054   SmallVector<llvm::Constant *, 4> CElts;
2055 
2056   for (unsigned i = 0, e = Indices.size(); i != e; ++i)
2057     CElts.push_back(BaseElts->getAggregateElement(Indices[i]));
2058   llvm::Constant *CV = llvm::ConstantVector::get(CElts);
2059   return LValue::MakeExtVectorElt(Base.getExtVectorAddr(), CV, type,
2060                                   Base.getAlignment());
2061 }
2062 
2063 LValue CodeGenFunction::EmitMemberExpr(const MemberExpr *E) {
2064   Expr *BaseExpr = E->getBase();
2065 
2066   // If this is s.x, emit s as an lvalue.  If it is s->x, emit s as a scalar.
2067   LValue BaseLV;
2068   if (E->isArrow())
2069     BaseLV = MakeNaturalAlignAddrLValue(EmitScalarExpr(BaseExpr),
2070                                         BaseExpr->getType()->getPointeeType());
2071   else
2072     BaseLV = EmitLValue(BaseExpr);
2073 
2074   NamedDecl *ND = E->getMemberDecl();
2075   if (FieldDecl *Field = dyn_cast<FieldDecl>(ND)) {
2076     LValue LV = EmitLValueForField(BaseLV, Field);
2077     setObjCGCLValueClass(getContext(), E, LV);
2078     return LV;
2079   }
2080 
2081   if (VarDecl *VD = dyn_cast<VarDecl>(ND))
2082     return EmitGlobalVarDeclLValue(*this, E, VD);
2083 
2084   if (const FunctionDecl *FD = dyn_cast<FunctionDecl>(ND))
2085     return EmitFunctionDeclLValue(*this, E, FD);
2086 
2087   llvm_unreachable("Unhandled member declaration!");
2088 }
2089 
2090 /// EmitLValueForAnonRecordField - Given that the field is a member of
2091 /// an anonymous struct or union buried inside a record, and given
2092 /// that the base value is a pointer to the enclosing record, derive
2093 /// an lvalue for the ultimate field.
2094 LValue CodeGenFunction::EmitLValueForAnonRecordField(llvm::Value *BaseValue,
2095                                              const IndirectFieldDecl *Field,
2096                                                      unsigned CVRQualifiers) {
2097   IndirectFieldDecl::chain_iterator I = Field->chain_begin(),
2098     IEnd = Field->chain_end();
2099   while (true) {
2100     QualType RecordTy =
2101         getContext().getTypeDeclType(cast<FieldDecl>(*I)->getParent());
2102     LValue LV = EmitLValueForField(MakeAddrLValue(BaseValue, RecordTy),
2103                                    cast<FieldDecl>(*I));
2104     if (++I == IEnd) return LV;
2105 
2106     assert(LV.isSimple());
2107     BaseValue = LV.getAddress();
2108     CVRQualifiers |= LV.getVRQualifiers();
2109   }
2110 }
2111 
2112 LValue CodeGenFunction::EmitLValueForField(LValue base,
2113                                            const FieldDecl *field) {
2114   if (field->isBitField()) {
2115     const CGRecordLayout &RL =
2116       CGM.getTypes().getCGRecordLayout(field->getParent());
2117     const CGBitFieldInfo &Info = RL.getBitFieldInfo(field);
2118     QualType fieldType =
2119       field->getType().withCVRQualifiers(base.getVRQualifiers());
2120     return LValue::MakeBitfield(base.getAddress(), Info, fieldType,
2121                                 base.getAlignment());
2122   }
2123 
2124   const RecordDecl *rec = field->getParent();
2125   QualType type = field->getType();
2126   CharUnits alignment = getContext().getDeclAlign(field);
2127 
2128   // FIXME: It should be impossible to have an LValue without alignment for a
2129   // complete type.
2130   if (!base.getAlignment().isZero())
2131     alignment = std::min(alignment, base.getAlignment());
2132 
2133   bool mayAlias = rec->hasAttr<MayAliasAttr>();
2134 
2135   llvm::Value *addr = base.getAddress();
2136   unsigned cvr = base.getVRQualifiers();
2137   if (rec->isUnion()) {
2138     // For unions, there is no pointer adjustment.
2139     assert(!type->isReferenceType() && "union has reference member");
2140   } else {
2141     // For structs, we GEP to the field that the record layout suggests.
2142     unsigned idx = CGM.getTypes().getCGRecordLayout(rec).getLLVMFieldNo(field);
2143     addr = Builder.CreateStructGEP(addr, idx, field->getName());
2144 
2145     // If this is a reference field, load the reference right now.
2146     if (const ReferenceType *refType = type->getAs<ReferenceType>()) {
2147       llvm::LoadInst *load = Builder.CreateLoad(addr, "ref");
2148       if (cvr & Qualifiers::Volatile) load->setVolatile(true);
2149       load->setAlignment(alignment.getQuantity());
2150 
2151       if (CGM.shouldUseTBAA()) {
2152         llvm::MDNode *tbaa;
2153         if (mayAlias)
2154           tbaa = CGM.getTBAAInfo(getContext().CharTy);
2155         else
2156           tbaa = CGM.getTBAAInfo(type);
2157         CGM.DecorateInstruction(load, tbaa);
2158       }
2159 
2160       addr = load;
2161       mayAlias = false;
2162       type = refType->getPointeeType();
2163       if (type->isIncompleteType())
2164         alignment = CharUnits();
2165       else
2166         alignment = getContext().getTypeAlignInChars(type);
2167       cvr = 0; // qualifiers don't recursively apply to referencee
2168     }
2169   }
2170 
2171   // Make sure that the address is pointing to the right type.  This is critical
2172   // for both unions and structs.  A union needs a bitcast, a struct element
2173   // will need a bitcast if the LLVM type laid out doesn't match the desired
2174   // type.
2175   addr = EmitBitCastOfLValueToProperType(*this, addr,
2176                                          CGM.getTypes().ConvertTypeForMem(type),
2177                                          field->getName());
2178 
2179   if (field->hasAttr<AnnotateAttr>())
2180     addr = EmitFieldAnnotations(field, addr);
2181 
2182   LValue LV = MakeAddrLValue(addr, type, alignment);
2183   LV.getQuals().addCVRQualifiers(cvr);
2184 
2185   // __weak attribute on a field is ignored.
2186   if (LV.getQuals().getObjCGCAttr() == Qualifiers::Weak)
2187     LV.getQuals().removeObjCGCAttr();
2188 
2189   // Fields of may_alias structs act like 'char' for TBAA purposes.
2190   // FIXME: this should get propagated down through anonymous structs
2191   // and unions.
2192   if (mayAlias && LV.getTBAAInfo())
2193     LV.setTBAAInfo(CGM.getTBAAInfo(getContext().CharTy));
2194 
2195   return LV;
2196 }
2197 
2198 LValue
2199 CodeGenFunction::EmitLValueForFieldInitialization(LValue Base,
2200                                                   const FieldDecl *Field) {
2201   QualType FieldType = Field->getType();
2202 
2203   if (!FieldType->isReferenceType())
2204     return EmitLValueForField(Base, Field);
2205 
2206   const CGRecordLayout &RL =
2207     CGM.getTypes().getCGRecordLayout(Field->getParent());
2208   unsigned idx = RL.getLLVMFieldNo(Field);
2209   llvm::Value *V = Builder.CreateStructGEP(Base.getAddress(), idx);
2210   assert(!FieldType.getObjCGCAttr() && "fields cannot have GC attrs");
2211 
2212   // Make sure that the address is pointing to the right type.  This is critical
2213   // for both unions and structs.  A union needs a bitcast, a struct element
2214   // will need a bitcast if the LLVM type laid out doesn't match the desired
2215   // type.
2216   llvm::Type *llvmType = ConvertTypeForMem(FieldType);
2217   V = EmitBitCastOfLValueToProperType(*this, V, llvmType, Field->getName());
2218 
2219   CharUnits Alignment = getContext().getDeclAlign(Field);
2220 
2221   // FIXME: It should be impossible to have an LValue without alignment for a
2222   // complete type.
2223   if (!Base.getAlignment().isZero())
2224     Alignment = std::min(Alignment, Base.getAlignment());
2225 
2226   return MakeAddrLValue(V, FieldType, Alignment);
2227 }
2228 
2229 LValue CodeGenFunction::EmitCompoundLiteralLValue(const CompoundLiteralExpr *E){
2230   if (E->isFileScope()) {
2231     llvm::Value *GlobalPtr = CGM.GetAddrOfConstantCompoundLiteral(E);
2232     return MakeAddrLValue(GlobalPtr, E->getType());
2233   }
2234   if (E->getType()->isVariablyModifiedType())
2235     // make sure to emit the VLA size.
2236     EmitVariablyModifiedType(E->getType());
2237 
2238   llvm::Value *DeclPtr = CreateMemTemp(E->getType(), ".compoundliteral");
2239   const Expr *InitExpr = E->getInitializer();
2240   LValue Result = MakeAddrLValue(DeclPtr, E->getType());
2241 
2242   EmitAnyExprToMem(InitExpr, DeclPtr, E->getType().getQualifiers(),
2243                    /*Init*/ true);
2244 
2245   return Result;
2246 }
2247 
2248 LValue CodeGenFunction::EmitInitListLValue(const InitListExpr *E) {
2249   if (!E->isGLValue())
2250     // Initializing an aggregate temporary in C++11: T{...}.
2251     return EmitAggExprToLValue(E);
2252 
2253   // An lvalue initializer list must be initializing a reference.
2254   assert(E->getNumInits() == 1 && "reference init with multiple values");
2255   return EmitLValue(E->getInit(0));
2256 }
2257 
2258 LValue CodeGenFunction::
2259 EmitConditionalOperatorLValue(const AbstractConditionalOperator *expr) {
2260   if (!expr->isGLValue()) {
2261     // ?: here should be an aggregate.
2262     assert((hasAggregateLLVMType(expr->getType()) &&
2263             !expr->getType()->isAnyComplexType()) &&
2264            "Unexpected conditional operator!");
2265     return EmitAggExprToLValue(expr);
2266   }
2267 
2268   OpaqueValueMapping binding(*this, expr);
2269 
2270   const Expr *condExpr = expr->getCond();
2271   bool CondExprBool;
2272   if (ConstantFoldsToSimpleInteger(condExpr, CondExprBool)) {
2273     const Expr *live = expr->getTrueExpr(), *dead = expr->getFalseExpr();
2274     if (!CondExprBool) std::swap(live, dead);
2275 
2276     if (!ContainsLabel(dead))
2277       return EmitLValue(live);
2278   }
2279 
2280   llvm::BasicBlock *lhsBlock = createBasicBlock("cond.true");
2281   llvm::BasicBlock *rhsBlock = createBasicBlock("cond.false");
2282   llvm::BasicBlock *contBlock = createBasicBlock("cond.end");
2283 
2284   ConditionalEvaluation eval(*this);
2285   EmitBranchOnBoolExpr(condExpr, lhsBlock, rhsBlock);
2286 
2287   // Any temporaries created here are conditional.
2288   EmitBlock(lhsBlock);
2289   eval.begin(*this);
2290   LValue lhs = EmitLValue(expr->getTrueExpr());
2291   eval.end(*this);
2292 
2293   if (!lhs.isSimple())
2294     return EmitUnsupportedLValue(expr, "conditional operator");
2295 
2296   lhsBlock = Builder.GetInsertBlock();
2297   Builder.CreateBr(contBlock);
2298 
2299   // Any temporaries created here are conditional.
2300   EmitBlock(rhsBlock);
2301   eval.begin(*this);
2302   LValue rhs = EmitLValue(expr->getFalseExpr());
2303   eval.end(*this);
2304   if (!rhs.isSimple())
2305     return EmitUnsupportedLValue(expr, "conditional operator");
2306   rhsBlock = Builder.GetInsertBlock();
2307 
2308   EmitBlock(contBlock);
2309 
2310   llvm::PHINode *phi = Builder.CreatePHI(lhs.getAddress()->getType(), 2,
2311                                          "cond-lvalue");
2312   phi->addIncoming(lhs.getAddress(), lhsBlock);
2313   phi->addIncoming(rhs.getAddress(), rhsBlock);
2314   return MakeAddrLValue(phi, expr->getType());
2315 }
2316 
2317 /// EmitCastLValue - Casts are never lvalues unless that cast is to a reference
2318 /// type. If the cast is to a reference, we can have the usual lvalue result,
2319 /// otherwise if a cast is needed by the code generator in an lvalue context,
2320 /// then it must mean that we need the address of an aggregate in order to
2321 /// access one of its members.  This can happen for all the reasons that casts
2322 /// are permitted with aggregate result, including noop aggregate casts, and
2323 /// cast from scalar to union.
2324 LValue CodeGenFunction::EmitCastLValue(const CastExpr *E) {
2325   switch (E->getCastKind()) {
2326   case CK_ToVoid:
2327     return EmitUnsupportedLValue(E, "unexpected cast lvalue");
2328 
2329   case CK_Dependent:
2330     llvm_unreachable("dependent cast kind in IR gen!");
2331 
2332   // These two casts are currently treated as no-ops, although they could
2333   // potentially be real operations depending on the target's ABI.
2334   case CK_NonAtomicToAtomic:
2335   case CK_AtomicToNonAtomic:
2336 
2337   case CK_NoOp:
2338   case CK_LValueToRValue:
2339     if (!E->getSubExpr()->Classify(getContext()).isPRValue()
2340         || E->getType()->isRecordType())
2341       return EmitLValue(E->getSubExpr());
2342     // Fall through to synthesize a temporary.
2343 
2344   case CK_BitCast:
2345   case CK_ArrayToPointerDecay:
2346   case CK_FunctionToPointerDecay:
2347   case CK_NullToMemberPointer:
2348   case CK_NullToPointer:
2349   case CK_IntegralToPointer:
2350   case CK_PointerToIntegral:
2351   case CK_PointerToBoolean:
2352   case CK_VectorSplat:
2353   case CK_IntegralCast:
2354   case CK_IntegralToBoolean:
2355   case CK_IntegralToFloating:
2356   case CK_FloatingToIntegral:
2357   case CK_FloatingToBoolean:
2358   case CK_FloatingCast:
2359   case CK_FloatingRealToComplex:
2360   case CK_FloatingComplexToReal:
2361   case CK_FloatingComplexToBoolean:
2362   case CK_FloatingComplexCast:
2363   case CK_FloatingComplexToIntegralComplex:
2364   case CK_IntegralRealToComplex:
2365   case CK_IntegralComplexToReal:
2366   case CK_IntegralComplexToBoolean:
2367   case CK_IntegralComplexCast:
2368   case CK_IntegralComplexToFloatingComplex:
2369   case CK_DerivedToBaseMemberPointer:
2370   case CK_BaseToDerivedMemberPointer:
2371   case CK_MemberPointerToBoolean:
2372   case CK_ReinterpretMemberPointer:
2373   case CK_AnyPointerToBlockPointerCast:
2374   case CK_ARCProduceObject:
2375   case CK_ARCConsumeObject:
2376   case CK_ARCReclaimReturnedObject:
2377   case CK_ARCExtendBlockObject:
2378   case CK_CopyAndAutoreleaseBlockObject: {
2379     // These casts only produce lvalues when we're binding a reference to a
2380     // temporary realized from a (converted) pure rvalue. Emit the expression
2381     // as a value, copy it into a temporary, and return an lvalue referring to
2382     // that temporary.
2383     llvm::Value *V = CreateMemTemp(E->getType(), "ref.temp");
2384     EmitAnyExprToMem(E, V, E->getType().getQualifiers(), false);
2385     return MakeAddrLValue(V, E->getType());
2386   }
2387 
2388   case CK_Dynamic: {
2389     LValue LV = EmitLValue(E->getSubExpr());
2390     llvm::Value *V = LV.getAddress();
2391     const CXXDynamicCastExpr *DCE = cast<CXXDynamicCastExpr>(E);
2392     return MakeAddrLValue(EmitDynamicCast(V, DCE), E->getType());
2393   }
2394 
2395   case CK_ConstructorConversion:
2396   case CK_UserDefinedConversion:
2397   case CK_CPointerToObjCPointerCast:
2398   case CK_BlockPointerToObjCPointerCast:
2399     return EmitLValue(E->getSubExpr());
2400 
2401   case CK_UncheckedDerivedToBase:
2402   case CK_DerivedToBase: {
2403     const RecordType *DerivedClassTy =
2404       E->getSubExpr()->getType()->getAs<RecordType>();
2405     CXXRecordDecl *DerivedClassDecl =
2406       cast<CXXRecordDecl>(DerivedClassTy->getDecl());
2407 
2408     LValue LV = EmitLValue(E->getSubExpr());
2409     llvm::Value *This = LV.getAddress();
2410 
2411     // Perform the derived-to-base conversion
2412     llvm::Value *Base =
2413       GetAddressOfBaseClass(This, DerivedClassDecl,
2414                             E->path_begin(), E->path_end(),
2415                             /*NullCheckValue=*/false);
2416 
2417     return MakeAddrLValue(Base, E->getType());
2418   }
2419   case CK_ToUnion:
2420     return EmitAggExprToLValue(E);
2421   case CK_BaseToDerived: {
2422     const RecordType *DerivedClassTy = E->getType()->getAs<RecordType>();
2423     CXXRecordDecl *DerivedClassDecl =
2424       cast<CXXRecordDecl>(DerivedClassTy->getDecl());
2425 
2426     LValue LV = EmitLValue(E->getSubExpr());
2427 
2428     // Perform the base-to-derived conversion
2429     llvm::Value *Derived =
2430       GetAddressOfDerivedClass(LV.getAddress(), DerivedClassDecl,
2431                                E->path_begin(), E->path_end(),
2432                                /*NullCheckValue=*/false);
2433 
2434     return MakeAddrLValue(Derived, E->getType());
2435   }
2436   case CK_LValueBitCast: {
2437     // This must be a reinterpret_cast (or c-style equivalent).
2438     const ExplicitCastExpr *CE = cast<ExplicitCastExpr>(E);
2439 
2440     LValue LV = EmitLValue(E->getSubExpr());
2441     llvm::Value *V = Builder.CreateBitCast(LV.getAddress(),
2442                                            ConvertType(CE->getTypeAsWritten()));
2443     return MakeAddrLValue(V, E->getType());
2444   }
2445   case CK_ObjCObjectLValueCast: {
2446     LValue LV = EmitLValue(E->getSubExpr());
2447     QualType ToType = getContext().getLValueReferenceType(E->getType());
2448     llvm::Value *V = Builder.CreateBitCast(LV.getAddress(),
2449                                            ConvertType(ToType));
2450     return MakeAddrLValue(V, E->getType());
2451   }
2452   }
2453 
2454   llvm_unreachable("Unhandled lvalue cast kind?");
2455 }
2456 
2457 LValue CodeGenFunction::EmitNullInitializationLValue(
2458                                               const CXXScalarValueInitExpr *E) {
2459   QualType Ty = E->getType();
2460   LValue LV = MakeAddrLValue(CreateMemTemp(Ty), Ty);
2461   EmitNullInitialization(LV.getAddress(), Ty);
2462   return LV;
2463 }
2464 
2465 LValue CodeGenFunction::EmitOpaqueValueLValue(const OpaqueValueExpr *e) {
2466   assert(OpaqueValueMappingData::shouldBindAsLValue(e));
2467   return getOpaqueLValueMapping(e);
2468 }
2469 
2470 LValue CodeGenFunction::EmitMaterializeTemporaryExpr(
2471                                            const MaterializeTemporaryExpr *E) {
2472   RValue RV = EmitReferenceBindingToExpr(E, /*InitializedDecl=*/0);
2473   return MakeAddrLValue(RV.getScalarVal(), E->getType());
2474 }
2475 
2476 RValue CodeGenFunction::EmitRValueForField(LValue LV,
2477                                            const FieldDecl *FD) {
2478   QualType FT = FD->getType();
2479   LValue FieldLV = EmitLValueForField(LV, FD);
2480   if (FT->isAnyComplexType())
2481     return RValue::getComplex(
2482         LoadComplexFromAddr(FieldLV.getAddress(),
2483                             FieldLV.isVolatileQualified()));
2484   else if (CodeGenFunction::hasAggregateLLVMType(FT))
2485     return FieldLV.asAggregateRValue();
2486 
2487   return EmitLoadOfLValue(FieldLV);
2488 }
2489 
2490 //===--------------------------------------------------------------------===//
2491 //                             Expression Emission
2492 //===--------------------------------------------------------------------===//
2493 
2494 RValue CodeGenFunction::EmitCallExpr(const CallExpr *E,
2495                                      ReturnValueSlot ReturnValue) {
2496   if (CGDebugInfo *DI = getDebugInfo())
2497     DI->EmitLocation(Builder, E->getLocStart());
2498 
2499   // Builtins never have block type.
2500   if (E->getCallee()->getType()->isBlockPointerType())
2501     return EmitBlockCallExpr(E, ReturnValue);
2502 
2503   if (const CXXMemberCallExpr *CE = dyn_cast<CXXMemberCallExpr>(E))
2504     return EmitCXXMemberCallExpr(CE, ReturnValue);
2505 
2506   if (const CUDAKernelCallExpr *CE = dyn_cast<CUDAKernelCallExpr>(E))
2507     return EmitCUDAKernelCallExpr(CE, ReturnValue);
2508 
2509   const Decl *TargetDecl = E->getCalleeDecl();
2510   if (const FunctionDecl *FD = dyn_cast_or_null<FunctionDecl>(TargetDecl)) {
2511     if (unsigned builtinID = FD->getBuiltinID())
2512       return EmitBuiltinExpr(FD, builtinID, E);
2513   }
2514 
2515   if (const CXXOperatorCallExpr *CE = dyn_cast<CXXOperatorCallExpr>(E))
2516     if (const CXXMethodDecl *MD = dyn_cast_or_null<CXXMethodDecl>(TargetDecl))
2517       return EmitCXXOperatorMemberCallExpr(CE, MD, ReturnValue);
2518 
2519   if (const CXXPseudoDestructorExpr *PseudoDtor
2520           = dyn_cast<CXXPseudoDestructorExpr>(E->getCallee()->IgnoreParens())) {
2521     QualType DestroyedType = PseudoDtor->getDestroyedType();
2522     if (getContext().getLangOpts().ObjCAutoRefCount &&
2523         DestroyedType->isObjCLifetimeType() &&
2524         (DestroyedType.getObjCLifetime() == Qualifiers::OCL_Strong ||
2525          DestroyedType.getObjCLifetime() == Qualifiers::OCL_Weak)) {
2526       // Automatic Reference Counting:
2527       //   If the pseudo-expression names a retainable object with weak or
2528       //   strong lifetime, the object shall be released.
2529       Expr *BaseExpr = PseudoDtor->getBase();
2530       llvm::Value *BaseValue = NULL;
2531       Qualifiers BaseQuals;
2532 
2533       // If this is s.x, emit s as an lvalue. If it is s->x, emit s as a scalar.
2534       if (PseudoDtor->isArrow()) {
2535         BaseValue = EmitScalarExpr(BaseExpr);
2536         const PointerType *PTy = BaseExpr->getType()->getAs<PointerType>();
2537         BaseQuals = PTy->getPointeeType().getQualifiers();
2538       } else {
2539         LValue BaseLV = EmitLValue(BaseExpr);
2540         BaseValue = BaseLV.getAddress();
2541         QualType BaseTy = BaseExpr->getType();
2542         BaseQuals = BaseTy.getQualifiers();
2543       }
2544 
2545       switch (PseudoDtor->getDestroyedType().getObjCLifetime()) {
2546       case Qualifiers::OCL_None:
2547       case Qualifiers::OCL_ExplicitNone:
2548       case Qualifiers::OCL_Autoreleasing:
2549         break;
2550 
2551       case Qualifiers::OCL_Strong:
2552         EmitARCRelease(Builder.CreateLoad(BaseValue,
2553                           PseudoDtor->getDestroyedType().isVolatileQualified()),
2554                        /*precise*/ true);
2555         break;
2556 
2557       case Qualifiers::OCL_Weak:
2558         EmitARCDestroyWeak(BaseValue);
2559         break;
2560       }
2561     } else {
2562       // C++ [expr.pseudo]p1:
2563       //   The result shall only be used as the operand for the function call
2564       //   operator (), and the result of such a call has type void. The only
2565       //   effect is the evaluation of the postfix-expression before the dot or
2566       //   arrow.
2567       EmitScalarExpr(E->getCallee());
2568     }
2569 
2570     return RValue::get(0);
2571   }
2572 
2573   llvm::Value *Callee = EmitScalarExpr(E->getCallee());
2574   return EmitCall(E->getCallee()->getType(), Callee, ReturnValue,
2575                   E->arg_begin(), E->arg_end(), TargetDecl);
2576 }
2577 
2578 LValue CodeGenFunction::EmitBinaryOperatorLValue(const BinaryOperator *E) {
2579   // Comma expressions just emit their LHS then their RHS as an l-value.
2580   if (E->getOpcode() == BO_Comma) {
2581     EmitIgnoredExpr(E->getLHS());
2582     EnsureInsertPoint();
2583     return EmitLValue(E->getRHS());
2584   }
2585 
2586   if (E->getOpcode() == BO_PtrMemD ||
2587       E->getOpcode() == BO_PtrMemI)
2588     return EmitPointerToDataMemberBinaryExpr(E);
2589 
2590   assert(E->getOpcode() == BO_Assign && "unexpected binary l-value");
2591 
2592   // Note that in all of these cases, __block variables need the RHS
2593   // evaluated first just in case the variable gets moved by the RHS.
2594 
2595   if (!hasAggregateLLVMType(E->getType())) {
2596     switch (E->getLHS()->getType().getObjCLifetime()) {
2597     case Qualifiers::OCL_Strong:
2598       return EmitARCStoreStrong(E, /*ignored*/ false).first;
2599 
2600     case Qualifiers::OCL_Autoreleasing:
2601       return EmitARCStoreAutoreleasing(E).first;
2602 
2603     // No reason to do any of these differently.
2604     case Qualifiers::OCL_None:
2605     case Qualifiers::OCL_ExplicitNone:
2606     case Qualifiers::OCL_Weak:
2607       break;
2608     }
2609 
2610     RValue RV = EmitAnyExpr(E->getRHS());
2611     LValue LV = EmitLValue(E->getLHS());
2612     EmitStoreThroughLValue(RV, LV);
2613     return LV;
2614   }
2615 
2616   if (E->getType()->isAnyComplexType())
2617     return EmitComplexAssignmentLValue(E);
2618 
2619   return EmitAggExprToLValue(E);
2620 }
2621 
2622 LValue CodeGenFunction::EmitCallExprLValue(const CallExpr *E) {
2623   RValue RV = EmitCallExpr(E);
2624 
2625   if (!RV.isScalar())
2626     return MakeAddrLValue(RV.getAggregateAddr(), E->getType());
2627 
2628   assert(E->getCallReturnType()->isReferenceType() &&
2629          "Can't have a scalar return unless the return type is a "
2630          "reference type!");
2631 
2632   return MakeAddrLValue(RV.getScalarVal(), E->getType());
2633 }
2634 
2635 LValue CodeGenFunction::EmitVAArgExprLValue(const VAArgExpr *E) {
2636   // FIXME: This shouldn't require another copy.
2637   return EmitAggExprToLValue(E);
2638 }
2639 
2640 LValue CodeGenFunction::EmitCXXConstructLValue(const CXXConstructExpr *E) {
2641   assert(E->getType()->getAsCXXRecordDecl()->hasTrivialDestructor()
2642          && "binding l-value to type which needs a temporary");
2643   AggValueSlot Slot = CreateAggTemp(E->getType());
2644   EmitCXXConstructExpr(E, Slot);
2645   return MakeAddrLValue(Slot.getAddr(), E->getType());
2646 }
2647 
2648 LValue
2649 CodeGenFunction::EmitCXXTypeidLValue(const CXXTypeidExpr *E) {
2650   return MakeAddrLValue(EmitCXXTypeidExpr(E), E->getType());
2651 }
2652 
2653 LValue
2654 CodeGenFunction::EmitCXXBindTemporaryLValue(const CXXBindTemporaryExpr *E) {
2655   AggValueSlot Slot = CreateAggTemp(E->getType(), "temp.lvalue");
2656   Slot.setExternallyDestructed();
2657   EmitAggExpr(E->getSubExpr(), Slot);
2658   EmitCXXTemporary(E->getTemporary(), E->getType(), Slot.getAddr());
2659   return MakeAddrLValue(Slot.getAddr(), E->getType());
2660 }
2661 
2662 LValue
2663 CodeGenFunction::EmitLambdaLValue(const LambdaExpr *E) {
2664   AggValueSlot Slot = CreateAggTemp(E->getType(), "temp.lvalue");
2665   EmitLambdaExpr(E, Slot);
2666   return MakeAddrLValue(Slot.getAddr(), E->getType());
2667 }
2668 
2669 LValue CodeGenFunction::EmitObjCMessageExprLValue(const ObjCMessageExpr *E) {
2670   RValue RV = EmitObjCMessageExpr(E);
2671 
2672   if (!RV.isScalar())
2673     return MakeAddrLValue(RV.getAggregateAddr(), E->getType());
2674 
2675   assert(E->getMethodDecl()->getResultType()->isReferenceType() &&
2676          "Can't have a scalar return unless the return type is a "
2677          "reference type!");
2678 
2679   return MakeAddrLValue(RV.getScalarVal(), E->getType());
2680 }
2681 
2682 LValue CodeGenFunction::EmitObjCSelectorLValue(const ObjCSelectorExpr *E) {
2683   llvm::Value *V =
2684     CGM.getObjCRuntime().GetSelector(Builder, E->getSelector(), true);
2685   return MakeAddrLValue(V, E->getType());
2686 }
2687 
2688 llvm::Value *CodeGenFunction::EmitIvarOffset(const ObjCInterfaceDecl *Interface,
2689                                              const ObjCIvarDecl *Ivar) {
2690   return CGM.getObjCRuntime().EmitIvarOffset(*this, Interface, Ivar);
2691 }
2692 
2693 LValue CodeGenFunction::EmitLValueForIvar(QualType ObjectTy,
2694                                           llvm::Value *BaseValue,
2695                                           const ObjCIvarDecl *Ivar,
2696                                           unsigned CVRQualifiers) {
2697   return CGM.getObjCRuntime().EmitObjCValueForIvar(*this, ObjectTy, BaseValue,
2698                                                    Ivar, CVRQualifiers);
2699 }
2700 
2701 LValue CodeGenFunction::EmitObjCIvarRefLValue(const ObjCIvarRefExpr *E) {
2702   // FIXME: A lot of the code below could be shared with EmitMemberExpr.
2703   llvm::Value *BaseValue = 0;
2704   const Expr *BaseExpr = E->getBase();
2705   Qualifiers BaseQuals;
2706   QualType ObjectTy;
2707   if (E->isArrow()) {
2708     BaseValue = EmitScalarExpr(BaseExpr);
2709     ObjectTy = BaseExpr->getType()->getPointeeType();
2710     BaseQuals = ObjectTy.getQualifiers();
2711   } else {
2712     LValue BaseLV = EmitLValue(BaseExpr);
2713     // FIXME: this isn't right for bitfields.
2714     BaseValue = BaseLV.getAddress();
2715     ObjectTy = BaseExpr->getType();
2716     BaseQuals = ObjectTy.getQualifiers();
2717   }
2718 
2719   LValue LV =
2720     EmitLValueForIvar(ObjectTy, BaseValue, E->getDecl(),
2721                       BaseQuals.getCVRQualifiers());
2722   setObjCGCLValueClass(getContext(), E, LV);
2723   return LV;
2724 }
2725 
2726 LValue CodeGenFunction::EmitStmtExprLValue(const StmtExpr *E) {
2727   // Can only get l-value for message expression returning aggregate type
2728   RValue RV = EmitAnyExprToTemp(E);
2729   return MakeAddrLValue(RV.getAggregateAddr(), E->getType());
2730 }
2731 
2732 RValue CodeGenFunction::EmitCall(QualType CalleeType, llvm::Value *Callee,
2733                                  ReturnValueSlot ReturnValue,
2734                                  CallExpr::const_arg_iterator ArgBeg,
2735                                  CallExpr::const_arg_iterator ArgEnd,
2736                                  const Decl *TargetDecl) {
2737   // Get the actual function type. The callee type will always be a pointer to
2738   // function type or a block pointer type.
2739   assert(CalleeType->isFunctionPointerType() &&
2740          "Call must have function pointer type!");
2741 
2742   CalleeType = getContext().getCanonicalType(CalleeType);
2743 
2744   const FunctionType *FnType
2745     = cast<FunctionType>(cast<PointerType>(CalleeType)->getPointeeType());
2746 
2747   CallArgList Args;
2748   EmitCallArgs(Args, dyn_cast<FunctionProtoType>(FnType), ArgBeg, ArgEnd);
2749 
2750   const CGFunctionInfo &FnInfo =
2751     CGM.getTypes().arrangeFunctionCall(Args, FnType);
2752 
2753   // C99 6.5.2.2p6:
2754   //   If the expression that denotes the called function has a type
2755   //   that does not include a prototype, [the default argument
2756   //   promotions are performed]. If the number of arguments does not
2757   //   equal the number of parameters, the behavior is undefined. If
2758   //   the function is defined with a type that includes a prototype,
2759   //   and either the prototype ends with an ellipsis (, ...) or the
2760   //   types of the arguments after promotion are not compatible with
2761   //   the types of the parameters, the behavior is undefined. If the
2762   //   function is defined with a type that does not include a
2763   //   prototype, and the types of the arguments after promotion are
2764   //   not compatible with those of the parameters after promotion,
2765   //   the behavior is undefined [except in some trivial cases].
2766   // That is, in the general case, we should assume that a call
2767   // through an unprototyped function type works like a *non-variadic*
2768   // call.  The way we make this work is to cast to the exact type
2769   // of the promoted arguments.
2770   if (isa<FunctionNoProtoType>(FnType) && !FnInfo.isVariadic()) {
2771     llvm::Type *CalleeTy = getTypes().GetFunctionType(FnInfo);
2772     CalleeTy = CalleeTy->getPointerTo();
2773     Callee = Builder.CreateBitCast(Callee, CalleeTy, "callee.knr.cast");
2774   }
2775 
2776   return EmitCall(FnInfo, Callee, ReturnValue, Args, TargetDecl);
2777 }
2778 
2779 LValue CodeGenFunction::
2780 EmitPointerToDataMemberBinaryExpr(const BinaryOperator *E) {
2781   llvm::Value *BaseV;
2782   if (E->getOpcode() == BO_PtrMemI)
2783     BaseV = EmitScalarExpr(E->getLHS());
2784   else
2785     BaseV = EmitLValue(E->getLHS()).getAddress();
2786 
2787   llvm::Value *OffsetV = EmitScalarExpr(E->getRHS());
2788 
2789   const MemberPointerType *MPT
2790     = E->getRHS()->getType()->getAs<MemberPointerType>();
2791 
2792   llvm::Value *AddV =
2793     CGM.getCXXABI().EmitMemberDataPointerAddress(*this, BaseV, OffsetV, MPT);
2794 
2795   return MakeAddrLValue(AddV, MPT->getPointeeType());
2796 }
2797 
2798 static void
2799 EmitAtomicOp(CodeGenFunction &CGF, AtomicExpr *E, llvm::Value *Dest,
2800              llvm::Value *Ptr, llvm::Value *Val1, llvm::Value *Val2,
2801              uint64_t Size, unsigned Align, llvm::AtomicOrdering Order) {
2802   llvm::AtomicRMWInst::BinOp Op = llvm::AtomicRMWInst::Add;
2803   llvm::Instruction::BinaryOps PostOp = (llvm::Instruction::BinaryOps)0;
2804 
2805   switch (E->getOp()) {
2806   case AtomicExpr::AO__c11_atomic_init:
2807     llvm_unreachable("Already handled!");
2808 
2809   case AtomicExpr::AO__c11_atomic_compare_exchange_strong:
2810   case AtomicExpr::AO__c11_atomic_compare_exchange_weak:
2811   case AtomicExpr::AO__atomic_compare_exchange:
2812   case AtomicExpr::AO__atomic_compare_exchange_n: {
2813     // Note that cmpxchg only supports specifying one ordering and
2814     // doesn't support weak cmpxchg, at least at the moment.
2815     llvm::LoadInst *LoadVal1 = CGF.Builder.CreateLoad(Val1);
2816     LoadVal1->setAlignment(Align);
2817     llvm::LoadInst *LoadVal2 = CGF.Builder.CreateLoad(Val2);
2818     LoadVal2->setAlignment(Align);
2819     llvm::AtomicCmpXchgInst *CXI =
2820         CGF.Builder.CreateAtomicCmpXchg(Ptr, LoadVal1, LoadVal2, Order);
2821     CXI->setVolatile(E->isVolatile());
2822     llvm::StoreInst *StoreVal1 = CGF.Builder.CreateStore(CXI, Val1);
2823     StoreVal1->setAlignment(Align);
2824     llvm::Value *Cmp = CGF.Builder.CreateICmpEQ(CXI, LoadVal1);
2825     CGF.EmitStoreOfScalar(Cmp, CGF.MakeAddrLValue(Dest, E->getType()));
2826     return;
2827   }
2828 
2829   case AtomicExpr::AO__c11_atomic_load:
2830   case AtomicExpr::AO__atomic_load_n:
2831   case AtomicExpr::AO__atomic_load: {
2832     llvm::LoadInst *Load = CGF.Builder.CreateLoad(Ptr);
2833     Load->setAtomic(Order);
2834     Load->setAlignment(Size);
2835     Load->setVolatile(E->isVolatile());
2836     llvm::StoreInst *StoreDest = CGF.Builder.CreateStore(Load, Dest);
2837     StoreDest->setAlignment(Align);
2838     return;
2839   }
2840 
2841   case AtomicExpr::AO__c11_atomic_store:
2842   case AtomicExpr::AO__atomic_store:
2843   case AtomicExpr::AO__atomic_store_n: {
2844     assert(!Dest && "Store does not return a value");
2845     llvm::LoadInst *LoadVal1 = CGF.Builder.CreateLoad(Val1);
2846     LoadVal1->setAlignment(Align);
2847     llvm::StoreInst *Store = CGF.Builder.CreateStore(LoadVal1, Ptr);
2848     Store->setAtomic(Order);
2849     Store->setAlignment(Size);
2850     Store->setVolatile(E->isVolatile());
2851     return;
2852   }
2853 
2854   case AtomicExpr::AO__c11_atomic_exchange:
2855   case AtomicExpr::AO__atomic_exchange_n:
2856   case AtomicExpr::AO__atomic_exchange:
2857     Op = llvm::AtomicRMWInst::Xchg;
2858     break;
2859 
2860   case AtomicExpr::AO__atomic_add_fetch:
2861     PostOp = llvm::Instruction::Add;
2862     // Fall through.
2863   case AtomicExpr::AO__c11_atomic_fetch_add:
2864   case AtomicExpr::AO__atomic_fetch_add:
2865     Op = llvm::AtomicRMWInst::Add;
2866     break;
2867 
2868   case AtomicExpr::AO__atomic_sub_fetch:
2869     PostOp = llvm::Instruction::Sub;
2870     // Fall through.
2871   case AtomicExpr::AO__c11_atomic_fetch_sub:
2872   case AtomicExpr::AO__atomic_fetch_sub:
2873     Op = llvm::AtomicRMWInst::Sub;
2874     break;
2875 
2876   case AtomicExpr::AO__atomic_and_fetch:
2877     PostOp = llvm::Instruction::And;
2878     // Fall through.
2879   case AtomicExpr::AO__c11_atomic_fetch_and:
2880   case AtomicExpr::AO__atomic_fetch_and:
2881     Op = llvm::AtomicRMWInst::And;
2882     break;
2883 
2884   case AtomicExpr::AO__atomic_or_fetch:
2885     PostOp = llvm::Instruction::Or;
2886     // Fall through.
2887   case AtomicExpr::AO__c11_atomic_fetch_or:
2888   case AtomicExpr::AO__atomic_fetch_or:
2889     Op = llvm::AtomicRMWInst::Or;
2890     break;
2891 
2892   case AtomicExpr::AO__atomic_xor_fetch:
2893     PostOp = llvm::Instruction::Xor;
2894     // Fall through.
2895   case AtomicExpr::AO__c11_atomic_fetch_xor:
2896   case AtomicExpr::AO__atomic_fetch_xor:
2897     Op = llvm::AtomicRMWInst::Xor;
2898     break;
2899 
2900   case AtomicExpr::AO__atomic_nand_fetch:
2901     PostOp = llvm::Instruction::And;
2902     // Fall through.
2903   case AtomicExpr::AO__atomic_fetch_nand:
2904     Op = llvm::AtomicRMWInst::Nand;
2905     break;
2906   }
2907 
2908   llvm::LoadInst *LoadVal1 = CGF.Builder.CreateLoad(Val1);
2909   LoadVal1->setAlignment(Align);
2910   llvm::AtomicRMWInst *RMWI =
2911       CGF.Builder.CreateAtomicRMW(Op, Ptr, LoadVal1, Order);
2912   RMWI->setVolatile(E->isVolatile());
2913 
2914   // For __atomic_*_fetch operations, perform the operation again to
2915   // determine the value which was written.
2916   llvm::Value *Result = RMWI;
2917   if (PostOp)
2918     Result = CGF.Builder.CreateBinOp(PostOp, RMWI, LoadVal1);
2919   if (E->getOp() == AtomicExpr::AO__atomic_nand_fetch)
2920     Result = CGF.Builder.CreateNot(Result);
2921   llvm::StoreInst *StoreDest = CGF.Builder.CreateStore(Result, Dest);
2922   StoreDest->setAlignment(Align);
2923 }
2924 
2925 // This function emits any expression (scalar, complex, or aggregate)
2926 // into a temporary alloca.
2927 static llvm::Value *
2928 EmitValToTemp(CodeGenFunction &CGF, Expr *E) {
2929   llvm::Value *DeclPtr = CGF.CreateMemTemp(E->getType(), ".atomictmp");
2930   CGF.EmitAnyExprToMem(E, DeclPtr, E->getType().getQualifiers(),
2931                        /*Init*/ true);
2932   return DeclPtr;
2933 }
2934 
2935 static RValue ConvertTempToRValue(CodeGenFunction &CGF, QualType Ty,
2936                                   llvm::Value *Dest) {
2937   if (Ty->isAnyComplexType())
2938     return RValue::getComplex(CGF.LoadComplexFromAddr(Dest, false));
2939   if (CGF.hasAggregateLLVMType(Ty))
2940     return RValue::getAggregate(Dest);
2941   return RValue::get(CGF.EmitLoadOfScalar(CGF.MakeAddrLValue(Dest, Ty)));
2942 }
2943 
2944 RValue CodeGenFunction::EmitAtomicExpr(AtomicExpr *E, llvm::Value *Dest) {
2945   QualType AtomicTy = E->getPtr()->getType()->getPointeeType();
2946   QualType MemTy = AtomicTy;
2947   if (const AtomicType *AT = AtomicTy->getAs<AtomicType>())
2948     MemTy = AT->getValueType();
2949   CharUnits sizeChars = getContext().getTypeSizeInChars(AtomicTy);
2950   uint64_t Size = sizeChars.getQuantity();
2951   CharUnits alignChars = getContext().getTypeAlignInChars(AtomicTy);
2952   unsigned Align = alignChars.getQuantity();
2953   unsigned MaxInlineWidth =
2954       getContext().getTargetInfo().getMaxAtomicInlineWidth();
2955   bool UseLibcall = (Size != Align || Size > MaxInlineWidth);
2956 
2957 
2958 
2959   llvm::Value *Ptr, *Order, *OrderFail = 0, *Val1 = 0, *Val2 = 0;
2960   Ptr = EmitScalarExpr(E->getPtr());
2961 
2962   if (E->getOp() == AtomicExpr::AO__c11_atomic_init) {
2963     assert(!Dest && "Init does not return a value");
2964     if (!hasAggregateLLVMType(E->getVal1()->getType())) {
2965       QualType PointeeType
2966         = E->getPtr()->getType()->getAs<PointerType>()->getPointeeType();
2967       EmitScalarInit(EmitScalarExpr(E->getVal1()),
2968                      LValue::MakeAddr(Ptr, PointeeType, alignChars,
2969                                       getContext()));
2970     } else if (E->getType()->isAnyComplexType()) {
2971       EmitComplexExprIntoAddr(E->getVal1(), Ptr, E->isVolatile());
2972     } else {
2973       AggValueSlot Slot = AggValueSlot::forAddr(Ptr, alignChars,
2974                                         AtomicTy.getQualifiers(),
2975                                         AggValueSlot::IsNotDestructed,
2976                                         AggValueSlot::DoesNotNeedGCBarriers,
2977                                         AggValueSlot::IsNotAliased);
2978       EmitAggExpr(E->getVal1(), Slot);
2979     }
2980     return RValue::get(0);
2981   }
2982 
2983   Order = EmitScalarExpr(E->getOrder());
2984 
2985   switch (E->getOp()) {
2986   case AtomicExpr::AO__c11_atomic_init:
2987     llvm_unreachable("Already handled!");
2988 
2989   case AtomicExpr::AO__c11_atomic_load:
2990   case AtomicExpr::AO__atomic_load_n:
2991     break;
2992 
2993   case AtomicExpr::AO__atomic_load:
2994     Dest = EmitScalarExpr(E->getVal1());
2995     break;
2996 
2997   case AtomicExpr::AO__atomic_store:
2998     Val1 = EmitScalarExpr(E->getVal1());
2999     break;
3000 
3001   case AtomicExpr::AO__atomic_exchange:
3002     Val1 = EmitScalarExpr(E->getVal1());
3003     Dest = EmitScalarExpr(E->getVal2());
3004     break;
3005 
3006   case AtomicExpr::AO__c11_atomic_compare_exchange_strong:
3007   case AtomicExpr::AO__c11_atomic_compare_exchange_weak:
3008   case AtomicExpr::AO__atomic_compare_exchange_n:
3009   case AtomicExpr::AO__atomic_compare_exchange:
3010     Val1 = EmitScalarExpr(E->getVal1());
3011     if (E->getOp() == AtomicExpr::AO__atomic_compare_exchange)
3012       Val2 = EmitScalarExpr(E->getVal2());
3013     else
3014       Val2 = EmitValToTemp(*this, E->getVal2());
3015     OrderFail = EmitScalarExpr(E->getOrderFail());
3016     // Evaluate and discard the 'weak' argument.
3017     if (E->getNumSubExprs() == 6)
3018       EmitScalarExpr(E->getWeak());
3019     break;
3020 
3021   case AtomicExpr::AO__c11_atomic_fetch_add:
3022   case AtomicExpr::AO__c11_atomic_fetch_sub:
3023     if (MemTy->isPointerType()) {
3024       // For pointer arithmetic, we're required to do a bit of math:
3025       // adding 1 to an int* is not the same as adding 1 to a uintptr_t.
3026       // ... but only for the C11 builtins. The GNU builtins expect the
3027       // user to multiply by sizeof(T).
3028       QualType Val1Ty = E->getVal1()->getType();
3029       llvm::Value *Val1Scalar = EmitScalarExpr(E->getVal1());
3030       CharUnits PointeeIncAmt =
3031           getContext().getTypeSizeInChars(MemTy->getPointeeType());
3032       Val1Scalar = Builder.CreateMul(Val1Scalar, CGM.getSize(PointeeIncAmt));
3033       Val1 = CreateMemTemp(Val1Ty, ".atomictmp");
3034       EmitStoreOfScalar(Val1Scalar, MakeAddrLValue(Val1, Val1Ty));
3035       break;
3036     }
3037     // Fall through.
3038   case AtomicExpr::AO__atomic_fetch_add:
3039   case AtomicExpr::AO__atomic_fetch_sub:
3040   case AtomicExpr::AO__atomic_add_fetch:
3041   case AtomicExpr::AO__atomic_sub_fetch:
3042   case AtomicExpr::AO__c11_atomic_store:
3043   case AtomicExpr::AO__c11_atomic_exchange:
3044   case AtomicExpr::AO__atomic_store_n:
3045   case AtomicExpr::AO__atomic_exchange_n:
3046   case AtomicExpr::AO__c11_atomic_fetch_and:
3047   case AtomicExpr::AO__c11_atomic_fetch_or:
3048   case AtomicExpr::AO__c11_atomic_fetch_xor:
3049   case AtomicExpr::AO__atomic_fetch_and:
3050   case AtomicExpr::AO__atomic_fetch_or:
3051   case AtomicExpr::AO__atomic_fetch_xor:
3052   case AtomicExpr::AO__atomic_fetch_nand:
3053   case AtomicExpr::AO__atomic_and_fetch:
3054   case AtomicExpr::AO__atomic_or_fetch:
3055   case AtomicExpr::AO__atomic_xor_fetch:
3056   case AtomicExpr::AO__atomic_nand_fetch:
3057     Val1 = EmitValToTemp(*this, E->getVal1());
3058     break;
3059   }
3060 
3061   if (!E->getType()->isVoidType() && !Dest)
3062     Dest = CreateMemTemp(E->getType(), ".atomicdst");
3063 
3064   // Use a library call.  See: http://gcc.gnu.org/wiki/Atomic/GCCMM/LIbrary .
3065   if (UseLibcall) {
3066 
3067     llvm::SmallVector<QualType, 5> Params;
3068     CallArgList Args;
3069     // Size is always the first parameter
3070     Args.add(RValue::get(llvm::ConstantInt::get(SizeTy, Size)),
3071              getContext().getSizeType());
3072     // Atomic address is always the second parameter
3073     Args.add(RValue::get(EmitCastToVoidPtr(Ptr)),
3074              getContext().VoidPtrTy);
3075 
3076     const char* LibCallName;
3077     QualType RetTy = getContext().VoidTy;
3078     switch (E->getOp()) {
3079     // There is only one libcall for compare an exchange, because there is no
3080     // optimisation benefit possible from a libcall version of a weak compare
3081     // and exchange.
3082     // bool __atomic_compare_exchange(size_t size, void *obj, void *expected,
3083     //                                void *desired, int success, int failure)
3084     case AtomicExpr::AO__c11_atomic_compare_exchange_weak:
3085     case AtomicExpr::AO__c11_atomic_compare_exchange_strong:
3086     case AtomicExpr::AO__atomic_compare_exchange:
3087     case AtomicExpr::AO__atomic_compare_exchange_n:
3088       LibCallName = "__atomic_compare_exchange";
3089       RetTy = getContext().BoolTy;
3090       Args.add(RValue::get(EmitCastToVoidPtr(Val1)),
3091                getContext().VoidPtrTy);
3092       Args.add(RValue::get(EmitCastToVoidPtr(Val2)),
3093                getContext().VoidPtrTy);
3094       Args.add(RValue::get(Order),
3095                getContext().IntTy);
3096       Order = OrderFail;
3097       break;
3098     // void __atomic_exchange(size_t size, void *mem, void *val, void *return,
3099     //                        int order)
3100     case AtomicExpr::AO__c11_atomic_exchange:
3101     case AtomicExpr::AO__atomic_exchange_n:
3102     case AtomicExpr::AO__atomic_exchange:
3103       LibCallName = "__atomic_exchange";
3104       Args.add(RValue::get(EmitCastToVoidPtr(Val1)),
3105                getContext().VoidPtrTy);
3106       Args.add(RValue::get(EmitCastToVoidPtr(Dest)),
3107                getContext().VoidPtrTy);
3108       break;
3109     // void __atomic_store(size_t size, void *mem, void *val, int order)
3110     case AtomicExpr::AO__c11_atomic_store:
3111     case AtomicExpr::AO__atomic_store:
3112     case AtomicExpr::AO__atomic_store_n:
3113       LibCallName = "__atomic_store";
3114       Args.add(RValue::get(EmitCastToVoidPtr(Val1)),
3115                getContext().VoidPtrTy);
3116       break;
3117     // void __atomic_load(size_t size, void *mem, void *return, int order)
3118     case AtomicExpr::AO__c11_atomic_load:
3119     case AtomicExpr::AO__atomic_load:
3120     case AtomicExpr::AO__atomic_load_n:
3121       LibCallName = "__atomic_load";
3122       Args.add(RValue::get(EmitCastToVoidPtr(Dest)),
3123                getContext().VoidPtrTy);
3124       break;
3125 #if 0
3126     // These are only defined for 1-16 byte integers.  It is not clear what
3127     // their semantics would be on anything else...
3128     case AtomicExpr::Add:   LibCallName = "__atomic_fetch_add_generic"; break;
3129     case AtomicExpr::Sub:   LibCallName = "__atomic_fetch_sub_generic"; break;
3130     case AtomicExpr::And:   LibCallName = "__atomic_fetch_and_generic"; break;
3131     case AtomicExpr::Or:    LibCallName = "__atomic_fetch_or_generic"; break;
3132     case AtomicExpr::Xor:   LibCallName = "__atomic_fetch_xor_generic"; break;
3133 #endif
3134     default: return EmitUnsupportedRValue(E, "atomic library call");
3135     }
3136     // order is always the last parameter
3137     Args.add(RValue::get(Order),
3138              getContext().IntTy);
3139 
3140     const CGFunctionInfo &FuncInfo =
3141         CGM.getTypes().arrangeFunctionCall(RetTy, Args,
3142             FunctionType::ExtInfo(), RequiredArgs::All);
3143     llvm::FunctionType *FTy = CGM.getTypes().GetFunctionType(FuncInfo);
3144     llvm::Constant *Func = CGM.CreateRuntimeFunction(FTy, LibCallName);
3145     RValue Res = EmitCall(FuncInfo, Func, ReturnValueSlot(), Args);
3146     if (E->isCmpXChg())
3147       return Res;
3148     if (E->getType()->isVoidType())
3149       return RValue::get(0);
3150     return ConvertTempToRValue(*this, E->getType(), Dest);
3151   }
3152 
3153   llvm::Type *IPtrTy =
3154       llvm::IntegerType::get(getLLVMContext(), Size * 8)->getPointerTo();
3155   llvm::Value *OrigDest = Dest;
3156   Ptr = Builder.CreateBitCast(Ptr, IPtrTy);
3157   if (Val1) Val1 = Builder.CreateBitCast(Val1, IPtrTy);
3158   if (Val2) Val2 = Builder.CreateBitCast(Val2, IPtrTy);
3159   if (Dest && !E->isCmpXChg()) Dest = Builder.CreateBitCast(Dest, IPtrTy);
3160 
3161   if (isa<llvm::ConstantInt>(Order)) {
3162     int ord = cast<llvm::ConstantInt>(Order)->getZExtValue();
3163     switch (ord) {
3164     case 0:  // memory_order_relaxed
3165       EmitAtomicOp(*this, E, Dest, Ptr, Val1, Val2, Size, Align,
3166                    llvm::Monotonic);
3167       break;
3168     case 1:  // memory_order_consume
3169     case 2:  // memory_order_acquire
3170       EmitAtomicOp(*this, E, Dest, Ptr, Val1, Val2, Size, Align,
3171                    llvm::Acquire);
3172       break;
3173     case 3:  // memory_order_release
3174       EmitAtomicOp(*this, E, Dest, Ptr, Val1, Val2, Size, Align,
3175                    llvm::Release);
3176       break;
3177     case 4:  // memory_order_acq_rel
3178       EmitAtomicOp(*this, E, Dest, Ptr, Val1, Val2, Size, Align,
3179                    llvm::AcquireRelease);
3180       break;
3181     case 5:  // memory_order_seq_cst
3182       EmitAtomicOp(*this, E, Dest, Ptr, Val1, Val2, Size, Align,
3183                    llvm::SequentiallyConsistent);
3184       break;
3185     default: // invalid order
3186       // We should not ever get here normally, but it's hard to
3187       // enforce that in general.
3188       break;
3189     }
3190     if (E->getType()->isVoidType())
3191       return RValue::get(0);
3192     return ConvertTempToRValue(*this, E->getType(), OrigDest);
3193   }
3194 
3195   // Long case, when Order isn't obviously constant.
3196 
3197   bool IsStore = E->getOp() == AtomicExpr::AO__c11_atomic_store ||
3198                  E->getOp() == AtomicExpr::AO__atomic_store ||
3199                  E->getOp() == AtomicExpr::AO__atomic_store_n;
3200   bool IsLoad = E->getOp() == AtomicExpr::AO__c11_atomic_load ||
3201                 E->getOp() == AtomicExpr::AO__atomic_load ||
3202                 E->getOp() == AtomicExpr::AO__atomic_load_n;
3203 
3204   // Create all the relevant BB's
3205   llvm::BasicBlock *MonotonicBB = 0, *AcquireBB = 0, *ReleaseBB = 0,
3206                    *AcqRelBB = 0, *SeqCstBB = 0;
3207   MonotonicBB = createBasicBlock("monotonic", CurFn);
3208   if (!IsStore)
3209     AcquireBB = createBasicBlock("acquire", CurFn);
3210   if (!IsLoad)
3211     ReleaseBB = createBasicBlock("release", CurFn);
3212   if (!IsLoad && !IsStore)
3213     AcqRelBB = createBasicBlock("acqrel", CurFn);
3214   SeqCstBB = createBasicBlock("seqcst", CurFn);
3215   llvm::BasicBlock *ContBB = createBasicBlock("atomic.continue", CurFn);
3216 
3217   // Create the switch for the split
3218   // MonotonicBB is arbitrarily chosen as the default case; in practice, this
3219   // doesn't matter unless someone is crazy enough to use something that
3220   // doesn't fold to a constant for the ordering.
3221   Order = Builder.CreateIntCast(Order, Builder.getInt32Ty(), false);
3222   llvm::SwitchInst *SI = Builder.CreateSwitch(Order, MonotonicBB);
3223 
3224   // Emit all the different atomics
3225   Builder.SetInsertPoint(MonotonicBB);
3226   EmitAtomicOp(*this, E, Dest, Ptr, Val1, Val2, Size, Align,
3227                llvm::Monotonic);
3228   Builder.CreateBr(ContBB);
3229   if (!IsStore) {
3230     Builder.SetInsertPoint(AcquireBB);
3231     EmitAtomicOp(*this, E, Dest, Ptr, Val1, Val2, Size, Align,
3232                  llvm::Acquire);
3233     Builder.CreateBr(ContBB);
3234     SI->addCase(Builder.getInt32(1), AcquireBB);
3235     SI->addCase(Builder.getInt32(2), AcquireBB);
3236   }
3237   if (!IsLoad) {
3238     Builder.SetInsertPoint(ReleaseBB);
3239     EmitAtomicOp(*this, E, Dest, Ptr, Val1, Val2, Size, Align,
3240                  llvm::Release);
3241     Builder.CreateBr(ContBB);
3242     SI->addCase(Builder.getInt32(3), ReleaseBB);
3243   }
3244   if (!IsLoad && !IsStore) {
3245     Builder.SetInsertPoint(AcqRelBB);
3246     EmitAtomicOp(*this, E, Dest, Ptr, Val1, Val2, Size, Align,
3247                  llvm::AcquireRelease);
3248     Builder.CreateBr(ContBB);
3249     SI->addCase(Builder.getInt32(4), AcqRelBB);
3250   }
3251   Builder.SetInsertPoint(SeqCstBB);
3252   EmitAtomicOp(*this, E, Dest, Ptr, Val1, Val2, Size, Align,
3253                llvm::SequentiallyConsistent);
3254   Builder.CreateBr(ContBB);
3255   SI->addCase(Builder.getInt32(5), SeqCstBB);
3256 
3257   // Cleanup and return
3258   Builder.SetInsertPoint(ContBB);
3259   if (E->getType()->isVoidType())
3260     return RValue::get(0);
3261   return ConvertTempToRValue(*this, E->getType(), OrigDest);
3262 }
3263 
3264 void CodeGenFunction::SetFPAccuracy(llvm::Value *Val, float Accuracy) {
3265   assert(Val->getType()->isFPOrFPVectorTy());
3266   if (Accuracy == 0.0 || !isa<llvm::Instruction>(Val))
3267     return;
3268 
3269   llvm::MDBuilder MDHelper(getLLVMContext());
3270   llvm::MDNode *Node = MDHelper.createFPMath(Accuracy);
3271 
3272   cast<llvm::Instruction>(Val)->setMetadata(llvm::LLVMContext::MD_fpmath, Node);
3273 }
3274 
3275 namespace {
3276   struct LValueOrRValue {
3277     LValue LV;
3278     RValue RV;
3279   };
3280 }
3281 
3282 static LValueOrRValue emitPseudoObjectExpr(CodeGenFunction &CGF,
3283                                            const PseudoObjectExpr *E,
3284                                            bool forLValue,
3285                                            AggValueSlot slot) {
3286   llvm::SmallVector<CodeGenFunction::OpaqueValueMappingData, 4> opaques;
3287 
3288   // Find the result expression, if any.
3289   const Expr *resultExpr = E->getResultExpr();
3290   LValueOrRValue result;
3291 
3292   for (PseudoObjectExpr::const_semantics_iterator
3293          i = E->semantics_begin(), e = E->semantics_end(); i != e; ++i) {
3294     const Expr *semantic = *i;
3295 
3296     // If this semantic expression is an opaque value, bind it
3297     // to the result of its source expression.
3298     if (const OpaqueValueExpr *ov = dyn_cast<OpaqueValueExpr>(semantic)) {
3299 
3300       // If this is the result expression, we may need to evaluate
3301       // directly into the slot.
3302       typedef CodeGenFunction::OpaqueValueMappingData OVMA;
3303       OVMA opaqueData;
3304       if (ov == resultExpr && ov->isRValue() && !forLValue &&
3305           CodeGenFunction::hasAggregateLLVMType(ov->getType()) &&
3306           !ov->getType()->isAnyComplexType()) {
3307         CGF.EmitAggExpr(ov->getSourceExpr(), slot);
3308 
3309         LValue LV = CGF.MakeAddrLValue(slot.getAddr(), ov->getType());
3310         opaqueData = OVMA::bind(CGF, ov, LV);
3311         result.RV = slot.asRValue();
3312 
3313       // Otherwise, emit as normal.
3314       } else {
3315         opaqueData = OVMA::bind(CGF, ov, ov->getSourceExpr());
3316 
3317         // If this is the result, also evaluate the result now.
3318         if (ov == resultExpr) {
3319           if (forLValue)
3320             result.LV = CGF.EmitLValue(ov);
3321           else
3322             result.RV = CGF.EmitAnyExpr(ov, slot);
3323         }
3324       }
3325 
3326       opaques.push_back(opaqueData);
3327 
3328     // Otherwise, if the expression is the result, evaluate it
3329     // and remember the result.
3330     } else if (semantic == resultExpr) {
3331       if (forLValue)
3332         result.LV = CGF.EmitLValue(semantic);
3333       else
3334         result.RV = CGF.EmitAnyExpr(semantic, slot);
3335 
3336     // Otherwise, evaluate the expression in an ignored context.
3337     } else {
3338       CGF.EmitIgnoredExpr(semantic);
3339     }
3340   }
3341 
3342   // Unbind all the opaques now.
3343   for (unsigned i = 0, e = opaques.size(); i != e; ++i)
3344     opaques[i].unbind(CGF);
3345 
3346   return result;
3347 }
3348 
3349 RValue CodeGenFunction::EmitPseudoObjectRValue(const PseudoObjectExpr *E,
3350                                                AggValueSlot slot) {
3351   return emitPseudoObjectExpr(*this, E, false, slot).RV;
3352 }
3353 
3354 LValue CodeGenFunction::EmitPseudoObjectLValue(const PseudoObjectExpr *E) {
3355   return emitPseudoObjectExpr(*this, E, true, AggValueSlot::ignored()).LV;
3356 }
3357