| ; NOTE: Assertions have been autogenerated by utils/update_analyze_test_checks.py UTC_ARGS: --version 4 |
| ; RUN: opt -disable-output "-passes=print<scalar-evolution>" -scalar-evolution-classify-expressions=0 < %s 2>&1 | FileCheck %s |
| |
| define i32 @pr34538() local_unnamed_addr #0 { |
| ; CHECK-LABEL: 'pr34538' |
| ; CHECK-NEXT: Determining loop execution counts for: @pr34538 |
| ; CHECK-NEXT: Loop %do.body: backedge-taken count is i32 10000 |
| ; CHECK-NEXT: Loop %do.body: constant max backedge-taken count is i32 10000 |
| ; CHECK-NEXT: Loop %do.body: symbolic max backedge-taken count is i32 10000 |
| ; CHECK-NEXT: Loop %do.body: Trip multiple is 10001 |
| ; |
| entry: |
| br label %do.body |
| |
| do.body: ; preds = %do.body, %entry |
| %start.0 = phi i32 [ 0, %entry ], [ %inc.start.0, %do.body ] |
| %cmp = icmp slt i32 %start.0, 10000 |
| %inc = zext i1 %cmp to i32 |
| %inc.start.0 = add nsw i32 %start.0, %inc |
| br i1 %cmp, label %do.body, label %do.end |
| |
| do.end: ; preds = %do.body |
| ret i32 0 |
| } |
| |
| |
| define i32 @foo() { |
| ; CHECK-LABEL: 'foo' |
| ; CHECK-NEXT: Determining loop execution counts for: @foo |
| ; CHECK-NEXT: Loop %do.body: backedge-taken count is i32 5000 |
| ; CHECK-NEXT: Loop %do.body: constant max backedge-taken count is i32 5000 |
| ; CHECK-NEXT: Loop %do.body: symbolic max backedge-taken count is i32 5000 |
| ; CHECK-NEXT: Loop %do.body: Trip multiple is 5001 |
| ; |
| entry: |
| br label %do.body |
| |
| do.body: ; preds = %do.body, %entry |
| %start.0 = phi i32 [ 0, %entry ], [ %inc.start.0, %do.body ] |
| %cmp = icmp slt i32 %start.0, 10000 |
| %select_ext = select i1 %cmp, i32 2 , i32 1 |
| %inc.start.0 = add nsw i32 %start.0, %select_ext |
| br i1 %cmp, label %do.body, label %do.end |
| |
| do.end: ; preds = %do.body |
| ret i32 0 |
| } |