Minor optimization to skip null check in generated code where it isn't

necessary.



git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@86741 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Eli Friedman 2009-11-10 22:42:26 +00:00
Родитель 7f1de456fe
Коммит db380b4f40
1 изменённых файлов: 11 добавлений и 9 удалений

Просмотреть файл

@ -127,7 +127,14 @@ CodeGenFunction::GetAddressCXXOfBaseClass(llvm::Value *BaseValue,
// Just cast back.
return Builder.CreateBitCast(BaseValue, BasePtrTy);
}
llvm::Value *Offset =
GetCXXBaseClassOffset(*this, BaseValue, ClassDecl, BaseClassDecl);
// If there is no offset, simply cast the pointer and return it.
if (!Offset)
return Builder.CreateBitCast(BaseValue, BasePtrTy);
llvm::BasicBlock *CastNull = 0;
llvm::BasicBlock *CastNotNull = 0;
llvm::BasicBlock *CastEnd = 0;
@ -145,15 +152,10 @@ CodeGenFunction::GetAddressCXXOfBaseClass(llvm::Value *BaseValue,
}
const llvm::Type *Int8PtrTy = llvm::Type::getInt8PtrTy(VMContext);
llvm::Value *Offset =
GetCXXBaseClassOffset(*this, BaseValue, ClassDecl, BaseClassDecl);
if (Offset) {
// Apply the offset.
BaseValue = Builder.CreateBitCast(BaseValue, Int8PtrTy);
BaseValue = Builder.CreateGEP(BaseValue, Offset, "add.ptr");
}
// Apply the offset.
BaseValue = Builder.CreateBitCast(BaseValue, Int8PtrTy);
BaseValue = Builder.CreateGEP(BaseValue, Offset, "add.ptr");
// Cast back.
BaseValue = Builder.CreateBitCast(BaseValue, BasePtrTy);