2019-06-25 05:35:21 +08:00
|
|
|
// RUN: mlir-opt -test-legalize-patterns -split-input-file -verify-diagnostics %s | FileCheck %s --dump-input=fail
|
2019-06-12 06:38:13 +08:00
|
|
|
|
|
|
|
// CHECK-LABEL: verifyDirectPattern
|
|
|
|
func @verifyDirectPattern() -> i32 {
|
2019-06-26 10:06:06 +08:00
|
|
|
// CHECK-NEXT: "test.legal_op_a"() {status = "Success"}
|
2019-06-12 06:38:13 +08:00
|
|
|
%result = "test.illegal_op_a"() : () -> (i32)
|
|
|
|
return %result : i32
|
|
|
|
}
|
|
|
|
|
|
|
|
// CHECK-LABEL: verifyLargerBenefit
|
|
|
|
func @verifyLargerBenefit() -> i32 {
|
2019-06-26 10:06:06 +08:00
|
|
|
// CHECK-NEXT: "test.legal_op_a"() {status = "Success"}
|
2019-06-12 06:38:13 +08:00
|
|
|
%result = "test.illegal_op_c"() : () -> (i32)
|
|
|
|
return %result : i32
|
|
|
|
}
|
2019-06-20 04:58:31 +08:00
|
|
|
|
|
|
|
// CHECK-LABEL: func @remap_input_1_to_0()
|
|
|
|
func @remap_input_1_to_0(i16)
|
|
|
|
|
|
|
|
// CHECK-LABEL: func @remap_input_1_to_1(%arg0: f64) -> f64
|
|
|
|
func @remap_input_1_to_1(%arg0: i64) -> i64 {
|
|
|
|
// CHECK-NEXT: return %arg0 : f64
|
|
|
|
return %arg0 : i64
|
|
|
|
}
|
|
|
|
|
2019-06-22 00:29:46 +08:00
|
|
|
// CHECK-LABEL: func @remap_input_1_to_N(%arg0: f16, %arg1: f16) -> (f16, f16)
|
|
|
|
func @remap_input_1_to_N(%arg0: f32) -> f32 {
|
|
|
|
// CHECK-NEXT: "test.return"(%arg0, %arg1) : (f16, f16) -> ()
|
|
|
|
"test.return"(%arg0) : (f32) -> ()
|
|
|
|
}
|
|
|
|
|
|
|
|
// CHECK-LABEL: func @remap_input_1_to_N_remaining_use(%arg0: f16, %arg1: f16)
|
|
|
|
func @remap_input_1_to_N_remaining_use(%arg0: f32) {
|
|
|
|
// CHECK-NEXT: [[CAST:%.*]] = "test.cast"(%arg0, %arg1) : (f16, f16) -> f32
|
|
|
|
// CHECK-NEXT: "work"([[CAST]]) : (f32) -> ()
|
|
|
|
"work"(%arg0) : (f32) -> ()
|
|
|
|
}
|
|
|
|
|
2019-06-20 04:58:31 +08:00
|
|
|
// CHECK-LABEL: func @remap_multi(%arg0: f64, %arg1: f64) -> (f64, f64)
|
|
|
|
func @remap_multi(%arg0: i64, %unused: i16, %arg1: i64) -> (i64, i64) {
|
|
|
|
// CHECK-NEXT: return %arg0, %arg1 : f64, f64
|
|
|
|
return %arg0, %arg1 : i64, i64
|
|
|
|
}
|
|
|
|
|
|
|
|
// CHECK-LABEL: func @remap_nested
|
|
|
|
func @remap_nested() {
|
|
|
|
// CHECK-NEXT: "foo.region"
|
|
|
|
"foo.region"() ({
|
|
|
|
// CHECK-NEXT: ^bb1(%i0: f64, %i1: f64):
|
|
|
|
^bb1(%i0: i64, %unused: i16, %i1: i64):
|
|
|
|
// CHECK-NEXT: "work"{{.*}} : (f64, f64)
|
|
|
|
"work"(%i0, %i1) : (i64, i64) -> ()
|
|
|
|
}) : () -> ()
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// CHECK-LABEL: func @remap_moved_region_args
|
|
|
|
func @remap_moved_region_args() {
|
|
|
|
// CHECK-NEXT: return
|
2019-06-22 00:29:46 +08:00
|
|
|
// CHECK-NEXT: ^bb1(%{{.*}}: f64, %{{.*}}: f64, %{{.*}}: f16, %{{.*}}: f16):
|
|
|
|
// CHECK-NEXT: "test.cast"{{.*}} : (f16, f16) -> f32
|
|
|
|
// CHECK-NEXT: "work"{{.*}} : (f64, f64, f32)
|
2019-06-20 04:58:31 +08:00
|
|
|
"test.region"() ({
|
2019-06-22 00:29:46 +08:00
|
|
|
^bb1(%i0: i64, %unused: i16, %i1: i64, %2: f32):
|
|
|
|
"work"(%i0, %i1, %2) : (i64, i64, f32) -> ()
|
2019-06-20 04:58:31 +08:00
|
|
|
}) : () -> ()
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// CHECK-LABEL: func @remap_drop_region
|
|
|
|
func @remap_drop_region() {
|
|
|
|
// CHECK-NEXT: return
|
|
|
|
// CHECK-NEXT: }
|
|
|
|
"test.drop_op"() ({
|
2019-06-22 00:29:46 +08:00
|
|
|
^bb1(%i0: i64, %unused: i16, %i1: i64, %2: f32):
|
|
|
|
"work"(%i0, %i1, %2) : (i64, i64, f32) -> ()
|
2019-06-20 04:58:31 +08:00
|
|
|
}) : () -> ()
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// -----
|
|
|
|
|
|
|
|
func @dropped_input_in_use(%arg: i16, %arg2: i64) {
|
|
|
|
// expected-error@-1 {{block argument #0 with type 'i16' has unexpected remaining uses}}
|
|
|
|
// expected-note@+1 {{unexpected user defined here}}
|
|
|
|
"work"(%arg) : (i16) -> ()
|
|
|
|
}
|