clang 17.0.0git
Cuda.cpp
Go to the documentation of this file.
1#include "clang/Basic/Cuda.h"
2
3#include "llvm/ADT/StringRef.h"
4#include "llvm/ADT/Twine.h"
5#include "llvm/Support/ErrorHandling.h"
6#include "llvm/Support/VersionTuple.h"
7
8namespace clang {
9
11 const char *Name;
13 llvm::VersionTuple TVersion;
14};
15#define CUDA_ENTRY(major, minor) \
16 { \
17#major "." #minor, CudaVersion::CUDA_##major##minor, \
18 llvm::VersionTuple(major, minor) \
19 }
20
22 CUDA_ENTRY(7, 0),
23 CUDA_ENTRY(7, 5),
24 CUDA_ENTRY(8, 0),
25 CUDA_ENTRY(9, 0),
26 CUDA_ENTRY(9, 1),
27 CUDA_ENTRY(9, 2),
28 CUDA_ENTRY(10, 0),
29 CUDA_ENTRY(10, 1),
30 CUDA_ENTRY(10, 2),
31 CUDA_ENTRY(11, 0),
32 CUDA_ENTRY(11, 1),
33 CUDA_ENTRY(11, 2),
34 CUDA_ENTRY(11, 3),
35 CUDA_ENTRY(11, 4),
36 CUDA_ENTRY(11, 5),
37 CUDA_ENTRY(11, 6),
38 CUDA_ENTRY(11, 7),
39 CUDA_ENTRY(11, 8),
40 {"", CudaVersion::NEW, llvm::VersionTuple(std::numeric_limits<int>::max())},
41 {"unknown", CudaVersion::UNKNOWN, {}} // End of list tombstone.
42};
43#undef CUDA_ENTRY
44
46 for (auto *I = CudaNameVersionMap; I->Version != CudaVersion::UNKNOWN; ++I)
47 if (I->Version == V)
48 return I->Name;
49
51}
52
53CudaVersion CudaStringToVersion(const llvm::Twine &S) {
54 std::string VS = S.str();
55 for (auto *I = CudaNameVersionMap; I->Version != CudaVersion::UNKNOWN; ++I)
56 if (I->Name == VS)
57 return I->Version;
59}
60
61CudaVersion ToCudaVersion(llvm::VersionTuple Version) {
62 for (auto *I = CudaNameVersionMap; I->Version != CudaVersion::UNKNOWN; ++I)
63 if (I->TVersion == Version)
64 return I->Version;
66}
67
68namespace {
69struct CudaArchToStringMap {
71 const char *arch_name;
72 const char *virtual_arch_name;
73};
74} // namespace
75
76#define SM2(sm, ca) \
77 { CudaArch::SM_##sm, "sm_" #sm, ca }
78#define SM(sm) SM2(sm, "compute_" #sm)
79#define GFX(gpu) \
80 { CudaArch::GFX##gpu, "gfx" #gpu, "compute_amdgcn" }
81static const CudaArchToStringMap arch_names[] = {
82 // clang-format off
83 {CudaArch::UNUSED, "", ""},
84 SM2(20, "compute_20"), SM2(21, "compute_20"), // Fermi
85 SM(30), SM(32), SM(35), SM(37), // Kepler
86 SM(50), SM(52), SM(53), // Maxwell
87 SM(60), SM(61), SM(62), // Pascal
88 SM(70), SM(72), // Volta
89 SM(75), // Turing
90 SM(80), SM(86), // Ampere
91 SM(87), // Jetson/Drive AGX Orin
92 SM(89), // Ada Lovelace
93 SM(90), // Hopper
94 GFX(600), // gfx600
95 GFX(601), // gfx601
96 GFX(602), // gfx602
97 GFX(700), // gfx700
98 GFX(701), // gfx701
99 GFX(702), // gfx702
100 GFX(703), // gfx703
101 GFX(704), // gfx704
102 GFX(705), // gfx705
103 GFX(801), // gfx801
104 GFX(802), // gfx802
105 GFX(803), // gfx803
106 GFX(805), // gfx805
107 GFX(810), // gfx810
108 GFX(900), // gfx900
109 GFX(902), // gfx902
110 GFX(904), // gfx903
111 GFX(906), // gfx906
112 GFX(908), // gfx908
113 GFX(909), // gfx909
114 GFX(90a), // gfx90a
115 GFX(90c), // gfx90c
116 GFX(940), // gfx940
117 GFX(1010), // gfx1010
118 GFX(1011), // gfx1011
119 GFX(1012), // gfx1012
120 GFX(1013), // gfx1013
121 GFX(1030), // gfx1030
122 GFX(1031), // gfx1031
123 GFX(1032), // gfx1032
124 GFX(1033), // gfx1033
125 GFX(1034), // gfx1034
126 GFX(1035), // gfx1035
127 GFX(1036), // gfx1036
128 GFX(1100), // gfx1100
129 GFX(1101), // gfx1101
130 GFX(1102), // gfx1102
131 GFX(1103), // gfx1103
132 {CudaArch::Generic, "generic", ""},
133 // clang-format on
134};
135#undef SM
136#undef SM2
137#undef GFX
138
140 auto result = std::find_if(
141 std::begin(arch_names), std::end(arch_names),
142 [A](const CudaArchToStringMap &map) { return A == map.arch; });
143 if (result == std::end(arch_names))
144 return "unknown";
145 return result->arch_name;
146}
147
149 auto result = std::find_if(
150 std::begin(arch_names), std::end(arch_names),
151 [A](const CudaArchToStringMap &map) { return A == map.arch; });
152 if (result == std::end(arch_names))
153 return "unknown";
154 return result->virtual_arch_name;
155}
156
157CudaArch StringToCudaArch(llvm::StringRef S) {
158 auto result = std::find_if(
159 std::begin(arch_names), std::end(arch_names),
160 [S](const CudaArchToStringMap &map) { return S == map.arch_name; });
161 if (result == std::end(arch_names))
162 return CudaArch::UNKNOWN;
163 return result->arch;
164}
165
167 if (A == CudaArch::UNKNOWN)
169
170 // AMD GPUs do not depend on CUDA versions.
171 if (IsAMDGpuArch(A))
173
174 switch (A) {
175 case CudaArch::SM_20:
176 case CudaArch::SM_21:
177 case CudaArch::SM_30:
178 case CudaArch::SM_32:
179 case CudaArch::SM_35:
180 case CudaArch::SM_37:
181 case CudaArch::SM_50:
182 case CudaArch::SM_52:
183 case CudaArch::SM_53:
185 case CudaArch::SM_60:
186 case CudaArch::SM_61:
187 case CudaArch::SM_62:
189 case CudaArch::SM_70:
191 case CudaArch::SM_72:
193 case CudaArch::SM_75:
195 case CudaArch::SM_80:
197 case CudaArch::SM_86:
199 case CudaArch::SM_87:
201 case CudaArch::SM_89:
202 case CudaArch::SM_90:
204 default:
205 llvm_unreachable("invalid enum");
206 }
207}
208
210 // AMD GPUs do not depend on CUDA versions.
211 if (IsAMDGpuArch(A))
212 return CudaVersion::NEW;
213
214 switch (A) {
217 case CudaArch::SM_20:
218 case CudaArch::SM_21:
220 case CudaArch::SM_30:
222 default:
223 return CudaVersion::NEW;
224 }
225}
226
227bool CudaFeatureEnabled(llvm::VersionTuple Version, CudaFeature Feature) {
228 return CudaFeatureEnabled(ToCudaVersion(Version), Feature);
229}
230
232 switch (Feature) {
234 return Version >= CudaVersion::CUDA_92;
236 return Version >= CudaVersion::CUDA_101;
237 }
238 llvm_unreachable("Unknown CUDA feature.");
239}
240} // namespace clang
#define V(N, I)
Definition: ASTContext.h:3217
const char * arch_name
Definition: Cuda.cpp:71
CudaArch arch
Definition: Cuda.cpp:70
#define SM2(sm, ca)
Definition: Cuda.cpp:76
#define GFX(gpu)
Definition: Cuda.cpp:79
#define SM(sm)
Definition: Cuda.cpp:78
const char * virtual_arch_name
Definition: Cuda.cpp:72
#define CUDA_ENTRY(major, minor)
Definition: Cuda.cpp:15
__device__ __2f16 float c
const char * CudaArchToVirtualArchString(CudaArch A)
Definition: Cuda.cpp:148
CudaArch
Definition: Cuda.h:49
CudaVersion MaxVersionForCudaArch(CudaArch A)
Get the latest CudaVersion that supports the given CudaArch.
Definition: Cuda.cpp:209
CudaVersion ToCudaVersion(llvm::VersionTuple)
Definition: Cuda.cpp:61
static const CudaArchToStringMap arch_names[]
Definition: Cuda.cpp:81
CudaArch StringToCudaArch(llvm::StringRef S)
Definition: Cuda.cpp:157
static bool IsAMDGpuArch(CudaArch A)
Definition: Cuda.h:122
CudaVersion CudaStringToVersion(const llvm::Twine &S)
Definition: Cuda.cpp:53
bool CudaFeatureEnabled(llvm::VersionTuple, CudaFeature)
Definition: Cuda.cpp:227
CudaVersion MinVersionForCudaArch(CudaArch A)
Get the earliest CudaVersion that supports the given CudaArch.
Definition: Cuda.cpp:166
const char * CudaVersionToString(CudaVersion V)
Definition: Cuda.cpp:45
static const CudaVersionMapEntry CudaNameVersionMap[]
Definition: Cuda.cpp:21
CudaVersion
Definition: Cuda.h:20
CudaFeature
Definition: Cuda.h:140
const char * CudaArchToString(CudaArch A)
Definition: Cuda.cpp:139
llvm::VersionTuple TVersion
Definition: Cuda.cpp:13
const char * Name
Definition: Cuda.cpp:11
CudaVersion Version
Definition: Cuda.cpp:12