[ORC] Add std::tuple support to SimplePackedSerialization.
[llvm-project.git] / llvm / test / Analysis / ScalarEvolution / huge_expression_limit.ll
blobe72c3b755032bf71c17ba52d150c5048c78c1288
1 ; NOTE: Assertions have been autogenerated by utils/update_analyze_test_checks.py
2 ; RUN: opt < %s -analyze -enable-new-pm=0 -scalar-evolution -scalar-evolution-huge-expr-threshold=1 | FileCheck %s
3 ; RUN: opt < %s -disable-output "-passes=print<scalar-evolution>" -scalar-evolution-huge-expr-threshold=1 2>&1 | FileCheck %s
5 define void @test(i32 %a, i32 %b, i32 %c, i32 %d, i32 %e, i32 %f) {
6 ; CHECK-LABEL: 'test'
7 ; CHECK-NEXT:  Classifying expressions for: @test
8 ; CHECK-NEXT:    %add1 = add i32 %a, %b
9 ; CHECK-NEXT:    --> (%a + %b) U: full-set S: full-set
10 ; CHECK-NEXT:    %add2 = add i32 %add1, %c
11 ; CHECK-NEXT:    --> ((%a + %b) + %c) U: full-set S: full-set
12 ; CHECK-NEXT:    %add3 = add i32 %add2, %d
13 ; CHECK-NEXT:    --> (((%a + %b) + %c) + %d) U: full-set S: full-set
14 ; CHECK-NEXT:    %add4 = add i32 %add3, %e
15 ; CHECK-NEXT:    --> ((((%a + %b) + %c) + %d) + %e) U: full-set S: full-set
16 ; CHECK-NEXT:    %add5 = add i32 %add4, %f
17 ; CHECK-NEXT:    --> (((((%a + %b) + %c) + %d) + %e) + %f) U: full-set S: full-set
18 ; CHECK-NEXT:    %mul1 = mul i32 %a, %b
19 ; CHECK-NEXT:    --> (%a * %b) U: full-set S: full-set
20 ; CHECK-NEXT:    %mul2 = mul i32 %mul1, %c
21 ; CHECK-NEXT:    --> ((%a * %b) * %c) U: full-set S: full-set
22 ; CHECK-NEXT:    %mul3 = mul i32 %mul2, %d
23 ; CHECK-NEXT:    --> (((%a * %b) * %c) * %d) U: full-set S: full-set
24 ; CHECK-NEXT:    %mul4 = mul i32 %mul3, %e
25 ; CHECK-NEXT:    --> ((((%a * %b) * %c) * %d) * %e) U: full-set S: full-set
26 ; CHECK-NEXT:    %mul5 = mul i32 %mul4, %f
27 ; CHECK-NEXT:    --> (((((%a * %b) * %c) * %d) * %e) * %f) U: full-set S: full-set
28 ; CHECK-NEXT:  Determining loop execution counts for: @test
30   %add1 = add i32 %a, %b
31   %add2 = add i32 %add1, %c
32   %add3 = add i32 %add2, %d
33   %add4 = add i32 %add3, %e
34   %add5 = add i32 %add4, %f
36   %mul1 = mul i32 %a, %b
37   %mul2 = mul i32 %mul1, %c
38   %mul3 = mul i32 %mul2, %d
39   %mul4 = mul i32 %mul3, %e
40   %mul5 = mul i32 %mul4, %f
41   ret void