| ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py |
| ; RUN: opt -S -passes=loop-rotate < %s | FileCheck %s |
| |
| define i64 @switch_multi_entry_known_entry() { |
| ; CHECK-LABEL: @switch_multi_entry_known_entry( |
| ; CHECK-NEXT: start: |
| ; CHECK-NEXT: br label [[HEADER:%.*]] |
| ; CHECK: header: |
| ; CHECK-NEXT: [[STATE:%.*]] = phi i8 [ 2, [[START:%.*]] ], [ [[NEXT_STATE:%.*]], [[LATCH:%.*]] ] |
| ; CHECK-NEXT: [[COUNT:%.*]] = phi i64 [ 0, [[START]] ], [ [[INC:%.*]], [[LATCH]] ] |
| ; CHECK-NEXT: switch i8 [[STATE]], label [[EXIT:%.*]] [ |
| ; CHECK-NEXT: i8 0, label [[LATCH]] |
| ; CHECK-NEXT: i8 2, label [[LATCH]] |
| ; CHECK-NEXT: ] |
| ; CHECK: latch: |
| ; CHECK-NEXT: [[CMP:%.*]] = icmp eq i64 [[COUNT]], 999 |
| ; CHECK-NEXT: [[NEXT_STATE]] = zext i1 [[CMP]] to i8 |
| ; CHECK-NEXT: [[INC]] = add i64 [[COUNT]], 1 |
| ; CHECK-NEXT: br label [[HEADER]] |
| ; CHECK: exit: |
| ; CHECK-NEXT: [[COUNT_LCSSA:%.*]] = phi i64 [ [[COUNT]], [[HEADER]] ] |
| ; CHECK-NEXT: ret i64 [[COUNT_LCSSA]] |
| ; |
| start: |
| br label %header |
| |
| header: ; preds = %latch, %start |
| %state = phi i8 [ 2, %start ], [ %next_state, %latch ] |
| %count = phi i64 [ 0, %start ], [ %inc, %latch ] |
| switch i8 %state, label %exit [ |
| i8 0, label %latch |
| i8 2, label %latch |
| ] |
| |
| latch: ; preds = %header, %header |
| %cmp = icmp eq i64 %count, 999 |
| %next_state = zext i1 %cmp to i8 |
| %inc = add i64 %count, 1 |
| br label %header |
| |
| exit: ; preds = %header |
| ret i64 %count |
| } |
| |
| define i64 @switch_multi_entry_unknown_entry(i8 %start_state) { |
| ; CHECK-LABEL: @switch_multi_entry_unknown_entry( |
| ; CHECK-NEXT: start: |
| ; CHECK-NEXT: br label [[HEADER:%.*]] |
| ; CHECK: header: |
| ; CHECK-NEXT: [[STATE:%.*]] = phi i8 [ [[START_STATE:%.*]], [[START:%.*]] ], [ [[NEXT_STATE:%.*]], [[LATCH:%.*]] ] |
| ; CHECK-NEXT: [[COUNT:%.*]] = phi i64 [ 0, [[START]] ], [ [[INC:%.*]], [[LATCH]] ] |
| ; CHECK-NEXT: switch i8 [[STATE]], label [[EXIT:%.*]] [ |
| ; CHECK-NEXT: i8 0, label [[LATCH]] |
| ; CHECK-NEXT: i8 2, label [[LATCH]] |
| ; CHECK-NEXT: ] |
| ; CHECK: latch: |
| ; CHECK-NEXT: [[CMP:%.*]] = icmp eq i64 [[COUNT]], 999 |
| ; CHECK-NEXT: [[NEXT_STATE]] = zext i1 [[CMP]] to i8 |
| ; CHECK-NEXT: [[INC]] = add i64 [[COUNT]], 1 |
| ; CHECK-NEXT: br label [[HEADER]] |
| ; CHECK: exit: |
| ; CHECK-NEXT: [[COUNT_LCSSA:%.*]] = phi i64 [ [[COUNT]], [[HEADER]] ] |
| ; CHECK-NEXT: ret i64 [[COUNT_LCSSA]] |
| ; |
| start: |
| br label %header |
| |
| header: ; preds = %latch, %start |
| %state = phi i8 [ %start_state, %start ], [ %next_state, %latch ] |
| %count = phi i64 [ 0, %start ], [ %inc, %latch ] |
| switch i8 %state, label %exit [ |
| i8 0, label %latch |
| i8 2, label %latch |
| ] |
| |
| latch: ; preds = %header, %header |
| %cmp = icmp eq i64 %count, 999 |
| %next_state = zext i1 %cmp to i8 |
| %inc = add i64 %count, 1 |
| br label %header |
| |
| exit: ; preds = %header |
| ret i64 %count |
| } |
| |
| define i64 @switch_multi_exit_known_entry() { |
| ; CHECK-LABEL: @switch_multi_exit_known_entry( |
| ; CHECK-NEXT: start: |
| ; CHECK-NEXT: br label [[HEADER:%.*]] |
| ; CHECK: header: |
| ; CHECK-NEXT: [[STATE:%.*]] = phi i8 [ 0, [[START:%.*]] ], [ [[NEXT_STATE:%.*]], [[LATCH:%.*]] ] |
| ; CHECK-NEXT: [[COUNT:%.*]] = phi i64 [ 0, [[START]] ], [ [[INC:%.*]], [[LATCH]] ] |
| ; CHECK-NEXT: switch i8 [[STATE]], label [[LATCH]] [ |
| ; CHECK-NEXT: i8 1, label [[EXIT:%.*]] |
| ; CHECK-NEXT: i8 2, label [[EXIT]] |
| ; CHECK-NEXT: ] |
| ; CHECK: latch: |
| ; CHECK-NEXT: [[CMP:%.*]] = icmp eq i64 [[COUNT]], 999 |
| ; CHECK-NEXT: [[NEXT_STATE]] = zext i1 [[CMP]] to i8 |
| ; CHECK-NEXT: [[INC]] = add i64 [[COUNT]], 1 |
| ; CHECK-NEXT: br label [[HEADER]] |
| ; CHECK: exit: |
| ; CHECK-NEXT: [[COUNT_LCSSA:%.*]] = phi i64 [ [[COUNT]], [[HEADER]] ], [ [[COUNT]], [[HEADER]] ] |
| ; CHECK-NEXT: ret i64 [[COUNT_LCSSA]] |
| ; |
| start: |
| br label %header |
| |
| header: ; preds = %latch, %start |
| %state = phi i8 [ 0, %start ], [ %next_state, %latch ] |
| %count = phi i64 [ 0, %start ], [ %inc, %latch ] |
| switch i8 %state, label %latch [ |
| i8 1, label %exit |
| i8 2, label %exit |
| ] |
| |
| latch: ; preds = %header, %header |
| %cmp = icmp eq i64 %count, 999 |
| %next_state = zext i1 %cmp to i8 |
| %inc = add i64 %count, 1 |
| br label %header |
| |
| exit: ; preds = %header |
| ret i64 %count |
| } |
| |
| define i64 @switch_multi_exit_unknown_entry(i8 %start_state) { |
| ; CHECK-LABEL: @switch_multi_exit_unknown_entry( |
| ; CHECK-NEXT: start: |
| ; CHECK-NEXT: br label [[HEADER:%.*]] |
| ; CHECK: header: |
| ; CHECK-NEXT: [[STATE:%.*]] = phi i8 [ [[START_STATE:%.*]], [[START:%.*]] ], [ [[NEXT_STATE:%.*]], [[LATCH:%.*]] ] |
| ; CHECK-NEXT: [[COUNT:%.*]] = phi i64 [ 0, [[START]] ], [ [[INC:%.*]], [[LATCH]] ] |
| ; CHECK-NEXT: switch i8 [[STATE]], label [[LATCH]] [ |
| ; CHECK-NEXT: i8 1, label [[EXIT:%.*]] |
| ; CHECK-NEXT: i8 2, label [[EXIT]] |
| ; CHECK-NEXT: ] |
| ; CHECK: latch: |
| ; CHECK-NEXT: [[CMP:%.*]] = icmp eq i64 [[COUNT]], 999 |
| ; CHECK-NEXT: [[NEXT_STATE]] = zext i1 [[CMP]] to i8 |
| ; CHECK-NEXT: [[INC]] = add i64 [[COUNT]], 1 |
| ; CHECK-NEXT: br label [[HEADER]] |
| ; CHECK: exit: |
| ; CHECK-NEXT: [[COUNT_LCSSA:%.*]] = phi i64 [ [[COUNT]], [[HEADER]] ], [ [[COUNT]], [[HEADER]] ] |
| ; CHECK-NEXT: ret i64 [[COUNT_LCSSA]] |
| ; |
| start: |
| br label %header |
| |
| header: ; preds = %latch, %start |
| %state = phi i8 [ %start_state, %start ], [ %next_state, %latch ] |
| %count = phi i64 [ 0, %start ], [ %inc, %latch ] |
| switch i8 %state, label %latch [ |
| i8 1, label %exit |
| i8 2, label %exit |
| ] |
| |
| latch: ; preds = %header, %header |
| %cmp = icmp eq i64 %count, 999 |
| %next_state = zext i1 %cmp to i8 |
| %inc = add i64 %count, 1 |
| br label %header |
| |
| exit: ; preds = %header |
| ret i64 %count |
| } |