| // RUN: mlir-opt %s -convert-cf-to-llvm -split-input-file | FileCheck %s |
| |
| // Unstructured control flow is converted, but the enclosing op is not |
| // converted. |
| |
| // CHECK-LABEL: func.func @single_case( |
| // CHECK-SAME: %[[val:.*]]: i32, %[[idx:.*]]: index) -> index { |
| // CHECK: %[[cast0:.*]] = builtin.unrealized_conversion_cast %[[idx]] : index to i64 |
| // CHECK: llvm.switch %[[val]] : i32, ^[[bb1:.*]](%[[cast0]] : i64) [ |
| // CHECK: ] |
| // CHECK: ^[[bb1]](%[[arg0:.*]]: i64): |
| // CHECK: %[[cast1:.*]] = builtin.unrealized_conversion_cast %[[arg0]] : i64 to index |
| // CHECK: return %[[cast1]] : index |
| // CHECK: } |
| func.func @single_case(%val: i32, %idx: index) -> index { |
| cf.switch %val : i32, [ |
| default: ^bb1(%idx : index) |
| ] |
| ^bb1(%arg0: index): |
| return %arg0 : index |
| } |
| |
| // ----- |
| |
| // func.func and func.return types match. No unrealized_conversion_cast is |
| // needed. |
| |
| // CHECK-LABEL: func.func @single_case_type_match( |
| // CHECK-SAME: %[[val:.*]]: i32, %[[i:.*]]: i64) -> i64 { |
| // CHECK: llvm.switch %[[val]] : i32, ^[[bb1:.*]](%[[i]] : i64) [ |
| // CHECK: ] |
| // CHECK: ^[[bb1]](%[[arg0:.*]]: i64): |
| // CHECK: return %[[arg0]] : i64 |
| // CHECK: } |
| func.func @single_case_type_match(%val: i32, %i: i64) -> i64 { |
| cf.switch %val : i32, [ |
| default: ^bb1(%i : i64) |
| ] |
| ^bb1(%arg0: i64): |
| return %arg0 : i64 |
| } |
| |
| // ----- |
| |
| // CHECK-LABEL: func.func @multi_case |
| // CHECK-COUNT-2: unrealized_conversion_cast {{.*}} : index to i64 |
| // CHECK: llvm.switch %{{.*}} : i32, ^{{.*}}(%{{.*}} : i64) [ |
| // CHECK: 12: ^{{.*}}(%{{.*}} : i64), |
| // CHECK: 13: ^{{.*}}(%{{.*}} : i64), |
| // CHECK: 14: ^{{.*}}(%{{.*}} : i64) |
| // CHECK: ] |
| func.func @multi_case(%val: i32, %idx1: index, %idx2: index, %i: i64) -> index { |
| cf.switch %val : i32, [ |
| default: ^bb1(%idx1 : index), |
| 12: ^bb2(%idx2 : index), |
| 13: ^bb1(%idx1 : index), |
| 14: ^bb3(%i : i64) |
| ] |
| ^bb1(%arg0: index): |
| return %arg0 : index |
| ^bb2(%arg1: index): |
| return %arg1 : index |
| ^bb3(%arg2: i64): |
| %cast = arith.index_cast %arg2 : i64 to index |
| return %cast : index |
| } |