clang 23.0.0git
NVPTX.h
Go to the documentation of this file.
1//===--- NVPTX.h - Declare NVPTX target feature support ---------*- 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 declares NVPTX TargetInfo objects.
10//
11//===----------------------------------------------------------------------===//
12
13#ifndef LLVM_CLANG_LIB_BASIC_TARGETS_NVPTX_H
14#define LLVM_CLANG_LIB_BASIC_TARGETS_NVPTX_H
15
16#include "clang/Basic/Cuda.h"
19#include "llvm/Support/Compiler.h"
20#include "llvm/Support/NVPTXAddrSpace.h"
21#include "llvm/TargetParser/Triple.h"
22#include <optional>
23
24namespace clang {
25namespace targets {
26
27static const unsigned NVPTXAddrSpaceMap[] = {
28 0, // Default
29 1, // opencl_global
30 3, // opencl_local
31 4, // opencl_constant
32 0, // opencl_private
33 // FIXME: generic has to be added to the target
34 0, // opencl_generic
35 1, // opencl_global_device
36 1, // opencl_global_host
37 1, // cuda_device
38 4, // cuda_constant
39 3, // cuda_shared
40 1, // sycl_global
41 1, // sycl_global_device
42 1, // sycl_global_host
43 3, // sycl_local
44 0, // sycl_private
45 0, // ptr32_sptr
46 0, // ptr32_uptr
47 0, // ptr64
48 0, // hlsl_groupshared
49 0, // hlsl_constant
50 0, // hlsl_private
51 0, // hlsl_device
52 0, // hlsl_input
53 0, // hlsl_push_constant
54 // Wasm address space values for this target are dummy values,
55 // as it is only enabled for Wasm targets.
56 20, // wasm_funcref
57};
58
59/// The DWARF address class. Taken from
60/// https://docs.nvidia.com/cuda/archive/10.0/ptx-writers-guide-to-interoperability/index.html#cuda-specific-dwarf
61static const int NVPTXDWARFAddrSpaceMap[] = {
62 -1, // Default, opencl_private or opencl_generic - not defined
63 5, // opencl_global
64 -1,
65 8, // opencl_local or cuda_shared
66 4, // opencl_constant or cuda_constant
67};
68
69class LLVM_LIBRARY_VISIBILITY NVPTXTargetInfo : public TargetInfo {
70 static const char *const GCCRegNames[];
71 OffloadArch GPU;
72 uint32_t PTXVersion;
73 std::unique_ptr<TargetInfo> HostTarget;
74
75public:
76 NVPTXTargetInfo(const llvm::Triple &Triple, const TargetOptions &Opts,
77 unsigned TargetPointerWidth);
78
79 void getTargetDefines(const LangOptions &Opts,
80 MacroBuilder &Builder) const override;
81
83
84 bool useFP16ConversionIntrinsics() const override { return false; }
85
86 bool
87 initFeatureMap(llvm::StringMap<bool> &Features, DiagnosticsEngine &Diags,
88 StringRef CPU,
89 const std::vector<std::string> &FeaturesVec) const override {
90 if (GPU != OffloadArch::UNUSED)
91 Features[OffloadArchToString(GPU)] = true;
92 // Only add PTX feature if explicitly requested. Otherwise, let the backend
93 // use the minimum required PTX version for the target SM.
94 if (PTXVersion != 0)
95 Features["ptx" + std::to_string(PTXVersion)] = true;
96 return TargetInfo::initFeatureMap(Features, Diags, CPU, FeaturesVec);
97 }
98
99 bool hasFeature(StringRef Feature) const override;
100
101 virtual bool isAddressSpaceSupersetOf(LangAS A, LangAS B) const override {
102 // The generic address space AS(0) is a superset of all the other address
103 // spaces used by the backend target.
104 return A == B ||
105 ((A == LangAS::Default ||
108 llvm::NVPTXAS::ADDRESS_SPACE_GENERIC)) &&
110 toTargetAddressSpace(B) >= llvm::NVPTXAS::ADDRESS_SPACE_GENERIC &&
111 toTargetAddressSpace(B) <= llvm::NVPTXAS::ADDRESS_SPACE_LOCAL &&
112 toTargetAddressSpace(B) != 2);
113 }
114
115 ArrayRef<const char *> getGCCRegNames() const override;
116
118 // No aliases.
119 return {};
120 }
121
122 bool validateAsmConstraint(const char *&Name,
123 TargetInfo::ConstraintInfo &Info) const override {
124 switch (*Name) {
125 default:
126 return false;
127 case 'c':
128 case 'h':
129 case 'r':
130 case 'l':
131 case 'f':
132 case 'd':
133 case 'q':
134 Info.setAllowsRegister();
135 return true;
136 }
137 }
138
139 std::string_view getClobbers() const override {
140 // FIXME: Is this really right?
141 return "";
142 }
143
147
148 bool isValidCPUName(StringRef Name) const override {
150 }
151
152 void fillValidCPUList(SmallVectorImpl<StringRef> &Values) const override {
153 for (int i = static_cast<int>(OffloadArch::SM_20);
154 i < static_cast<int>(OffloadArch::Generic); ++i)
155 Values.emplace_back(OffloadArchToString(static_cast<OffloadArch>(i)));
156 }
157
158 bool setCPU(const std::string &Name) override {
159 GPU = StringToOffloadArch(Name);
160 return GPU != OffloadArch::UNKNOWN;
161 }
162
163 void setSupportedOpenCLOpts() override {
164 auto &Opts = getSupportedOpenCLOpts();
165 Opts["cl_clang_storage_class_specifiers"] = true;
166 Opts["__cl_clang_function_pointers"] = true;
167 Opts["__cl_clang_variadic_functions"] = true;
168 Opts["__cl_clang_function_scope_local_variables"] = true;
169 Opts["__cl_clang_non_portable_kernel_param_types"] = true;
170 Opts["__cl_clang_bitfields"] = true;
171
172 Opts["cl_khr_fp64"] = true;
173 Opts["__opencl_c_fp64"] = true;
174 Opts["cl_khr_byte_addressable_store"] = true;
175 Opts["cl_khr_global_int32_base_atomics"] = true;
176 Opts["cl_khr_global_int32_extended_atomics"] = true;
177 Opts["cl_khr_local_int32_base_atomics"] = true;
178 Opts["cl_khr_local_int32_extended_atomics"] = true;
179
180 Opts["__opencl_c_generic_address_space"] = true;
181 }
182
183 const llvm::omp::GV &getGridValue() const override {
184 return llvm::omp::NVPTXGridValues;
185 }
186
187 /// \returns If a target requires an address within a target specific address
188 /// space \p AddressSpace to be converted in order to be used, then return the
189 /// corresponding target specific DWARF address space.
190 ///
191 /// \returns Otherwise return std::nullopt and no conversion will be emitted
192 /// in the DWARF.
193 std::optional<unsigned>
194 getDWARFAddressSpace(unsigned AddressSpace) const override {
195 if (AddressSpace >= std::size(NVPTXDWARFAddrSpaceMap) ||
196 NVPTXDWARFAddrSpaceMap[AddressSpace] < 0)
197 return std::nullopt;
198 return NVPTXDWARFAddrSpaceMap[AddressSpace];
199 }
200
202 // CUDA compilations support all of the host's calling conventions.
203 //
204 // TODO: We should warn if you apply a non-default CC to anything other than
205 // a host function.
206 if (HostTarget)
207 return HostTarget->checkCallingConvention(CC);
208 return CC == CC_DeviceKernel ? CCCR_OK : CCCR_Warning;
209 }
210
211 bool hasBitIntType() const override { return true; }
212 bool hasBFloat16Type() const override { return true; }
213
214 OffloadArch getGPU() const { return GPU; }
215};
216} // namespace targets
217} // namespace clang
218#endif // LLVM_CLANG_LIB_BASIC_TARGETS_NVPTX_H
static bool hasFeature(StringRef Feature, const LangOptions &LangOpts, const TargetInfo &Target)
Determine whether a translation unit built using the current language options has the given feature.
Definition Module.cpp:95
Defines the clang::TargetOptions class.
Concrete class used by the front-end to report problems and issues.
Definition Diagnostic.h:232
Keeps track of the various options that can be enabled, which controls the dialect of C or C++ that i...
TargetInfo(const llvm::Triple &T)
BuiltinVaListKind
The different kinds of __builtin_va_list types defined by the target implementation.
Definition TargetInfo.h:333
@ CharPtrBuiltinVaList
typedef char* __builtin_va_list;
Definition TargetInfo.h:335
llvm::StringMap< bool > & getSupportedOpenCLOpts()
Get supported OpenCL extensions and optional core features.
virtual bool initFeatureMap(llvm::StringMap< bool > &Features, DiagnosticsEngine &Diags, StringRef CPU, const std::vector< std::string > &FeatureVec) const
Initialize the map with the default set of target features for the CPU this should include all legal ...
Options for controlling the target.
bool hasBitIntType() const override
Determine whether the _BitInt type is supported on this target.
Definition NVPTX.h:211
BuiltinVaListKind getBuiltinVaListKind() const override
Returns the kind of __builtin_va_list type that should be used with this target.
Definition NVPTX.h:144
OffloadArch getGPU() const
Definition NVPTX.h:214
virtual bool isAddressSpaceSupersetOf(LangAS A, LangAS B) const override
Returns true if an address space can be safely converted to another.
Definition NVPTX.h:101
NVPTXTargetInfo(const llvm::Triple &Triple, const TargetOptions &Opts, unsigned TargetPointerWidth)
Definition NVPTX.cpp:38
void getTargetDefines(const LangOptions &Opts, MacroBuilder &Builder) const override
===-— Other target property query methods -----------------------—===//
Definition NVPTX.cpp:173
ArrayRef< TargetInfo::GCCRegAlias > getGCCRegAliases() const override
Definition NVPTX.h:117
void fillValidCPUList(SmallVectorImpl< StringRef > &Values) const override
Fill a SmallVectorImpl with the valid values to setCPU.
Definition NVPTX.h:152
bool validateAsmConstraint(const char *&Name, TargetInfo::ConstraintInfo &Info) const override
Definition NVPTX.h:122
bool hasBFloat16Type() const override
Determine whether the _BFloat16 type is supported on this target.
Definition NVPTX.h:212
std::string_view getClobbers() const override
Returns a string of target-specific clobbers, in LLVM format.
Definition NVPTX.h:139
llvm::SmallVector< Builtin::InfosShard > getTargetBuiltins() const override
Return information about target-specific builtins for the current primary target, and info about whic...
Definition NVPTX.cpp:194
std::optional< unsigned > getDWARFAddressSpace(unsigned AddressSpace) const override
Definition NVPTX.h:194
const llvm::omp::GV & getGridValue() const override
Definition NVPTX.h:183
bool setCPU(const std::string &Name) override
Target the specified CPU.
Definition NVPTX.h:158
CallingConvCheckResult checkCallingConvention(CallingConv CC) const override
Determines whether a given calling convention is valid for the target.
Definition NVPTX.h:201
bool isValidCPUName(StringRef Name) const override
Determine whether this TargetInfo supports the given CPU name.
Definition NVPTX.h:148
bool useFP16ConversionIntrinsics() const override
Check whether conversions to and from __fp16 should go through an integer bitcast with i16.
Definition NVPTX.h:84
bool initFeatureMap(llvm::StringMap< bool > &Features, DiagnosticsEngine &Diags, StringRef CPU, const std::vector< std::string > &FeaturesVec) const override
Initialize the map with the default set of target features for the CPU this should include all legal ...
Definition NVPTX.h:87
void setSupportedOpenCLOpts() override
Set supported OpenCL extensions and optional core features.
Definition NVPTX.h:163
Defines the clang::TargetInfo interface.
static const unsigned NVPTXAddrSpaceMap[]
Definition NVPTX.h:27
static const int NVPTXDWARFAddrSpaceMap[]
The DWARF address class.
Definition NVPTX.h:61
The JSON file list parser is used to communicate input to InstallAPI.
bool isTargetAddressSpace(LangAS AS)
unsigned toTargetAddressSpace(LangAS AS)
OffloadArch StringToOffloadArch(llvm::StringRef S)
LangAS
Defines the address space values used by the address space qualifier of QualType.
const char * OffloadArchToString(OffloadArch A)
CallingConv
CallingConv - Specifies the calling convention that a function uses.
Definition Specifiers.h:278
@ CC_DeviceKernel
Definition Specifiers.h:292