My Project
ROCDLDialect.h
Go to the documentation of this file.
1 //===- ROCDLDialect.h - MLIR ROCDL IR dialect -------------------*- C++ -*-===//
2 //
3 // Part of the MLIR 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 // This file defines the ROCDL dialect in MLIR, containing ROCDL operations
10 // and ROCDL specific extensions to the LLVM type system.
11 //
12 // Unfortunately there does not exists a formal definition of ROCDL IR that be
13 // pointed to here. However the following links contain more information about
14 // ROCDL (ROCm-Device-Library)
15 //
16 // https://github.com/RadeonOpenCompute/ROCm-Device-Libs/blob/master/doc/OCML.md
17 // https://github.com/RadeonOpenCompute/ROCm-Device-Libs/blob/master/doc/OCKL.md
18 // https://llvm.org/docs/AMDGPUUsage.html
19 //
20 //===----------------------------------------------------------------------===//
21 
22 #ifndef MLIR_DIALECT_LLVMIR_ROCDLDIALECT_H_
23 #define MLIR_DIALECT_LLVMIR_ROCDLDIALECT_H_
24 
25 #include "mlir/IR/Dialect.h"
26 #include "mlir/IR/OpDefinition.h"
27 
28 namespace mlir {
29 namespace ROCDL {
30 
32 #define GET_OP_CLASSES
33 #include "mlir/Dialect/LLVMIR/ROCDLOps.h.inc"
34 
35 class ROCDLDialect : public Dialect {
36 public:
37  explicit ROCDLDialect(MLIRContext *context);
38 
39  static StringRef getDialectNamespace() { return "rocdl"; }
40 };
41 
42 } // namespace ROCDL
43 } // namespace mlir
44 
45 #endif /* MLIR_DIALECT_LLVMIR_ROCDLDIALECT_H_ */
Definition: InferTypeOpInterface.cpp:20
static StringRef getDialectNamespace()
Definition: ROCDLDialect.h:39
Definition: Dialect.h:39
Definition: ROCDLDialect.h:35
Definition: MLIRContext.h:34
ROCDLDialect(MLIRContext *context)
Definition: ROCDLDialect.cpp:56