clang 23.0.0git
AMDGPU.h
Go to the documentation of this file.
1//===--- AMDGPU.h - AMDGPU ToolChain Implementations ----------*- 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#ifndef LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_AMDGPU_H
10#define LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_AMDGPU_H
11
12#include "Gnu.h"
14#include "clang/Driver/Tool.h"
17#include "llvm/ADT/SmallString.h"
18#include "llvm/TargetParser/TargetParser.h"
19
20#include <map>
21
22namespace clang {
23namespace driver {
24
25namespace tools {
26namespace amdgpu {
27
28class LLVM_LIBRARY_VISIBILITY Linker final : public Tool {
29public:
30 Linker(const ToolChain &TC) : Tool("amdgpu::Linker", "ld.lld", TC) {}
31 bool isLinkJob() const override { return true; }
32 bool hasIntegratedCPP() const override { return false; }
33 void ConstructJob(Compilation &C, const JobAction &JA,
34 const InputInfo &Output, const InputInfoList &Inputs,
35 const llvm::opt::ArgList &TCArgs,
36 const char *LinkingOutput) const override;
37};
38
39void getAMDGPUTargetFeatures(const Driver &D, const llvm::Triple &Triple,
40 const llvm::opt::ArgList &Args,
41 std::vector<StringRef> &Features);
42
43void addFullLTOPartitionOption(const Driver &D, const llvm::opt::ArgList &Args,
44 llvm::opt::ArgStringList &CmdArgs);
45} // end namespace amdgpu
46} // end namespace tools
47
48namespace toolchains {
49
50class LLVM_LIBRARY_VISIBILITY AMDGPUToolChain : public Generic_ELF {
51protected:
52 const std::map<options::ID, const StringRef> OptionsDefault;
53
54 Tool *buildLinker() const override;
55 StringRef getOptionDefault(options::ID OptID) const {
56 auto opt = OptionsDefault.find(OptID);
57 assert(opt != OptionsDefault.end() && "No Default for Option");
58 return opt->second;
59 }
60
61public:
62 AMDGPUToolChain(const Driver &D, const llvm::Triple &Triple,
63 const llvm::opt::ArgList &Args);
64 unsigned GetDefaultDwarfVersion() const override { return 5; }
65
66 bool IsMathErrnoDefault() const override { return false; }
67 bool isCrossCompiling() const override { return true; }
68 bool isPICDefault() const override { return true; }
69 bool isPIEDefault(const llvm::opt::ArgList &Args) const override {
70 return false;
71 }
72 bool isPICDefaultForced() const override { return true; }
73 bool SupportsProfiling() const override { return false; }
74
75 llvm::opt::DerivedArgList *
76 TranslateArgs(const llvm::opt::DerivedArgList &Args, StringRef BoundArch,
77 Action::OffloadKind DeviceOffloadKind) const override;
78
79 void addClangTargetOptions(const llvm::opt::ArgList &DriverArgs,
80 llvm::opt::ArgStringList &CC1Args,
81 Action::OffloadKind DeviceOffloadKind) const override;
82 void
83 AddClangSystemIncludeArgs(const llvm::opt::ArgList &DriverArgs,
84 llvm::opt::ArgStringList &CC1Args) const override;
85
86 /// Return whether denormals should be flushed, and treated as 0 by default
87 /// for the subtarget.
88 static bool getDefaultDenormsAreZeroForTarget(llvm::AMDGPU::GPUKind GPUKind);
89
90 llvm::DenormalMode getDefaultDenormalModeForType(
91 const llvm::opt::ArgList &DriverArgs, const JobAction &JA,
92 const llvm::fltSemantics *FPType = nullptr) const override;
93
94 static bool isWave64(const llvm::opt::ArgList &DriverArgs,
95 llvm::AMDGPU::GPUKind Kind);
96 /// Needed for using lto.
97 bool HasNativeLLVMSupport() const override {
98 return true;
99 }
100
101 /// Needed for translating LTO options.
102 const char *getDefaultLinker() const override { return "ld.lld"; }
103
104 /// Should skip sanitize option.
105 bool shouldSkipSanitizeOption(const ToolChain &TC,
106 const llvm::opt::ArgList &DriverArgs,
107 StringRef TargetID,
108 const llvm::opt::Arg *A) const;
109
110 /// Uses amdgpu-arch tool to get arch of the system GPU. Will return error
111 /// if unable to find one.
113 getSystemGPUArchs(const llvm::opt::ArgList &Args) const override;
114
115protected:
116 /// Check and diagnose invalid target ID specified by -mcpu.
117 virtual void checkTargetID(const llvm::opt::ArgList &DriverArgs) const;
118
119 /// The struct type returned by getParsedTargetID.
121 std::optional<std::string> OptionalTargetID;
122 std::optional<std::string> OptionalGPUArch;
123 std::optional<llvm::StringMap<bool>> OptionalFeatures;
124 };
125
126 /// Get target ID, GPU arch, and target ID features if the target ID is
127 /// specified and valid.
129 getParsedTargetID(const llvm::opt::ArgList &DriverArgs) const;
130
131 /// Get GPU arch from -mcpu without checking.
132 StringRef getGPUArch(const llvm::opt::ArgList &DriverArgs) const;
133
134 /// Common warning options shared by AMDGPU HIP, OpenCL and OpenMP toolchains.
135 /// Language specific warning options should go to derived classes.
136 void addClangWarningOptions(llvm::opt::ArgStringList &CC1Args) const override;
137};
138
139class LLVM_LIBRARY_VISIBILITY ROCMToolChain : public AMDGPUToolChain {
140public:
141 ROCMToolChain(const Driver &D, const llvm::Triple &Triple,
142 const llvm::opt::ArgList &Args);
143 void
144 addClangTargetOptions(const llvm::opt::ArgList &DriverArgs,
145 llvm::opt::ArgStringList &CC1Args,
146 Action::OffloadKind DeviceOffloadKind) const override;
147
148 // Returns a list of device library names shared by different languages
150 getCommonDeviceLibNames(const llvm::opt::ArgList &DriverArgs,
151 const std::string &GPUArch,
152 Action::OffloadKind DeviceOffloadingKind) const;
153
155 return SanitizerKind::Address | SanitizerKind::Undefined |
156 SanitizerKind::UndefinedGroup;
157 }
158
159 bool diagnoseUnsupportedOption(const llvm::opt::Arg *A,
160 const llvm::opt::DerivedArgList &DAL,
161 const llvm::opt::ArgList &DriverArgs,
162 const char *Value = nullptr) const {
163 auto &Diags = getDriver().getDiags();
164 bool IsExplicitDevice =
165 A->getBaseArg().getOption().matches(options::OPT_Xarch_device);
166
167 if (Value) {
168 unsigned DiagID =
169 IsExplicitDevice
170 ? clang::diag::err_drv_unsupported_option_part_for_target
171 : clang::diag::warn_drv_unsupported_option_part_for_target;
172 Diags.Report(DiagID) << Value << A->getAsString(DriverArgs)
173 << getTriple().str();
174 } else {
175 unsigned DiagID =
176 IsExplicitDevice
177 ? clang::diag::err_drv_unsupported_option_for_target
178 : clang::diag::warn_drv_unsupported_option_for_target;
179 Diags.Report(DiagID) << A->getAsString(DAL) << getTriple().str();
180 }
181 return true;
182 }
183
184 bool handleSanitizeOption(const ToolChain &TC, llvm::opt::DerivedArgList &DAL,
185 const llvm::opt::ArgList &DriverArgs,
186 StringRef TargetID, const llvm::opt::Arg *A) const {
187 if (TargetID.empty())
188 return false;
189 // If we shouldn't do sanitizing, skip it.
190 if (!DriverArgs.hasFlag(options::OPT_fgpu_sanitize,
191 options::OPT_fno_gpu_sanitize, true))
192 return true;
193 const llvm::opt::Option &Opt = A->getOption();
194 // Sanitizer coverage is currently not supported for AMDGPU, so warn/error
195 // on every related option.
196 if (Opt.matches(options::OPT_fsan_cov_Group)) {
197 diagnoseUnsupportedOption(A, DAL, DriverArgs);
198 }
199 // If this isn't a sanitizer option, don't handle it.
200 if (!Opt.matches(options::OPT_fsanitize_EQ))
201 return false;
202
203 SmallVector<const char *, 4> SupportedSanitizers;
204 SmallVector<const char *, 4> UnSupportedSanitizers;
205
207 SanitizerMask SupportedMask;
208 for (const char *Value : A->getValues()) {
209 SanitizerMask K = parseSanitizerValue(Value, /*Allow Groups*/ true);
210 if (K & Supported) {
211 SupportedSanitizers.push_back(Value);
212 SupportedMask |= K;
213 } else {
214 UnSupportedSanitizers.push_back(Value);
215 }
216 }
217
218 // If there are no supported sanitizers, drop the whole argument.
219 if (SupportedSanitizers.empty()) {
220 diagnoseUnsupportedOption(A, DAL, DriverArgs);
221 return true;
222 }
223 // If only some sanitizers are unsupported, report each one individually.
224 if (!UnSupportedSanitizers.empty()) {
225 for (const char *Value : UnSupportedSanitizers) {
226 diagnoseUnsupportedOption(A, DAL, DriverArgs, Value);
227 }
228 }
229 // The xnack+ feature is only required for ASan on AMDGPU.
230 if ((SupportedMask & SanitizerKind::Address) &&
231 shouldSkipSanitizeOption(TC, DriverArgs, TargetID, A))
232 return true;
233
234 // Add a new argument with only the supported sanitizers.
235 DAL.AddJoinedArg(A, A->getOption(), llvm::join(SupportedSanitizers, ","));
236 return true;
237 }
238};
239
240} // end namespace toolchains
241} // end namespace driver
242} // end namespace clang
243
244#endif // LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_AMDGPU_H
static StringRef getTriple(const Command &Job)
Compilation - A set of tasks to perform for a single driver invocation.
Definition Compilation.h:45
Driver - Encapsulate logic for constructing compilation processes from a set of gcc-driver-like comma...
Definition Driver.h:99
InputInfo - Wrapper for information about an input source.
Definition InputInfo.h:22
ToolChain - Access to tools for a single platform.
Definition ToolChain.h:92
const Driver & getDriver() const
Definition ToolChain.h:277
Tool - Information on a specific compilation tool.
Definition Tool.h:32
Tool(const char *Name, const char *ShortName, const ToolChain &TC)
Definition Tool.cpp:14
bool isPIEDefault(const llvm::opt::ArgList &Args) const override
Test whether this toolchain defaults to PIE.
Definition AMDGPU.h:69
bool isPICDefault() const override
Test whether this toolchain defaults to PIC.
Definition AMDGPU.h:68
StringRef getGPUArch(const llvm::opt::ArgList &DriverArgs) const
Get GPU arch from -mcpu without checking.
Definition AMDGPU.cpp:904
bool SupportsProfiling() const override
SupportsProfiling - Does this tool chain support -pg.
Definition AMDGPU.h:73
bool shouldSkipSanitizeOption(const ToolChain &TC, const llvm::opt::ArgList &DriverArgs, StringRef TargetID, const llvm::opt::Arg *A) const
Should skip sanitize option.
Definition AMDGPU.cpp:1095
bool HasNativeLLVMSupport() const override
Needed for using lto.
Definition AMDGPU.h:97
bool IsMathErrnoDefault() const override
IsMathErrnoDefault - Does this tool chain use -fmath-errno by default.
Definition AMDGPU.h:66
Tool * buildLinker() const override
Definition AMDGPU.cpp:713
unsigned GetDefaultDwarfVersion() const override
Definition AMDGPU.h:64
void addClangWarningOptions(llvm::opt::ArgStringList &CC1Args) const override
Common warning options shared by AMDGPU HIP, OpenCL and OpenMP toolchains.
Definition AMDGPU.cpp:875
AMDGPUToolChain(const Driver &D, const llvm::Triple &Triple, const llvm::opt::ArgList &Args)
AMDGPU Toolchain.
Definition AMDGPU.cpp:699
ParsedTargetIDType getParsedTargetID(const llvm::opt::ArgList &DriverArgs) const
Get target ID, GPU arch, and target ID features if the target ID is specified and valid.
Definition AMDGPU.cpp:910
const std::map< options::ID, const StringRef > OptionsDefault
Definition AMDGPU.h:52
bool isPICDefaultForced() const override
Tests whether this toolchain forces its default for PIC, PIE or non-PIC.
Definition AMDGPU.h:72
const char * getDefaultLinker() const override
Needed for translating LTO options.
Definition AMDGPU.h:102
StringRef getOptionDefault(options::ID OptID) const
Definition AMDGPU.h:55
bool isCrossCompiling() const override
Returns true if the toolchain is targeting a non-native architecture.
Definition AMDGPU.h:67
Generic_ELF(const Driver &D, const llvm::Triple &Triple, const llvm::opt::ArgList &Args)
Definition Gnu.h:439
void addClangTargetOptions(const llvm::opt::ArgList &DriverArgs, llvm::opt::ArgStringList &CC1Args, Action::OffloadKind DeviceOffloadKind) const override
Add options that need to be passed to cc1 for this target.
Definition AMDGPU.cpp:957
bool handleSanitizeOption(const ToolChain &TC, llvm::opt::DerivedArgList &DAL, const llvm::opt::ArgList &DriverArgs, StringRef TargetID, const llvm::opt::Arg *A) const
Definition AMDGPU.h:184
llvm::SmallVector< BitCodeLibraryInfo, 12 > getCommonDeviceLibNames(const llvm::opt::ArgList &DriverArgs, const std::string &GPUArch, Action::OffloadKind DeviceOffloadingKind) const
Definition AMDGPU.cpp:1077
SanitizerMask getSupportedSanitizers() const override
Return sanitizers which are available in this toolchain.
Definition AMDGPU.h:154
ROCMToolChain(const Driver &D, const llvm::Triple &Triple, const llvm::opt::ArgList &Args)
ROCM Toolchain.
Definition AMDGPU.cpp:836
bool diagnoseUnsupportedOption(const llvm::opt::Arg *A, const llvm::opt::DerivedArgList &DAL, const llvm::opt::ArgList &DriverArgs, const char *Value=nullptr) const
Definition AMDGPU.h:159
Linker(const ToolChain &TC)
Definition AMDGPU.h:30
bool hasIntegratedCPP() const override
Definition AMDGPU.h:32
bool isLinkJob() const override
Definition AMDGPU.h:31
void getAMDGPUTargetFeatures(const Driver &D, const llvm::Triple &Triple, const llvm::opt::ArgList &Args, std::vector< StringRef > &Features)
Definition AMDGPU.cpp:656
void addFullLTOPartitionOption(const Driver &D, const llvm::opt::ArgList &Args, llvm::opt::ArgStringList &CmdArgs)
SmallVector< InputInfo, 4 > InputInfoList
Definition Driver.h:50
The JSON file list parser is used to communicate input to InstallAPI.
SanitizerMask parseSanitizerValue(StringRef Value, bool AllowGroups)
Parse a single value from a -fsanitize= or -fno-sanitize= value list.
The struct type returned by getParsedTargetID.
Definition AMDGPU.h:120
std::optional< llvm::StringMap< bool > > OptionalFeatures
Definition AMDGPU.h:123