summaryrefslogtreecommitdiffstats
path: root/llvm/test/Analysis/ScalarEvolution/max-addops-inline.ll
diff options
context:
space:
mode:
authorDaniil Fukalov <daniil.fukalov@amd.com>2017-01-26 13:33:17 +0000
committerDaniil Fukalov <daniil.fukalov@amd.com>2017-01-26 13:33:17 +0000
commitb09dac59fc7b988fd4062345108f54b2520edf3d (patch)
treea6cb2995ac634d532354c090fabb2a0d3f4292e6 /llvm/test/Analysis/ScalarEvolution/max-addops-inline.ll
parent3057fd53f969bec658f45640d333faa8b8843cb3 (diff)
downloadbcm5719-llvm-b09dac59fc7b988fd4062345108f54b2520edf3d.tar.gz
bcm5719-llvm-b09dac59fc7b988fd4062345108f54b2520edf3d.zip
[SCEV] Introduce add operation inlining limit
Inlining in getAddExpr() can cause abnormal computational time in some cases. New parameter -scev-addops-inline-threshold is intruduced with default value 500. Reviewers: sanjoy Subscribers: mzolotukhin, llvm-commits Differential Revision: https://reviews.llvm.org/D28812 llvm-svn: 293176
Diffstat (limited to 'llvm/test/Analysis/ScalarEvolution/max-addops-inline.ll')
-rw-r--r--llvm/test/Analysis/ScalarEvolution/max-addops-inline.ll17
1 files changed, 17 insertions, 0 deletions
diff --git a/llvm/test/Analysis/ScalarEvolution/max-addops-inline.ll b/llvm/test/Analysis/ScalarEvolution/max-addops-inline.ll
new file mode 100644
index 00000000000..2701ed32839
--- /dev/null
+++ b/llvm/test/Analysis/ScalarEvolution/max-addops-inline.ll
@@ -0,0 +1,17 @@
+; RUN: opt -analyze -scalar-evolution -scev-addops-inline-threshold=1 < %s | FileCheck --check-prefix=CHECK1 %s
+; RUN: opt -analyze -scalar-evolution -scev-addops-inline-threshold=10 < %s | FileCheck --check-prefix=CHECK10 %s
+
+define i32 @foo(i64 %p0, i32 %p1) {
+; CHECK1: %add2 = add nsw i32 %mul1, %add
+; CHECK1-NEXT: --> ((trunc i64 %p0 to i32) * (1 + (trunc i64 %p0 to i32)) * (1 + %p1))
+
+; CHECK10: %add2 = add nsw i32 %mul1, %add
+; CHECK10-NEXT: --> ((trunc i64 %p0 to i32) * (1 + ((trunc i64 %p0 to i32) * (1 + %p1)) + %p1))
+entry:
+ %tr = trunc i64 %p0 to i32
+ %mul = mul nsw i32 %tr, %p1
+ %add = add nsw i32 %mul, %tr
+ %mul1 = mul nsw i32 %add, %tr
+ %add2 = add nsw i32 %mul1, %add
+ ret i32 %add2
+}
OpenPOWER on IntegriCloud