aboutsummaryrefslogtreecommitdiff
path: root/lib/CodeGen/CGCXX.cpp
diff options
context:
space:
mode:
authorFariborz Jahanian <fjahanian@apple.com>2009-07-29 15:54:56 +0000
committerFariborz Jahanian <fjahanian@apple.com>2009-07-29 15:54:56 +0000
commit5a8503b333f50acd6012859853612229f38cb420 (patch)
treefa800317895bd65dd2bd9a946a4d8541e3972d0d /lib/CodeGen/CGCXX.cpp
parentc50315b9ac611cb4873d4d3192bcb4970b96b98e (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.cpp24
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 =