2019-06-20 02:21:41 +08:00
|
|
|
// RUN: mlir-opt %s -split-input-file -verify-diagnostics
|
2019-02-08 04:29:31 +08:00
|
|
|
|
|
|
|
// -----
|
|
|
|
|
2019-06-13 22:08:46 +08:00
|
|
|
func @affine_apply_operand_non_index(%arg0 : i32) {
|
|
|
|
// Custom parser automatically assigns all arguments the `index` so we must
|
|
|
|
// use the generic syntax here to exercise the verifier.
|
|
|
|
// expected-error@+1 {{operands must be of type 'index'}}
|
2020-01-14 05:12:37 +08:00
|
|
|
%0 = "affine.apply"(%arg0) {map = affine_map<(d0) -> (d0)>} : (i32) -> (index)
|
2019-06-13 22:08:46 +08:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// -----
|
|
|
|
|
|
|
|
func @affine_apply_resul_non_index(%arg0 : index) {
|
|
|
|
// Custom parser automatically assigns `index` as the result type so we must
|
|
|
|
// use the generic syntax here to exercise the verifier.
|
|
|
|
// expected-error@+1 {{result must be of type 'index'}}
|
2020-01-14 05:12:37 +08:00
|
|
|
%0 = "affine.apply"(%arg0) {map = affine_map<(d0) -> (d0)>} : (index) -> (i32)
|
2019-06-13 22:08:46 +08:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// -----
|
|
|
|
|
2020-01-14 05:12:37 +08:00
|
|
|
#map = affine_map<(d0)[s0] -> (d0 + s0)>
|
2019-02-08 04:29:31 +08:00
|
|
|
|
|
|
|
func @affine_for_lower_bound_invalid_dim(%arg : index) {
|
2019-03-26 01:14:34 +08:00
|
|
|
affine.for %n0 = 0 to 7 {
|
2019-02-08 04:29:31 +08:00
|
|
|
%dim = addi %arg, %arg : index
|
|
|
|
|
|
|
|
// expected-error@+1 {{operand cannot be used as a dimension id}}
|
2019-03-26 01:14:34 +08:00
|
|
|
affine.for %n1 = 0 to #map(%dim)[%arg] {
|
2019-02-08 04:29:31 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// -----
|
|
|
|
|
2020-01-14 05:12:37 +08:00
|
|
|
#map = affine_map<(d0)[s0] -> (d0 + s0)>
|
2019-02-08 04:29:31 +08:00
|
|
|
|
|
|
|
func @affine_for_upper_bound_invalid_dim(%arg : index) {
|
2019-03-26 01:14:34 +08:00
|
|
|
affine.for %n0 = 0 to 7 {
|
2019-02-08 04:29:31 +08:00
|
|
|
%dim = addi %arg, %arg : index
|
|
|
|
|
|
|
|
// expected-error@+1 {{operand cannot be used as a dimension id}}
|
2019-03-26 01:14:34 +08:00
|
|
|
affine.for %n1 = #map(%dim)[%arg] to 7 {
|
2019-02-08 04:29:31 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2019-12-21 01:43:34 +08:00
|
|
|
// -----
|
|
|
|
func @affine_load_invalid_dim(%M : memref<10xi32>) {
|
|
|
|
"unknown"() ({
|
|
|
|
^bb0(%arg: index):
|
|
|
|
affine.load %M[%arg] : memref<10xi32>
|
|
|
|
// expected-error@-1 {{index must be a dimension or symbol identifier}}
|
|
|
|
br ^bb1
|
|
|
|
^bb1:
|
|
|
|
br ^bb1
|
|
|
|
}) : () -> ()
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2019-02-08 04:29:31 +08:00
|
|
|
// -----
|
|
|
|
|
2020-01-14 05:12:37 +08:00
|
|
|
#map0 = affine_map<(d0)[s0] -> (d0 + s0)>
|
2019-02-08 04:29:31 +08:00
|
|
|
|
|
|
|
func @affine_for_lower_bound_invalid_sym() {
|
2019-03-26 01:14:34 +08:00
|
|
|
affine.for %i0 = 0 to 7 {
|
2019-02-08 04:29:31 +08:00
|
|
|
// expected-error@+1 {{operand cannot be used as a symbol}}
|
2019-03-26 01:14:34 +08:00
|
|
|
affine.for %n0 = #map0(%i0)[%i0] to 7 {
|
2019-02-08 04:29:31 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// -----
|
|
|
|
|
2020-01-14 05:12:37 +08:00
|
|
|
#map0 = affine_map<(d0)[s0] -> (d0 + s0)>
|
2019-02-08 04:29:31 +08:00
|
|
|
|
|
|
|
func @affine_for_upper_bound_invalid_sym() {
|
2019-03-26 01:14:34 +08:00
|
|
|
affine.for %i0 = 0 to 7 {
|
2019-02-08 04:29:31 +08:00
|
|
|
// expected-error@+1 {{operand cannot be used as a symbol}}
|
2019-03-26 01:14:34 +08:00
|
|
|
affine.for %n0 = 0 to #map0(%i0)[%i0] {
|
2019-02-08 04:29:31 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// -----
|
|
|
|
|
2020-01-14 05:12:37 +08:00
|
|
|
#set0 = affine_set<(i)[N] : (i >= 0, N - i >= 0)>
|
2019-02-08 04:29:31 +08:00
|
|
|
|
|
|
|
func @affine_if_invalid_dim(%arg : index) {
|
2019-03-26 01:14:34 +08:00
|
|
|
affine.for %n0 = 0 to 7 {
|
2019-02-08 04:29:31 +08:00
|
|
|
%dim = addi %arg, %arg : index
|
|
|
|
|
|
|
|
// expected-error@+1 {{operand cannot be used as a dimension id}}
|
2019-03-25 11:35:07 +08:00
|
|
|
affine.if #set0(%dim)[%n0] {}
|
2019-02-08 04:29:31 +08:00
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// -----
|
|
|
|
|
2020-01-14 05:12:37 +08:00
|
|
|
#set0 = affine_set<(i)[N] : (i >= 0, N - i >= 0)>
|
2019-02-08 04:29:31 +08:00
|
|
|
|
|
|
|
func @affine_if_invalid_sym() {
|
2019-03-26 01:14:34 +08:00
|
|
|
affine.for %i0 = 0 to 7 {
|
2019-02-08 04:29:31 +08:00
|
|
|
// expected-error@+1 {{operand cannot be used as a symbol}}
|
2019-03-25 11:35:07 +08:00
|
|
|
affine.if #set0(%i0)[%i0] {}
|
2019-02-08 04:29:31 +08:00
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// -----
|
|
|
|
|
2020-01-14 05:12:37 +08:00
|
|
|
#set0 = affine_set<(i)[N] : (i >= 0, N - i >= 0)>
|
2019-02-08 04:29:31 +08:00
|
|
|
|
|
|
|
func @affine_if_invalid_dimop_dim(%arg0: index, %arg1: index, %arg2: index, %arg3: index) {
|
2019-03-26 01:14:34 +08:00
|
|
|
affine.for %n0 = 0 to 7 {
|
2019-02-08 04:29:31 +08:00
|
|
|
%0 = alloc(%arg0, %arg1, %arg2, %arg3) : memref<?x?x?x?xf32>
|
|
|
|
%dim = dim %0, 0 : memref<?x?x?x?xf32>
|
|
|
|
|
|
|
|
// expected-error@+1 {{operand cannot be used as a dimension id}}
|
2019-03-25 11:35:07 +08:00
|
|
|
affine.if #set0(%dim)[%n0] {}
|
2019-02-08 04:29:31 +08:00
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
2019-07-23 06:06:15 +08:00
|
|
|
|
|
|
|
// -----
|
|
|
|
|
|
|
|
func @affine_store_missing_l_square(%C: memref<4096x4096xf32>) {
|
|
|
|
%9 = constant 0.0 : f32
|
|
|
|
// expected-error@+1 {{expected '['}}
|
|
|
|
affine.store %9, %C : memref<4096x4096xf32>
|
|
|
|
return
|
|
|
|
}
|
2019-11-12 23:08:23 +08:00
|
|
|
|
|
|
|
// -----
|
|
|
|
|
|
|
|
// CHECK-LABEL: @affine_min
|
|
|
|
func @affine_min(%arg0 : index, %arg1 : index, %arg2 : index) {
|
|
|
|
// expected-error@+1 {{operand count and affine map dimension and symbol count must match}}
|
2020-01-14 05:12:37 +08:00
|
|
|
%0 = affine.min affine_map<(d0) -> (d0)> (%arg0, %arg1)
|
2019-11-12 23:08:23 +08:00
|
|
|
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// -----
|
|
|
|
|
|
|
|
// CHECK-LABEL: @affine_min
|
|
|
|
func @affine_min(%arg0 : index, %arg1 : index, %arg2 : index) {
|
|
|
|
// expected-error@+1 {{operand count and affine map dimension and symbol count must match}}
|
2020-01-14 05:12:37 +08:00
|
|
|
%0 = affine.min affine_map<()[s0] -> (s0)> (%arg0, %arg1)
|
2019-11-12 23:08:23 +08:00
|
|
|
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// -----
|
|
|
|
|
|
|
|
// CHECK-LABEL: @affine_min
|
|
|
|
func @affine_min(%arg0 : index, %arg1 : index, %arg2 : index) {
|
|
|
|
// expected-error@+1 {{operand count and affine map dimension and symbol count must match}}
|
2020-01-14 05:12:37 +08:00
|
|
|
%0 = affine.min affine_map<(d0) -> (d0)> ()
|
2019-11-12 23:08:23 +08:00
|
|
|
|
|
|
|
return
|
|
|
|
}
|