Revert "[InstCombine] Support gep nuw in icmp folds" (#118698)
[llvm-project.git] / llvm / test / Analysis / ScalarEvolution / max-addops-inline.ll
blob65c9ff6da362d3ae22a7ae739ad4613802c5bda4
1 ; RUN: opt -disable-output "-passes=print<scalar-evolution>" -scev-addops-inline-threshold=1 < %s 2>&1 | FileCheck --check-prefix=CHECK1 %s
2 ; RUN: opt -disable-output "-passes=print<scalar-evolution>" -scev-addops-inline-threshold=10 < %s 2>&1 | FileCheck --check-prefix=CHECK10 %s
4 define i32 @foo(i64 %p0, i32 %p1) {
5 ; CHECK1: %add2 = add nsw i32 %mul1, %add
6 ; CHECK1-NEXT: -->  ((trunc i64 %p0 to i32) * (1 + (trunc i64 %p0 to i32)) * (1 + %p1))
8 ; CHECK10: %add2 = add nsw i32 %mul1, %add
9 ; CHECK10-NEXT: -->  ((trunc i64 %p0 to i32) * (1 + ((trunc i64 %p0 to i32) * (1 + %p1)) + %p1))
10 entry:
11   %tr = trunc i64 %p0 to i32
12   %mul = mul nsw i32 %tr, %p1
13   %add = add nsw i32 %mul, %tr
14   %mul1 = mul nsw i32 %add, %tr
15   %add2 = add nsw i32 %mul1, %add
16   ret i32 %add2