blob: a73ec292ea697980b7c3c4ae33e314027e0e1928 [file] [edit]
; NOTE: Assertions have been autogenerated by utils/update_analyze_test_checks.py UTC_ARGS: --version 6
; RUN: opt -disable-output -passes='print<scalar-evolution>' < %s 2>&1 | FileCheck %s
; Test where the outermost loop doesn't contain exactly one latch;
; ScalarEvolution shouldn't crash in this case.
define void @f(ptr %a0) {
; CHECK-LABEL: 'f'
; CHECK-NEXT: Classifying expressions for: @f
; CHECK-NEXT: %phi1 = phi ptr [ null, %entry ], [ %inc, %b3 ], [ %inc, %b4 ]
; CHECK-NEXT: --> {null,+,-32}<%b1> U: [0,-31) S: [-9223372036854775808,9223372036854775777) Exits: <<Unknown>> LoopDispositions: { %b1: Computable, %b3: Invariant }
; CHECK-NEXT: %inc = getelementptr i8, ptr %phi1, i64 -32
; CHECK-NEXT: --> {(-32 + null)<nuw><nsw>,+,-32}<%b1> U: [0,-31) S: [-9223372036854775808,9223372036854775777) Exits: <<Unknown>> LoopDispositions: { %b1: Computable, %b3: Invariant }
; CHECK-NEXT: %phi2 = phi ptr [ %a0, %b2 ], [ %inc2, %b5 ]
; CHECK-NEXT: --> {%a0,+,1}<%b3> U: full-set S: full-set Exits: ((-1 * (ptrtoint ptr %a0 to i64)) + %a0) LoopDispositions: { %b3: Computable, %b1: Variant }
; CHECK-NEXT: %ld1 = load i8, ptr %phi2, align 1
; CHECK-NEXT: --> %ld1 U: full-set S: full-set Exits: <<Unknown>> LoopDispositions: { %b3: Variant, %b1: Variant }
; CHECK-NEXT: %ld2 = load i8, ptr null, align 1
; CHECK-NEXT: --> %ld2 U: full-set S: full-set Exits: <<Unknown>> LoopDispositions: { %b3: Variant, %b1: Variant }
; CHECK-NEXT: %inc2 = getelementptr i8, ptr %phi2, i64 1
; CHECK-NEXT: --> {(1 + %a0),+,1}<%b3> U: full-set S: full-set Exits: (1 + (-1 * (ptrtoint ptr %a0 to i64)) + %a0) LoopDispositions: { %b3: Computable, %b1: Variant }
; CHECK-NEXT: Determining loop execution counts for: @f
; CHECK-NEXT: Loop %b3: <multiple exits> backedge-taken count is (-1 * (ptrtoint ptr %a0 to i64))
; CHECK-NEXT: exit count for b3: (-1 * (ptrtoint ptr %a0 to i64))
; CHECK-NEXT: exit count for b4: ***COULDNOTCOMPUTE***
; CHECK-NEXT: Loop %b3: constant max backedge-taken count is i64 -1
; CHECK-NEXT: Loop %b3: symbolic max backedge-taken count is (-1 * (ptrtoint ptr %a0 to i64))
; CHECK-NEXT: symbolic max exit count for b3: (-1 * (ptrtoint ptr %a0 to i64))
; CHECK-NEXT: symbolic max exit count for b4: ***COULDNOTCOMPUTE***
; CHECK-NEXT: Loop %b3: Trip multiple is 1
; CHECK-NEXT: Loop %b1: Unpredictable backedge-taken count.
; CHECK-NEXT: Loop %b1: Unpredictable constant max backedge-taken count.
; CHECK-NEXT: Loop %b1: Unpredictable symbolic max backedge-taken count.
;
entry:
br label %b1
b1:
%phi1 = phi ptr [ null, %entry ], [ %inc, %b3 ], [ %inc, %b4 ]
%cmp1 = icmp eq ptr %phi1, null
br i1 %cmp1, label %ret, label %b2
b2:
%inc = getelementptr i8, ptr %phi1, i64 -32
br label %b3
b3:
%phi2 = phi ptr [ %a0, %b2 ], [ %inc2, %b5 ]
%cmp2 = icmp eq ptr %phi2, null
br i1 %cmp2, label %b1, label %b4
b4:
%ld1 = load i8, ptr %phi2, align 1
%ld2 = load i8, ptr null, align 1
%cmp3 = icmp slt i8 %ld1, %ld2
br i1 false, label %b1, label %b5
b5:
%inc2 = getelementptr i8, ptr %phi2, i64 1
br label %b3
ret:
ret void
}