clang 22.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 // Wasm address space values for this target are dummy values,
54 // as it is only enabled for Wasm targets.
55 20, // wasm_funcref
56};
57
58/// The DWARF address class. Taken from
59/// https://docs.nvidia.com/cuda/archive/10.0/ptx-writers-guide-to-interoperability/index.html#cuda-specific-dwarf
60static const int NVPTXDWARFAddrSpaceMap[] = {
61 -1, // Default, opencl_private or opencl_generic - not defined
62 5, // opencl_global
63 -1,
64 8, // opencl_local or cuda_shared
65 4, // opencl_constant or cuda_constant
66};
67
68class LLVM_LIBRARY_VISIBILITY NVPTXTargetInfo : public TargetInfo {
69 static const char *const GCCRegNames[];
70 OffloadArch GPU;
71 uint32_t PTXVersion;
72 std::unique_ptr<TargetInfo> HostTarget;
73
74public:
75 NVPTXTargetInfo(const llvm::Triple &Triple, const TargetOptions &Opts,
76 unsigned TargetPointerWidth);
77
78 void getTargetDefines(const LangOptions &Opts,
79 MacroBuilder &Builder) const override;
80
82
83 bool useFP16ConversionIntrinsics() const override { return false; }
84
85 bool
86 initFeatureMap(llvm::StringMap<bool> &Features, DiagnosticsEngine &Diags,
87 StringRef CPU,
88 const std::vector<std::string> &FeaturesVec) const override {
89 if (GPU != OffloadArch::UNUSED)
90 Features[OffloadArchToString(GPU)] = true;
91 Features["ptx" + std::to_string(PTXVersion)] = true;
92 return TargetInfo::initFeatureMap(Features, Diags, CPU, FeaturesVec);
93 }
94
95 bool hasFeature(StringRef Feature) const override;
96
97 virtual bool isAddressSpaceSupersetOf(LangAS A, LangAS B) const override {
98 // The generic address space AS(0) is a superset of all the other address
99 // spaces used by the backend target.
100 return A == B ||
101 ((A == LangAS::Default ||
104 llvm::NVPTXAS::ADDRESS_SPACE_GENERIC)) &&
106 toTargetAddressSpace(B) >= llvm::NVPTXAS::ADDRESS_SPACE_GENERIC &&
107 toTargetAddressSpace(B) <= llvm::NVPTXAS::ADDRESS_SPACE_LOCAL &&
108 toTargetAddressSpace(B) != 2);
109 }
110
111 ArrayRef<const char *> getGCCRegNames() const override;
112
114 // No aliases.
115 return {};
116 }
117
118 bool validateAsmConstraint(const char *&Name,
119 TargetInfo::ConstraintInfo &Info) const override {
120 switch (*Name) {
121 default:
122 return false;
123 case 'c':
124 case 'h':
125 case 'r':
126 case 'l':
127 case 'f':
128 case 'd':
129 case 'q':
130 Info.setAllowsRegister();
131 return true;
132 }
133 }
134
135 std::string_view getClobbers() const override {
136 // FIXME: Is this really right?
137 return "";
138 }
139
143
144 bool isValidCPUName(StringRef Name) const override {
146 }
147
148 void fillValidCPUList(SmallVectorImpl<StringRef> &Values) const override {
149 for (int i = static_cast<int>(OffloadArch::SM_20);
150 i < static_cast<int>(OffloadArch::Generic); ++i)
151 Values.emplace_back(OffloadArchToString(static_cast<OffloadArch>(i)));
152 }
153
154 bool setCPU(const std::string &Name) override {
155 GPU = StringToOffloadArch(Name);
156 return GPU != OffloadArch::UNKNOWN;
157 }
158
159 void setSupportedOpenCLOpts() override {
160 auto &Opts = getSupportedOpenCLOpts();
161 Opts["cl_clang_storage_class_specifiers"] = true;
162 Opts["__cl_clang_function_pointers"] = true;
163 Opts["__cl_clang_variadic_functions"] = true;
164 Opts["__cl_clang_non_portable_kernel_param_types"] = true;
165 Opts["__cl_clang_bitfields"] = true;
166
167 Opts["cl_khr_fp64"] = true;
168 Opts["__opencl_c_fp64"] = true;
169 Opts["cl_khr_byte_addressable_store"] = true;
170 Opts["cl_khr_global_int32_base_atomics"] = true;
171 Opts["cl_khr_global_int32_extended_atomics"] = true;
172 Opts["cl_khr_local_int32_base_atomics"] = true;
173 Opts["cl_khr_local_int32_extended_atomics"] = true;
174
175 Opts["__opencl_c_generic_address_space"] = true;
176 }
177
178 const llvm::omp::GV &getGridValue() const override {
179 return llvm::omp::NVPTXGridValues;
180 }
181
182 /// \returns If a target requires an address within a target specific address
183 /// space \p AddressSpace to be converted in order to be used, then return the
184 /// corresponding target specific DWARF address space.
185 ///
186 /// \returns Otherwise return std::nullopt and no conversion will be emitted
187 /// in the DWARF.
188 std::optional<unsigned>
189 getDWARFAddressSpace(unsigned AddressSpace) const override {
190 if (AddressSpace >= std::size(NVPTXDWARFAddrSpaceMap) ||
191 NVPTXDWARFAddrSpaceMap[AddressSpace] < 0)
192 return std::nullopt;
193 return NVPTXDWARFAddrSpaceMap[AddressSpace];
194 }
195
197 // CUDA compilations support all of the host's calling conventions.
198 //
199 // TODO: We should warn if you apply a non-default CC to anything other than
200 // a host function.
201 if (HostTarget)
202 return HostTarget->checkCallingConvention(CC);
203 return CCCR_Warning;
204 }
205
206 bool hasBitIntType() const override { return true; }
207 bool hasBFloat16Type() const override { return true; }
208
209 OffloadArch getGPU() const { return GPU; }
210};
211} // namespace targets
212} // namespace clang
213#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:231
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:330
@ CharPtrBuiltinVaList
typedef char* __builtin_va_list;
Definition TargetInfo.h:332
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:206
BuiltinVaListKind getBuiltinVaListKind() const override
Returns the kind of __builtin_va_list type that should be used with this target.
Definition NVPTX.h:140
OffloadArch getGPU() const
Definition NVPTX.h:209
virtual bool isAddressSpaceSupersetOf(LangAS A, LangAS B) const override
Returns true if an address space can be safely converted to another.
Definition NVPTX.h:97
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:178
ArrayRef< TargetInfo::GCCRegAlias > getGCCRegAliases() const override
Definition NVPTX.h:113
void fillValidCPUList(SmallVectorImpl< StringRef > &Values) const override
Fill a SmallVectorImpl with the valid values to setCPU.
Definition NVPTX.h:148
bool validateAsmConstraint(const char *&Name, TargetInfo::ConstraintInfo &Info) const override
Definition NVPTX.h:118
bool hasBFloat16Type() const override
Determine whether the _BFloat16 type is supported on this target.
Definition NVPTX.h:207
std::string_view getClobbers() const override
Returns a string of target-specific clobbers, in LLVM format.
Definition NVPTX.h:135
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:331
std::optional< unsigned > getDWARFAddressSpace(unsigned AddressSpace) const override
Definition NVPTX.h:189
const llvm::omp::GV & getGridValue() const override
Definition NVPTX.h:178
bool setCPU(const std::string &Name) override
Target the specified CPU.
Definition NVPTX.h:154
CallingConvCheckResult checkCallingConvention(CallingConv CC) const override
Determines whether a given calling convention is valid for the target.
Definition NVPTX.h:196
bool isValidCPUName(StringRef Name) const override
Determine whether this TargetInfo supports the given CPU name.
Definition NVPTX.h:144
bool useFP16ConversionIntrinsics() const override
Check whether llvm intrinsics such as llvm.convert.to.fp16 should be used to convert to and from __fp...
Definition NVPTX.h:83
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:86
void setSupportedOpenCLOpts() override
Set supported OpenCL extensions and optional core features.
Definition NVPTX.h:159
Defines the clang::TargetInfo interface.
static const unsigned NVPTXAddrSpaceMap[]
Definition NVPTX.h:27
static const int NVPTXDWARFAddrSpaceMap[]
The DWARF address class.
Definition NVPTX.h:60
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