# RUN: %PYTHON %s | FileCheck %s
# This is just a smoke test that the dialect is functional.
from mlir.ir import *
from mlir.dialects import ml_program, arith, builtin
def constructAndPrintInModule(f):
print("\nTEST:", f.__name__)
with Context(), Location.unknown():
module = Module.create()
with InsertionPoint(module.body):
f()
print(module)
return f
# CHECK-LABEL: testFuncOp
@constructAndPrintInModule
def testFuncOp():
# CHECK: ml_program.func @foobar(%arg0: si32) -> si32
f = ml_program.FuncOp(
name="foobar", type=([IntegerType.get_signed(32)], [IntegerType.get_signed(32)])
)
block = f.add_entry_block()
with InsertionPoint(block):
# CHECK: ml_program.return
ml_program.ReturnOp([block.arguments[0]])
# CHECK-LABEL: testGlobalStoreOp
@constructAndPrintInModule
def testGlobalStoreOp():
# CHECK: %cst = arith.constant 4.242000e+01 : f32
cst = arith.ConstantOp(value=42.42, result=F32Type.get())
m = builtin.ModuleOp()
m.sym_name = StringAttr.get("symbol1")
m.sym_visibility = StringAttr.get("public")
# CHECK: module @symbol1 attributes {sym_visibility = "public"} {
# CHECK: ml_program.global public mutable @symbol2 : f32
# CHECK: }
with InsertionPoint(m.body):
ml_program.GlobalOp("symbol2", F32Type.get(), is_mutable=True)
# CHECK: ml_program.global_store @symbol1::@symbol2 = %cst : f32
ml_program.GlobalStoreOp(["symbol1", "symbol2"], cst)