11#include "clang/Config/config.h"
18#include "llvm/ADT/SmallSet.h"
19#include "llvm/ADT/StringExtras.h"
20#include "llvm/Config/llvm-config.h"
21#include "llvm/Option/ArgList.h"
22#include "llvm/Support/FileSystem.h"
23#include "llvm/Support/Path.h"
24#include "llvm/Support/Process.h"
25#include "llvm/Support/Program.h"
26#include "llvm/Support/VirtualFileSystem.h"
27#include "llvm/TargetParser/Host.h"
28#include "llvm/TargetParser/TargetParser.h"
29#include <system_error>
40 if (raw_version < 7050)
42 if (raw_version < 8000)
44 if (raw_version < 9000)
46 if (raw_version < 9010)
48 if (raw_version < 9020)
50 if (raw_version < 10000)
52 if (raw_version < 10010)
54 if (raw_version < 10020)
56 if (raw_version < 11000)
58 if (raw_version < 11010)
60 if (raw_version < 11020)
62 if (raw_version < 11030)
64 if (raw_version < 11040)
66 if (raw_version < 11050)
68 if (raw_version < 11060)
70 if (raw_version < 11070)
72 if (raw_version < 11080)
74 if (raw_version < 11090)
76 if (raw_version < 12010)
78 if (raw_version < 12020)
80 if (raw_version < 12030)
82 if (raw_version < 12040)
84 if (raw_version < 12050)
86 if (raw_version < 12060)
88 if (raw_version < 12070)
90 if (raw_version < 12090)
92 if (raw_version < 13000)
94 if (raw_version < 13010)
96 if (raw_version < 13020)
98 if (raw_version < 13030)
106 auto StartsWithWords =
107 [](llvm::StringRef
Line,
109 for (StringRef word : words) {
110 if (!
Line.consume_front(word))
117 Input = Input.ltrim();
118 while (!Input.empty()) {
120 StartsWithWords(Input.ltrim(), {
"#",
"define",
"CUDA_VERSION"})) {
122 Line->consumeInteger(10, RawVersion);
123 return getCudaVersion(RawVersion);
126 Input = Input.drop_front(Input.find_first_of(
"\n\r")).ltrim();
135 if (!VersionString.empty())
136 VersionString.insert(0,
" ");
137 D.Diag(diag::warn_drv_new_cuda_version)
142 D.Diag(diag::warn_drv_partially_supported_cuda_version)
147 const Driver &D,
const llvm::Triple &HostTriple,
148 const llvm::opt::ArgList &Args)
154 Candidate(std::string Path,
bool StrictChecking =
false)
155 : Path(Path), StrictChecking(StrictChecking) {}
160 std::initializer_list<const char *> Versions = {
"8.0",
"7.5",
"7.0"};
161 auto &FS = D.getVFS();
163 if (Args.hasArg(options::OPT_cuda_path_EQ)) {
164 Candidates.emplace_back(
165 Args.getLastArgValue(options::OPT_cuda_path_EQ).str());
166 }
else if (HostTriple.isOSWindows()) {
167 for (
const char *Ver : Versions)
168 Candidates.emplace_back(
169 D.SysRoot +
"/Program Files/NVIDIA GPU Computing Toolkit/CUDA/v" +
172 if (!Args.hasArg(options::OPT_cuda_path_ignore_env)) {
181 if (llvm::ErrorOr<std::string> ptxas =
182 llvm::sys::findProgramByName(
"ptxas")) {
184 llvm::sys::fs::real_path(*ptxas, ptxasAbsolutePath);
186 StringRef ptxasDir = llvm::sys::path::parent_path(ptxasAbsolutePath);
187 if (llvm::sys::path::filename(ptxasDir) ==
"bin")
188 Candidates.emplace_back(
189 std::string(llvm::sys::path::parent_path(ptxasDir)),
194 Candidates.emplace_back(D.SysRoot +
"/usr/local/cuda");
195 for (
const char *Ver : Versions)
196 Candidates.emplace_back(D.SysRoot +
"/usr/local/cuda-" + Ver);
198 Distro Dist(FS, llvm::Triple(llvm::sys::getProcessTriple()));
202 Candidates.emplace_back(D.SysRoot +
"/usr/lib/cuda");
206 !Args.hasFlag(options::OPT_offloadlib, options::OPT_no_offloadlib,
true);
208 for (
const auto &Candidate : Candidates) {
209 InstallPath = Candidate.Path;
210 if (InstallPath.empty() || !FS.exists(InstallPath))
213 BinPath = InstallPath +
"/bin";
214 IncludePath = InstallPath +
"/include";
215 LibDevicePath = InstallPath +
"/nvvm/libdevice";
217 if (!(FS.exists(IncludePath) && FS.exists(BinPath)))
219 bool CheckLibDevice = (!NoCudaLib || Candidate.StrictChecking);
220 if (CheckLibDevice && !FS.exists(LibDevicePath))
224 if (
auto CudaHFile = FS.getBufferForFile(InstallPath +
"/include/cuda.h"))
225 Version = parseCudaHFile((*CudaHFile)->getBuffer());
229 Version = FS.exists(LibDevicePath +
"/libdevice.10.bc")
236 std::string FilePath = LibDevicePath +
"/libdevice.10.bc";
237 if (FS.exists(FilePath)) {
244 LibDeviceMap[OffloadArchName] = FilePath;
249 for (llvm::vfs::directory_iterator LI = FS.dir_begin(LibDevicePath, EC),
251 !EC && LI != LE; LI = LI.increment(EC)) {
252 StringRef FilePath = LI->path();
253 StringRef
FileName = llvm::sys::path::filename(FilePath);
256 const StringRef LibDeviceName =
"libdevice.";
260 LibDeviceName.size(),
FileName.find(
'.', LibDeviceName.size()));
261 LibDeviceMap[GpuArch] = FilePath.str();
265 if (GpuArch ==
"compute_20") {
266 LibDeviceMap[
"sm_20"] = std::string(FilePath);
267 LibDeviceMap[
"sm_21"] = std::string(FilePath);
268 LibDeviceMap[
"sm_32"] = std::string(FilePath);
269 }
else if (GpuArch ==
"compute_30") {
270 LibDeviceMap[
"sm_30"] = std::string(FilePath);
272 LibDeviceMap[
"sm_50"] = std::string(FilePath);
273 LibDeviceMap[
"sm_52"] = std::string(FilePath);
274 LibDeviceMap[
"sm_53"] = std::string(FilePath);
276 LibDeviceMap[
"sm_60"] = std::string(FilePath);
277 LibDeviceMap[
"sm_61"] = std::string(FilePath);
278 LibDeviceMap[
"sm_62"] = std::string(FilePath);
279 }
else if (GpuArch ==
"compute_35") {
280 LibDeviceMap[
"sm_35"] = std::string(FilePath);
281 LibDeviceMap[
"sm_37"] = std::string(FilePath);
282 }
else if (GpuArch ==
"compute_50") {
284 LibDeviceMap[
"sm_50"] = std::string(FilePath);
285 LibDeviceMap[
"sm_52"] = std::string(FilePath);
286 LibDeviceMap[
"sm_53"] = std::string(FilePath);
294 if (LibDeviceMap.empty() && !NoCudaLib)
303 const ArgList &DriverArgs, ArgStringList &CC1Args)
const {
304 if (!DriverArgs.hasArg(options::OPT_nobuiltininc)) {
308 llvm::sys::path::append(P,
"include");
309 llvm::sys::path::append(P,
"cuda_wrappers");
310 CC1Args.push_back(
"-internal-isystem");
311 CC1Args.push_back(DriverArgs.MakeArgString(P));
314 if (!DriverArgs.hasFlag(options::OPT_offload_inc, options::OPT_no_offload_inc,
319 D.Diag(diag::err_drv_no_cuda_installation);
323 CC1Args.push_back(
"-include");
324 CC1Args.push_back(
"__clang_cuda_runtime_wrapper.h");
330 ArchsWithBadVersion[(
int)
Arch])
335 if (Version < MinVersion || Version > MaxVersion) {
336 ArchsWithBadVersion[(int)
Arch] =
true;
337 D.Diag(diag::err_drv_cuda_version_unsupported)
346 OS <<
"Found CUDA installation: " << InstallPath <<
", version "
356enum DeviceDebugInfoLevel {
359 EmitSameDebugInfoAsHost,
373 const Arg *A = Args.getLastArg(options::OPT_O_Group);
374 bool IsDebugEnabled = !A || A->getOption().matches(options::OPT_O0) ||
375 Args.hasFlag(options::OPT_cuda_noopt_device_debug,
376 options::OPT_no_cuda_noopt_device_debug,
378 if (
const Arg *A = Args.getLastArg(options::OPT_g_Group)) {
379 const Option &Opt = A->getOption();
380 if (Opt.matches(options::OPT_gN_Group)) {
381 if (Opt.matches(options::OPT_g0) || Opt.matches(options::OPT_ggdb0))
382 return DisableDebugInfo;
383 if (Opt.matches(options::OPT_gline_directives_only))
384 return DebugDirectivesOnly;
386 return IsDebugEnabled ? EmitSameDebugInfoAsHost : DebugDirectivesOnly;
395 const char *LinkingOutput)
const {
398 assert(TC.getTriple().isNVPTX() &&
"Wrong platform");
400 StringRef GPUArchName;
408 GPUArchName = Args.getLastArgValue(options::OPT_march_EQ);
409 if (GPUArchName.empty()) {
410 C.getDriver().Diag(diag::err_drv_offload_missing_gpu_arch)
419 "Device action expected to have an architecture.");
422 if (!Args.hasArg(options::OPT_no_cuda_version_check)) {
423 TC.CudaInstallation.CheckCudaVersionSupportsArch(gpu_arch);
426 ArgStringList CmdArgs;
427 CmdArgs.push_back(TC.getTriple().isArch64Bit() ?
"-m64" :
"-m32");
429 if (DIKind == EmitSameDebugInfoAsHost) {
432 CmdArgs.push_back(
"-g");
433 CmdArgs.push_back(
"--dont-merge-basicblocks");
434 CmdArgs.push_back(
"--return-at-end");
435 }
else if (Arg *A = Args.getLastArg(options::OPT_O_Group)) {
443 StringRef OOpt =
"3";
444 if (A->getOption().matches(options::OPT_O4) ||
445 A->getOption().matches(options::OPT_Ofast))
447 else if (A->getOption().matches(options::OPT_O0))
449 else if (A->getOption().matches(options::OPT_O)) {
451 OOpt = llvm::StringSwitch<const char *>(A->getValue())
459 CmdArgs.push_back(Args.MakeArgString(llvm::Twine(
"-O") + OOpt));
463 CmdArgs.push_back(
"-O0");
465 if (DIKind == DebugDirectivesOnly)
466 CmdArgs.push_back(
"-lineinfo");
469 if (Args.hasArg(options::OPT_v))
470 CmdArgs.push_back(
"-v");
472 CmdArgs.push_back(
"--gpu-name");
474 CmdArgs.push_back(
"--output-file");
475 std::string OutputFileName = TC.getInputFilename(Output);
478 C.addTempFile(Args.MakeArgString(OutputFileName));
480 CmdArgs.push_back(Args.MakeArgString(OutputFileName));
481 for (
const auto &II : Inputs)
482 CmdArgs.push_back(Args.MakeArgString(II.getFilename()));
484 for (
const auto &A : Args.getAllArgValues(options::OPT_Xcuda_ptxas))
485 CmdArgs.push_back(Args.MakeArgString(A));
490 Relocatable = Args.hasFlag(options::OPT_fopenmp_relocatable_target,
491 options::OPT_fnoopenmp_relocatable_target,
495 Relocatable = Args.hasFlag(options::OPT_fgpu_rdc, options::OPT_fno_gpu_rdc,
502 CmdArgs.push_back(
"-c");
505 if (Arg *A = Args.getLastArg(options::OPT_ptxas_path_EQ))
506 Exec = A->getValue();
508 Exec = Args.MakeArgString(TC.GetProgramPath(
"ptxas"));
509 C.addCommand(std::make_unique<Command>(
513 Exec, CmdArgs, Inputs, Output));
518 bool includePTX = !Args.hasFlag(options::OPT_offload_new_driver,
519 options::OPT_no_offload_new_driver,
true);
520 for (Arg *A : Args.filtered(options::OPT_cuda_include_ptx_EQ,
521 options::OPT_no_cuda_include_ptx_EQ)) {
523 const StringRef ArchStr = A->getValue();
524 if (A->getOption().matches(options::OPT_cuda_include_ptx_EQ) &&
525 (ArchStr ==
"all" || ArchStr == InputArch))
527 else if (A->getOption().matches(options::OPT_no_cuda_include_ptx_EQ) &&
528 (ArchStr ==
"all" || ArchStr == InputArch))
541 const char *LinkingOutput)
const {
544 assert(TC.getTriple().isNVPTX() &&
"Wrong platform");
546 ArgStringList CmdArgs;
548 CmdArgs.push_back(
"--cuda");
549 CmdArgs.push_back(TC.getTriple().isArch64Bit() ?
"-64" :
"-32");
550 CmdArgs.push_back(Args.MakeArgString(
"--create"));
551 CmdArgs.push_back(Args.MakeArgString(Output.
getFilename()));
553 CmdArgs.push_back(
"-g");
555 for (
const auto &II : Inputs) {
556 auto *A = II.getAction();
557 assert(A->getInputs().size() == 1 &&
558 "Device offload action is expected to have a single input");
559 StringRef GpuArch = A->getOffloadingArch();
560 assert(!GpuArch.empty() &&
561 "Device action expected to have associated a GPU architecture!");
565 StringRef Kind = (II.getType() == types::TY_PP_Asm) ?
"ptx" :
"elf";
566 CmdArgs.push_back(Args.MakeArgString(
567 "--image3=kind=" + Kind +
",sm=" + GpuArch.drop_front(3) +
571 for (
const auto &A : Args.getAllArgValues(options::OPT_Xcuda_fatbinary))
572 CmdArgs.push_back(Args.MakeArgString(A));
574 const char *Exec = Args.MakeArgString(TC.GetProgramPath(
"fatbinary"));
575 C.addCommand(std::make_unique<Command>(
579 Exec, CmdArgs, Inputs, Output));
586 const char *LinkingOutput)
const {
589 ArgStringList CmdArgs;
591 assert(TC.getTriple().isNVPTX() &&
"Wrong platform");
595 CmdArgs.push_back(
"-o");
600 CmdArgs.push_back(
"-g");
602 if (Args.hasArg(options::OPT_v))
603 CmdArgs.push_back(
"-v");
605 StringRef GPUArch = Args.getLastArgValue(options::OPT_march_EQ);
606 if (GPUArch.empty() && !
C.getDriver().isUsingLTO()) {
607 C.getDriver().Diag(diag::err_drv_offload_missing_gpu_arch)
612 if (!GPUArch.empty()) {
613 CmdArgs.push_back(
"-arch");
614 CmdArgs.push_back(Args.MakeArgString(GPUArch));
617 if (Args.hasArg(options::OPT_ptxas_path_EQ))
618 CmdArgs.push_back(Args.MakeArgString(
619 "--pxtas-path=" + Args.getLastArgValue(options::OPT_ptxas_path_EQ)));
621 if (Args.hasArg(options::OPT_cuda_path_EQ) || TC.CudaInstallation.isValid()) {
622 StringRef CudaPath = Args.getLastArgValue(
623 options::OPT_cuda_path_EQ,
624 llvm::sys::path::parent_path(TC.CudaInstallation.getBinPath()));
625 CmdArgs.push_back(Args.MakeArgString(
"--cuda-path=" + CudaPath));
632 Args.AddAllArgs(CmdArgs, options::OPT_L);
636 if (
C.getDriver().isUsingLTO())
641 std::vector<StringRef> Features;
645 Args.MakeArgString(
"--plugin-opt=-mattr=" + llvm::join(Features,
",")));
649 llvm::sys::path::parent_path(TC.getDriver().Dir);
650 llvm::sys::path::append(DefaultLibPath, CLANG_INSTALL_LIBDIR_BASENAME);
651 CmdArgs.push_back(Args.MakeArgString(Twine(
"-L") + DefaultLibPath));
656 if (Args.hasArg(options::OPT_stdlib))
657 CmdArgs.append({
"-lc",
"-lm"});
658 if (Args.hasArg(options::OPT_startfiles)) {
659 std::optional<std::string> IncludePath =
getToolChain().getStdlibPath();
661 IncludePath =
"/lib";
663 llvm::sys::path::append(P,
"crt1.o");
664 CmdArgs.push_back(Args.MakeArgString(P));
667 C.addCommand(std::make_unique<Command>(
671 Args.MakeArgString(
getToolChain().GetProgramPath(
"clang-nvlink-wrapper")),
672 CmdArgs, Inputs, Output));
676 const llvm::opt::ArgList &Args,
677 std::vector<StringRef> &Features) {
678 if (Args.hasArg(options::OPT_cuda_feature_EQ)) {
679 StringRef PtxFeature = Args.getLastArgValue(options::OPT_cuda_feature_EQ);
680 Features.push_back(Args.MakeArgString(PtxFeature));
688 const char *PtxFeature =
nullptr;
689 switch (CudaInstallation.
version()) {
690#define CASE_CUDA_VERSION(CUDA_VER, PTX_VER) \
691 case CudaVersion::CUDA_##CUDA_VER: \
692 PtxFeature = "+ptx" #PTX_VER; \
724#undef CASE_CUDA_VERSION
727 PtxFeature =
"+ptx86";
734 Features.push_back(PtxFeature);
741 const llvm::Triple &HostTriple,
743 :
ToolChain(D, Triple, Args), CudaInstallation(D, HostTriple, Args) {
744 if (CudaInstallation.isValid())
745 getProgramPaths().push_back(std::string(CudaInstallation.getBinPath()));
748 getProgramPaths().push_back(getDriver().Dir);
756 loadMultilibsFromYAML(Args, D);
759llvm::opt::DerivedArgList *
765 DAL =
new DerivedArgList(Args.getBaseArgs());
767 const OptTable &Opts =
getDriver().getOpts();
770 if (!llvm::is_contained(*DAL, A))
773 if (!DAL->hasArg(options::OPT_march_EQ) && OffloadKind !=
Action::OFK_None) {
774 DAL->AddJoinedArg(
nullptr, Opts.getOption(options::OPT_march_EQ),
776 }
else if (DAL->getLastArgValue(options::OPT_march_EQ) ==
"generic" &&
778 DAL->eraseArg(options::OPT_march_EQ);
779 }
else if (DAL->getLastArgValue(options::OPT_march_EQ) ==
"native") {
782 getDriver().Diag(diag::err_drv_undetermined_gpu_arch)
783 <<
getArchName() << llvm::toString(GPUsOrErr.takeError()) <<
"-march";
785 auto &GPUs = *GPUsOrErr;
786 if (llvm::SmallSet<std::string, 1>(GPUs.begin(), GPUs.end()).size() > 1)
787 getDriver().Diag(diag::warn_drv_multi_gpu_arch)
788 <<
getArchName() << llvm::join(GPUs,
", ") <<
"-march";
789 DAL->AddJoinedArg(
nullptr, Opts.getOption(options::OPT_march_EQ),
790 Args.MakeArgString(GPUs.front()));
798 const llvm::opt::ArgList &DriverArgs, llvm::opt::ArgStringList &CC1Args,
802 ArgStringList &CC1Args)
const {
803 if (DriverArgs.hasArg(options::OPT_nostdinc) ||
804 DriverArgs.hasArg(options::OPT_nostdlibinc))
813 llvm::sys::path::append(Dir, M.includeSuffix());
824 const Option &O = A->getOption();
825 return (O.matches(options::OPT_gN_Group) &&
826 !O.matches(options::OPT_gmodules)) ||
827 O.matches(options::OPT_g_Flag) ||
828 O.matches(options::OPT_ggdbN_Group) || O.matches(options::OPT_ggdb) ||
829 O.matches(options::OPT_gdwarf) || O.matches(options::OPT_gdwarf_2) ||
830 O.matches(options::OPT_gdwarf_3) || O.matches(options::OPT_gdwarf_4) ||
831 O.matches(options::OPT_gdwarf_5) ||
832 O.matches(options::OPT_gcolumn_info);
836 llvm::codegenoptions::DebugInfoKind &DebugInfoKind,
837 const ArgList &Args)
const {
839 case DisableDebugInfo:
840 DebugInfoKind = llvm::codegenoptions::NoDebugInfo;
842 case DebugDirectivesOnly:
843 DebugInfoKind = llvm::codegenoptions::DebugDirectivesOnly;
845 case EmitSameDebugInfoAsHost:
855 if (Arg *A = Args.getLastArg(options::OPT_offload_arch_tool_EQ))
856 Program = A->getValue();
860 auto StdoutOrErr =
getDriver().executeProgram({Program});
862 return StdoutOrErr.takeError();
865 for (StringRef
Arch : llvm::split((*StdoutOrErr)->getBuffer(),
"\n"))
867 GPUArchs.push_back(
Arch.str());
869 if (GPUArchs.empty())
870 return llvm::createStringError(std::error_code(),
871 "No NVIDIA GPU detected in the system");
873 return std::move(GPUArchs);
885 const llvm::opt::ArgList &DriverArgs, llvm::opt::ArgStringList &CC1Args,
887 HostTC.addClangTargetOptions(DriverArgs, CC1Args, DeviceOffloadingKind);
889 StringRef GpuArch = DriverArgs.getLastArgValue(options::OPT_march_EQ);
892 "Only OpenMP or CUDA offloading kinds are supported for NVIDIA GPUs.");
894 CC1Args.append({
"-fcuda-is-device",
"-mllvm",
895 "-enable-memcpyopt-without-libcalls",
896 "-fno-threadsafe-statics"});
898 if (DriverArgs.hasFlag(options::OPT_fcuda_short_ptr,
899 options::OPT_fno_cuda_short_ptr,
false))
900 CC1Args.append({
"-mllvm",
"--nvptx-short-ptr"});
902 if (!DriverArgs.hasFlag(options::OPT_offloadlib, options::OPT_no_offloadlib,
907 DriverArgs.hasArg(options::OPT_S))
911 if (LibDeviceFile.empty()) {
912 getDriver().
Diag(diag::err_drv_no_cuda_libdevice) << GpuArch;
916 CC1Args.push_back(
"-mlink-builtin-bitcode");
917 CC1Args.push_back(DriverArgs.MakeArgString(LibDeviceFile));
922 if (DriverArgs.hasFlag(options::OPT_foffload_via_llvm,
923 options::OPT_fno_offload_via_llvm,
false))
930 DriverArgs.MakeArgString(Twine(
"-target-sdk-version=") +
936 diag::err_drv_omp_offload_target_cuda_version_not_support)
951 const llvm::opt::ArgList &DriverArgs,
const JobAction &JA,
952 const llvm::fltSemantics *FPType)
const {
954 if (FPType && FPType == &llvm::APFloat::IEEEsingle() &&
955 DriverArgs.hasFlag(options::OPT_fgpu_flush_denormals_to_zero,
956 options::OPT_fno_gpu_flush_denormals_to_zero,
false))
957 return llvm::DenormalMode::getPreserveSign();
961 return llvm::DenormalMode::getIEEE();
965 ArgStringList &CC1Args)
const {
967 if (DriverArgs.hasFlag(options::OPT_offload_inc, options::OPT_no_offload_inc,
969 !DriverArgs.hasArg(options::OPT_no_cuda_version_check)) {
970 StringRef
Arch = DriverArgs.getLastArgValue(options::OPT_march_EQ);
971 assert(!
Arch.empty() &&
"Must have an explicit GPU arch.");
986llvm::opt::DerivedArgList *
990 DerivedArgList *DAL =
991 HostTC.TranslateArgs(Args, BoundArch, DeviceOffloadKind);
993 DAL =
new DerivedArgList(Args.getBaseArgs());
997 for (Arg *A : Args) {
999 if (!llvm::is_contained(*DAL, A)) {
1004 if (!BoundArch.empty()) {
1005 DAL->eraseArg(options::OPT_march_EQ);
1006 DAL->AddJoinedArg(
nullptr, Opts.getOption(options::OPT_march_EQ),
1029 HostTC.addClangWarningOptions(CC1Args);
1034 return HostTC.GetCXXStdlibType(Args);
1038 ArgStringList &CC1Args)
const {
1039 HostTC.AddClangSystemIncludeArgs(DriverArgs, CC1Args);
1041 if (DriverArgs.hasFlag(options::OPT_offload_inc, options::OPT_no_offload_inc,
1045 {
"-internal-isystem",
1050 ArgStringList &CC1Args)
const {
1051 HostTC.AddClangCXXStdlibIncludeArgs(Args, CC1Args);
1055 ArgStringList &CC1Args)
const {
1056 HostTC.AddIAMCUIncludeArgs(Args, CC1Args);
1072 return HostTC.getSupportedSanitizers(BoundArch, DeviceOffloadKind);
1076 const ArgList &Args)
const {
1077 return HostTC.computeMSVCVersion(D, Args);
static StringRef getTriple(const Command &Job)
const char * getOffloadingArch() const
OffloadKind getOffloadingDeviceKind() const
bool isDeviceOffloading(OffloadKind OKind) const
bool isOffloading(OffloadKind OKind) const
Compilation - A set of tasks to perform for a single driver invocation.
A class to find a viable CUDA installation.
void AddCudaIncludeArgs(const llvm::opt::ArgList &DriverArgs, llvm::opt::ArgStringList &CC1Args) const
CudaInstallationDetector(const Driver &D, const llvm::Triple &HostTriple, const llvm::opt::ArgList &Args)
CudaVersion version() const
Get the detected Cuda install's version.
void WarnIfUnsupportedVersion() const
void CheckCudaVersionSupportsArch(OffloadArch Arch) const
Emit an error if Version does not support the given Arch.
void print(raw_ostream &OS) const
Print information about the detected CUDA installation.
bool isValid() const
Check whether we detected a valid Cuda install.
Distro - Helper class for detecting and classifying Linux distributions.
Driver - Encapsulate logic for constructing compilation processes from a set of gcc-driver-like comma...
DiagnosticBuilder Diag(unsigned DiagID) const
const llvm::opt::OptTable & getOpts() const
This corresponds to a single GCC Multilib, or a segment of one controlled by a command line flag.
SmallVector< InputInfo, 4 > InputInfoList
bool willEmitRemarks(const llvm::opt::ArgList &Args)
The JSON file list parser is used to communicate input to InstallAPI.
CudaVersion MaxVersionForOffloadArch(OffloadArch A)
Get the latest CudaVersion that supports the given OffloadArch.
static bool IsNVIDIAOffloadArch(OffloadArch A)
const char * CudaVersionToString(CudaVersion V)
OffloadArch StringToOffloadArch(llvm::StringRef S)
const char * OffloadArchToString(OffloadArch A)
CudaVersion MinVersionForOffloadArch(OffloadArch A)
Get the earliest CudaVersion that supports the given OffloadArch.
Diagnostic wrappers for TextAPI types for error reporting.