diff options
author | Ken Dyck <kd@kendyck.com> | 2011-03-22 01:21:15 +0000 |
---|---|---|
committer | Ken Dyck <kd@kendyck.com> | 2011-03-22 01:21:15 +0000 |
commit | 6aa767c18ef7f21ecda3c92bfa96ec7d6c026948 (patch) | |
tree | f04c821a4f6e5f84cc43312e4a3c01a8631a3fb5 /clang/lib/CodeGen/CGClass.cpp | |
parent | 022a4904faf358962dcbef4b1e6bf9aaef3cd2ee (diff) | |
download | bcm5719-llvm-6aa767c18ef7f21ecda3c92bfa96ec7d6c026948.tar.gz bcm5719-llvm-6aa767c18ef7f21ecda3c92bfa96ec7d6c026948.zip |
Convert Offset variable in GetAddressOfDirectBaseInCompleteClass() to
CharUnits. No change in functionality intended.
llvm-svn: 128060
Diffstat (limited to 'clang/lib/CodeGen/CGClass.cpp')
-rw-r--r-- | clang/lib/CodeGen/CGClass.cpp | 10 |
1 files changed, 5 insertions, 5 deletions
diff --git a/clang/lib/CodeGen/CGClass.cpp b/clang/lib/CodeGen/CGClass.cpp index 15d87f78353..69fcf9010bc 100644 --- a/clang/lib/CodeGen/CGClass.cpp +++ b/clang/lib/CodeGen/CGClass.cpp @@ -84,20 +84,20 @@ CodeGenFunction::GetAddressOfDirectBaseInCompleteClass(llvm::Value *This, == ConvertType(Derived)); // Compute the offset of the virtual base. - uint64_t Offset; + CharUnits Offset; const ASTRecordLayout &Layout = getContext().getASTRecordLayout(Derived); if (BaseIsVirtual) - Offset = Layout.getVBaseClassOffsetInBits(Base); + Offset = Layout.getVBaseClassOffset(Base); else - Offset = Layout.getBaseClassOffsetInBits(Base); + Offset = Layout.getBaseClassOffset(Base); // Shift and cast down to the base type. // TODO: for complete types, this should be possible with a GEP. llvm::Value *V = This; - if (Offset) { + if (Offset.isPositive()) { const llvm::Type *Int8PtrTy = llvm::Type::getInt8PtrTy(getLLVMContext()); V = Builder.CreateBitCast(V, Int8PtrTy); - V = Builder.CreateConstInBoundsGEP1_64(V, Offset / 8); + V = Builder.CreateConstInBoundsGEP1_64(V, Offset.getQuantity()); } V = Builder.CreateBitCast(V, ConvertType(Base)->getPointerTo()); |