[mlir][int-range] Limit xor int range inference to i1 (#116968)
[llvm-project.git] / llvm / test / Analysis / ScalarEvolution / pr22179.ll
blob8a2249fb4b20934bb2fa7cb2ca2d32e1def87abe
1 ; RUN: opt -disable-output "-passes=print<scalar-evolution>" < %s 2>&1 | FileCheck %s
3 %struct.anon = type { i8 }
4 %struct.S = type { i32 }
6 @a = common global %struct.anon zeroinitializer, align 1
7 @b = common global %struct.S zeroinitializer, align 4
9 ; Function Attrs: nounwind ssp uwtable
10 define i32 @main() {
11 ; CHECK-LABEL: Classifying expressions for: @main
12   store i8 0, ptr @a, align 1
13   br label %loop
15 loop:
16   %storemerge1 = phi i8 [ 0, %0 ], [ %inc, %loop ]
17   %m = load volatile i32, ptr @b, align 4
18   %inc = add nuw i8 %storemerge1, 1
19 ; CHECK:   %inc = add nuw i8 %storemerge1, 1
20 ; CHECK-NEXT: -->  {1,+,1}<nuw><%loop>
21 ; CHECK-NOT: -->  {1,+,1}<nuw><nsw><%loop>
22   %exitcond = icmp eq i8 %inc, -128
23   br i1 %exitcond, label %exit, label %loop
25 exit:
26   store i8 -128, ptr @a, align 1
27   ret i32 0