xref: /llvm-project/mlir/test/mlir-runner/global-memref.mlir (revision eb206e9ea84eff0a0596fed2de8316d924f946d1)
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