[llvm] 142ba7d - [LoopRotate] Add tests for rotate with switch; NFC

Nikita Popov via llvm-commits llvm-commits at lists.llvm.org
Sat Jan 11 02:05:18 PST 2020


Author: Nikita Popov
Date: 2020-01-11T11:03:29+01:00
New Revision: 142ba7d76af4a66037fd180db371da19f35ef5f3

URL: https://github.com/llvm/llvm-project/commit/142ba7d76af4a66037fd180db371da19f35ef5f3
DIFF: https://github.com/llvm/llvm-project/commit/142ba7d76af4a66037fd180db371da19f35ef5f3.diff

LOG: [LoopRotate] Add tests for rotate with switch; NFC

For D72420.

Added: 
    llvm/test/Transforms/LoopRotate/switch.ll

Modified: 
    

Removed: 
    


################################################################################
diff  --git a/llvm/test/Transforms/LoopRotate/switch.ll b/llvm/test/Transforms/LoopRotate/switch.ll
new file mode 100644
index 000000000000..08d64eace2ec
--- /dev/null
+++ b/llvm/test/Transforms/LoopRotate/switch.ll
@@ -0,0 +1,166 @@
+; 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
+}


        


More information about the llvm-commits mailing list