MLIR  20.0.0git
DialectNVGPU.cpp
Go to the documentation of this file.
1 //===--- DialectNVGPU.cpp - Pybind module for NVGPU dialect API support ---===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 
9 #include "mlir-c/Dialect/NVGPU.h"
10 #include "mlir-c/IR.h"
13 
14 namespace nb = nanobind;
15 using namespace llvm;
16 using namespace mlir;
17 using namespace mlir::python;
18 using namespace mlir::python::nanobind_adaptors;
19 
20 static void populateDialectNVGPUSubmodule(const nb::module_ &m) {
21  auto nvgpuTensorMapDescriptorType = mlir_type_subclass(
22  m, "TensorMapDescriptorType", mlirTypeIsANVGPUTensorMapDescriptorType);
23 
24  nvgpuTensorMapDescriptorType.def_classmethod(
25  "get",
26  [](nb::object cls, MlirType tensorMemrefType, int swizzle, int l2promo,
27  int oobFill, int interleave, MlirContext ctx) {
29  ctx, tensorMemrefType, swizzle, l2promo, oobFill, interleave));
30  },
31  "Gets an instance of TensorMapDescriptorType in the same context",
32  nb::arg("cls"), nb::arg("tensor_type"), nb::arg("swizzle"),
33  nb::arg("l2promo"), nb::arg("oob_fill"), nb::arg("interleave"),
34  nb::arg("ctx").none() = nb::none());
35 }
36 
37 NB_MODULE(_mlirDialectsNVGPU, m) {
38  m.doc() = "MLIR NVGPU dialect.";
39 
41 }
NB_MODULE(_mlirDialectsNVGPU, m)
static void populateDialectNVGPUSubmodule(const nb::module_ &m)
MLIR_CAPI_EXPORTED bool mlirTypeIsANVGPUTensorMapDescriptorType(MlirType type)
Definition: NVGPU.cpp:19
MLIR_CAPI_EXPORTED MlirType mlirNVGPUTensorMapDescriptorTypeGet(MlirContext ctx, MlirType tensorMemrefType, int swizzle, int l2promo, int oobFill, int interleave)
Definition: NVGPU.cpp:23
Creates a custom subclass of mlir.ir.Type, implementing a casting constructor and type checking metho...
The OpAsmOpInterface, see OpAsmInterface.td for more details.
Definition: CallGraph.h:229
Include the generated interface declarations.