forked from OSchip/llvm-project
Re-commit 97860 with fix. getMallocAllocatedType may return null.
llvm-svn: 98000
This commit is contained in:
parent
ee20b5f236
commit
4f2fd2d2be
|
@ -337,6 +337,16 @@ Instruction *InstCombiner::visitCallInst(CallInst &CI) {
|
||||||
}
|
}
|
||||||
return ReplaceInstUsesWith(CI, ConstantInt::get(ReturnTy, AllocaSize));
|
return ReplaceInstUsesWith(CI, ConstantInt::get(ReturnTy, AllocaSize));
|
||||||
}
|
}
|
||||||
|
} else if (CallInst *MI = extractMallocCall(Op1)) {
|
||||||
|
const Type* MallocType = getMallocAllocatedType(MI);
|
||||||
|
// Get alloca size.
|
||||||
|
if (MallocType && MallocType->isSized()) {
|
||||||
|
if (Value *NElems = getMallocArraySize(MI, TD, true)) {
|
||||||
|
if (ConstantInt *NElements = dyn_cast<ConstantInt>(NElems))
|
||||||
|
return ReplaceInstUsesWith(CI, ConstantInt::get(ReturnTy,
|
||||||
|
(NElements->getZExtValue() * TD->getTypeAllocSize(MallocType))));
|
||||||
|
}
|
||||||
|
}
|
||||||
} else if (ConstantExpr *CE = dyn_cast<ConstantExpr>(Op1)) {
|
} else if (ConstantExpr *CE = dyn_cast<ConstantExpr>(Op1)) {
|
||||||
// Only handle constant GEPs here.
|
// Only handle constant GEPs here.
|
||||||
if (CE->getOpcode() != Instruction::GetElementPtr) break;
|
if (CE->getOpcode() != Instruction::GetElementPtr) break;
|
||||||
|
|
|
@ -118,8 +118,24 @@ entry:
|
||||||
ret i32 0
|
ret i32 0
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@s = external global i8*
|
||||||
|
|
||||||
|
define void @test5(i32 %n) nounwind ssp {
|
||||||
|
; CHECK: @test5
|
||||||
|
entry:
|
||||||
|
%0 = tail call noalias i8* @malloc(i32 20) nounwind
|
||||||
|
%1 = tail call i32 @llvm.objectsize.i32(i8* %0, i1 false)
|
||||||
|
%2 = load i8** @s, align 8
|
||||||
|
; CHECK-NOT: @llvm.objectsize
|
||||||
|
; CHECK: @__memcpy_chk(i8* %0, i8* %1, i32 10, i32 20)
|
||||||
|
%3 = tail call i8* @__memcpy_chk(i8* %0, i8* %2, i32 10, i32 %1) nounwind
|
||||||
|
ret void
|
||||||
|
}
|
||||||
|
|
||||||
declare i8* @__memset_chk(i8*, i32, i64, i64) nounwind
|
declare i8* @__memset_chk(i8*, i32, i64, i64) nounwind
|
||||||
|
|
||||||
|
declare noalias i8* @malloc(i32) nounwind
|
||||||
|
|
||||||
declare i32 @llvm.objectsize.i32(i8*, i1) nounwind readonly
|
declare i32 @llvm.objectsize.i32(i8*, i1) nounwind readonly
|
||||||
|
|
||||||
declare i64 @llvm.objectsize.i64(i8*, i1) nounwind readonly
|
declare i64 @llvm.objectsize.i64(i8*, i1) nounwind readonly
|
||||||
|
|
Loading…
Reference in New Issue