[ORC] Add std::tuple support to SimplePackedSerialization.
[llvm-project.git] / llvm / test / Transforms / PhaseOrdering / pr44461-br-to-switch-rotate.ll
blob474c5b7ab2f88b59cfa47a6654ea2e006162540b
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ; RUN: opt -S -O2 < %s | FileCheck %s
3 ; RUN: opt -S -passes='default<O2>' < %s | FileCheck %s
5 ; FIXME: The br -> switch conversion blocks loop rotation.
7 define i64 @test() {
8 ; CHECK-LABEL: @test(
9 ; CHECK-NEXT:  start:
10 ; CHECK-NEXT:    br label [[BB10:%.*]]
11 ; CHECK:       bb10:
12 ; CHECK-NEXT:    [[ITER1_SROA_5_0:%.*]] = phi i64 [ 100000, [[START:%.*]] ], [ [[SPEC_SELECT:%.*]], [[BB3_I_I:%.*]] ]
13 ; CHECK-NEXT:    [[ITER1_SROA_9_0:%.*]] = phi i2 [ -2, [[START]] ], [ [[TMP3:%.*]], [[BB3_I_I]] ]
14 ; CHECK-NEXT:    [[COUNT_1:%.*]] = phi i64 [ 0, [[START]] ], [ [[TMP4:%.*]], [[BB3_I_I]] ]
15 ; CHECK-NEXT:    switch i2 [[ITER1_SROA_9_0]], label [[BB12:%.*]] [
16 ; CHECK-NEXT:    i2 -2, label [[BB3_I_I]]
17 ; CHECK-NEXT:    i2 0, label [[BB3_I_I]]
18 ; CHECK-NEXT:    ]
19 ; CHECK:       bb3.i.i:
20 ; CHECK-NEXT:    [[TMP2:%.*]] = icmp eq i64 [[ITER1_SROA_5_0]], 0
21 ; CHECK-NEXT:    [[TMP3]] = zext i1 [[TMP2]] to i2
22 ; CHECK-NEXT:    [[_5_0_I_I_I_I:%.*]] = add i64 [[ITER1_SROA_5_0]], -1
23 ; CHECK-NEXT:    [[SPEC_SELECT]] = select i1 [[TMP2]], i64 0, i64 [[_5_0_I_I_I_I]]
24 ; CHECK-NEXT:    [[TMP4]] = add i64 [[COUNT_1]], [[ITER1_SROA_5_0]]
25 ; CHECK-NEXT:    br label [[BB10]]
26 ; CHECK:       bb12:
27 ; CHECK-NEXT:    ret i64 [[COUNT_1]]
29 start:
30   br label %bb10
32 bb10:                                             ; preds = %bb3.i.i, %bb6
33   %iter1.sroa.5.0 = phi i64 [ 100000, %start ], [ %spec.select, %bb3.i.i ]
34   %iter1.sroa.9.0 = phi i8 [ 2, %start ], [ %tmp3, %bb3.i.i ]
35   %count.1 = phi i64 [ 0, %start ], [ %tmp4, %bb3.i.i ]
36   %c1 = icmp eq i8 %iter1.sroa.9.0, 2
37   %c2 = icmp eq i8 %iter1.sroa.9.0, 0
38   %c3 = or i1 %c1, %c2
39   br i1 %c3, label %bb3.i.i, label %bb12
41 bb3.i.i:                                          ; preds = %bb10, %bb10
42   %tmp2 = icmp eq i64 %iter1.sroa.5.0, 0
43   %tmp3 = zext i1 %tmp2 to i8
44   %_5.0.i.i.i.i = add i64 %iter1.sroa.5.0, -1
45   %spec.select = select i1 %tmp2, i64 0, i64 %_5.0.i.i.i.i
47   %tmp4 = add i64 %count.1, %iter1.sroa.5.0
48   br label %bb10
50 bb12:                                             ; preds = %bb10
51   ret i64 %count.1