[docs] Fix build-docs.sh
[llvm-project.git] / clang / lib / Driver / ToolChains / Cuda.h
blobc073a9abceb9a8fe20cc57d719fbdeac2ac56755
1 //===--- Cuda.h - Cuda 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 //===----------------------------------------------------------------------===//
9 #ifndef LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_CUDA_H
10 #define LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_CUDA_H
12 #include "clang/Basic/Cuda.h"
13 #include "clang/Driver/Action.h"
14 #include "clang/Driver/Multilib.h"
15 #include "clang/Driver/Tool.h"
16 #include "clang/Driver/ToolChain.h"
17 #include "llvm/ADT/Optional.h"
18 #include "llvm/Support/Compiler.h"
19 #include "llvm/Support/VersionTuple.h"
20 #include <bitset>
21 #include <set>
22 #include <vector>
24 namespace clang {
25 namespace driver {
27 /// A class to find a viable CUDA installation
28 class CudaInstallationDetector {
29 private:
30 const Driver &D;
31 bool IsValid = false;
32 CudaVersion Version = CudaVersion::UNKNOWN;
33 std::string InstallPath;
34 std::string BinPath;
35 std::string LibPath;
36 std::string LibDevicePath;
37 std::string IncludePath;
38 llvm::StringMap<std::string> LibDeviceMap;
40 // CUDA architectures for which we have raised an error in
41 // CheckCudaVersionSupportsArch.
42 mutable std::bitset<(int)CudaArch::LAST> ArchsWithBadVersion;
44 public:
45 CudaInstallationDetector(const Driver &D, const llvm::Triple &HostTriple,
46 const llvm::opt::ArgList &Args);
48 void AddCudaIncludeArgs(const llvm::opt::ArgList &DriverArgs,
49 llvm::opt::ArgStringList &CC1Args) const;
51 /// Emit an error if Version does not support the given Arch.
52 ///
53 /// If either Version or Arch is unknown, does not emit an error. Emits at
54 /// most one error per Arch.
55 void CheckCudaVersionSupportsArch(CudaArch Arch) const;
57 /// Check whether we detected a valid Cuda install.
58 bool isValid() const { return IsValid; }
59 /// Print information about the detected CUDA installation.
60 void print(raw_ostream &OS) const;
62 /// Get the detected Cuda install's version.
63 CudaVersion version() const {
64 return Version == CudaVersion::NEW ? CudaVersion::PARTIALLY_SUPPORTED
65 : Version;
67 /// Get the detected Cuda installation path.
68 StringRef getInstallPath() const { return InstallPath; }
69 /// Get the detected path to Cuda's bin directory.
70 StringRef getBinPath() const { return BinPath; }
71 /// Get the detected Cuda Include path.
72 StringRef getIncludePath() const { return IncludePath; }
73 /// Get the detected Cuda library path.
74 StringRef getLibPath() const { return LibPath; }
75 /// Get the detected Cuda device library path.
76 StringRef getLibDevicePath() const { return LibDevicePath; }
77 /// Get libdevice file for given architecture
78 std::string getLibDeviceFile(StringRef Gpu) const {
79 return LibDeviceMap.lookup(Gpu);
81 void WarnIfUnsupportedVersion();
84 namespace tools {
85 namespace NVPTX {
87 // Run ptxas, the NVPTX assembler.
88 class LLVM_LIBRARY_VISIBILITY Assembler : public Tool {
89 public:
90 Assembler(const ToolChain &TC) : Tool("NVPTX::Assembler", "ptxas", TC) {}
92 bool hasIntegratedCPP() const override { return false; }
94 void ConstructJob(Compilation &C, const JobAction &JA,
95 const InputInfo &Output, const InputInfoList &Inputs,
96 const llvm::opt::ArgList &TCArgs,
97 const char *LinkingOutput) const override;
100 // Runs fatbinary, which combines GPU object files ("cubin" files) and/or PTX
101 // assembly into a single output file.
102 class LLVM_LIBRARY_VISIBILITY Linker : public Tool {
103 public:
104 Linker(const ToolChain &TC) : Tool("NVPTX::Linker", "fatbinary", TC) {}
106 bool hasIntegratedCPP() const override { return false; }
108 void ConstructJob(Compilation &C, const JobAction &JA,
109 const InputInfo &Output, const InputInfoList &Inputs,
110 const llvm::opt::ArgList &TCArgs,
111 const char *LinkingOutput) const override;
114 void getNVPTXTargetFeatures(const Driver &D, const llvm::Triple &Triple,
115 const llvm::opt::ArgList &Args,
116 std::vector<StringRef> &Features);
118 } // end namespace NVPTX
119 } // end namespace tools
121 namespace toolchains {
123 class LLVM_LIBRARY_VISIBILITY CudaToolChain : public ToolChain {
124 public:
125 CudaToolChain(const Driver &D, const llvm::Triple &Triple,
126 const ToolChain &HostTC, const llvm::opt::ArgList &Args);
128 const llvm::Triple *getAuxTriple() const override {
129 return &HostTC.getTriple();
132 std::string getInputFilename(const InputInfo &Input) const override;
134 llvm::opt::DerivedArgList *
135 TranslateArgs(const llvm::opt::DerivedArgList &Args, StringRef BoundArch,
136 Action::OffloadKind DeviceOffloadKind) const override;
137 void addClangTargetOptions(const llvm::opt::ArgList &DriverArgs,
138 llvm::opt::ArgStringList &CC1Args,
139 Action::OffloadKind DeviceOffloadKind) const override;
141 llvm::DenormalMode getDefaultDenormalModeForType(
142 const llvm::opt::ArgList &DriverArgs, const JobAction &JA,
143 const llvm::fltSemantics *FPType = nullptr) const override;
145 // Never try to use the integrated assembler with CUDA; always fork out to
146 // ptxas.
147 bool useIntegratedAs() const override { return false; }
148 bool isCrossCompiling() const override { return true; }
149 bool isPICDefault() const override { return false; }
150 bool isPIEDefault(const llvm::opt::ArgList &Args) const override {
151 return false;
153 bool isPICDefaultForced() const override { return false; }
154 bool SupportsProfiling() const override { return false; }
155 bool supportsDebugInfoOption(const llvm::opt::Arg *A) const override;
156 void adjustDebugInfoKind(codegenoptions::DebugInfoKind &DebugInfoKind,
157 const llvm::opt::ArgList &Args) const override;
158 bool IsMathErrnoDefault() const override { return false; }
160 void AddCudaIncludeArgs(const llvm::opt::ArgList &DriverArgs,
161 llvm::opt::ArgStringList &CC1Args) const override;
163 void addClangWarningOptions(llvm::opt::ArgStringList &CC1Args) const override;
164 CXXStdlibType GetCXXStdlibType(const llvm::opt::ArgList &Args) const override;
165 void
166 AddClangSystemIncludeArgs(const llvm::opt::ArgList &DriverArgs,
167 llvm::opt::ArgStringList &CC1Args) const override;
168 void AddClangCXXStdlibIncludeArgs(
169 const llvm::opt::ArgList &Args,
170 llvm::opt::ArgStringList &CC1Args) const override;
171 void AddIAMCUIncludeArgs(const llvm::opt::ArgList &DriverArgs,
172 llvm::opt::ArgStringList &CC1Args) const override;
174 SanitizerMask getSupportedSanitizers() const override;
176 VersionTuple
177 computeMSVCVersion(const Driver *D,
178 const llvm::opt::ArgList &Args) const override;
180 unsigned GetDefaultDwarfVersion() const override { return 2; }
181 // NVPTX supports only DWARF2.
182 unsigned getMaxDwarfVersion() const override { return 2; }
184 const ToolChain &HostTC;
185 CudaInstallationDetector CudaInstallation;
187 protected:
188 Tool *buildAssembler() const override; // ptxas
189 Tool *buildLinker() const override; // fatbinary (ok, not really a linker)
192 } // end namespace toolchains
193 } // end namespace driver
194 } // end namespace clang
196 #endif // LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_CUDA_H