forked from OSchip/llvm-project
167 lines
5.9 KiB
LLVM
167 lines
5.9 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
|
|
; RUN: opt -S -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
|
|
}
|