; NOTE: Assertions have been autogenerated by utils/update_analyze_test_checks.py UTC_ARGS: --version 4 ; RUN: opt -disable-output "-passes=print" -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 }