1*eb206e9eSAndrea Faulds// RUN: mlir-opt %s -pass-pipeline="builtin.module(func.func(convert-arith-to-llvm),finalize-memref-to-llvm,convert-func-to-llvm,reconcile-unrealized-casts)" | mlir-runner -e main -entry-point-result=void -shared-libs=%mlir_runner_utils,%mlir_c_runner_utils | FileCheck %s 2*eb206e9eSAndrea Faulds 3*eb206e9eSAndrea Fauldsfunc.func private @printMemrefF32(memref<*xf32>) attributes { llvm.emit_c_interface } 4*eb206e9eSAndrea Fauldsfunc.func private @printMemrefI32(memref<*xi32>) attributes { llvm.emit_c_interface } 5*eb206e9eSAndrea Fauldsfunc.func private @printNewline() -> () 6*eb206e9eSAndrea Faulds 7*eb206e9eSAndrea Fauldsmemref.global "private" @gv0 : memref<4xf32> = dense<[0.0, 1.0, 2.0, 3.0]> 8*eb206e9eSAndrea Fauldsfunc.func @test1DMemref() { 9*eb206e9eSAndrea Faulds %0 = memref.get_global @gv0 : memref<4xf32> 10*eb206e9eSAndrea Faulds %U = memref.cast %0 : memref<4xf32> to memref<*xf32> 11*eb206e9eSAndrea Faulds // CHECK: rank = 1 12*eb206e9eSAndrea Faulds // CHECK: offset = 0 13*eb206e9eSAndrea Faulds // CHECK: sizes = [4] 14*eb206e9eSAndrea Faulds // CHECK: strides = [1] 15*eb206e9eSAndrea Faulds // CHECK: [0, 1, 2, 3] 16*eb206e9eSAndrea Faulds call @printMemrefF32(%U) : (memref<*xf32>) -> () 17*eb206e9eSAndrea Faulds call @printNewline() : () -> () 18*eb206e9eSAndrea Faulds 19*eb206e9eSAndrea Faulds // Overwrite some of the elements. 20*eb206e9eSAndrea Faulds %c0 = arith.constant 0 : index 21*eb206e9eSAndrea Faulds %c2 = arith.constant 2 : index 22*eb206e9eSAndrea Faulds %fp0 = arith.constant 4.0 : f32 23*eb206e9eSAndrea Faulds %fp1 = arith.constant 5.0 : f32 24*eb206e9eSAndrea Faulds memref.store %fp0, %0[%c0] : memref<4xf32> 25*eb206e9eSAndrea Faulds memref.store %fp1, %0[%c2] : memref<4xf32> 26*eb206e9eSAndrea Faulds // CHECK: rank = 1 27*eb206e9eSAndrea Faulds // CHECK: offset = 0 28*eb206e9eSAndrea Faulds // CHECK: sizes = [4] 29*eb206e9eSAndrea Faulds // CHECK: strides = [1] 30*eb206e9eSAndrea Faulds // CHECK: [4, 1, 5, 3] 31*eb206e9eSAndrea Faulds call @printMemrefF32(%U) : (memref<*xf32>) -> () 32*eb206e9eSAndrea Faulds call @printNewline() : () -> () 33*eb206e9eSAndrea Faulds return 34*eb206e9eSAndrea Faulds} 35*eb206e9eSAndrea Faulds 36*eb206e9eSAndrea Fauldsmemref.global constant @gv1 : memref<3x2xi32> = dense<[[0, 1],[2, 3],[4, 5]]> 37*eb206e9eSAndrea Fauldsfunc.func @testConstantMemref() { 38*eb206e9eSAndrea Faulds %0 = memref.get_global @gv1 : memref<3x2xi32> 39*eb206e9eSAndrea Faulds %U = memref.cast %0 : memref<3x2xi32> to memref<*xi32> 40*eb206e9eSAndrea Faulds // CHECK: rank = 2 41*eb206e9eSAndrea Faulds // CHECK: offset = 0 42*eb206e9eSAndrea Faulds // CHECK: sizes = [3, 2] 43*eb206e9eSAndrea Faulds // CHECK: strides = [2, 1] 44*eb206e9eSAndrea Faulds // CHECK: [0, 1] 45*eb206e9eSAndrea Faulds // CHECK: [2, 3] 46*eb206e9eSAndrea Faulds // CHECK: [4, 5] 47*eb206e9eSAndrea Faulds call @printMemrefI32(%U) : (memref<*xi32>) -> () 48*eb206e9eSAndrea Faulds call @printNewline() : () -> () 49*eb206e9eSAndrea Faulds return 50*eb206e9eSAndrea Faulds} 51*eb206e9eSAndrea Faulds 52*eb206e9eSAndrea Fauldsmemref.global "private" @gv2 : memref<4x2xf32> = dense<[[0.0, 1.0], [2.0, 3.0], [4.0, 5.0], [6.0, 7.0]]> 53*eb206e9eSAndrea Fauldsfunc.func @test2DMemref() { 54*eb206e9eSAndrea Faulds %0 = memref.get_global @gv2 : memref<4x2xf32> 55*eb206e9eSAndrea Faulds %U = memref.cast %0 : memref<4x2xf32> to memref<*xf32> 56*eb206e9eSAndrea Faulds // CHECK: rank = 2 57*eb206e9eSAndrea Faulds // CHECK: offset = 0 58*eb206e9eSAndrea Faulds // CHECK: sizes = [4, 2] 59*eb206e9eSAndrea Faulds // CHECK: strides = [2, 1] 60*eb206e9eSAndrea Faulds // CHECK: [0, 1] 61*eb206e9eSAndrea Faulds // CHECK: [2, 3] 62*eb206e9eSAndrea Faulds // CHECK: [4, 5] 63*eb206e9eSAndrea Faulds // CHECK: [6, 7] 64*eb206e9eSAndrea Faulds call @printMemrefF32(%U) : (memref<*xf32>) -> () 65*eb206e9eSAndrea Faulds call @printNewline() : () -> () 66*eb206e9eSAndrea Faulds 67*eb206e9eSAndrea Faulds // Overwrite the 1.0 (at index [0, 1]) with 10.0 68*eb206e9eSAndrea Faulds %c0 = arith.constant 0 : index 69*eb206e9eSAndrea Faulds %c1 = arith.constant 1 : index 70*eb206e9eSAndrea Faulds %fp10 = arith.constant 10.0 : f32 71*eb206e9eSAndrea Faulds memref.store %fp10, %0[%c0, %c1] : memref<4x2xf32> 72*eb206e9eSAndrea Faulds // CHECK: rank = 2 73*eb206e9eSAndrea Faulds // CHECK: offset = 0 74*eb206e9eSAndrea Faulds // CHECK: sizes = [4, 2] 75*eb206e9eSAndrea Faulds // CHECK: strides = [2, 1] 76*eb206e9eSAndrea Faulds // CHECK: [0, 10] 77*eb206e9eSAndrea Faulds // CHECK: [2, 3] 78*eb206e9eSAndrea Faulds // CHECK: [4, 5] 79*eb206e9eSAndrea Faulds // CHECK: [6, 7] 80*eb206e9eSAndrea Faulds call @printMemrefF32(%U) : (memref<*xf32>) -> () 81*eb206e9eSAndrea Faulds call @printNewline() : () -> () 82*eb206e9eSAndrea Faulds return 83*eb206e9eSAndrea Faulds} 84*eb206e9eSAndrea Faulds 85*eb206e9eSAndrea Fauldsmemref.global @gv3 : memref<i32> = dense<11> 86*eb206e9eSAndrea Fauldsfunc.func @testScalarMemref() { 87*eb206e9eSAndrea Faulds %0 = memref.get_global @gv3 : memref<i32> 88*eb206e9eSAndrea Faulds %U = memref.cast %0 : memref<i32> to memref<*xi32> 89*eb206e9eSAndrea Faulds // CHECK: rank = 0 90*eb206e9eSAndrea Faulds // CHECK: offset = 0 91*eb206e9eSAndrea Faulds // CHECK: sizes = [] 92*eb206e9eSAndrea Faulds // CHECK: strides = [] 93*eb206e9eSAndrea Faulds // CHECK: [11] 94*eb206e9eSAndrea Faulds call @printMemrefI32(%U) : (memref<*xi32>) -> () 95*eb206e9eSAndrea Faulds call @printNewline() : () -> () 96*eb206e9eSAndrea Faulds return 97*eb206e9eSAndrea Faulds} 98*eb206e9eSAndrea Faulds 99*eb206e9eSAndrea Fauldsfunc.func @main() -> () { 100*eb206e9eSAndrea Faulds call @test1DMemref() : () -> () 101*eb206e9eSAndrea Faulds call @testConstantMemref() : () -> () 102*eb206e9eSAndrea Faulds call @test2DMemref() : () -> () 103*eb206e9eSAndrea Faulds call @testScalarMemref() : () -> () 104*eb206e9eSAndrea Faulds return 105*eb206e9eSAndrea Faulds} 106*eb206e9eSAndrea Faulds 107*eb206e9eSAndrea Faulds 108