MLIR  20.0.0git
CompilationInterfaces.h
Go to the documentation of this file.
1 //===-- CompilationInterfaces.h - GPU compilation interfaces ---*- C++ -*-===//
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 // This file defines interfaces for GPU compilation.
10 //
11 //===----------------------------------------------------------------------===//
12 
13 #ifndef MLIR_DIALECT_GPU_IR_COMPILATIONINTERFACES_H
14 #define MLIR_DIALECT_GPU_IR_COMPILATIONINTERFACES_H
15 
16 #include "mlir/IR/Attributes.h"
17 
18 namespace llvm {
19 class IRBuilderBase;
20 }
21 
22 namespace mlir {
23 class SymbolTable;
24 namespace LLVM {
25 class ModuleTranslation;
26 }
27 namespace gpu {
28 enum class CompilationTarget : uint32_t;
29 
30 /// This class indicates that the attribute associated with this trait is a GPU
31 /// offloading translation attribute. These kinds of attributes must implement
32 /// an interface for handling the translation of GPU offloading operations like
33 /// `gpu.binary` & `gpu.launch_func`.
34 template <typename ConcreteType>
36  : public AttributeTrait::TraitBase<ConcreteType,
37  OffloadingTranslationAttrTrait> {
38  // TODO: Verify the attribute promises or implements the interface.
39 };
40 
41 /// This class serves as an opaque interface for passing options to the
42 /// `TargetAttrInterface` methods. Users of this class must implement the
43 /// `classof` method as well as using the macros `MLIR_*_EXPLICIT_TYPE_ID` to
44 /// ensure type safeness. Targets are free to ignore these options.
46 public:
47  /// Constructor initializing the toolkit path, the list of files to link to,
48  /// extra command line options, the compilation target and a callback for
49  /// obtaining the parent symbol table. The default compilation target is
50  /// `Fatbin`.
52  StringRef toolkitPath = {}, ArrayRef<std::string> linkFiles = {},
53  StringRef cmdOptions = {},
54  CompilationTarget compilationTarget = getDefaultCompilationTarget(),
56 
57  /// Returns the typeID.
58  TypeID getTypeID() const;
59 
60  /// Returns the toolkit path.
61  StringRef getToolkitPath() const;
62 
63  /// Returns the files to link to.
65 
66  /// Returns the command line options.
67  StringRef getCmdOptions() const;
68 
69  /// Returns a tokenization of the command line options.
70  std::pair<llvm::BumpPtrAllocator, SmallVector<const char *>>
71  tokenizeCmdOptions() const;
72 
73  /// Returns the compilation target.
74  CompilationTarget getCompilationTarget() const;
75 
76  /// Returns the result of the `getSymbolTableCallback` callback or a nullptr
77  /// if no callback was provided.
78  /// Note: The callback itself can return nullptr. It is up to the target how
79  /// to react to getting a nullptr, e.g., emitting an error or constructing the
80  /// table.
81  SymbolTable *getSymbolTable() const;
82 
83  /// Returns the default compilation target: `CompilationTarget::Fatbin`.
84  static CompilationTarget getDefaultCompilationTarget();
85 
86 protected:
87  /// Derived classes must use this constructor to initialize `typeID` to the
88  /// appropiate value: ie. `TargetOptions(TypeID::get<DerivedClass>())`.
90  TypeID typeID, StringRef toolkitPath = {},
91  ArrayRef<std::string> linkFiles = {}, StringRef cmdOptions = {},
92  CompilationTarget compilationTarget = getDefaultCompilationTarget(),
94 
95  /// Path to the target toolkit.
96  std::string toolkitPath;
97 
98  /// List of files to link with the LLVM module.
100 
101  /// An optional set of command line options to be used by the compilation
102  /// process.
103  std::string cmdOptions;
104 
105  /// Compilation process target format.
106  CompilationTarget compilationTarget;
107 
108  /// Callback for obtaining the parent symbol table of all the GPU modules
109  /// being serialized.
111 
112 private:
113  TypeID typeID;
114 };
115 } // namespace gpu
116 } // namespace mlir
117 
119 
120 #include "mlir/Dialect/GPU/IR/CompilationAttrInterfaces.h.inc"
121 
122 #endif // MLIR_DIALECT_GPU_IR_COMPILATIONINTERFACES_H
#define MLIR_DECLARE_EXPLICIT_TYPE_ID(CLASS_NAME)
Definition: TypeID.h:249
This class allows for representing and managing the symbol table used by operations with the 'SymbolT...
Definition: SymbolTable.h:24
This class provides an efficient unique identifier for a specific C++ type.
Definition: TypeID.h:104
Helper class for implementing traits for storage classes.
This class indicates that the attribute associated with this trait is a GPU offloading translation at...
This class serves as an opaque interface for passing options to the TargetAttrInterface methods.
ArrayRef< std::string > getLinkFiles() const
Returns the files to link to.
TypeID getTypeID() const
Returns the typeID.
std::string toolkitPath
Path to the target toolkit.
SymbolTable * getSymbolTable() const
Returns the result of the getSymbolTableCallback callback or a nullptr if no callback was provided.
StringRef getCmdOptions() const
Returns the command line options.
std::string cmdOptions
An optional set of command line options to be used by the compilation process.
CompilationTarget compilationTarget
Compilation process target format.
std::pair< llvm::BumpPtrAllocator, SmallVector< const char * > > tokenizeCmdOptions() const
Returns a tokenization of the command line options.
StringRef getToolkitPath() const
Returns the toolkit path.
TargetOptions(StringRef toolkitPath={}, ArrayRef< std::string > linkFiles={}, StringRef cmdOptions={}, CompilationTarget compilationTarget=getDefaultCompilationTarget(), function_ref< SymbolTable *()> getSymbolTableCallback={})
Constructor initializing the toolkit path, the list of files to link to, extra command line options,...
SmallVector< std::string > linkFiles
List of files to link with the LLVM module.
function_ref< SymbolTable *()> getSymbolTableCallback
Callback for obtaining the parent symbol table of all the GPU modules being serialized.
static CompilationTarget getDefaultCompilationTarget()
Returns the default compilation target: CompilationTarget::Fatbin.
CompilationTarget getCompilationTarget() const
Returns the compilation target.
The OpAsmOpInterface, see OpAsmInterface.td for more details.
Definition: CallGraph.h:229
Include the generated interface declarations.