[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / llvm / test / Transforms / LoopVersioning / loop-invariant-bound.ll
blob4bd78e0a386dcbd1442a320092e720b2c1576710
1 ; RUN: opt -passes=loop-versioning -S < %s | FileCheck %s
2 ; Checks that when introducing check, we don't accidentally introduce non-dominating instructions
3 target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
5 %Dual.212 = type { %Dual.213, %Partials.215 }
6 %Dual.213 = type { double, %Partials.214 }
7 %Partials.214 = type { [2 x double] }
8 %Partials.215 = type { [2 x %Dual.213] }
10 ; Function Attrs: sspreq
11 define void @"julia_axpy!_65480"(ptr, ptr %other) {
12 top:
13   br label %if24
15 ; CHECK-NOT: %bc = bitcast ptr %v2.sroa.0.0..sroa_cast
16 ; CHECK: %bound0 = icmp ult ptr %[[x:[a-z0-9]+]], %[[y:[a-z0-9]+]]
17 ; CHECK-NOT: %bound1 = icmp ult ptr %[[y]], %[[x]]
19 if24:                                             ; preds = %if24, %top
20   %"#temp#1.sroa.3.02" = phi i64 [ undef, %top ], [ %2, %if24 ]
21   %"#temp#1.sroa.0.01" = phi i64 [ undef, %top ], [ %1, %if24 ]
22   %1 = add i64 %"#temp#1.sroa.0.01", 1
23   %2 = add i64 %"#temp#1.sroa.3.02", 1
24   ; This pointer is loop invariant. LAA used to re-use it from memcheck, even though it didn't dominate.
25   %v2.sroa.0.0.copyload = load i64, ptr %0, align 1
26   %3 = add i64 %"#temp#1.sroa.0.01", -1
27   %4 = getelementptr inbounds %Dual.212, ptr %other, i64 0, i32 1, i32 0, i64 0, i32 1, i32 0, i64 0
28   store i64 undef, ptr %4, align 8
29   %notlhs27 = icmp eq i64 %2, undef
30   %notrhs28 = icmp eq i64 %1, undef
31   %5 = or i1 %notrhs28, %notlhs27
32   br i1 %5, label %L41.L335_crit_edge, label %if24
34 L41.L335_crit_edge:                               ; preds = %if24
35   ret void