From: Eli Friedman Date: Tue, 10 Nov 2009 22:42:26 +0000 (+0000) Subject: Minor optimization to skip null check in generated code where it isn't X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=db380b4f40889f981b6f3f9f82730f91976f5fdf;p=clang 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 --- diff --git a/lib/CodeGen/CGCXXClass.cpp b/lib/CodeGen/CGCXXClass.cpp index 56a28fc9a0..668139ffb5 100644 --- a/lib/CodeGen/CGCXXClass.cpp +++ b/lib/CodeGen/CGCXXClass.cpp @@ -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);