MLIR 22.0.0git
Utils.h
Go to the documentation of this file.
1//===- Utils.h - MLIR ROCDL target utils ------------------------*- 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 files declares ROCDL target related utility classes and functions.
10//
11//===----------------------------------------------------------------------===//
12
13#ifndef MLIR_TARGET_LLVM_ROCDL_UTILS_H
14#define MLIR_TARGET_LLVM_ROCDL_UTILS_H
15
19#include "mlir/IR/Attributes.h"
20#include "mlir/Support/LLVM.h"
22
23namespace mlir {
24namespace ROCDL {
25/// Searches & returns the path ROCM toolkit path, the search order is:
26/// 1. The `ROCM_PATH` environment variable.
27/// 2. The `ROCM_ROOT` environment variable.
28/// 3. The `ROCM_HOME` environment variable.
29/// 4. The ROCM path detected by CMake.
30/// 5. Returns an empty string.
31StringRef getROCMPath();
32
33/// Helper enum for specifying the AMD GCN device libraries required for
34/// compilation.
35enum class AMDGCNLibraries : uint32_t {
36 None = 0,
37 Ockl = 1,
38 Ocml = 2,
39 OpenCL = 4,
40 Hip = 8,
43 All = (LastLib << 1) - 1
44};
45
46/// Base class for all ROCDL serializations from GPU modules into binary
47/// strings. By default this class serializes into LLVM bitcode.
49public:
50 /// Initializes the `toolkitPath` with the path in `targetOptions` or if empty
51 /// with the path in `getROCMPath`.
53 const gpu::TargetOptions &targetOptions = {});
54
55 /// Initializes the LLVM AMDGPU target by safely calling
56 /// `LLVMInitializeAMDGPU*` methods if available.
57 static void init();
58
59 /// Returns the target attribute.
60 ROCDLTargetAttr getTarget() const;
61
62 /// Returns the ROCM toolkit path.
63 StringRef getToolkitPath() const;
64
65 /// Returns the LLVM bitcode libraries to be linked.
67
68 /// Appends standard ROCm device libraries to `fileList`.
69 LogicalResult appendStandardLibs(AMDGCNLibraries libs);
70
71 /// Loads the bitcode files in `fileList`.
72 virtual std::optional<SmallVector<std::unique_ptr<llvm::Module>>>
73 loadBitcodeFiles(llvm::Module &module) override;
74
75 /// Determines required Device Libraries and adds `oclc` control variables to
76 /// the LLVM Module if needed. Also sets
77 /// `amdhsa_code_object_version` module flag.
78 void handleModulePreLink(llvm::Module &module) override;
79
80 /// Removes unnecessary metadata from the loaded bitcode files.
81 LogicalResult handleBitcodeFile(llvm::Module &module) override;
82
83protected:
84 /// Adds `oclc` control variables to the LLVM Module if needed. It also sets
85 /// `amdhsa_code_object_version` module flag which is equal to ABI version and
86 /// it uses "llvm::Module::Error" to set that flag.
87 void addControlVariables(llvm::Module &module, AMDGCNLibraries libs,
88 bool wave64, bool daz, bool finiteOnly,
89 bool unsafeMath, bool fastMath, bool correctSqrt,
90 StringRef abiVer);
91
92 /// Compiles assembly to a binary.
93 virtual std::optional<SmallVector<char, 0>>
94 compileToBinary(const std::string &serializedISA);
95
96 /// Default implementation of `ModuleToObject::moduleToObject`.
97 std::optional<SmallVector<char, 0>>
98 moduleToObjectImpl(const gpu::TargetOptions &targetOptions,
99 llvm::Module &llvmModule);
100
101 /// Returns the assembled ISA.
102 std::optional<SmallVector<char, 0>> assembleIsa(StringRef isa);
103
104 /// ROCDL target attribute.
105 ROCDLTargetAttr target;
106
107 /// ROCM toolkit path.
108 std::string toolkitPath;
109
110 /// List of LLVM bitcode files to link to.
112
113 /// AMD GCN libraries to use when linking, the default is using none.
115};
116
117/// Returns a map containing the `amdhsa.kernels` ELF metadata for each of the
118/// kernels in the binary, or `std::nullopt` if the metadata couldn't be
119/// retrieved. The map associates the name of the kernel with the list of named
120/// attributes found in `amdhsa.kernels`. For more information on the ELF
121/// metadata see: https://llvm.org/docs/AMDGPUUsage.html#amdhsa
122std::optional<DenseMap<StringAttr, NamedAttrList>>
124
125/// Returns a `#gpu.kernel_table` containing kernel metadata for each of the
126/// kernels in `gpuModule`. If `elfData` is valid, then the `amdhsa.kernels` ELF
127/// metadata will be added to the `#gpu.kernel_table`.
128gpu::KernelTableAttr getKernelMetadata(Operation *gpuModule,
129 ArrayRef<char> elfData = {});
130} // namespace ROCDL
131} // namespace mlir
132
133#endif // MLIR_TARGET_LLVM_ROCDL_UTILS_H
This class is a general helper class for creating context-global objects like types,...
Definition Builders.h:51
Utility base class for transforming operations into binary objects, by default it returns the seriali...
Operation & module
Module to transform to a binary object.
Operation is the basic unit of execution within MLIR.
Definition Operation.h:88
ROCDLTargetAttr getTarget() const
Returns the target attribute.
Definition Target.cpp:125
ArrayRef< Attribute > getLibrariesToLink() const
Returns the LLVM bitcode libraries to be linked.
Definition Target.cpp:129
AMDGCNLibraries deviceLibs
AMD GCN libraries to use when linking, the default is using none.
Definition Utils.h:114
ROCDLTargetAttr target
ROCDL target attribute.
Definition Utils.h:105
SerializeGPUModuleBase(Operation &module, ROCDLTargetAttr target, const gpu::TargetOptions &targetOptions={})
Initializes the toolkitPath with the path in targetOptions or if empty with the path in getROCMPath.
Definition Target.cpp:94
std::optional< SmallVector< char, 0 > > moduleToObjectImpl(const gpu::TargetOptions &targetOptions, llvm::Module &llvmModule)
Default implementation of ModuleToObject::moduleToObject.
Definition Target.cpp:403
virtual std::optional< SmallVector< std::unique_ptr< llvm::Module > > > loadBitcodeFiles(llvm::Module &module) override
Loads the bitcode files in fileList.
Definition Target.cpp:177
void addControlVariables(llvm::Module &module, AMDGCNLibraries libs, bool wave64, bool daz, bool finiteOnly, bool unsafeMath, bool fastMath, bool correctSqrt, StringRef abiVer)
Adds oclc control variables to the LLVM Module if needed.
Definition Target.cpp:228
std::optional< SmallVector< char, 0 > > assembleIsa(StringRef isa)
Returns the assembled ISA.
Definition Target.cpp:281
std::string toolkitPath
ROCM toolkit path.
Definition Utils.h:108
SmallVector< Attribute > librariesToLink
List of LLVM bitcode files to link to.
Definition Utils.h:111
static void init()
Initializes the LLVM AMDGPU target by safely calling LLVMInitializeAMDGPU* methods if available.
Definition Target.cpp:111
StringRef getToolkitPath() const
Returns the ROCM toolkit path.
Definition Target.cpp:127
LogicalResult appendStandardLibs(AMDGCNLibraries libs)
Appends standard ROCm device libraries to fileList.
Definition Target.cpp:133
LogicalResult handleBitcodeFile(llvm::Module &module) override
Removes unnecessary metadata from the loaded bitcode files.
Definition Target.cpp:190
virtual std::optional< SmallVector< char, 0 > > compileToBinary(const std::string &serializedISA)
Compiles assembly to a binary.
Definition Target.cpp:344
void handleModulePreLink(llvm::Module &module) override
Determines required Device Libraries and adds oclc control variables to the LLVM Module if needed.
Definition Target.cpp:203
This class serves as an opaque interface for passing options to the TargetAttrInterface methods.
AMDGCNLibraries
Helper enum for specifying the AMD GCN device libraries required for compilation.
Definition Utils.h:35
std::optional< DenseMap< StringAttr, NamedAttrList > > getAMDHSAKernelsELFMetadata(Builder &builder, ArrayRef< char > elfData)
Returns a map containing the amdhsa.kernels ELF metadata for each of the kernels in the binary,...
Definition Utils.cpp:23
gpu::KernelTableAttr getKernelMetadata(Operation *gpuModule, ArrayRef< char > elfData={})
Returns a #gpu.kernel_table containing kernel metadata for each of the kernels in gpuModule.
Definition Utils.cpp:70
StringRef getROCMPath()
Searches & returns the path ROCM toolkit path, the search order is:
Definition Target.cpp:84
Include the generated interface declarations.