diff options
author | Fariborz Jahanian <fjahanian@apple.com> | 2009-07-29 15:54:56 +0000 |
---|---|---|
committer | Fariborz Jahanian <fjahanian@apple.com> | 2009-07-29 15:54:56 +0000 |
commit | 5a8503b333f50acd6012859853612229f38cb420 (patch) | |
tree | fa800317895bd65dd2bd9a946a4d8541e3972d0d /lib/CodeGen/CGCXX.cpp | |
parent | c50315b9ac611cb4873d4d3192bcb4970b96b98e (diff) |
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
Diffstat (limited to 'lib/CodeGen/CGCXX.cpp')
-rw-r--r-- | lib/CodeGen/CGCXX.cpp | 24 |
1 files changed, 4 insertions, 20 deletions
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<CXXRecordDecl>(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 = |