From: Fariborz Jahanian Date: Wed, 29 Jul 2009 15:54:56 +0000 (+0000) Subject: Use the existing API for base offset. Use suitable llvm type X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=5a8503b333f50acd6012859853612229f38cb420;p=clang Use the existing API for base offset. Use suitable llvm type for offset ir-gen. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@77458 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/CGCXX.cpp b/lib/CodeGen/CGCXX.cpp index 0b22eb49be..050323a5b6 100644 --- a/lib/CodeGen/CGCXX.cpp +++ b/lib/CodeGen/CGCXX.cpp @@ -167,26 +167,10 @@ llvm::Value *CodeGenFunction::AddressCXXOfBaseClass(llvm::Value *BaseValue, const ASTRecordLayout &Layout = getContext().getASTRecordLayout(ClassDecl); llvm::Type *I8Ptr = VMContext.getPointerTypeUnqual(llvm::Type::Int8Ty); - unsigned Idx = 0; - bool DerivedToBaseConversion = false; - for (CXXRecordDecl::base_class_const_iterator i = - ClassDecl->bases_begin(), - e = ClassDecl->bases_end(); i != e; ++i, ++Idx) { - if (!i->isVirtual()) { - const CXXRecordDecl *Base = - cast(i->getType()->getAsRecordType()->getDecl()); - if (Base == BaseClassDecl) { - DerivedToBaseConversion = true; - break; - } - } - } - if (!DerivedToBaseConversion) { - assert(false && "FIXME - Only derived to imm. base convesion is supported"); - return BaseValue; - } - uint64_t Offset = Layout.getFieldOffset(Idx) / 8; - llvm::Value *OffsetVal = llvm::ConstantInt::get(llvm::Type::Int32Ty, Offset); + uint64_t Offset = Layout.getBaseClassOffset(BaseClassDecl) / 8; + llvm::Value *OffsetVal = + llvm::ConstantInt::get( + CGM.getTypes().ConvertType(CGM.getContext().LongTy), Offset); BaseValue = Builder.CreateBitCast(BaseValue, I8Ptr); BaseValue = Builder.CreateGEP(BaseValue, OffsetVal, "add.ptr"); QualType BTy =