blob: 0bf4b02e8e3d70505a79c30e32a1c65dfe53e383 [file] [log] [blame] [edit]
// 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
}