blob: 4d569cc69fa2b1151ebfb7de1a7f0a1f7222fc3a [file] [log] [blame]
; NOTE: Assertions have been autogenerated by utils/update_analyze_test_checks.py UTC_ARGS: --version 5
; RUN: opt -disable-output "-passes=print<scalar-evolution>" \
; RUN: -scalar-evolution-classify-expressions=0 < %s 2>&1 | FileCheck %s
define i32 @exit_count_samesign(i32 %iter.count, ptr %ptr) {
; CHECK-LABEL: 'exit_count_samesign'
; CHECK-NEXT: Determining loop execution counts for: @exit_count_samesign
; CHECK-NEXT: Loop %inner.loop: backedge-taken count is {(-2 + %iter.count),+,-1}<nw><%outer.loop>
; CHECK-NEXT: Loop %inner.loop: constant max backedge-taken count is i32 2147483646
; CHECK-NEXT: Loop %inner.loop: symbolic max backedge-taken count is {(-2 + %iter.count),+,-1}<nw><%outer.loop>
; CHECK-NEXT: Loop %inner.loop: Trip multiple is 1
; CHECK-NEXT: Loop %outer.loop: <multiple exits> Unpredictable backedge-taken count.
; CHECK-NEXT: Loop %outer.loop: Unpredictable constant max backedge-taken count.
; CHECK-NEXT: Loop %outer.loop: Unpredictable symbolic max backedge-taken count.
;
entry:
br label %outer.loop
ph:
br label %outer.loop
outer.loop:
%iv.outer = phi i32 [ %iv.outer.1, %ph ], [ %iter.count, %entry ]
%iv.outer.1 = add nsw i32 %iv.outer, -1
%ext.outer = zext nneg i32 %iv.outer.1 to i64
%gep.outer = getelementptr double, ptr %ptr, i64 %ext.outer
store double poison, ptr %gep.outer
%exit.cond.outer = icmp samesign ugt i32 %iv.outer, 1
br i1 %exit.cond.outer, label %inner.loop, label %ph
inner.loop:
%iv.inner = phi i32 [ %iv.next, %inner.loop ], [ 0, %outer.loop ]
%ext.inner = zext nneg i32 %iv.inner to i64
%gep.inner = getelementptr double, ptr %ptr, i64 %ext.inner
store double poison, ptr %gep.inner
%iv.next = add nuw nsw i32 %iv.inner, 1
%exit.cond.inner = icmp slt i32 %iv.next, %iv.outer.1
br i1 %exit.cond.inner, label %inner.loop, label %ph
exit:
ret i32 0
}