19f3f6d7bSStella Laurenzo# RUN: %PYTHON %s 2>&1 | FileCheck %s 29f3f6d7bSStella Laurenzo 39f3f6d7bSStella Laurenzoimport gc, sys 49f3f6d7bSStella Laurenzofrom mlir.ir import * 59f3f6d7bSStella Laurenzofrom mlir.passmanager import * 69f3f6d7bSStella Laurenzofrom mlir.execution_engine import * 79f3f6d7bSStella Laurenzofrom mlir.runtime import * 89f3f6d7bSStella Laurenzo 9*a54f4eaeSMogball 109f3f6d7bSStella Laurenzo# Log everything to stderr and flush so that we have a unified stream to match 119f3f6d7bSStella Laurenzo# errors/info emitted by MLIR to stderr. 129f3f6d7bSStella Laurenzodef log(*args): 139f3f6d7bSStella Laurenzo print(*args, file=sys.stderr) 149f3f6d7bSStella Laurenzo sys.stderr.flush() 159f3f6d7bSStella Laurenzo 16*a54f4eaeSMogball 179f3f6d7bSStella Laurenzodef run(f): 189f3f6d7bSStella Laurenzo log("\nTEST:", f.__name__) 199f3f6d7bSStella Laurenzo f() 209f3f6d7bSStella Laurenzo gc.collect() 219f3f6d7bSStella Laurenzo assert Context._get_live_count() == 0 229f3f6d7bSStella Laurenzo 23*a54f4eaeSMogball 249f3f6d7bSStella Laurenzo# Verify capsule interop. 259f3f6d7bSStella Laurenzo# CHECK-LABEL: TEST: testCapsule 269f3f6d7bSStella Laurenzodef testCapsule(): 279f3f6d7bSStella Laurenzo with Context(): 289f3f6d7bSStella Laurenzo module = Module.parse(r""" 299f3f6d7bSStella Laurenzollvm.func @none() { 309f3f6d7bSStella Laurenzo llvm.return 319f3f6d7bSStella Laurenzo} 329f3f6d7bSStella Laurenzo """) 339f3f6d7bSStella Laurenzo execution_engine = ExecutionEngine(module) 349f3f6d7bSStella Laurenzo execution_engine_capsule = execution_engine._CAPIPtr 359f3f6d7bSStella Laurenzo # CHECK: mlir.execution_engine.ExecutionEngine._CAPIPtr 369f3f6d7bSStella Laurenzo log(repr(execution_engine_capsule)) 379f3f6d7bSStella Laurenzo execution_engine._testing_release() 389f3f6d7bSStella Laurenzo execution_engine1 = ExecutionEngine._CAPICreate(execution_engine_capsule) 390cdf4915SStella Laurenzo # CHECK: _mlirExecutionEngine.ExecutionEngine 409f3f6d7bSStella Laurenzo log(repr(execution_engine1)) 419f3f6d7bSStella Laurenzo 42*a54f4eaeSMogball 439f3f6d7bSStella Laurenzorun(testCapsule) 449f3f6d7bSStella Laurenzo 45*a54f4eaeSMogball 469f3f6d7bSStella Laurenzo# Test invalid ExecutionEngine creation 479f3f6d7bSStella Laurenzo# CHECK-LABEL: TEST: testInvalidModule 489f3f6d7bSStella Laurenzodef testInvalidModule(): 499f3f6d7bSStella Laurenzo with Context(): 509f3f6d7bSStella Laurenzo # Builtin function 519f3f6d7bSStella Laurenzo module = Module.parse(r""" 529f3f6d7bSStella Laurenzo func @foo() { return } 539f3f6d7bSStella Laurenzo """) 549f3f6d7bSStella Laurenzo # CHECK: Got RuntimeError: Failure while creating the ExecutionEngine. 559f3f6d7bSStella Laurenzo try: 569f3f6d7bSStella Laurenzo execution_engine = ExecutionEngine(module) 579f3f6d7bSStella Laurenzo except RuntimeError as e: 589f3f6d7bSStella Laurenzo log("Got RuntimeError: ", e) 599f3f6d7bSStella Laurenzo 60*a54f4eaeSMogball 619f3f6d7bSStella Laurenzorun(testInvalidModule) 629f3f6d7bSStella Laurenzo 63*a54f4eaeSMogball 649f3f6d7bSStella Laurenzodef lowerToLLVM(module): 659f3f6d7bSStella Laurenzo import mlir.conversions 66*a54f4eaeSMogball pm = PassManager.parse( 67*a54f4eaeSMogball "convert-memref-to-llvm,convert-std-to-llvm,reconcile-unrealized-casts") 689f3f6d7bSStella Laurenzo pm.run(module) 699f3f6d7bSStella Laurenzo return module 709f3f6d7bSStella Laurenzo 71*a54f4eaeSMogball 729f3f6d7bSStella Laurenzo# Test simple ExecutionEngine execution 739f3f6d7bSStella Laurenzo# CHECK-LABEL: TEST: testInvokeVoid 749f3f6d7bSStella Laurenzodef testInvokeVoid(): 759f3f6d7bSStella Laurenzo with Context(): 769f3f6d7bSStella Laurenzo module = Module.parse(r""" 779f3f6d7bSStella Laurenzofunc @void() attributes { llvm.emit_c_interface } { 789f3f6d7bSStella Laurenzo return 799f3f6d7bSStella Laurenzo} 809f3f6d7bSStella Laurenzo """) 819f3f6d7bSStella Laurenzo execution_engine = ExecutionEngine(lowerToLLVM(module)) 829f3f6d7bSStella Laurenzo # Nothing to check other than no exception thrown here. 839f3f6d7bSStella Laurenzo execution_engine.invoke("void") 849f3f6d7bSStella Laurenzo 85*a54f4eaeSMogball 869f3f6d7bSStella Laurenzorun(testInvokeVoid) 879f3f6d7bSStella Laurenzo 889f3f6d7bSStella Laurenzo 899f3f6d7bSStella Laurenzo# Test argument passing and result with a simple float addition. 909f3f6d7bSStella Laurenzo# CHECK-LABEL: TEST: testInvokeFloatAdd 919f3f6d7bSStella Laurenzodef testInvokeFloatAdd(): 929f3f6d7bSStella Laurenzo with Context(): 939f3f6d7bSStella Laurenzo module = Module.parse(r""" 949f3f6d7bSStella Laurenzofunc @add(%arg0: f32, %arg1: f32) -> f32 attributes { llvm.emit_c_interface } { 95*a54f4eaeSMogball %add = arith.addf %arg0, %arg1 : f32 969f3f6d7bSStella Laurenzo return %add : f32 979f3f6d7bSStella Laurenzo} 989f3f6d7bSStella Laurenzo """) 999f3f6d7bSStella Laurenzo execution_engine = ExecutionEngine(lowerToLLVM(module)) 1009f3f6d7bSStella Laurenzo # Prepare arguments: two input floats and one result. 1019f3f6d7bSStella Laurenzo # Arguments must be passed as pointers. 1029f3f6d7bSStella Laurenzo c_float_p = ctypes.c_float * 1 1039f3f6d7bSStella Laurenzo arg0 = c_float_p(42.) 1049f3f6d7bSStella Laurenzo arg1 = c_float_p(2.) 1059f3f6d7bSStella Laurenzo res = c_float_p(-1.) 1069f3f6d7bSStella Laurenzo execution_engine.invoke("add", arg0, arg1, res) 1079f3f6d7bSStella Laurenzo # CHECK: 42.0 + 2.0 = 44.0 1089f3f6d7bSStella Laurenzo log("{0} + {1} = {2}".format(arg0[0], arg1[0], res[0])) 1099f3f6d7bSStella Laurenzo 110*a54f4eaeSMogball 1119f3f6d7bSStella Laurenzorun(testInvokeFloatAdd) 1129f3f6d7bSStella Laurenzo 1139f3f6d7bSStella Laurenzo 1149f3f6d7bSStella Laurenzo# Test callback 1159f3f6d7bSStella Laurenzo# CHECK-LABEL: TEST: testBasicCallback 1169f3f6d7bSStella Laurenzodef testBasicCallback(): 1179f3f6d7bSStella Laurenzo # Define a callback function that takes a float and an integer and returns a float. 1189f3f6d7bSStella Laurenzo @ctypes.CFUNCTYPE(ctypes.c_float, ctypes.c_float, ctypes.c_int) 1199f3f6d7bSStella Laurenzo def callback(a, b): 1209f3f6d7bSStella Laurenzo return a / 2 + b / 2 1219f3f6d7bSStella Laurenzo 1229f3f6d7bSStella Laurenzo with Context(): 1239f3f6d7bSStella Laurenzo # The module just forwards to a runtime function known as "some_callback_into_python". 1249f3f6d7bSStella Laurenzo module = Module.parse(r""" 1259f3f6d7bSStella Laurenzofunc @add(%arg0: f32, %arg1: i32) -> f32 attributes { llvm.emit_c_interface } { 1269f3f6d7bSStella Laurenzo %resf = call @some_callback_into_python(%arg0, %arg1) : (f32, i32) -> (f32) 1279f3f6d7bSStella Laurenzo return %resf : f32 1289f3f6d7bSStella Laurenzo} 1299f3f6d7bSStella Laurenzofunc private @some_callback_into_python(f32, i32) -> f32 attributes { llvm.emit_c_interface } 1309f3f6d7bSStella Laurenzo """) 1319f3f6d7bSStella Laurenzo execution_engine = ExecutionEngine(lowerToLLVM(module)) 1329f3f6d7bSStella Laurenzo execution_engine.register_runtime("some_callback_into_python", callback) 1339f3f6d7bSStella Laurenzo 1349f3f6d7bSStella Laurenzo # Prepare arguments: two input floats and one result. 1359f3f6d7bSStella Laurenzo # Arguments must be passed as pointers. 1369f3f6d7bSStella Laurenzo c_float_p = ctypes.c_float * 1 1379f3f6d7bSStella Laurenzo c_int_p = ctypes.c_int * 1 1389f3f6d7bSStella Laurenzo arg0 = c_float_p(42.) 1399f3f6d7bSStella Laurenzo arg1 = c_int_p(2) 1409f3f6d7bSStella Laurenzo res = c_float_p(-1.) 1419f3f6d7bSStella Laurenzo execution_engine.invoke("add", arg0, arg1, res) 1429f3f6d7bSStella Laurenzo # CHECK: 42.0 + 2 = 44.0 1439f3f6d7bSStella Laurenzo log("{0} + {1} = {2}".format(arg0[0], arg1[0], res[0] * 2)) 1449f3f6d7bSStella Laurenzo 145*a54f4eaeSMogball 1469f3f6d7bSStella Laurenzorun(testBasicCallback) 1479f3f6d7bSStella Laurenzo 148*a54f4eaeSMogball 1499f3f6d7bSStella Laurenzo# Test callback with an unranked memref 1509f3f6d7bSStella Laurenzo# CHECK-LABEL: TEST: testUnrankedMemRefCallback 1519f3f6d7bSStella Laurenzodef testUnrankedMemRefCallback(): 1529f3f6d7bSStella Laurenzo # Define a callback function that takes an unranked memref, converts it to a numpy array and prints it. 1539f3f6d7bSStella Laurenzo @ctypes.CFUNCTYPE(None, ctypes.POINTER(UnrankedMemRefDescriptor)) 1549f3f6d7bSStella Laurenzo def callback(a): 1559f3f6d7bSStella Laurenzo arr = unranked_memref_to_numpy(a, np.float32) 1569f3f6d7bSStella Laurenzo log("Inside callback: ") 1579f3f6d7bSStella Laurenzo log(arr) 1589f3f6d7bSStella Laurenzo 1599f3f6d7bSStella Laurenzo with Context(): 1609f3f6d7bSStella Laurenzo # The module just forwards to a runtime function known as "some_callback_into_python". 161*a54f4eaeSMogball module = Module.parse(r""" 1629f3f6d7bSStella Laurenzofunc @callback_memref(%arg0: memref<*xf32>) attributes { llvm.emit_c_interface } { 1639f3f6d7bSStella Laurenzo call @some_callback_into_python(%arg0) : (memref<*xf32>) -> () 1649f3f6d7bSStella Laurenzo return 1659f3f6d7bSStella Laurenzo} 1669f3f6d7bSStella Laurenzofunc private @some_callback_into_python(memref<*xf32>) -> () attributes { llvm.emit_c_interface } 167*a54f4eaeSMogball""") 1689f3f6d7bSStella Laurenzo execution_engine = ExecutionEngine(lowerToLLVM(module)) 1699f3f6d7bSStella Laurenzo execution_engine.register_runtime("some_callback_into_python", callback) 1709f3f6d7bSStella Laurenzo inp_arr = np.array([[1.0, 2.0], [3.0, 4.0]], np.float32) 1719f3f6d7bSStella Laurenzo # CHECK: Inside callback: 1729f3f6d7bSStella Laurenzo # CHECK{LITERAL}: [[1. 2.] 1739f3f6d7bSStella Laurenzo # CHECK{LITERAL}: [3. 4.]] 1749f3f6d7bSStella Laurenzo execution_engine.invoke( 1759f3f6d7bSStella Laurenzo "callback_memref", 1769f3f6d7bSStella Laurenzo ctypes.pointer(ctypes.pointer(get_unranked_memref_descriptor(inp_arr))), 1779f3f6d7bSStella Laurenzo ) 1789f3f6d7bSStella Laurenzo inp_arr_1 = np.array([5, 6, 7], dtype=np.float32) 1799f3f6d7bSStella Laurenzo strided_arr = np.lib.stride_tricks.as_strided( 180*a54f4eaeSMogball inp_arr_1, strides=(4, 0), shape=(3, 4)) 1819f3f6d7bSStella Laurenzo # CHECK: Inside callback: 1829f3f6d7bSStella Laurenzo # CHECK{LITERAL}: [[5. 5. 5. 5.] 1839f3f6d7bSStella Laurenzo # CHECK{LITERAL}: [6. 6. 6. 6.] 1849f3f6d7bSStella Laurenzo # CHECK{LITERAL}: [7. 7. 7. 7.]] 1859f3f6d7bSStella Laurenzo execution_engine.invoke( 1869f3f6d7bSStella Laurenzo "callback_memref", 1879f3f6d7bSStella Laurenzo ctypes.pointer( 188*a54f4eaeSMogball ctypes.pointer(get_unranked_memref_descriptor(strided_arr))), 1899f3f6d7bSStella Laurenzo ) 1909f3f6d7bSStella Laurenzo 191*a54f4eaeSMogball 1929f3f6d7bSStella Laurenzorun(testUnrankedMemRefCallback) 1939f3f6d7bSStella Laurenzo 194*a54f4eaeSMogball 1959f3f6d7bSStella Laurenzo# Test callback with a ranked memref. 1969f3f6d7bSStella Laurenzo# CHECK-LABEL: TEST: testRankedMemRefCallback 1979f3f6d7bSStella Laurenzodef testRankedMemRefCallback(): 1989f3f6d7bSStella Laurenzo # Define a callback function that takes a ranked memref, converts it to a numpy array and prints it. 1999f3f6d7bSStella Laurenzo @ctypes.CFUNCTYPE( 2009f3f6d7bSStella Laurenzo None, 2019f3f6d7bSStella Laurenzo ctypes.POINTER( 202*a54f4eaeSMogball make_nd_memref_descriptor(2, 203*a54f4eaeSMogball np.ctypeslib.as_ctypes_type(np.float32))), 2049f3f6d7bSStella Laurenzo ) 2059f3f6d7bSStella Laurenzo def callback(a): 2069f3f6d7bSStella Laurenzo arr = ranked_memref_to_numpy(a) 2079f3f6d7bSStella Laurenzo log("Inside Callback: ") 2089f3f6d7bSStella Laurenzo log(arr) 2099f3f6d7bSStella Laurenzo 2109f3f6d7bSStella Laurenzo with Context(): 2119f3f6d7bSStella Laurenzo # The module just forwards to a runtime function known as "some_callback_into_python". 212*a54f4eaeSMogball module = Module.parse(r""" 2139f3f6d7bSStella Laurenzofunc @callback_memref(%arg0: memref<2x2xf32>) attributes { llvm.emit_c_interface } { 2149f3f6d7bSStella Laurenzo call @some_callback_into_python(%arg0) : (memref<2x2xf32>) -> () 2159f3f6d7bSStella Laurenzo return 2169f3f6d7bSStella Laurenzo} 2179f3f6d7bSStella Laurenzofunc private @some_callback_into_python(memref<2x2xf32>) -> () attributes { llvm.emit_c_interface } 218*a54f4eaeSMogball""") 2199f3f6d7bSStella Laurenzo execution_engine = ExecutionEngine(lowerToLLVM(module)) 2209f3f6d7bSStella Laurenzo execution_engine.register_runtime("some_callback_into_python", callback) 2219f3f6d7bSStella Laurenzo inp_arr = np.array([[1.0, 5.0], [6.0, 7.0]], np.float32) 2229f3f6d7bSStella Laurenzo # CHECK: Inside Callback: 2239f3f6d7bSStella Laurenzo # CHECK{LITERAL}: [[1. 5.] 2249f3f6d7bSStella Laurenzo # CHECK{LITERAL}: [6. 7.]] 2259f3f6d7bSStella Laurenzo execution_engine.invoke( 226*a54f4eaeSMogball "callback_memref", 227*a54f4eaeSMogball ctypes.pointer(ctypes.pointer(get_ranked_memref_descriptor(inp_arr)))) 228*a54f4eaeSMogball 2299f3f6d7bSStella Laurenzo 2309f3f6d7bSStella Laurenzorun(testRankedMemRefCallback) 2319f3f6d7bSStella Laurenzo 232*a54f4eaeSMogball 233c8b8e8e0SUday Bondhugula# Test addition of two memrefs. 2349f3f6d7bSStella Laurenzo# CHECK-LABEL: TEST: testMemrefAdd 2359f3f6d7bSStella Laurenzodef testMemrefAdd(): 2369f3f6d7bSStella Laurenzo with Context(): 237*a54f4eaeSMogball module = Module.parse(""" 2389f3f6d7bSStella Laurenzo module { 2399f3f6d7bSStella Laurenzo func @main(%arg0: memref<1xf32>, %arg1: memref<f32>, %arg2: memref<1xf32>) attributes { llvm.emit_c_interface } { 240*a54f4eaeSMogball %0 = arith.constant 0 : index 2419f3f6d7bSStella Laurenzo %1 = memref.load %arg0[%0] : memref<1xf32> 2429f3f6d7bSStella Laurenzo %2 = memref.load %arg1[] : memref<f32> 243*a54f4eaeSMogball %3 = arith.addf %1, %2 : f32 2449f3f6d7bSStella Laurenzo memref.store %3, %arg2[%0] : memref<1xf32> 2459f3f6d7bSStella Laurenzo return 2469f3f6d7bSStella Laurenzo } 247*a54f4eaeSMogball } """) 2489f3f6d7bSStella Laurenzo arg1 = np.array([32.5]).astype(np.float32) 2499f3f6d7bSStella Laurenzo arg2 = np.array(6).astype(np.float32) 2509f3f6d7bSStella Laurenzo res = np.array([0]).astype(np.float32) 2519f3f6d7bSStella Laurenzo 252*a54f4eaeSMogball arg1_memref_ptr = ctypes.pointer( 253*a54f4eaeSMogball ctypes.pointer(get_ranked_memref_descriptor(arg1))) 254*a54f4eaeSMogball arg2_memref_ptr = ctypes.pointer( 255*a54f4eaeSMogball ctypes.pointer(get_ranked_memref_descriptor(arg2))) 256*a54f4eaeSMogball res_memref_ptr = ctypes.pointer( 257*a54f4eaeSMogball ctypes.pointer(get_ranked_memref_descriptor(res))) 2589f3f6d7bSStella Laurenzo 2599f3f6d7bSStella Laurenzo execution_engine = ExecutionEngine(lowerToLLVM(module)) 260*a54f4eaeSMogball execution_engine.invoke("main", arg1_memref_ptr, arg2_memref_ptr, 261*a54f4eaeSMogball res_memref_ptr) 2629f3f6d7bSStella Laurenzo # CHECK: [32.5] + 6.0 = [38.5] 2639f3f6d7bSStella Laurenzo log("{0} + {1} = {2}".format(arg1, arg2, res)) 2649f3f6d7bSStella Laurenzo 265*a54f4eaeSMogball 2669f3f6d7bSStella Laurenzorun(testMemrefAdd) 2679f3f6d7bSStella Laurenzo 268*a54f4eaeSMogball 2699f3f6d7bSStella Laurenzo# Test addition of two 2d_memref 2709f3f6d7bSStella Laurenzo# CHECK-LABEL: TEST: testDynamicMemrefAdd2D 2719f3f6d7bSStella Laurenzodef testDynamicMemrefAdd2D(): 2729f3f6d7bSStella Laurenzo with Context(): 273*a54f4eaeSMogball module = Module.parse(""" 2749f3f6d7bSStella Laurenzo module { 2759f3f6d7bSStella Laurenzo func @memref_add_2d(%arg0: memref<2x2xf32>, %arg1: memref<?x?xf32>, %arg2: memref<2x2xf32>) attributes {llvm.emit_c_interface} { 276*a54f4eaeSMogball %c0 = arith.constant 0 : index 277*a54f4eaeSMogball %c2 = arith.constant 2 : index 278*a54f4eaeSMogball %c1 = arith.constant 1 : index 2799f3f6d7bSStella Laurenzo br ^bb1(%c0 : index) 2809f3f6d7bSStella Laurenzo ^bb1(%0: index): // 2 preds: ^bb0, ^bb5 281*a54f4eaeSMogball %1 = arith.cmpi slt, %0, %c2 : index 2829f3f6d7bSStella Laurenzo cond_br %1, ^bb2, ^bb6 2839f3f6d7bSStella Laurenzo ^bb2: // pred: ^bb1 284*a54f4eaeSMogball %c0_0 = arith.constant 0 : index 285*a54f4eaeSMogball %c2_1 = arith.constant 2 : index 286*a54f4eaeSMogball %c1_2 = arith.constant 1 : index 2879f3f6d7bSStella Laurenzo br ^bb3(%c0_0 : index) 2889f3f6d7bSStella Laurenzo ^bb3(%2: index): // 2 preds: ^bb2, ^bb4 289*a54f4eaeSMogball %3 = arith.cmpi slt, %2, %c2_1 : index 2909f3f6d7bSStella Laurenzo cond_br %3, ^bb4, ^bb5 2919f3f6d7bSStella Laurenzo ^bb4: // pred: ^bb3 2929f3f6d7bSStella Laurenzo %4 = memref.load %arg0[%0, %2] : memref<2x2xf32> 2939f3f6d7bSStella Laurenzo %5 = memref.load %arg1[%0, %2] : memref<?x?xf32> 294*a54f4eaeSMogball %6 = arith.addf %4, %5 : f32 2959f3f6d7bSStella Laurenzo memref.store %6, %arg2[%0, %2] : memref<2x2xf32> 296*a54f4eaeSMogball %7 = arith.addi %2, %c1_2 : index 2979f3f6d7bSStella Laurenzo br ^bb3(%7 : index) 2989f3f6d7bSStella Laurenzo ^bb5: // pred: ^bb3 299*a54f4eaeSMogball %8 = arith.addi %0, %c1 : index 3009f3f6d7bSStella Laurenzo br ^bb1(%8 : index) 3019f3f6d7bSStella Laurenzo ^bb6: // pred: ^bb1 3029f3f6d7bSStella Laurenzo return 3039f3f6d7bSStella Laurenzo } 3049f3f6d7bSStella Laurenzo } 305*a54f4eaeSMogball """) 3069f3f6d7bSStella Laurenzo arg1 = np.random.randn(2, 2).astype(np.float32) 3079f3f6d7bSStella Laurenzo arg2 = np.random.randn(2, 2).astype(np.float32) 3089f3f6d7bSStella Laurenzo res = np.random.randn(2, 2).astype(np.float32) 3099f3f6d7bSStella Laurenzo 310*a54f4eaeSMogball arg1_memref_ptr = ctypes.pointer( 311*a54f4eaeSMogball ctypes.pointer(get_ranked_memref_descriptor(arg1))) 312*a54f4eaeSMogball arg2_memref_ptr = ctypes.pointer( 313*a54f4eaeSMogball ctypes.pointer(get_ranked_memref_descriptor(arg2))) 314*a54f4eaeSMogball res_memref_ptr = ctypes.pointer( 315*a54f4eaeSMogball ctypes.pointer(get_ranked_memref_descriptor(res))) 3169f3f6d7bSStella Laurenzo 3179f3f6d7bSStella Laurenzo execution_engine = ExecutionEngine(lowerToLLVM(module)) 318*a54f4eaeSMogball execution_engine.invoke("memref_add_2d", arg1_memref_ptr, arg2_memref_ptr, 319*a54f4eaeSMogball res_memref_ptr) 3209f3f6d7bSStella Laurenzo # CHECK: True 3219f3f6d7bSStella Laurenzo log(np.allclose(arg1 + arg2, res)) 3229f3f6d7bSStella Laurenzo 323*a54f4eaeSMogball 3249f3f6d7bSStella Laurenzorun(testDynamicMemrefAdd2D) 325c8b8e8e0SUday Bondhugula 326*a54f4eaeSMogball 327c8b8e8e0SUday Bondhugula# Test loading of shared libraries. 328c8b8e8e0SUday Bondhugula# CHECK-LABEL: TEST: testSharedLibLoad 329c8b8e8e0SUday Bondhuguladef testSharedLibLoad(): 330c8b8e8e0SUday Bondhugula with Context(): 331*a54f4eaeSMogball module = Module.parse(""" 332c8b8e8e0SUday Bondhugula module { 333c8b8e8e0SUday Bondhugula func @main(%arg0: memref<1xf32>) attributes { llvm.emit_c_interface } { 334*a54f4eaeSMogball %c0 = arith.constant 0 : index 335*a54f4eaeSMogball %cst42 = arith.constant 42.0 : f32 336c8b8e8e0SUday Bondhugula memref.store %cst42, %arg0[%c0] : memref<1xf32> 337c8b8e8e0SUday Bondhugula %u_memref = memref.cast %arg0 : memref<1xf32> to memref<*xf32> 338c8b8e8e0SUday Bondhugula call @print_memref_f32(%u_memref) : (memref<*xf32>) -> () 339c8b8e8e0SUday Bondhugula return 340c8b8e8e0SUday Bondhugula } 341c8b8e8e0SUday Bondhugula func private @print_memref_f32(memref<*xf32>) attributes { llvm.emit_c_interface } 342*a54f4eaeSMogball } """) 343c8b8e8e0SUday Bondhugula arg0 = np.array([0.0]).astype(np.float32) 344c8b8e8e0SUday Bondhugula 345*a54f4eaeSMogball arg0_memref_ptr = ctypes.pointer( 346*a54f4eaeSMogball ctypes.pointer(get_ranked_memref_descriptor(arg0))) 347c8b8e8e0SUday Bondhugula 348*a54f4eaeSMogball execution_engine = ExecutionEngine( 349*a54f4eaeSMogball lowerToLLVM(module), 350*a54f4eaeSMogball opt_level=3, 351*a54f4eaeSMogball shared_libs=[ 352*a54f4eaeSMogball "../../../../lib/libmlir_runner_utils.so", 353*a54f4eaeSMogball "../../../../lib/libmlir_c_runner_utils.so" 354*a54f4eaeSMogball ]) 355c8b8e8e0SUday Bondhugula execution_engine.invoke("main", arg0_memref_ptr) 356c8b8e8e0SUday Bondhugula # CHECK: Unranked Memref 357c8b8e8e0SUday Bondhugula # CHECK-NEXT: [42] 358c8b8e8e0SUday Bondhugula 359*a54f4eaeSMogball 360c8b8e8e0SUday Bondhugularun(testSharedLibLoad) 361