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 | 72b1f24bd271ae1e703480a2825c3e1544b6a579 (patch) | |
| tree | 9d933890885cd79199e8caca0ebc7f9bb66329c7 /clang/lib/CodeGen | |
| parent | b2cde2db67ed96b180e8c338a5108d0d943003c7 (diff) | |
| download | bcm5719-llvm-72b1f24bd271ae1e703480a2825c3e1544b6a579.tar.gz bcm5719-llvm-72b1f24bd271ae1e703480a2825c3e1544b6a579.zip | |
Use the existing API for base offset. Use suitable llvm type
for offset ir-gen.
llvm-svn: 77458
Diffstat (limited to 'clang/lib/CodeGen')
| -rw-r--r-- | clang/lib/CodeGen/CGCXX.cpp | 24 |
1 files changed, 4 insertions, 20 deletions
diff --git a/clang/lib/CodeGen/CGCXX.cpp b/clang/lib/CodeGen/CGCXX.cpp index 0b22eb49be8..050323a5b6c 100644 --- a/clang/lib/CodeGen/CGCXX.cpp +++ b/clang/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 = |

