bounds checking: add support for byval arguments

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@157498 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Nuno Lopes 2012-05-25 21:15:17 +00:00
parent 06a2f42d11
commit d72d67da07
2 changed files with 18 additions and 1 deletions

View File

@ -104,7 +104,6 @@ void BoundsChecking::emitBranchToTrap(Value *Cmp) {
BasicBlock *Cont = OldBB->splitBasicBlock(Inst); BasicBlock *Cont = OldBB->splitBasicBlock(Inst);
OldBB->getTerminator()->eraseFromParent(); OldBB->getTerminator()->eraseFromParent();
// FIXME: add unlikely branch taken metadata?
if (Cmp) if (Cmp)
BranchInst::Create(getTrapBB(), Cont, Cmp, OldBB); BranchInst::Create(getTrapBB(), Cont, Cmp, OldBB);
else else
@ -152,6 +151,15 @@ ConstTriState BoundsChecking::computeAllocSize(Value *Alloc, uint64_t &Size,
SizeValue = Builder->CreateMul(SizeValue, ArraySize); SizeValue = Builder->CreateMul(SizeValue, ArraySize);
return NotConst; return NotConst;
// function arguments
} else if (Argument *A = dyn_cast<Argument>(Alloc)) {
if (!A->hasByValAttr())
return Dunno;
PointerType *PT = cast<PointerType>(A->getType());
Size = TD->getTypeAllocSize(PT->getElementType());
return Const;
// ptr = select(ptr1, ptr2) // ptr = select(ptr1, ptr2)
} else if (SelectInst *SI = dyn_cast<SelectInst>(Alloc)) { } else if (SelectInst *SI = dyn_cast<SelectInst>(Alloc)) {
uint64_t SizeFalse; uint64_t SizeFalse;

View File

@ -107,3 +107,12 @@ define void @f10(i64 %x, i64 %y) nounwind {
%4 = load i128* %3, align 4 %4 = load i128* %3, align 4
ret void ret void
} }
; CHECK: @f11
define void @f11(i128* byval %x) nounwind {
%1 = bitcast i128* %x to i8*
%2 = getelementptr inbounds i8* %1, i64 16
; CHECK: br label
%3 = load i8* %2, align 4
ret void
}