; 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
}