9#ifndef LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_AMDGPU_H
10#define LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_AMDGPU_H
17#include "llvm/ADT/SmallString.h"
18#include "llvm/TargetParser/AMDGPUTargetParser.h"
28class LLVM_LIBRARY_VISIBILITY
Linker final :
public Tool {
35 const llvm::opt::ArgList &TCArgs,
36 const char *LinkingOutput)
const override;
40 const llvm::opt::ArgList &Args,
41 std::vector<StringRef> &Features);
44 llvm::opt::ArgStringList &CmdArgs);
63 const llvm::opt::ArgList &Args);
75 llvm::opt::DerivedArgList *
76 TranslateArgs(
const llvm::opt::DerivedArgList &Args, StringRef BoundArch,
79 void addClangTargetOptions(
const llvm::opt::ArgList &DriverArgs,
80 llvm::opt::ArgStringList &CC1Args,
83 AddClangSystemIncludeArgs(
const llvm::opt::ArgList &DriverArgs,
84 llvm::opt::ArgStringList &CC1Args)
const override;
88 static bool getDefaultDenormsAreZeroForTarget(llvm::AMDGPU::GPUKind GPUKind);
90 llvm::DenormalMode getDefaultDenormalModeForType(
91 const llvm::opt::ArgList &DriverArgs,
const JobAction &JA,
92 const llvm::fltSemantics *FPType =
nullptr)
const override;
94 static bool isWave64(
const llvm::opt::ArgList &DriverArgs,
95 llvm::AMDGPU::GPUKind Kind);
105 StringRef BoundArch)
const override;
110 getSystemGPUArchs(
const llvm::opt::ArgList &Args)
const override;
114 virtual void checkTargetID(
const llvm::opt::ArgList &DriverArgs)
const;
129 StringRef
getGPUArch(
const llvm::opt::ArgList &DriverArgs)
const;
143 const llvm::opt::ArgList &Args);
146 llvm::opt::ArgStringList &CC1Args,
152 llvm::StringRef TargetID, llvm::StringRef GPUArch,
156 const llvm::opt::DerivedArgList &DAL,
157 const llvm::opt::ArgList &DriverArgs,
158 const char *
Value =
nullptr)
const {
160 bool IsExplicitDevice =
161 A->getBaseArg().getOption().matches(options::OPT_Xarch_device);
166 ? clang::diag::err_drv_unsupported_option_part_for_target
167 : clang::diag::warn_drv_unsupported_option_part_for_target;
168 Diags.Report(DiagID) <<
Value << A->getAsString(DriverArgs)
173 ? clang::diag::err_drv_unsupported_option_for_target
174 : clang::diag::warn_drv_unsupported_option_for_target;
175 Diags.Report(DiagID) << A->getAsString(DAL) <<
getTriple().str();
static StringRef getTriple(const Command &Job)
Compilation - A set of tasks to perform for a single driver invocation.
Driver - Encapsulate logic for constructing compilation processes from a set of gcc-driver-like comma...
SmallVector< InputInfo, 4 > InputInfoList
The JSON file list parser is used to communicate input to InstallAPI.