67 lines
2.5 KiB
MLIR
67 lines
2.5 KiB
MLIR
// RUN: mlir-opt %s -generate-runtime-verification \
|
|
// RUN: -expand-strided-metadata \
|
|
// RUN: -finalize-memref-to-llvm \
|
|
// RUN: -test-cf-assert \
|
|
// RUN: -convert-func-to-llvm \
|
|
// RUN: -reconcile-unrealized-casts | \
|
|
// RUN: mlir-cpu-runner -e main -entry-point-result=void \
|
|
// RUN: -shared-libs=%mlir_runner_utils 2>&1 | \
|
|
// RUN: FileCheck %s
|
|
|
|
func.func @load(%memref: memref<1xf32>, %index: index) {
|
|
memref.load %memref[%index] : memref<1xf32>
|
|
return
|
|
}
|
|
|
|
func.func @load_dynamic(%memref: memref<?xf32>, %index: index) {
|
|
memref.load %memref[%index] : memref<?xf32>
|
|
return
|
|
}
|
|
|
|
func.func @load_nd_dynamic(%memref: memref<?x?x?xf32>, %index0: index, %index1: index, %index2: index) {
|
|
memref.load %memref[%index0, %index1, %index2] : memref<?x?x?xf32>
|
|
return
|
|
}
|
|
|
|
func.func @main() {
|
|
%0 = arith.constant 0 : index
|
|
%1 = arith.constant 1 : index
|
|
%n1 = arith.constant -1 : index
|
|
%2 = arith.constant 2 : index
|
|
%alloca_1 = memref.alloca() : memref<1xf32>
|
|
%alloc_1 = memref.alloc(%1) : memref<?xf32>
|
|
%alloc_2x2x2 = memref.alloc(%2, %2, %2) : memref<?x?x?xf32>
|
|
|
|
// CHECK: ERROR: Runtime op verification failed
|
|
// CHECK-NEXT: "memref.load"(%{{.*}}, %{{.*}}) : (memref<1xf32>, index) -> f32
|
|
// CHECK-NEXT: ^ out-of-bounds access
|
|
// CHECK-NEXT: Location: loc({{.*}})
|
|
func.call @load(%alloca_1, %1) : (memref<1xf32>, index) -> ()
|
|
|
|
// CHECK: ERROR: Runtime op verification failed
|
|
// CHECK-NEXT: "memref.load"(%{{.*}}, %{{.*}}) : (memref<?xf32>, index) -> f32
|
|
// CHECK-NEXT: ^ out-of-bounds access
|
|
// CHECK-NEXT: Location: loc({{.*}})
|
|
func.call @load_dynamic(%alloc_1, %1) : (memref<?xf32>, index) -> ()
|
|
|
|
// CHECK: ERROR: Runtime op verification failed
|
|
// CHECK-NEXT: "memref.load"(%{{.*}}, %{{.*}}) : (memref<?x?x?xf32>, index, index, index) -> f32
|
|
// CHECK-NEXT: ^ out-of-bounds access
|
|
// CHECK-NEXT: Location: loc({{.*}})
|
|
func.call @load_nd_dynamic(%alloc_2x2x2, %1, %n1, %0) : (memref<?x?x?xf32>, index, index, index) -> ()
|
|
|
|
// CHECK-NOT: ERROR: Runtime op verification failed
|
|
func.call @load(%alloca_1, %0) : (memref<1xf32>, index) -> ()
|
|
|
|
// CHECK-NOT: ERROR: Runtime op verification failed
|
|
func.call @load_dynamic(%alloc_1, %0) : (memref<?xf32>, index) -> ()
|
|
|
|
// CHECK-NOT: ERROR: Runtime op verification failed
|
|
func.call @load_nd_dynamic(%alloc_2x2x2, %1, %1, %0) : (memref<?x?x?xf32>, index, index, index) -> ()
|
|
|
|
memref.dealloc %alloc_1 : memref<?xf32>
|
|
memref.dealloc %alloc_2x2x2 : memref<?x?x?xf32>
|
|
|
|
return
|
|
}
|
|
|