// 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, %index: index) { memref.load %memref[%index] : memref return } func.func @load_nd_dynamic(%memref: memref, %index0: index, %index1: index, %index2: index) { memref.load %memref[%index0, %index1, %index2] : memref 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 %alloc_2x2x2 = memref.alloc(%2, %2, %2) : memref // 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, index) -> f32 // CHECK-NEXT: ^ out-of-bounds access // CHECK-NEXT: Location: loc({{.*}}) func.call @load_dynamic(%alloc_1, %1) : (memref, index) -> () // CHECK: ERROR: Runtime op verification failed // CHECK-NEXT: "memref.load"(%{{.*}}, %{{.*}}) : (memref, 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, 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, index) -> () // CHECK-NOT: ERROR: Runtime op verification failed func.call @load_nd_dynamic(%alloc_2x2x2, %1, %1, %0) : (memref, index, index, index) -> () memref.dealloc %alloc_1 : memref memref.dealloc %alloc_2x2x2 : memref return }