diff options
Diffstat (limited to 'lib/CodeGen/CGExpr.cpp')
| -rw-r--r-- | lib/CodeGen/CGExpr.cpp | 15 | 
1 files changed, 11 insertions, 4 deletions
| diff --git a/lib/CodeGen/CGExpr.cpp b/lib/CodeGen/CGExpr.cpp index dc9ecd64f4e46..87ec159a60109 100644 --- a/lib/CodeGen/CGExpr.cpp +++ b/lib/CodeGen/CGExpr.cpp @@ -14,6 +14,7 @@  #include "CodeGenFunction.h"  #include "CodeGenModule.h"  #include "CGCall.h" +#include "CGRecordLayout.h"  #include "CGObjCRuntime.h"  #include "clang/AST/ASTContext.h"  #include "clang/AST/DeclObjC.h" @@ -1468,7 +1469,9 @@ LValue CodeGenFunction::EmitMemberExpr(const MemberExpr *E) {  LValue CodeGenFunction::EmitLValueForBitfield(llvm::Value* BaseValue,                                                const FieldDecl* Field,                                                unsigned CVRQualifiers) { -  CodeGenTypes::BitFieldInfo Info = CGM.getTypes().getBitFieldInfo(Field); +  const CGRecordLayout &RL = +    CGM.getTypes().getCGRecordLayout(Field->getParent()); +  const CGRecordLayout::BitFieldInfo &Info = RL.getBitFieldInfo(Field);    // FIXME: CodeGenTypes should expose a method to get the appropriate type for    // FieldTy (the appropriate type is ABI-dependent). @@ -1496,7 +1499,9 @@ LValue CodeGenFunction::EmitLValueForField(llvm::Value* BaseValue,    if (Field->isBitField())      return EmitLValueForBitfield(BaseValue, Field, CVRQualifiers); -  unsigned idx = CGM.getTypes().getLLVMFieldNo(Field); +  const CGRecordLayout &RL = +    CGM.getTypes().getCGRecordLayout(Field->getParent()); +  unsigned idx = RL.getLLVMFieldNo(Field);    llvm::Value *V = Builder.CreateStructGEP(BaseValue, idx, "tmp");    // Match union field type. @@ -1531,7 +1536,9 @@ CodeGenFunction::EmitLValueForFieldInitialization(llvm::Value* BaseValue,    if (!FieldType->isReferenceType())      return EmitLValueForField(BaseValue, Field, CVRQualifiers); -  unsigned idx = CGM.getTypes().getLLVMFieldNo(Field); +  const CGRecordLayout &RL = +    CGM.getTypes().getCGRecordLayout(Field->getParent()); +  unsigned idx = RL.getLLVMFieldNo(Field);    llvm::Value *V = Builder.CreateStructGEP(BaseValue, idx, "tmp");    assert(!FieldType.getObjCGCAttr() && "fields cannot have GC attrs"); @@ -1637,6 +1644,7 @@ LValue CodeGenFunction::EmitCastLValue(const CastExpr *E) {    case CastExpr::CK_AnyPointerToObjCPointerCast:      return EmitLValue(E->getSubExpr()); +  case CastExpr::CK_UncheckedDerivedToBase:    case CastExpr::CK_DerivedToBase: {      const RecordType *DerivedClassTy =         E->getSubExpr()->getType()->getAs<RecordType>(); @@ -1872,7 +1880,6 @@ LValue CodeGenFunction::EmitObjCSuperExprLValue(const ObjCSuperExpr *E) {  LValue CodeGenFunction::EmitStmtExprLValue(const StmtExpr *E) {    // Can only get l-value for message expression returning aggregate type    RValue RV = EmitAnyExprToTemp(E); -  // FIXME: can this be volatile?    return LValue::MakeAddr(RV.getAggregateAddr(), MakeQualifiers(E->getType()));  } | 
