[TySan] Don't report globals with incomplete types. (#121922)
[llvm-project.git] / llvm / test / Transforms / IRCE / bug-loop-varying-upper-limit.ll
blobcfa6cdb5c9aec315a9ad817c3c2b3b9dd5f1079b
1 ; RUN: opt -irce-print-changed-loops -S -verify-loop-info -passes=irce,verify < %s 2>&1 | FileCheck %s
2 ; RUN: opt -irce-print-changed-loops -S -verify-loop-info -passes='require<branch-prob>,irce,verify' < %s 2>&1 | FileCheck %s
4 ; CHECK-NOT: constrained loop
6 define void @single_access_no_preloop_no_offset(ptr %arr, ptr %a_len_ptr, i32 %n) {
7  entry:
8   %first.itr.check = icmp sgt i32 %n, 0
9   br i1 %first.itr.check, label %loop, label %exit
11  loop:
12   %idx = phi i32 [ 0, %entry ] , [ %idx.next, %in.bounds ]
13   %idx.next = add i32 %idx, 1
14   %len = load i32, ptr %a_len_ptr, !range !0
15   %abc = icmp slt i32 %idx, %len
16   br i1 %abc, label %in.bounds, label %out.of.bounds, !prof !1
18  in.bounds:
19   %addr = getelementptr i32, ptr %arr, i32 %idx
20   store i32 0, ptr %addr
21   %next = icmp slt i32 %idx.next, %n
22   br i1 %next, label %loop, label %exit
24  out.of.bounds:
25   ret void
27  exit:
28   ret void
31 !0 = !{i32 0, i32 2147483647}
32 !1 = !{!"branch_weights", i32 64, i32 4}