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 "CGObjCRuntime.h"
18 #include "clang/AST/ASTContext.h"
19 #include "clang/AST/DeclObjC.h"
20 #include "llvm/Target/TargetData.h"
21 using namespace clang;
22 using namespace CodeGen;
23 
24 //===--------------------------------------------------------------------===//
25 //                        Miscellaneous Helper Methods
26 //===--------------------------------------------------------------------===//
27 
28 /// CreateTempAlloca - This creates a alloca and inserts it into the entry
29 /// block.
30 llvm::AllocaInst *CodeGenFunction::CreateTempAlloca(const llvm::Type *Ty,
31                                                     const llvm::Twine &Name) {
32   if (!Builder.isNamePreserving())
33     return new llvm::AllocaInst(Ty, 0, "", AllocaInsertPt);
34   return new llvm::AllocaInst(Ty, 0, Name, AllocaInsertPt);
35 }
36 
37 /// EvaluateExprAsBool - Perform the usual unary conversions on the specified
38 /// expression and compare the result against zero, returning an Int1Ty value.
39 llvm::Value *CodeGenFunction::EvaluateExprAsBool(const Expr *E) {
40   QualType BoolTy = getContext().BoolTy;
41   if (E->getType()->isMemberFunctionPointerType()) {
42     llvm::Value *Ptr = CreateTempAlloca(ConvertType(E->getType()));
43     EmitAggExpr(E, Ptr, /*VolatileDest=*/false);
44 
45     // Get the pointer.
46     llvm::Value *FuncPtr = Builder.CreateStructGEP(Ptr, 0, "src.ptr");
47     FuncPtr = Builder.CreateLoad(FuncPtr);
48 
49     llvm::Value *IsNotNull =
50       Builder.CreateICmpNE(FuncPtr,
51                             llvm::Constant::getNullValue(FuncPtr->getType()),
52                             "tobool");
53 
54     return IsNotNull;
55   }
56   if (!E->getType()->isAnyComplexType())
57     return EmitScalarConversion(EmitScalarExpr(E), E->getType(), BoolTy);
58 
59   return EmitComplexToScalarConversion(EmitComplexExpr(E), E->getType(),BoolTy);
60 }
61 
62 /// EmitAnyExpr - Emit code to compute the specified expression which can have
63 /// any type.  The result is returned as an RValue struct.  If this is an
64 /// aggregate expression, the aggloc/agglocvolatile arguments indicate where the
65 /// result should be returned.
66 RValue CodeGenFunction::EmitAnyExpr(const Expr *E, llvm::Value *AggLoc,
67                                     bool IsAggLocVolatile, bool IgnoreResult,
68                                     bool IsInitializer) {
69   if (!hasAggregateLLVMType(E->getType()))
70     return RValue::get(EmitScalarExpr(E, IgnoreResult));
71   else if (E->getType()->isAnyComplexType())
72     return RValue::getComplex(EmitComplexExpr(E, false, false,
73                                               IgnoreResult, IgnoreResult));
74 
75   EmitAggExpr(E, AggLoc, IsAggLocVolatile, IgnoreResult, IsInitializer);
76   return RValue::getAggregate(AggLoc, IsAggLocVolatile);
77 }
78 
79 /// EmitAnyExprToTemp - Similary to EmitAnyExpr(), however, the result will
80 /// always be accessible even if no aggregate location is provided.
81 RValue CodeGenFunction::EmitAnyExprToTemp(const Expr *E,
82                                           bool IsAggLocVolatile,
83                                           bool IsInitializer) {
84   llvm::Value *AggLoc = 0;
85 
86   if (hasAggregateLLVMType(E->getType()) &&
87       !E->getType()->isAnyComplexType())
88     AggLoc = CreateTempAlloca(ConvertType(E->getType()), "agg.tmp");
89   return EmitAnyExpr(E, AggLoc, IsAggLocVolatile, /*IgnoreResult=*/false,
90                      IsInitializer);
91 }
92 
93 RValue CodeGenFunction::EmitReferenceBindingToExpr(const Expr* E,
94                                                    QualType DestType,
95                                                    bool IsInitializer) {
96   bool ShouldDestroyTemporaries = false;
97   unsigned OldNumLiveTemporaries = 0;
98 
99   if (const CXXExprWithTemporaries *TE = dyn_cast<CXXExprWithTemporaries>(E)) {
100     ShouldDestroyTemporaries = TE->shouldDestroyTemporaries();
101 
102     // Keep track of the current cleanup stack depth.
103     if (ShouldDestroyTemporaries)
104       OldNumLiveTemporaries = LiveTemporaries.size();
105 
106     E = TE->getSubExpr();
107   }
108 
109   RValue Val;
110   if (E->isLvalue(getContext()) == Expr::LV_Valid) {
111     // Emit the expr as an lvalue.
112     LValue LV = EmitLValue(E);
113     if (LV.isSimple())
114       return RValue::get(LV.getAddress());
115     Val = EmitLoadOfLValue(LV, E->getType());
116 
117     if (ShouldDestroyTemporaries) {
118       // Pop temporaries.
119       while (LiveTemporaries.size() > OldNumLiveTemporaries)
120         PopCXXTemporary();
121     }
122   } else {
123     const CXXRecordDecl *BaseClassDecl = 0;
124     const CXXRecordDecl *DerivedClassDecl = 0;
125 
126     if (const CastExpr *CE =
127           dyn_cast<CastExpr>(E->IgnoreParenNoopCasts(getContext()))) {
128       if (CE->getCastKind() == CastExpr::CK_DerivedToBase) {
129         E = CE->getSubExpr();
130 
131         BaseClassDecl =
132           cast<CXXRecordDecl>(CE->getType()->getAs<RecordType>()->getDecl());
133         DerivedClassDecl =
134           cast<CXXRecordDecl>(E->getType()->getAs<RecordType>()->getDecl());
135       }
136     }
137 
138     Val = EmitAnyExprToTemp(E, /*IsAggLocVolatile=*/false,
139                             IsInitializer);
140 
141     if (ShouldDestroyTemporaries) {
142       // Pop temporaries.
143       while (LiveTemporaries.size() > OldNumLiveTemporaries)
144         PopCXXTemporary();
145     }
146 
147     if (IsInitializer) {
148       // We might have to destroy the temporary variable.
149       if (const RecordType *RT = E->getType()->getAs<RecordType>()) {
150         if (CXXRecordDecl *ClassDecl = dyn_cast<CXXRecordDecl>(RT->getDecl())) {
151           if (!ClassDecl->hasTrivialDestructor()) {
152             const CXXDestructorDecl *Dtor =
153               ClassDecl->getDestructor(getContext());
154 
155             {
156               DelayedCleanupBlock Scope(*this);
157               EmitCXXDestructorCall(Dtor, Dtor_Complete,
158                                     Val.getAggregateAddr());
159 
160               // Make sure to jump to the exit block.
161               EmitBranch(Scope.getCleanupExitBlock());
162             }
163             if (Exceptions) {
164               EHCleanupBlock Cleanup(*this);
165               EmitCXXDestructorCall(Dtor, Dtor_Complete,
166                                     Val.getAggregateAddr());
167             }
168           }
169         }
170       }
171     }
172 
173     // Check if need to perform the derived-to-base cast.
174     if (BaseClassDecl) {
175       llvm::Value *Derived = Val.getAggregateAddr();
176       llvm::Value *Base =
177         GetAddressOfBaseClass(Derived, DerivedClassDecl, BaseClassDecl,
178                               /*NullCheckValue=*/false);
179       return RValue::get(Base);
180     }
181   }
182 
183   if (Val.isAggregate()) {
184     Val = RValue::get(Val.getAggregateAddr());
185   } else {
186     // Create a temporary variable that we can bind the reference to.
187     llvm::Value *Temp = CreateTempAlloca(ConvertTypeForMem(E->getType()),
188                                          "reftmp");
189     if (Val.isScalar())
190       EmitStoreOfScalar(Val.getScalarVal(), Temp, false, E->getType());
191     else
192       StoreComplexToAddr(Val.getComplexVal(), Temp, false);
193     Val = RValue::get(Temp);
194   }
195 
196   return Val;
197 }
198 
199 
200 /// getAccessedFieldNo - Given an encoded value and a result number, return the
201 /// input field number being accessed.
202 unsigned CodeGenFunction::getAccessedFieldNo(unsigned Idx,
203                                              const llvm::Constant *Elts) {
204   if (isa<llvm::ConstantAggregateZero>(Elts))
205     return 0;
206 
207   return cast<llvm::ConstantInt>(Elts->getOperand(Idx))->getZExtValue();
208 }
209 
210 
211 //===----------------------------------------------------------------------===//
212 //                         LValue Expression Emission
213 //===----------------------------------------------------------------------===//
214 
215 RValue CodeGenFunction::GetUndefRValue(QualType Ty) {
216   if (Ty->isVoidType())
217     return RValue::get(0);
218 
219   if (const ComplexType *CTy = Ty->getAs<ComplexType>()) {
220     const llvm::Type *EltTy = ConvertType(CTy->getElementType());
221     llvm::Value *U = llvm::UndefValue::get(EltTy);
222     return RValue::getComplex(std::make_pair(U, U));
223   }
224 
225   if (hasAggregateLLVMType(Ty)) {
226     const llvm::Type *LTy = llvm::PointerType::getUnqual(ConvertType(Ty));
227     return RValue::getAggregate(llvm::UndefValue::get(LTy));
228   }
229 
230   return RValue::get(llvm::UndefValue::get(ConvertType(Ty)));
231 }
232 
233 RValue CodeGenFunction::EmitUnsupportedRValue(const Expr *E,
234                                               const char *Name) {
235   ErrorUnsupported(E, Name);
236   return GetUndefRValue(E->getType());
237 }
238 
239 LValue CodeGenFunction::EmitUnsupportedLValue(const Expr *E,
240                                               const char *Name) {
241   ErrorUnsupported(E, Name);
242   llvm::Type *Ty = llvm::PointerType::getUnqual(ConvertType(E->getType()));
243   return LValue::MakeAddr(llvm::UndefValue::get(Ty),
244                           MakeQualifiers(E->getType()));
245 }
246 
247 /// EmitLValue - Emit code to compute a designator that specifies the location
248 /// of the expression.
249 ///
250 /// This can return one of two things: a simple address or a bitfield reference.
251 /// In either case, the LLVM Value* in the LValue structure is guaranteed to be
252 /// an LLVM pointer type.
253 ///
254 /// If this returns a bitfield reference, nothing about the pointee type of the
255 /// LLVM value is known: For example, it may not be a pointer to an integer.
256 ///
257 /// If this returns a normal address, and if the lvalue's C type is fixed size,
258 /// this method guarantees that the returned pointer type will point to an LLVM
259 /// type of the same size of the lvalue's type.  If the lvalue has a variable
260 /// length type, this is not possible.
261 ///
262 LValue CodeGenFunction::EmitLValue(const Expr *E) {
263   switch (E->getStmtClass()) {
264   default: return EmitUnsupportedLValue(E, "l-value expression");
265 
266   case Expr::ObjCIsaExprClass:
267     return EmitObjCIsaExpr(cast<ObjCIsaExpr>(E));
268   case Expr::BinaryOperatorClass:
269     return EmitBinaryOperatorLValue(cast<BinaryOperator>(E));
270   case Expr::CallExprClass:
271   case Expr::CXXMemberCallExprClass:
272   case Expr::CXXOperatorCallExprClass:
273     return EmitCallExprLValue(cast<CallExpr>(E));
274   case Expr::VAArgExprClass:
275     return EmitVAArgExprLValue(cast<VAArgExpr>(E));
276   case Expr::DeclRefExprClass:
277     return EmitDeclRefLValue(cast<DeclRefExpr>(E));
278   case Expr::ParenExprClass:return EmitLValue(cast<ParenExpr>(E)->getSubExpr());
279   case Expr::PredefinedExprClass:
280     return EmitPredefinedLValue(cast<PredefinedExpr>(E));
281   case Expr::StringLiteralClass:
282     return EmitStringLiteralLValue(cast<StringLiteral>(E));
283   case Expr::ObjCEncodeExprClass:
284     return EmitObjCEncodeExprLValue(cast<ObjCEncodeExpr>(E));
285 
286   case Expr::BlockDeclRefExprClass:
287     return EmitBlockDeclRefLValue(cast<BlockDeclRefExpr>(E));
288 
289   case Expr::CXXTemporaryObjectExprClass:
290   case Expr::CXXConstructExprClass:
291     return EmitCXXConstructLValue(cast<CXXConstructExpr>(E));
292   case Expr::CXXBindTemporaryExprClass:
293     return EmitCXXBindTemporaryLValue(cast<CXXBindTemporaryExpr>(E));
294   case Expr::CXXExprWithTemporariesClass:
295     return EmitCXXExprWithTemporariesLValue(cast<CXXExprWithTemporaries>(E));
296   case Expr::CXXZeroInitValueExprClass:
297     return EmitNullInitializationLValue(cast<CXXZeroInitValueExpr>(E));
298   case Expr::CXXDefaultArgExprClass:
299     return EmitLValue(cast<CXXDefaultArgExpr>(E)->getExpr());
300   case Expr::CXXTypeidExprClass:
301     return EmitCXXTypeidLValue(cast<CXXTypeidExpr>(E));
302 
303   case Expr::ObjCMessageExprClass:
304     return EmitObjCMessageExprLValue(cast<ObjCMessageExpr>(E));
305   case Expr::ObjCIvarRefExprClass:
306     return EmitObjCIvarRefLValue(cast<ObjCIvarRefExpr>(E));
307   case Expr::ObjCPropertyRefExprClass:
308     return EmitObjCPropertyRefLValue(cast<ObjCPropertyRefExpr>(E));
309   case Expr::ObjCImplicitSetterGetterRefExprClass:
310     return EmitObjCKVCRefLValue(cast<ObjCImplicitSetterGetterRefExpr>(E));
311   case Expr::ObjCSuperExprClass:
312     return EmitObjCSuperExprLValue(cast<ObjCSuperExpr>(E));
313 
314   case Expr::StmtExprClass:
315     return EmitStmtExprLValue(cast<StmtExpr>(E));
316   case Expr::UnaryOperatorClass:
317     return EmitUnaryOpLValue(cast<UnaryOperator>(E));
318   case Expr::ArraySubscriptExprClass:
319     return EmitArraySubscriptExpr(cast<ArraySubscriptExpr>(E));
320   case Expr::ExtVectorElementExprClass:
321     return EmitExtVectorElementExpr(cast<ExtVectorElementExpr>(E));
322   case Expr::MemberExprClass:
323     return EmitMemberExpr(cast<MemberExpr>(E));
324   case Expr::CompoundLiteralExprClass:
325     return EmitCompoundLiteralLValue(cast<CompoundLiteralExpr>(E));
326   case Expr::ConditionalOperatorClass:
327     return EmitConditionalOperatorLValue(cast<ConditionalOperator>(E));
328   case Expr::ChooseExprClass:
329     return EmitLValue(cast<ChooseExpr>(E)->getChosenSubExpr(getContext()));
330   case Expr::ImplicitCastExprClass:
331   case Expr::CStyleCastExprClass:
332   case Expr::CXXFunctionalCastExprClass:
333   case Expr::CXXStaticCastExprClass:
334   case Expr::CXXDynamicCastExprClass:
335   case Expr::CXXReinterpretCastExprClass:
336   case Expr::CXXConstCastExprClass:
337     return EmitCastLValue(cast<CastExpr>(E));
338   }
339 }
340 
341 llvm::Value *CodeGenFunction::EmitLoadOfScalar(llvm::Value *Addr, bool Volatile,
342                                                QualType Ty) {
343   llvm::LoadInst *Load = Builder.CreateLoad(Addr, "tmp");
344   if (Volatile)
345     Load->setVolatile(true);
346 
347   // Bool can have different representation in memory than in registers.
348   llvm::Value *V = Load;
349   if (Ty->isBooleanType())
350     if (V->getType() != llvm::Type::getInt1Ty(VMContext))
351       V = Builder.CreateTrunc(V, llvm::Type::getInt1Ty(VMContext), "tobool");
352 
353   return V;
354 }
355 
356 void CodeGenFunction::EmitStoreOfScalar(llvm::Value *Value, llvm::Value *Addr,
357                                         bool Volatile, QualType Ty) {
358 
359   if (Ty->isBooleanType()) {
360     // Bool can have different representation in memory than in registers.
361     const llvm::PointerType *DstPtr = cast<llvm::PointerType>(Addr->getType());
362     Value = Builder.CreateIntCast(Value, DstPtr->getElementType(), false);
363   }
364   Builder.CreateStore(Value, Addr, Volatile);
365 }
366 
367 /// EmitLoadOfLValue - Given an expression that represents a value lvalue, this
368 /// method emits the address of the lvalue, then loads the result as an rvalue,
369 /// returning the rvalue.
370 RValue CodeGenFunction::EmitLoadOfLValue(LValue LV, QualType ExprType) {
371   if (LV.isObjCWeak()) {
372     // load of a __weak object.
373     llvm::Value *AddrWeakObj = LV.getAddress();
374     return RValue::get(CGM.getObjCRuntime().EmitObjCWeakRead(*this,
375                                                              AddrWeakObj));
376   }
377 
378   if (LV.isSimple()) {
379     llvm::Value *Ptr = LV.getAddress();
380     const llvm::Type *EltTy =
381       cast<llvm::PointerType>(Ptr->getType())->getElementType();
382 
383     // Simple scalar l-value.
384     if (EltTy->isSingleValueType())
385       return RValue::get(EmitLoadOfScalar(Ptr, LV.isVolatileQualified(),
386                                           ExprType));
387 
388     assert(ExprType->isFunctionType() && "Unknown scalar value");
389     return RValue::get(Ptr);
390   }
391 
392   if (LV.isVectorElt()) {
393     llvm::Value *Vec = Builder.CreateLoad(LV.getVectorAddr(),
394                                           LV.isVolatileQualified(), "tmp");
395     return RValue::get(Builder.CreateExtractElement(Vec, LV.getVectorIdx(),
396                                                     "vecext"));
397   }
398 
399   // If this is a reference to a subset of the elements of a vector, either
400   // shuffle the input or extract/insert them as appropriate.
401   if (LV.isExtVectorElt())
402     return EmitLoadOfExtVectorElementLValue(LV, ExprType);
403 
404   if (LV.isBitfield())
405     return EmitLoadOfBitfieldLValue(LV, ExprType);
406 
407   if (LV.isPropertyRef())
408     return EmitLoadOfPropertyRefLValue(LV, ExprType);
409 
410   assert(LV.isKVCRef() && "Unknown LValue type!");
411   return EmitLoadOfKVCRefLValue(LV, ExprType);
412 }
413 
414 RValue CodeGenFunction::EmitLoadOfBitfieldLValue(LValue LV,
415                                                  QualType ExprType) {
416   unsigned StartBit = LV.getBitfieldStartBit();
417   unsigned BitfieldSize = LV.getBitfieldSize();
418   llvm::Value *Ptr = LV.getBitfieldAddr();
419 
420   const llvm::Type *EltTy =
421     cast<llvm::PointerType>(Ptr->getType())->getElementType();
422   unsigned EltTySize = CGM.getTargetData().getTypeSizeInBits(EltTy);
423 
424   // In some cases the bitfield may straddle two memory locations.  Currently we
425   // load the entire bitfield, then do the magic to sign-extend it if
426   // necessary. This results in somewhat more code than necessary for the common
427   // case (one load), since two shifts accomplish both the masking and sign
428   // extension.
429   unsigned LowBits = std::min(BitfieldSize, EltTySize - StartBit);
430   llvm::Value *Val = Builder.CreateLoad(Ptr, LV.isVolatileQualified(), "tmp");
431 
432   // Shift to proper location.
433   if (StartBit)
434     Val = Builder.CreateLShr(Val, StartBit, "bf.lo");
435 
436   // Mask off unused bits.
437   llvm::Constant *LowMask = llvm::ConstantInt::get(VMContext,
438                                 llvm::APInt::getLowBitsSet(EltTySize, LowBits));
439   Val = Builder.CreateAnd(Val, LowMask, "bf.lo.cleared");
440 
441   // Fetch the high bits if necessary.
442   if (LowBits < BitfieldSize) {
443     unsigned HighBits = BitfieldSize - LowBits;
444     llvm::Value *HighPtr = Builder.CreateGEP(Ptr, llvm::ConstantInt::get(
445                             llvm::Type::getInt32Ty(VMContext), 1), "bf.ptr.hi");
446     llvm::Value *HighVal = Builder.CreateLoad(HighPtr,
447                                               LV.isVolatileQualified(),
448                                               "tmp");
449 
450     // Mask off unused bits.
451     llvm::Constant *HighMask = llvm::ConstantInt::get(VMContext,
452                                llvm::APInt::getLowBitsSet(EltTySize, HighBits));
453     HighVal = Builder.CreateAnd(HighVal, HighMask, "bf.lo.cleared");
454 
455     // Shift to proper location and or in to bitfield value.
456     HighVal = Builder.CreateShl(HighVal, LowBits);
457     Val = Builder.CreateOr(Val, HighVal, "bf.val");
458   }
459 
460   // Sign extend if necessary.
461   if (LV.isBitfieldSigned()) {
462     llvm::Value *ExtraBits = llvm::ConstantInt::get(EltTy,
463                                                     EltTySize - BitfieldSize);
464     Val = Builder.CreateAShr(Builder.CreateShl(Val, ExtraBits),
465                              ExtraBits, "bf.val.sext");
466   }
467 
468   // The bitfield type and the normal type differ when the storage sizes differ
469   // (currently just _Bool).
470   Val = Builder.CreateIntCast(Val, ConvertType(ExprType), false, "tmp");
471 
472   return RValue::get(Val);
473 }
474 
475 RValue CodeGenFunction::EmitLoadOfPropertyRefLValue(LValue LV,
476                                                     QualType ExprType) {
477   return EmitObjCPropertyGet(LV.getPropertyRefExpr());
478 }
479 
480 RValue CodeGenFunction::EmitLoadOfKVCRefLValue(LValue LV,
481                                                QualType ExprType) {
482   return EmitObjCPropertyGet(LV.getKVCRefExpr());
483 }
484 
485 // If this is a reference to a subset of the elements of a vector, create an
486 // appropriate shufflevector.
487 RValue CodeGenFunction::EmitLoadOfExtVectorElementLValue(LValue LV,
488                                                          QualType ExprType) {
489   llvm::Value *Vec = Builder.CreateLoad(LV.getExtVectorAddr(),
490                                         LV.isVolatileQualified(), "tmp");
491 
492   const llvm::Constant *Elts = LV.getExtVectorElts();
493 
494   // If the result of the expression is a non-vector type, we must be extracting
495   // a single element.  Just codegen as an extractelement.
496   const VectorType *ExprVT = ExprType->getAs<VectorType>();
497   if (!ExprVT) {
498     unsigned InIdx = getAccessedFieldNo(0, Elts);
499     llvm::Value *Elt = llvm::ConstantInt::get(
500                                       llvm::Type::getInt32Ty(VMContext), InIdx);
501     return RValue::get(Builder.CreateExtractElement(Vec, Elt, "tmp"));
502   }
503 
504   // Always use shuffle vector to try to retain the original program structure
505   unsigned NumResultElts = ExprVT->getNumElements();
506 
507   llvm::SmallVector<llvm::Constant*, 4> Mask;
508   for (unsigned i = 0; i != NumResultElts; ++i) {
509     unsigned InIdx = getAccessedFieldNo(i, Elts);
510     Mask.push_back(llvm::ConstantInt::get(
511                                      llvm::Type::getInt32Ty(VMContext), InIdx));
512   }
513 
514   llvm::Value *MaskV = llvm::ConstantVector::get(&Mask[0], Mask.size());
515   Vec = Builder.CreateShuffleVector(Vec,
516                                     llvm::UndefValue::get(Vec->getType()),
517                                     MaskV, "tmp");
518   return RValue::get(Vec);
519 }
520 
521 
522 
523 /// EmitStoreThroughLValue - Store the specified rvalue into the specified
524 /// lvalue, where both are guaranteed to the have the same type, and that type
525 /// is 'Ty'.
526 void CodeGenFunction::EmitStoreThroughLValue(RValue Src, LValue Dst,
527                                              QualType Ty) {
528   if (!Dst.isSimple()) {
529     if (Dst.isVectorElt()) {
530       // Read/modify/write the vector, inserting the new element.
531       llvm::Value *Vec = Builder.CreateLoad(Dst.getVectorAddr(),
532                                             Dst.isVolatileQualified(), "tmp");
533       Vec = Builder.CreateInsertElement(Vec, Src.getScalarVal(),
534                                         Dst.getVectorIdx(), "vecins");
535       Builder.CreateStore(Vec, Dst.getVectorAddr(),Dst.isVolatileQualified());
536       return;
537     }
538 
539     // If this is an update of extended vector elements, insert them as
540     // appropriate.
541     if (Dst.isExtVectorElt())
542       return EmitStoreThroughExtVectorComponentLValue(Src, Dst, Ty);
543 
544     if (Dst.isBitfield())
545       return EmitStoreThroughBitfieldLValue(Src, Dst, Ty);
546 
547     if (Dst.isPropertyRef())
548       return EmitStoreThroughPropertyRefLValue(Src, Dst, Ty);
549 
550     assert(Dst.isKVCRef() && "Unknown LValue type");
551     return EmitStoreThroughKVCRefLValue(Src, Dst, Ty);
552   }
553 
554   if (Dst.isObjCWeak() && !Dst.isNonGC()) {
555     // load of a __weak object.
556     llvm::Value *LvalueDst = Dst.getAddress();
557     llvm::Value *src = Src.getScalarVal();
558      CGM.getObjCRuntime().EmitObjCWeakAssign(*this, src, LvalueDst);
559     return;
560   }
561 
562   if (Dst.isObjCStrong() && !Dst.isNonGC()) {
563     // load of a __strong object.
564     llvm::Value *LvalueDst = Dst.getAddress();
565     llvm::Value *src = Src.getScalarVal();
566     if (Dst.isObjCIvar()) {
567       assert(Dst.getBaseIvarExp() && "BaseIvarExp is NULL");
568       const llvm::Type *ResultType = ConvertType(getContext().LongTy);
569       llvm::Value *RHS = EmitScalarExpr(Dst.getBaseIvarExp());
570       llvm::Value *dst = RHS;
571       RHS = Builder.CreatePtrToInt(RHS, ResultType, "sub.ptr.rhs.cast");
572       llvm::Value *LHS =
573         Builder.CreatePtrToInt(LvalueDst, ResultType, "sub.ptr.lhs.cast");
574       llvm::Value *BytesBetween = Builder.CreateSub(LHS, RHS, "ivar.offset");
575       CGM.getObjCRuntime().EmitObjCIvarAssign(*this, src, dst,
576                                               BytesBetween);
577     } else if (Dst.isGlobalObjCRef())
578       CGM.getObjCRuntime().EmitObjCGlobalAssign(*this, src, LvalueDst);
579     else
580       CGM.getObjCRuntime().EmitObjCStrongCastAssign(*this, src, LvalueDst);
581     return;
582   }
583 
584   assert(Src.isScalar() && "Can't emit an agg store with this method");
585   EmitStoreOfScalar(Src.getScalarVal(), Dst.getAddress(),
586                     Dst.isVolatileQualified(), Ty);
587 }
588 
589 void CodeGenFunction::EmitStoreThroughBitfieldLValue(RValue Src, LValue Dst,
590                                                      QualType Ty,
591                                                      llvm::Value **Result) {
592   unsigned StartBit = Dst.getBitfieldStartBit();
593   unsigned BitfieldSize = Dst.getBitfieldSize();
594   llvm::Value *Ptr = Dst.getBitfieldAddr();
595 
596   const llvm::Type *EltTy =
597     cast<llvm::PointerType>(Ptr->getType())->getElementType();
598   unsigned EltTySize = CGM.getTargetData().getTypeSizeInBits(EltTy);
599 
600   // Get the new value, cast to the appropriate type and masked to exactly the
601   // size of the bit-field.
602   llvm::Value *SrcVal = Src.getScalarVal();
603   llvm::Value *NewVal = Builder.CreateIntCast(SrcVal, EltTy, false, "tmp");
604   llvm::Constant *Mask = llvm::ConstantInt::get(VMContext,
605                            llvm::APInt::getLowBitsSet(EltTySize, BitfieldSize));
606   NewVal = Builder.CreateAnd(NewVal, Mask, "bf.value");
607 
608   // Return the new value of the bit-field, if requested.
609   if (Result) {
610     // Cast back to the proper type for result.
611     const llvm::Type *SrcTy = SrcVal->getType();
612     llvm::Value *SrcTrunc = Builder.CreateIntCast(NewVal, SrcTy, false,
613                                                   "bf.reload.val");
614 
615     // Sign extend if necessary.
616     if (Dst.isBitfieldSigned()) {
617       unsigned SrcTySize = CGM.getTargetData().getTypeSizeInBits(SrcTy);
618       llvm::Value *ExtraBits = llvm::ConstantInt::get(SrcTy,
619                                                       SrcTySize - BitfieldSize);
620       SrcTrunc = Builder.CreateAShr(Builder.CreateShl(SrcTrunc, ExtraBits),
621                                     ExtraBits, "bf.reload.sext");
622     }
623 
624     *Result = SrcTrunc;
625   }
626 
627   // In some cases the bitfield may straddle two memory locations.  Emit the low
628   // part first and check to see if the high needs to be done.
629   unsigned LowBits = std::min(BitfieldSize, EltTySize - StartBit);
630   llvm::Value *LowVal = Builder.CreateLoad(Ptr, Dst.isVolatileQualified(),
631                                            "bf.prev.low");
632 
633   // Compute the mask for zero-ing the low part of this bitfield.
634   llvm::Constant *InvMask =
635     llvm::ConstantInt::get(VMContext,
636              ~llvm::APInt::getBitsSet(EltTySize, StartBit, StartBit + LowBits));
637 
638   // Compute the new low part as
639   //   LowVal = (LowVal & InvMask) | (NewVal << StartBit),
640   // with the shift of NewVal implicitly stripping the high bits.
641   llvm::Value *NewLowVal =
642     Builder.CreateShl(NewVal, StartBit, "bf.value.lo");
643   LowVal = Builder.CreateAnd(LowVal, InvMask, "bf.prev.lo.cleared");
644   LowVal = Builder.CreateOr(LowVal, NewLowVal, "bf.new.lo");
645 
646   // Write back.
647   Builder.CreateStore(LowVal, Ptr, Dst.isVolatileQualified());
648 
649   // If the low part doesn't cover the bitfield emit a high part.
650   if (LowBits < BitfieldSize) {
651     unsigned HighBits = BitfieldSize - LowBits;
652     llvm::Value *HighPtr =  Builder.CreateGEP(Ptr, llvm::ConstantInt::get(
653                             llvm::Type::getInt32Ty(VMContext), 1), "bf.ptr.hi");
654     llvm::Value *HighVal = Builder.CreateLoad(HighPtr,
655                                               Dst.isVolatileQualified(),
656                                               "bf.prev.hi");
657 
658     // Compute the mask for zero-ing the high part of this bitfield.
659     llvm::Constant *InvMask =
660       llvm::ConstantInt::get(VMContext, ~llvm::APInt::getLowBitsSet(EltTySize,
661                                HighBits));
662 
663     // Compute the new high part as
664     //   HighVal = (HighVal & InvMask) | (NewVal lshr LowBits),
665     // where the high bits of NewVal have already been cleared and the
666     // shift stripping the low bits.
667     llvm::Value *NewHighVal =
668       Builder.CreateLShr(NewVal, LowBits, "bf.value.high");
669     HighVal = Builder.CreateAnd(HighVal, InvMask, "bf.prev.hi.cleared");
670     HighVal = Builder.CreateOr(HighVal, NewHighVal, "bf.new.hi");
671 
672     // Write back.
673     Builder.CreateStore(HighVal, HighPtr, Dst.isVolatileQualified());
674   }
675 }
676 
677 void CodeGenFunction::EmitStoreThroughPropertyRefLValue(RValue Src,
678                                                         LValue Dst,
679                                                         QualType Ty) {
680   EmitObjCPropertySet(Dst.getPropertyRefExpr(), Src);
681 }
682 
683 void CodeGenFunction::EmitStoreThroughKVCRefLValue(RValue Src,
684                                                    LValue Dst,
685                                                    QualType Ty) {
686   EmitObjCPropertySet(Dst.getKVCRefExpr(), Src);
687 }
688 
689 void CodeGenFunction::EmitStoreThroughExtVectorComponentLValue(RValue Src,
690                                                                LValue Dst,
691                                                                QualType Ty) {
692   // This access turns into a read/modify/write of the vector.  Load the input
693   // value now.
694   llvm::Value *Vec = Builder.CreateLoad(Dst.getExtVectorAddr(),
695                                         Dst.isVolatileQualified(), "tmp");
696   const llvm::Constant *Elts = Dst.getExtVectorElts();
697 
698   llvm::Value *SrcVal = Src.getScalarVal();
699 
700   if (const VectorType *VTy = Ty->getAs<VectorType>()) {
701     unsigned NumSrcElts = VTy->getNumElements();
702     unsigned NumDstElts =
703        cast<llvm::VectorType>(Vec->getType())->getNumElements();
704     if (NumDstElts == NumSrcElts) {
705       // Use shuffle vector is the src and destination are the same number of
706       // elements and restore the vector mask since it is on the side it will be
707       // stored.
708       llvm::SmallVector<llvm::Constant*, 4> Mask(NumDstElts);
709       for (unsigned i = 0; i != NumSrcElts; ++i) {
710         unsigned InIdx = getAccessedFieldNo(i, Elts);
711         Mask[InIdx] = llvm::ConstantInt::get(
712                                           llvm::Type::getInt32Ty(VMContext), i);
713       }
714 
715       llvm::Value *MaskV = llvm::ConstantVector::get(&Mask[0], Mask.size());
716       Vec = Builder.CreateShuffleVector(SrcVal,
717                                         llvm::UndefValue::get(Vec->getType()),
718                                         MaskV, "tmp");
719     } else if (NumDstElts > NumSrcElts) {
720       // Extended the source vector to the same length and then shuffle it
721       // into the destination.
722       // FIXME: since we're shuffling with undef, can we just use the indices
723       //        into that?  This could be simpler.
724       llvm::SmallVector<llvm::Constant*, 4> ExtMask;
725       const llvm::Type *Int32Ty = llvm::Type::getInt32Ty(VMContext);
726       unsigned i;
727       for (i = 0; i != NumSrcElts; ++i)
728         ExtMask.push_back(llvm::ConstantInt::get(Int32Ty, i));
729       for (; i != NumDstElts; ++i)
730         ExtMask.push_back(llvm::UndefValue::get(Int32Ty));
731       llvm::Value *ExtMaskV = llvm::ConstantVector::get(&ExtMask[0],
732                                                         ExtMask.size());
733       llvm::Value *ExtSrcVal =
734         Builder.CreateShuffleVector(SrcVal,
735                                     llvm::UndefValue::get(SrcVal->getType()),
736                                     ExtMaskV, "tmp");
737       // build identity
738       llvm::SmallVector<llvm::Constant*, 4> Mask;
739       for (unsigned i = 0; i != NumDstElts; ++i)
740         Mask.push_back(llvm::ConstantInt::get(Int32Ty, i));
741 
742       // modify when what gets shuffled in
743       for (unsigned i = 0; i != NumSrcElts; ++i) {
744         unsigned Idx = getAccessedFieldNo(i, Elts);
745         Mask[Idx] = llvm::ConstantInt::get(Int32Ty, i+NumDstElts);
746       }
747       llvm::Value *MaskV = llvm::ConstantVector::get(&Mask[0], Mask.size());
748       Vec = Builder.CreateShuffleVector(Vec, ExtSrcVal, MaskV, "tmp");
749     } else {
750       // We should never shorten the vector
751       assert(0 && "unexpected shorten vector length");
752     }
753   } else {
754     // If the Src is a scalar (not a vector) it must be updating one element.
755     unsigned InIdx = getAccessedFieldNo(0, Elts);
756     const llvm::Type *Int32Ty = llvm::Type::getInt32Ty(VMContext);
757     llvm::Value *Elt = llvm::ConstantInt::get(Int32Ty, InIdx);
758     Vec = Builder.CreateInsertElement(Vec, SrcVal, Elt, "tmp");
759   }
760 
761   Builder.CreateStore(Vec, Dst.getExtVectorAddr(), Dst.isVolatileQualified());
762 }
763 
764 // setObjCGCLValueClass - sets class of he lvalue for the purpose of
765 // generating write-barries API. It is currently a global, ivar,
766 // or neither.
767 static void setObjCGCLValueClass(const ASTContext &Ctx, const Expr *E,
768                                  LValue &LV) {
769   if (Ctx.getLangOptions().getGCMode() == LangOptions::NonGC)
770     return;
771 
772   if (isa<ObjCIvarRefExpr>(E)) {
773     LV.SetObjCIvar(LV, true);
774     ObjCIvarRefExpr *Exp = cast<ObjCIvarRefExpr>(const_cast<Expr*>(E));
775     LV.setBaseIvarExp(Exp->getBase());
776     LV.SetObjCArray(LV, E->getType()->isArrayType());
777     return;
778   }
779 
780   if (const DeclRefExpr *Exp = dyn_cast<DeclRefExpr>(E)) {
781     if (const VarDecl *VD = dyn_cast<VarDecl>(Exp->getDecl())) {
782       if ((VD->isBlockVarDecl() && !VD->hasLocalStorage()) ||
783           VD->isFileVarDecl())
784         LV.SetGlobalObjCRef(LV, true);
785     }
786     LV.SetObjCArray(LV, E->getType()->isArrayType());
787     return;
788   }
789 
790   if (const UnaryOperator *Exp = dyn_cast<UnaryOperator>(E)) {
791     setObjCGCLValueClass(Ctx, Exp->getSubExpr(), LV);
792     return;
793   }
794 
795   if (const ParenExpr *Exp = dyn_cast<ParenExpr>(E)) {
796     setObjCGCLValueClass(Ctx, Exp->getSubExpr(), LV);
797     if (LV.isObjCIvar()) {
798       // If cast is to a structure pointer, follow gcc's behavior and make it
799       // a non-ivar write-barrier.
800       QualType ExpTy = E->getType();
801       if (ExpTy->isPointerType())
802         ExpTy = ExpTy->getAs<PointerType>()->getPointeeType();
803       if (ExpTy->isRecordType())
804         LV.SetObjCIvar(LV, false);
805     }
806     return;
807   }
808   if (const ImplicitCastExpr *Exp = dyn_cast<ImplicitCastExpr>(E)) {
809     setObjCGCLValueClass(Ctx, Exp->getSubExpr(), LV);
810     return;
811   }
812 
813   if (const CStyleCastExpr *Exp = dyn_cast<CStyleCastExpr>(E)) {
814     setObjCGCLValueClass(Ctx, Exp->getSubExpr(), LV);
815     return;
816   }
817 
818   if (const ArraySubscriptExpr *Exp = dyn_cast<ArraySubscriptExpr>(E)) {
819     setObjCGCLValueClass(Ctx, Exp->getBase(), LV);
820     if (LV.isObjCIvar() && !LV.isObjCArray())
821       // Using array syntax to assigning to what an ivar points to is not
822       // same as assigning to the ivar itself. {id *Names;} Names[i] = 0;
823       LV.SetObjCIvar(LV, false);
824     else if (LV.isGlobalObjCRef() && !LV.isObjCArray())
825       // Using array syntax to assigning to what global points to is not
826       // same as assigning to the global itself. {id *G;} G[i] = 0;
827       LV.SetGlobalObjCRef(LV, false);
828     return;
829   }
830 
831   if (const MemberExpr *Exp = dyn_cast<MemberExpr>(E)) {
832     setObjCGCLValueClass(Ctx, Exp->getBase(), LV);
833     // We don't know if member is an 'ivar', but this flag is looked at
834     // only in the context of LV.isObjCIvar().
835     LV.SetObjCArray(LV, E->getType()->isArrayType());
836     return;
837   }
838 }
839 
840 static LValue EmitGlobalVarDeclLValue(CodeGenFunction &CGF,
841                                       const Expr *E, const VarDecl *VD) {
842   assert((VD->hasExternalStorage() || VD->isFileVarDecl()) &&
843          "Var decl must have external storage or be a file var decl!");
844 
845   llvm::Value *V = CGF.CGM.GetAddrOfGlobalVar(VD);
846   if (VD->getType()->isReferenceType())
847     V = CGF.Builder.CreateLoad(V, "tmp");
848   LValue LV = LValue::MakeAddr(V, CGF.MakeQualifiers(E->getType()));
849   setObjCGCLValueClass(CGF.getContext(), E, LV);
850   return LV;
851 }
852 
853 static LValue EmitFunctionDeclLValue(CodeGenFunction &CGF,
854                                       const Expr *E, const FunctionDecl *FD) {
855   llvm::Value* V = CGF.CGM.GetAddrOfFunction(FD);
856   if (!FD->hasPrototype()) {
857     if (const FunctionProtoType *Proto =
858             FD->getType()->getAs<FunctionProtoType>()) {
859       // Ugly case: for a K&R-style definition, the type of the definition
860       // isn't the same as the type of a use.  Correct for this with a
861       // bitcast.
862       QualType NoProtoType =
863           CGF.getContext().getFunctionNoProtoType(Proto->getResultType());
864       NoProtoType = CGF.getContext().getPointerType(NoProtoType);
865       V = CGF.Builder.CreateBitCast(V, CGF.ConvertType(NoProtoType), "tmp");
866     }
867   }
868   return LValue::MakeAddr(V, CGF.MakeQualifiers(E->getType()));
869 }
870 
871 LValue CodeGenFunction::EmitDeclRefLValue(const DeclRefExpr *E) {
872   const NamedDecl *ND = E->getDecl();
873 
874   if (const VarDecl *VD = dyn_cast<VarDecl>(ND)) {
875 
876     // Check if this is a global variable.
877     if (VD->hasExternalStorage() || VD->isFileVarDecl())
878       return EmitGlobalVarDeclLValue(*this, E, VD);
879 
880     bool NonGCable = VD->hasLocalStorage() && !VD->hasAttr<BlocksAttr>();
881 
882     llvm::Value *V = LocalDeclMap[VD];
883     assert(V && "DeclRefExpr not entered in LocalDeclMap?");
884 
885     Qualifiers Quals = MakeQualifiers(E->getType());
886     // local variables do not get their gc attribute set.
887     // local static?
888     if (NonGCable) Quals.removeObjCGCAttr();
889 
890     if (VD->hasAttr<BlocksAttr>()) {
891       V = Builder.CreateStructGEP(V, 1, "forwarding");
892       V = Builder.CreateLoad(V);
893       V = Builder.CreateStructGEP(V, getByRefValueLLVMField(VD),
894                                   VD->getNameAsString());
895     }
896     if (VD->getType()->isReferenceType())
897       V = Builder.CreateLoad(V, "tmp");
898     LValue LV = LValue::MakeAddr(V, Quals);
899     LValue::SetObjCNonGC(LV, NonGCable);
900     setObjCGCLValueClass(getContext(), E, LV);
901     return LV;
902   }
903 
904   if (const FunctionDecl *FD = dyn_cast<FunctionDecl>(ND))
905     return EmitFunctionDeclLValue(*this, E, FD);
906 
907   if (E->getQualifier()) {
908     // FIXME: the qualifier check does not seem sufficient here
909     return EmitPointerToDataMemberLValue(cast<FieldDecl>(ND));
910   }
911 
912   assert(false && "Unhandled DeclRefExpr");
913 
914   // an invalid LValue, but the assert will
915   // ensure that this point is never reached.
916   return LValue();
917 }
918 
919 LValue CodeGenFunction::EmitBlockDeclRefLValue(const BlockDeclRefExpr *E) {
920   return LValue::MakeAddr(GetAddrOfBlockDecl(E), MakeQualifiers(E->getType()));
921 }
922 
923 LValue CodeGenFunction::EmitUnaryOpLValue(const UnaryOperator *E) {
924   // __extension__ doesn't affect lvalue-ness.
925   if (E->getOpcode() == UnaryOperator::Extension)
926     return EmitLValue(E->getSubExpr());
927 
928   QualType ExprTy = getContext().getCanonicalType(E->getSubExpr()->getType());
929   switch (E->getOpcode()) {
930   default: assert(0 && "Unknown unary operator lvalue!");
931   case UnaryOperator::Deref: {
932     QualType T = E->getSubExpr()->getType()->getPointeeType();
933     assert(!T.isNull() && "CodeGenFunction::EmitUnaryOpLValue: Illegal type");
934 
935     Qualifiers Quals = MakeQualifiers(T);
936     Quals.setAddressSpace(ExprTy.getAddressSpace());
937 
938     LValue LV = LValue::MakeAddr(EmitScalarExpr(E->getSubExpr()), Quals);
939     // We should not generate __weak write barrier on indirect reference
940     // of a pointer to object; as in void foo (__weak id *param); *param = 0;
941     // But, we continue to generate __strong write barrier on indirect write
942     // into a pointer to object.
943     if (getContext().getLangOptions().ObjC1 &&
944         getContext().getLangOptions().getGCMode() != LangOptions::NonGC &&
945         LV.isObjCWeak())
946       LValue::SetObjCNonGC(LV, !E->isOBJCGCCandidate(getContext()));
947     return LV;
948   }
949   case UnaryOperator::Real:
950   case UnaryOperator::Imag: {
951     LValue LV = EmitLValue(E->getSubExpr());
952     unsigned Idx = E->getOpcode() == UnaryOperator::Imag;
953     return LValue::MakeAddr(Builder.CreateStructGEP(LV.getAddress(),
954                                                     Idx, "idx"),
955                             MakeQualifiers(ExprTy));
956   }
957   case UnaryOperator::PreInc:
958   case UnaryOperator::PreDec:
959     return EmitUnsupportedLValue(E, "pre-inc/dec expression");
960   }
961 }
962 
963 LValue CodeGenFunction::EmitStringLiteralLValue(const StringLiteral *E) {
964   return LValue::MakeAddr(CGM.GetAddrOfConstantStringFromLiteral(E),
965                           Qualifiers());
966 }
967 
968 LValue CodeGenFunction::EmitObjCEncodeExprLValue(const ObjCEncodeExpr *E) {
969   return LValue::MakeAddr(CGM.GetAddrOfConstantStringFromObjCEncode(E),
970                           Qualifiers());
971 }
972 
973 
974 LValue CodeGenFunction::EmitPredefinedFunctionName(unsigned Type) {
975   std::string GlobalVarName;
976 
977   switch (Type) {
978   default: assert(0 && "Invalid type");
979   case PredefinedExpr::Func:
980     GlobalVarName = "__func__.";
981     break;
982   case PredefinedExpr::Function:
983     GlobalVarName = "__FUNCTION__.";
984     break;
985   case PredefinedExpr::PrettyFunction:
986     GlobalVarName = "__PRETTY_FUNCTION__.";
987     break;
988   }
989 
990   llvm::StringRef FnName = CurFn->getName();
991   if (FnName.startswith("\01"))
992     FnName = FnName.substr(1);
993   GlobalVarName += FnName;
994 
995   std::string FunctionName =
996     PredefinedExpr::ComputeName(getContext(), (PredefinedExpr::IdentType)Type,
997                                 CurCodeDecl);
998 
999   llvm::Constant *C =
1000     CGM.GetAddrOfConstantCString(FunctionName, GlobalVarName.c_str());
1001   return LValue::MakeAddr(C, Qualifiers());
1002 }
1003 
1004 LValue CodeGenFunction::EmitPredefinedLValue(const PredefinedExpr *E) {
1005   switch (E->getIdentType()) {
1006   default:
1007     return EmitUnsupportedLValue(E, "predefined expression");
1008   case PredefinedExpr::Func:
1009   case PredefinedExpr::Function:
1010   case PredefinedExpr::PrettyFunction:
1011     return EmitPredefinedFunctionName(E->getIdentType());
1012   }
1013 }
1014 
1015 LValue CodeGenFunction::EmitArraySubscriptExpr(const ArraySubscriptExpr *E) {
1016   // The index must always be an integer, which is not an aggregate.  Emit it.
1017   llvm::Value *Idx = EmitScalarExpr(E->getIdx());
1018   QualType IdxTy  = E->getIdx()->getType();
1019   bool IdxSigned = IdxTy->isSignedIntegerType();
1020 
1021   // If the base is a vector type, then we are forming a vector element lvalue
1022   // with this subscript.
1023   if (E->getBase()->getType()->isVectorType()) {
1024     // Emit the vector as an lvalue to get its address.
1025     LValue LHS = EmitLValue(E->getBase());
1026     assert(LHS.isSimple() && "Can only subscript lvalue vectors here!");
1027     Idx = Builder.CreateIntCast(Idx,
1028                           llvm::Type::getInt32Ty(VMContext), IdxSigned, "vidx");
1029     return LValue::MakeVectorElt(LHS.getAddress(), Idx,
1030                                  E->getBase()->getType().getCVRQualifiers());
1031   }
1032 
1033   // The base must be a pointer, which is not an aggregate.  Emit it.
1034   llvm::Value *Base = EmitScalarExpr(E->getBase());
1035 
1036   // Extend or truncate the index type to 32 or 64-bits.
1037   unsigned IdxBitwidth = cast<llvm::IntegerType>(Idx->getType())->getBitWidth();
1038   if (IdxBitwidth != LLVMPointerWidth)
1039     Idx = Builder.CreateIntCast(Idx,
1040                             llvm::IntegerType::get(VMContext, LLVMPointerWidth),
1041                                 IdxSigned, "idxprom");
1042 
1043   // We know that the pointer points to a type of the correct size, unless the
1044   // size is a VLA or Objective-C interface.
1045   llvm::Value *Address = 0;
1046   if (const VariableArrayType *VAT =
1047         getContext().getAsVariableArrayType(E->getType())) {
1048     llvm::Value *VLASize = GetVLASize(VAT);
1049 
1050     Idx = Builder.CreateMul(Idx, VLASize);
1051 
1052     QualType BaseType = getContext().getBaseElementType(VAT);
1053 
1054     uint64_t BaseTypeSize = getContext().getTypeSize(BaseType) / 8;
1055     Idx = Builder.CreateUDiv(Idx,
1056                              llvm::ConstantInt::get(Idx->getType(),
1057                                                     BaseTypeSize));
1058     Address = Builder.CreateInBoundsGEP(Base, Idx, "arrayidx");
1059   } else if (const ObjCInterfaceType *OIT =
1060              dyn_cast<ObjCInterfaceType>(E->getType())) {
1061     llvm::Value *InterfaceSize =
1062       llvm::ConstantInt::get(Idx->getType(),
1063                              getContext().getTypeSize(OIT) / 8);
1064 
1065     Idx = Builder.CreateMul(Idx, InterfaceSize);
1066 
1067     const llvm::Type *i8PTy = llvm::Type::getInt8PtrTy(VMContext);
1068     Address = Builder.CreateGEP(Builder.CreateBitCast(Base, i8PTy),
1069                                 Idx, "arrayidx");
1070     Address = Builder.CreateBitCast(Address, Base->getType());
1071   } else {
1072     Address = Builder.CreateInBoundsGEP(Base, Idx, "arrayidx");
1073   }
1074 
1075   QualType T = E->getBase()->getType()->getPointeeType();
1076   assert(!T.isNull() &&
1077          "CodeGenFunction::EmitArraySubscriptExpr(): Illegal base type");
1078 
1079   Qualifiers Quals = MakeQualifiers(T);
1080   Quals.setAddressSpace(E->getBase()->getType().getAddressSpace());
1081 
1082   LValue LV = LValue::MakeAddr(Address, Quals);
1083   if (getContext().getLangOptions().ObjC1 &&
1084       getContext().getLangOptions().getGCMode() != LangOptions::NonGC) {
1085     LValue::SetObjCNonGC(LV, !E->isOBJCGCCandidate(getContext()));
1086     setObjCGCLValueClass(getContext(), E, LV);
1087   }
1088   return LV;
1089 }
1090 
1091 static
1092 llvm::Constant *GenerateConstantVector(llvm::LLVMContext &VMContext,
1093                                        llvm::SmallVector<unsigned, 4> &Elts) {
1094   llvm::SmallVector<llvm::Constant *, 4> CElts;
1095 
1096   for (unsigned i = 0, e = Elts.size(); i != e; ++i)
1097     CElts.push_back(llvm::ConstantInt::get(
1098                                    llvm::Type::getInt32Ty(VMContext), Elts[i]));
1099 
1100   return llvm::ConstantVector::get(&CElts[0], CElts.size());
1101 }
1102 
1103 LValue CodeGenFunction::
1104 EmitExtVectorElementExpr(const ExtVectorElementExpr *E) {
1105   // Emit the base vector as an l-value.
1106   LValue Base;
1107 
1108   // ExtVectorElementExpr's base can either be a vector or pointer to vector.
1109   if (!E->isArrow()) {
1110     assert(E->getBase()->getType()->isVectorType());
1111     Base = EmitLValue(E->getBase());
1112   } else {
1113     const PointerType *PT = E->getBase()->getType()->getAs<PointerType>();
1114     llvm::Value *Ptr = EmitScalarExpr(E->getBase());
1115     Qualifiers Quals = MakeQualifiers(PT->getPointeeType());
1116     Quals.removeObjCGCAttr();
1117     Base = LValue::MakeAddr(Ptr, Quals);
1118   }
1119 
1120   // Encode the element access list into a vector of unsigned indices.
1121   llvm::SmallVector<unsigned, 4> Indices;
1122   E->getEncodedElementAccess(Indices);
1123 
1124   if (Base.isSimple()) {
1125     llvm::Constant *CV = GenerateConstantVector(VMContext, Indices);
1126     return LValue::MakeExtVectorElt(Base.getAddress(), CV,
1127                                     Base.getVRQualifiers());
1128   }
1129   assert(Base.isExtVectorElt() && "Can only subscript lvalue vec elts here!");
1130 
1131   llvm::Constant *BaseElts = Base.getExtVectorElts();
1132   llvm::SmallVector<llvm::Constant *, 4> CElts;
1133 
1134   const llvm::Type *Int32Ty = llvm::Type::getInt32Ty(VMContext);
1135   for (unsigned i = 0, e = Indices.size(); i != e; ++i) {
1136     if (isa<llvm::ConstantAggregateZero>(BaseElts))
1137       CElts.push_back(llvm::ConstantInt::get(Int32Ty, 0));
1138     else
1139       CElts.push_back(cast<llvm::Constant>(BaseElts->getOperand(Indices[i])));
1140   }
1141   llvm::Constant *CV = llvm::ConstantVector::get(&CElts[0], CElts.size());
1142   return LValue::MakeExtVectorElt(Base.getExtVectorAddr(), CV,
1143                                   Base.getVRQualifiers());
1144 }
1145 
1146 LValue CodeGenFunction::EmitMemberExpr(const MemberExpr *E) {
1147   bool isUnion = false;
1148   bool isNonGC = false;
1149   Expr *BaseExpr = E->getBase();
1150   llvm::Value *BaseValue = NULL;
1151   Qualifiers BaseQuals;
1152 
1153   // If this is s.x, emit s as an lvalue.  If it is s->x, emit s as a scalar.
1154   if (E->isArrow()) {
1155     BaseValue = EmitScalarExpr(BaseExpr);
1156     const PointerType *PTy =
1157       BaseExpr->getType()->getAs<PointerType>();
1158     if (PTy->getPointeeType()->isUnionType())
1159       isUnion = true;
1160     BaseQuals = PTy->getPointeeType().getQualifiers();
1161   } else if (isa<ObjCPropertyRefExpr>(BaseExpr->IgnoreParens()) ||
1162              isa<ObjCImplicitSetterGetterRefExpr>(
1163                BaseExpr->IgnoreParens())) {
1164     RValue RV = EmitObjCPropertyGet(BaseExpr);
1165     BaseValue = RV.getAggregateAddr();
1166     if (BaseExpr->getType()->isUnionType())
1167       isUnion = true;
1168     BaseQuals = BaseExpr->getType().getQualifiers();
1169   } else {
1170     LValue BaseLV = EmitLValue(BaseExpr);
1171     if (BaseLV.isNonGC())
1172       isNonGC = true;
1173     // FIXME: this isn't right for bitfields.
1174     BaseValue = BaseLV.getAddress();
1175     QualType BaseTy = BaseExpr->getType();
1176     if (BaseTy->isUnionType())
1177       isUnion = true;
1178     BaseQuals = BaseTy.getQualifiers();
1179   }
1180 
1181   NamedDecl *ND = E->getMemberDecl();
1182   if (FieldDecl *Field = dyn_cast<FieldDecl>(ND)) {
1183     LValue LV = EmitLValueForField(BaseValue, Field, isUnion,
1184                                    BaseQuals.getCVRQualifiers());
1185     LValue::SetObjCNonGC(LV, isNonGC);
1186     setObjCGCLValueClass(getContext(), E, LV);
1187     return LV;
1188   }
1189 
1190   if (VarDecl *VD = dyn_cast<VarDecl>(ND))
1191     return EmitGlobalVarDeclLValue(*this, E, VD);
1192 
1193   if (const FunctionDecl *FD = dyn_cast<FunctionDecl>(ND))
1194     return EmitFunctionDeclLValue(*this, E, FD);
1195 
1196   assert(false && "Unhandled member declaration!");
1197   return LValue();
1198 }
1199 
1200 LValue CodeGenFunction::EmitLValueForBitfield(llvm::Value* BaseValue,
1201                                               const FieldDecl* Field,
1202                                               unsigned CVRQualifiers) {
1203   CodeGenTypes::BitFieldInfo Info = CGM.getTypes().getBitFieldInfo(Field);
1204 
1205   // FIXME: CodeGenTypes should expose a method to get the appropriate type for
1206   // FieldTy (the appropriate type is ABI-dependent).
1207   const llvm::Type *FieldTy =
1208     CGM.getTypes().ConvertTypeForMem(Field->getType());
1209   const llvm::PointerType *BaseTy =
1210   cast<llvm::PointerType>(BaseValue->getType());
1211   unsigned AS = BaseTy->getAddressSpace();
1212   BaseValue = Builder.CreateBitCast(BaseValue,
1213                                     llvm::PointerType::get(FieldTy, AS),
1214                                     "tmp");
1215 
1216   llvm::Value *Idx =
1217     llvm::ConstantInt::get(llvm::Type::getInt32Ty(VMContext), Info.FieldNo);
1218   llvm::Value *V = Builder.CreateGEP(BaseValue, Idx, "tmp");
1219 
1220   return LValue::MakeBitfield(V, Info.Start, Info.Size,
1221                               Field->getType()->isSignedIntegerType(),
1222                             Field->getType().getCVRQualifiers()|CVRQualifiers);
1223 }
1224 
1225 LValue CodeGenFunction::EmitLValueForField(llvm::Value* BaseValue,
1226                                            const FieldDecl* Field,
1227                                            bool isUnion,
1228                                            unsigned CVRQualifiers) {
1229   if (Field->isBitField())
1230     return EmitLValueForBitfield(BaseValue, Field, CVRQualifiers);
1231 
1232   unsigned idx = CGM.getTypes().getLLVMFieldNo(Field);
1233   llvm::Value *V = Builder.CreateStructGEP(BaseValue, idx, "tmp");
1234 
1235   // Match union field type.
1236   if (isUnion) {
1237     const llvm::Type *FieldTy =
1238       CGM.getTypes().ConvertTypeForMem(Field->getType());
1239     const llvm::PointerType * BaseTy =
1240       cast<llvm::PointerType>(BaseValue->getType());
1241     unsigned AS = BaseTy->getAddressSpace();
1242     V = Builder.CreateBitCast(V,
1243                               llvm::PointerType::get(FieldTy, AS),
1244                               "tmp");
1245   }
1246   if (Field->getType()->isReferenceType())
1247     V = Builder.CreateLoad(V, "tmp");
1248 
1249   Qualifiers Quals = MakeQualifiers(Field->getType());
1250   Quals.addCVRQualifiers(CVRQualifiers);
1251   // __weak attribute on a field is ignored.
1252   if (Quals.getObjCGCAttr() == Qualifiers::Weak)
1253     Quals.removeObjCGCAttr();
1254 
1255   return LValue::MakeAddr(V, Quals);
1256 }
1257 
1258 LValue CodeGenFunction::EmitCompoundLiteralLValue(const CompoundLiteralExpr* E){
1259   const llvm::Type *LTy = ConvertType(E->getType());
1260   llvm::Value *DeclPtr = CreateTempAlloca(LTy, ".compoundliteral");
1261 
1262   const Expr* InitExpr = E->getInitializer();
1263   LValue Result = LValue::MakeAddr(DeclPtr, MakeQualifiers(E->getType()));
1264 
1265   if (E->getType()->isComplexType())
1266     EmitComplexExprIntoAddr(InitExpr, DeclPtr, false);
1267   else if (hasAggregateLLVMType(E->getType()))
1268     EmitAnyExpr(InitExpr, DeclPtr, false);
1269   else
1270     EmitStoreThroughLValue(EmitAnyExpr(InitExpr), Result, E->getType());
1271 
1272   return Result;
1273 }
1274 
1275 LValue
1276 CodeGenFunction::EmitConditionalOperatorLValue(const ConditionalOperator* E) {
1277   if (E->isLvalue(getContext()) == Expr::LV_Valid) {
1278     llvm::BasicBlock *LHSBlock = createBasicBlock("cond.true");
1279     llvm::BasicBlock *RHSBlock = createBasicBlock("cond.false");
1280     llvm::BasicBlock *ContBlock = createBasicBlock("cond.end");
1281 
1282     llvm::Value *Cond = EvaluateExprAsBool(E->getCond());
1283     Builder.CreateCondBr(Cond, LHSBlock, RHSBlock);
1284 
1285     EmitBlock(LHSBlock);
1286 
1287     LValue LHS = EmitLValue(E->getLHS());
1288     if (!LHS.isSimple())
1289       return EmitUnsupportedLValue(E, "conditional operator");
1290 
1291     llvm::Value *Temp = CreateTempAlloca(LHS.getAddress()->getType(),"condtmp");
1292     Builder.CreateStore(LHS.getAddress(), Temp);
1293     EmitBranch(ContBlock);
1294 
1295     EmitBlock(RHSBlock);
1296     LValue RHS = EmitLValue(E->getRHS());
1297     if (!RHS.isSimple())
1298       return EmitUnsupportedLValue(E, "conditional operator");
1299 
1300     Builder.CreateStore(RHS.getAddress(), Temp);
1301     EmitBranch(ContBlock);
1302 
1303     EmitBlock(ContBlock);
1304 
1305     Temp = Builder.CreateLoad(Temp, "lv");
1306     return LValue::MakeAddr(Temp, MakeQualifiers(E->getType()));
1307   }
1308 
1309   // ?: here should be an aggregate.
1310   assert((hasAggregateLLVMType(E->getType()) &&
1311           !E->getType()->isAnyComplexType()) &&
1312          "Unexpected conditional operator!");
1313 
1314   llvm::Value *Temp = CreateTempAlloca(ConvertType(E->getType()));
1315   EmitAggExpr(E, Temp, false);
1316 
1317   return LValue::MakeAddr(Temp, MakeQualifiers(E->getType()));
1318 }
1319 
1320 /// EmitCastLValue - Casts are never lvalues unless that cast is a dynamic_cast.
1321 /// If the cast is a dynamic_cast, we can have the usual lvalue result,
1322 /// otherwise if a cast is needed by the code generator in an lvalue context,
1323 /// then it must mean that we need the address of an aggregate in order to
1324 /// access one of its fields.  This can happen for all the reasons that casts
1325 /// are permitted with aggregate result, including noop aggregate casts, and
1326 /// cast from scalar to union.
1327 LValue CodeGenFunction::EmitCastLValue(const CastExpr *E) {
1328   switch (E->getCastKind()) {
1329   default:
1330     return EmitUnsupportedLValue(E, "unexpected cast lvalue");
1331 
1332   case CastExpr::CK_Dynamic: {
1333     LValue LV = EmitLValue(E->getSubExpr());
1334     llvm::Value *V = LV.getAddress();
1335     const CXXDynamicCastExpr *DCE = cast<CXXDynamicCastExpr>(E);
1336     return LValue::MakeAddr(EmitDynamicCast(V, DCE),
1337                             MakeQualifiers(E->getType()));
1338   }
1339 
1340   case CastExpr::CK_NoOp:
1341   case CastExpr::CK_ConstructorConversion:
1342   case CastExpr::CK_UserDefinedConversion:
1343     return EmitLValue(E->getSubExpr());
1344 
1345   case CastExpr::CK_DerivedToBase: {
1346     const RecordType *DerivedClassTy =
1347       E->getSubExpr()->getType()->getAs<RecordType>();
1348     CXXRecordDecl *DerivedClassDecl =
1349       cast<CXXRecordDecl>(DerivedClassTy->getDecl());
1350 
1351     const RecordType *BaseClassTy = E->getType()->getAs<RecordType>();
1352     CXXRecordDecl *BaseClassDecl = cast<CXXRecordDecl>(BaseClassTy->getDecl());
1353 
1354     LValue LV = EmitLValue(E->getSubExpr());
1355 
1356     // Perform the derived-to-base conversion
1357     llvm::Value *Base =
1358       GetAddressOfBaseClass(LV.getAddress(), DerivedClassDecl,
1359                             BaseClassDecl, /*NullCheckValue=*/false);
1360 
1361     return LValue::MakeAddr(Base, MakeQualifiers(E->getType()));
1362   }
1363   case CastExpr::CK_ToUnion: {
1364     llvm::Value *Temp = CreateTempAlloca(ConvertType(E->getType()));
1365     EmitAnyExpr(E->getSubExpr(), Temp, false);
1366 
1367     return LValue::MakeAddr(Temp, MakeQualifiers(E->getType()));
1368   }
1369   case CastExpr::CK_BaseToDerived: {
1370     const RecordType *BaseClassTy =
1371       E->getSubExpr()->getType()->getAs<RecordType>();
1372     CXXRecordDecl *BaseClassDecl =
1373       cast<CXXRecordDecl>(BaseClassTy->getDecl());
1374 
1375     const RecordType *DerivedClassTy = E->getType()->getAs<RecordType>();
1376     CXXRecordDecl *DerivedClassDecl =
1377       cast<CXXRecordDecl>(DerivedClassTy->getDecl());
1378 
1379     LValue LV = EmitLValue(E->getSubExpr());
1380 
1381     // Perform the base-to-derived conversion
1382     llvm::Value *Derived =
1383       GetAddressOfDerivedClass(LV.getAddress(), BaseClassDecl,
1384                                DerivedClassDecl, /*NullCheckValue=*/false);
1385 
1386     return LValue::MakeAddr(Derived, MakeQualifiers(E->getType()));
1387   }
1388   case CastExpr::CK_BitCast: {
1389     // This must be a reinterpret_cast (or c-style equivalent).
1390     const ExplicitCastExpr *CE = cast<ExplicitCastExpr>(E);
1391 
1392     LValue LV = EmitLValue(E->getSubExpr());
1393     llvm::Value *V = Builder.CreateBitCast(LV.getAddress(),
1394                                            ConvertType(CE->getTypeAsWritten()));
1395     return LValue::MakeAddr(V, MakeQualifiers(E->getType()));
1396   }
1397   }
1398 }
1399 
1400 LValue CodeGenFunction::EmitNullInitializationLValue(
1401                                               const CXXZeroInitValueExpr *E) {
1402   QualType Ty = E->getType();
1403   const llvm::Type *LTy = ConvertTypeForMem(Ty);
1404   llvm::AllocaInst *Alloc = CreateTempAlloca(LTy);
1405   unsigned Align = getContext().getTypeAlign(Ty)/8;
1406   Alloc->setAlignment(Align);
1407   LValue lvalue = LValue::MakeAddr(Alloc, Qualifiers());
1408   EmitMemSetToZero(lvalue.getAddress(), Ty);
1409   return lvalue;
1410 }
1411 
1412 //===--------------------------------------------------------------------===//
1413 //                             Expression Emission
1414 //===--------------------------------------------------------------------===//
1415 
1416 
1417 RValue CodeGenFunction::EmitCallExpr(const CallExpr *E) {
1418   // Builtins never have block type.
1419   if (E->getCallee()->getType()->isBlockPointerType())
1420     return EmitBlockCallExpr(E);
1421 
1422   if (const CXXMemberCallExpr *CE = dyn_cast<CXXMemberCallExpr>(E))
1423     return EmitCXXMemberCallExpr(CE);
1424 
1425   const Decl *TargetDecl = 0;
1426   if (const ImplicitCastExpr *CE = dyn_cast<ImplicitCastExpr>(E->getCallee())) {
1427     if (const DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(CE->getSubExpr())) {
1428       TargetDecl = DRE->getDecl();
1429       if (const FunctionDecl *FD = dyn_cast<FunctionDecl>(TargetDecl))
1430         if (unsigned builtinID = FD->getBuiltinID())
1431           return EmitBuiltinExpr(FD, builtinID, E);
1432     }
1433   }
1434 
1435   if (const CXXOperatorCallExpr *CE = dyn_cast<CXXOperatorCallExpr>(E))
1436     if (const CXXMethodDecl *MD = dyn_cast_or_null<CXXMethodDecl>(TargetDecl))
1437       return EmitCXXOperatorMemberCallExpr(CE, MD);
1438 
1439   if (isa<CXXPseudoDestructorExpr>(E->getCallee()->IgnoreParens())) {
1440     // C++ [expr.pseudo]p1:
1441     //   The result shall only be used as the operand for the function call
1442     //   operator (), and the result of such a call has type void. The only
1443     //   effect is the evaluation of the postfix-expression before the dot or
1444     //   arrow.
1445     EmitScalarExpr(E->getCallee());
1446     return RValue::get(0);
1447   }
1448 
1449   llvm::Value *Callee = EmitScalarExpr(E->getCallee());
1450   return EmitCall(Callee, E->getCallee()->getType(),
1451                   E->arg_begin(), E->arg_end(), TargetDecl);
1452 }
1453 
1454 LValue CodeGenFunction::EmitBinaryOperatorLValue(const BinaryOperator *E) {
1455   // Comma expressions just emit their LHS then their RHS as an l-value.
1456   if (E->getOpcode() == BinaryOperator::Comma) {
1457     EmitAnyExpr(E->getLHS());
1458     EnsureInsertPoint();
1459     return EmitLValue(E->getRHS());
1460   }
1461 
1462   if (E->getOpcode() == BinaryOperator::PtrMemD ||
1463       E->getOpcode() == BinaryOperator::PtrMemI)
1464     return EmitPointerToDataMemberBinaryExpr(E);
1465 
1466   // Can only get l-value for binary operator expressions which are a
1467   // simple assignment of aggregate type.
1468   if (E->getOpcode() != BinaryOperator::Assign)
1469     return EmitUnsupportedLValue(E, "binary l-value expression");
1470 
1471   if (!hasAggregateLLVMType(E->getType())) {
1472     // Emit the LHS as an l-value.
1473     LValue LV = EmitLValue(E->getLHS());
1474 
1475     llvm::Value *RHS = EmitScalarExpr(E->getRHS());
1476     EmitStoreOfScalar(RHS, LV.getAddress(), LV.isVolatileQualified(),
1477                       E->getType());
1478     return LV;
1479   }
1480 
1481   llvm::Value *Temp = CreateTempAlloca(ConvertType(E->getType()));
1482   EmitAggExpr(E, Temp, false);
1483   // FIXME: Are these qualifiers correct?
1484   return LValue::MakeAddr(Temp, MakeQualifiers(E->getType()));
1485 }
1486 
1487 LValue CodeGenFunction::EmitCallExprLValue(const CallExpr *E) {
1488   RValue RV = EmitCallExpr(E);
1489 
1490   if (!RV.isScalar())
1491     return LValue::MakeAddr(RV.getAggregateAddr(),MakeQualifiers(E->getType()));
1492 
1493   assert(E->getCallReturnType()->isReferenceType() &&
1494          "Can't have a scalar return unless the return type is a "
1495          "reference type!");
1496 
1497   return LValue::MakeAddr(RV.getScalarVal(), MakeQualifiers(E->getType()));
1498 }
1499 
1500 LValue CodeGenFunction::EmitVAArgExprLValue(const VAArgExpr *E) {
1501   // FIXME: This shouldn't require another copy.
1502   llvm::Value *Temp = CreateTempAlloca(ConvertType(E->getType()));
1503   EmitAggExpr(E, Temp, false);
1504   return LValue::MakeAddr(Temp, MakeQualifiers(E->getType()));
1505 }
1506 
1507 LValue CodeGenFunction::EmitCXXConstructLValue(const CXXConstructExpr *E) {
1508   llvm::Value *Temp = CreateTempAlloca(ConvertTypeForMem(E->getType()), "tmp");
1509   EmitCXXConstructExpr(Temp, E);
1510   return LValue::MakeAddr(Temp, MakeQualifiers(E->getType()));
1511 }
1512 
1513 LValue
1514 CodeGenFunction::EmitCXXTypeidLValue(const CXXTypeidExpr *E) {
1515   llvm::Value *Temp = EmitCXXTypeidExpr(E);
1516   return LValue::MakeAddr(Temp, MakeQualifiers(E->getType()));
1517 }
1518 
1519 LValue
1520 CodeGenFunction::EmitCXXBindTemporaryLValue(const CXXBindTemporaryExpr *E) {
1521   LValue LV = EmitLValue(E->getSubExpr());
1522   PushCXXTemporary(E->getTemporary(), LV.getAddress());
1523   return LV;
1524 }
1525 
1526 LValue CodeGenFunction::EmitObjCMessageExprLValue(const ObjCMessageExpr *E) {
1527   // Can only get l-value for message expression returning aggregate type
1528   RValue RV = EmitObjCMessageExpr(E);
1529   // FIXME: can this be volatile?
1530   return LValue::MakeAddr(RV.getAggregateAddr(), MakeQualifiers(E->getType()));
1531 }
1532 
1533 llvm::Value *CodeGenFunction::EmitIvarOffset(const ObjCInterfaceDecl *Interface,
1534                                              const ObjCIvarDecl *Ivar) {
1535   return CGM.getObjCRuntime().EmitIvarOffset(*this, Interface, Ivar);
1536 }
1537 
1538 LValue CodeGenFunction::EmitLValueForIvar(QualType ObjectTy,
1539                                           llvm::Value *BaseValue,
1540                                           const ObjCIvarDecl *Ivar,
1541                                           unsigned CVRQualifiers) {
1542   return CGM.getObjCRuntime().EmitObjCValueForIvar(*this, ObjectTy, BaseValue,
1543                                                    Ivar, CVRQualifiers);
1544 }
1545 
1546 LValue CodeGenFunction::EmitObjCIvarRefLValue(const ObjCIvarRefExpr *E) {
1547   // FIXME: A lot of the code below could be shared with EmitMemberExpr.
1548   llvm::Value *BaseValue = 0;
1549   const Expr *BaseExpr = E->getBase();
1550   Qualifiers BaseQuals;
1551   QualType ObjectTy;
1552   if (E->isArrow()) {
1553     BaseValue = EmitScalarExpr(BaseExpr);
1554     ObjectTy = BaseExpr->getType()->getPointeeType();
1555     BaseQuals = ObjectTy.getQualifiers();
1556   } else {
1557     LValue BaseLV = EmitLValue(BaseExpr);
1558     // FIXME: this isn't right for bitfields.
1559     BaseValue = BaseLV.getAddress();
1560     ObjectTy = BaseExpr->getType();
1561     BaseQuals = ObjectTy.getQualifiers();
1562   }
1563 
1564   LValue LV =
1565     EmitLValueForIvar(ObjectTy, BaseValue, E->getDecl(),
1566                       BaseQuals.getCVRQualifiers());
1567   setObjCGCLValueClass(getContext(), E, LV);
1568   return LV;
1569 }
1570 
1571 LValue
1572 CodeGenFunction::EmitObjCPropertyRefLValue(const ObjCPropertyRefExpr *E) {
1573   // This is a special l-value that just issues sends when we load or store
1574   // through it.
1575   return LValue::MakePropertyRef(E, E->getType().getCVRQualifiers());
1576 }
1577 
1578 LValue CodeGenFunction::EmitObjCKVCRefLValue(
1579                                 const ObjCImplicitSetterGetterRefExpr *E) {
1580   // This is a special l-value that just issues sends when we load or store
1581   // through it.
1582   return LValue::MakeKVCRef(E, E->getType().getCVRQualifiers());
1583 }
1584 
1585 LValue CodeGenFunction::EmitObjCSuperExprLValue(const ObjCSuperExpr *E) {
1586   return EmitUnsupportedLValue(E, "use of super");
1587 }
1588 
1589 LValue CodeGenFunction::EmitStmtExprLValue(const StmtExpr *E) {
1590   // Can only get l-value for message expression returning aggregate type
1591   RValue RV = EmitAnyExprToTemp(E);
1592   // FIXME: can this be volatile?
1593   return LValue::MakeAddr(RV.getAggregateAddr(), MakeQualifiers(E->getType()));
1594 }
1595 
1596 
1597 LValue CodeGenFunction::EmitPointerToDataMemberLValue(const FieldDecl *Field) {
1598   const CXXRecordDecl *ClassDecl = cast<CXXRecordDecl>(Field->getDeclContext());
1599   QualType NNSpecTy =
1600     getContext().getCanonicalType(
1601       getContext().getTypeDeclType(const_cast<CXXRecordDecl*>(ClassDecl)));
1602   NNSpecTy = getContext().getPointerType(NNSpecTy);
1603   llvm::Value *V = llvm::Constant::getNullValue(ConvertType(NNSpecTy));
1604   LValue MemExpLV = EmitLValueForField(V, Field, /*isUnion=*/false,
1605                                        /*Qualifiers=*/0);
1606   const llvm::Type *ResultType = ConvertType(getContext().getPointerDiffType());
1607   V = Builder.CreatePtrToInt(MemExpLV.getAddress(), ResultType, "datamember");
1608   return LValue::MakeAddr(V, MakeQualifiers(Field->getType()));
1609 }
1610 
1611 RValue CodeGenFunction::EmitCall(llvm::Value *Callee, QualType CalleeType,
1612                                  CallExpr::const_arg_iterator ArgBeg,
1613                                  CallExpr::const_arg_iterator ArgEnd,
1614                                  const Decl *TargetDecl) {
1615   // Get the actual function type. The callee type will always be a pointer to
1616   // function type or a block pointer type.
1617   assert(CalleeType->isFunctionPointerType() &&
1618          "Call must have function pointer type!");
1619 
1620   CalleeType = getContext().getCanonicalType(CalleeType);
1621 
1622   QualType FnType = cast<PointerType>(CalleeType)->getPointeeType();
1623   QualType ResultType = cast<FunctionType>(FnType)->getResultType();
1624 
1625   CallArgList Args;
1626   EmitCallArgs(Args, dyn_cast<FunctionProtoType>(FnType), ArgBeg, ArgEnd);
1627 
1628   // FIXME: We should not need to do this, it should be part of the function
1629   // type.
1630   unsigned CallingConvention = 0;
1631   if (const llvm::Function *F =
1632       dyn_cast<llvm::Function>(Callee->stripPointerCasts()))
1633     CallingConvention = F->getCallingConv();
1634   return EmitCall(CGM.getTypes().getFunctionInfo(ResultType, Args,
1635                                                  CallingConvention),
1636                   Callee, Args, TargetDecl);
1637 }
1638 
1639 LValue CodeGenFunction::
1640 EmitPointerToDataMemberBinaryExpr(const BinaryOperator *E) {
1641   llvm::Value *BaseV;
1642   if (E->getOpcode() == BinaryOperator::PtrMemI)
1643     BaseV = EmitScalarExpr(E->getLHS());
1644   else
1645     BaseV = EmitLValue(E->getLHS()).getAddress();
1646   const llvm::Type *i8Ty = llvm::Type::getInt8PtrTy(getLLVMContext());
1647   BaseV = Builder.CreateBitCast(BaseV, i8Ty);
1648   llvm::Value *OffsetV = EmitScalarExpr(E->getRHS());
1649   llvm::Value *AddV = Builder.CreateInBoundsGEP(BaseV, OffsetV, "add.ptr");
1650 
1651   QualType Ty = E->getRHS()->getType();
1652   Ty = Ty->getAs<MemberPointerType>()->getPointeeType();
1653 
1654   const llvm::Type *PType = ConvertType(getContext().getPointerType(Ty));
1655   AddV = Builder.CreateBitCast(AddV, PType);
1656   return LValue::MakeAddr(AddV, MakeQualifiers(Ty));
1657 }
1658 
1659