llvm/mlir/test/python/dialects/ml_program.py

# 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)