
This is a companion to #118583, although it can be landed independently because since #117922 dialects do not have to use the same Python binding framework as the Python core code. This PR ports all of the in-tree dialect and pass extensions to nanobind, with the exception of those that remain for testing pybind11 support. This PR also: * removes CollectDiagnosticsToStringScope from NanobindAdaptors.h. This was overlooked in a previous PR and it is duplicated in Diagnostics.h. --------- Co-authored-by: Jacques Pienaar <jpienaar@google.com>
30 lines
949 B
C++
30 lines
949 B
C++
//===- DialectLinalg.cpp - Pybind module for Linalg dialect API support --===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "mlir-c/Dialect/Linalg.h"
|
|
#include "mlir-c/IR.h"
|
|
#include "mlir/Bindings/Python/NanobindAdaptors.h"
|
|
#include "mlir/Bindings/Python/Nanobind.h"
|
|
|
|
namespace nb = nanobind;
|
|
|
|
static void populateDialectLinalgSubmodule(nb::module_ m) {
|
|
m.def(
|
|
"fill_builtin_region",
|
|
[](MlirOperation op) { mlirLinalgFillBuiltinNamedOpRegion(op); },
|
|
nb::arg("op"),
|
|
"Fill the region for `op`, which is assumed to be a builtin named Linalg "
|
|
"op.");
|
|
}
|
|
|
|
NB_MODULE(_mlirDialectsLinalg, m) {
|
|
m.doc() = "MLIR Linalg dialect.";
|
|
|
|
populateDialectLinalgSubmodule(m);
|
|
}
|