[PATCH] D21690: Fix size computation of array allocation in inline cost analysis
Easwaran Raman via llvm-commits
llvm-commits at lists.llvm.org
Mon Jun 27 15:39:03 PDT 2016
This revision was automatically updated to reflect the committed changes.
Closed by commit rL273952: Fix size computation of array allocation in inline cost analysis (authored by eraman).
Changed prior to commit:
http://reviews.llvm.org/D21690?vs=62021&id=62028#toc
Repository:
rL LLVM
http://reviews.llvm.org/D21690
Files:
llvm/trunk/lib/Analysis/InlineCost.cpp
llvm/trunk/test/Transforms/Inline/array-alloca.ll
Index: llvm/trunk/lib/Analysis/InlineCost.cpp
===================================================================
--- llvm/trunk/lib/Analysis/InlineCost.cpp
+++ llvm/trunk/lib/Analysis/InlineCost.cpp
@@ -339,18 +339,19 @@
if (I.isArrayAllocation()) {
Constant *Size = SimplifiedValues.lookup(I.getArraySize());
if (auto *AllocSize = dyn_cast_or_null<ConstantInt>(Size)) {
+ const DataLayout &DL = F.getParent()->getDataLayout();
Type *Ty = I.getAllocatedType();
- // FIXME: This can't be right. AllocatedSize is in *bytes*.
- AllocatedSize += Ty->getPrimitiveSizeInBits() * AllocSize->getZExtValue();
+ AllocatedSize = SaturatingMultiplyAdd(
+ AllocSize->getLimitedValue(), DL.getTypeAllocSize(Ty), AllocatedSize);
return Base::visitAlloca(I);
}
}
// Accumulate the allocated size.
if (I.isStaticAlloca()) {
const DataLayout &DL = F.getParent()->getDataLayout();
Type *Ty = I.getAllocatedType();
- AllocatedSize += DL.getTypeAllocSize(Ty);
+ AllocatedSize = SaturatingAdd(DL.getTypeAllocSize(Ty), AllocatedSize);
}
// We will happily inline static alloca instructions.
Index: llvm/trunk/test/Transforms/Inline/array-alloca.ll
===================================================================
--- llvm/trunk/test/Transforms/Inline/array-alloca.ll
+++ llvm/trunk/test/Transforms/Inline/array-alloca.ll
@@ -0,0 +1,36 @@
+; RUN: opt -inline -S < %s | FileCheck %s
+%struct.A = type { i32 }
+
+define void @callee1(i32 %M) {
+entry:
+ %vla = alloca i32, i32 %M, align 16
+ ret void
+}
+
+define void @callee2(i32 %M) {
+entry:
+ %vla = alloca %struct.A, i32 %M, align 16
+ ret void
+}
+
+define void @callee3(i128 %M) {
+entry:
+ %vla = alloca i32, i128 %M, align 16
+ ret void
+}
+
+; CHECK-LABEL: @caller
+define void @caller() #0 {
+entry:
+ call void @caller()
+; CHECK-NOT: call void @callee1
+ call void @callee1(i32 256)
+; CHECK: call void @callee2
+ call void @callee2(i32 4096)
+; CHECK: call void @callee3
+; This is to test that there is no overflow in computing allocated size
+; call void @callee3(i128 0x8000000000000000);
+ call void @callee3(i128 9223372036854775808);
+ ret void
+}
+
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D21690.62028.patch
Type: text/x-patch
Size: 2206 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20160627/3dad91ad/attachment.bin>
More information about the llvm-commits
mailing list