24 const llvm::opt::ArgStringList &Args) {
25 llvm::opt::ArgStringList CmdArgs(Args);
28 assert(Input.
getType() != types::TY_PP_Asm &&
"Unexpected input type");
30 if (Output.
getType() == types::TY_PP_Asm)
31 CmdArgs.push_back(
"--spirv-tools-dis");
37 using namespace std::string_literals;
38 auto VersionedTool =
"llvm-spirv-"s + std::to_string(LLVM_VERSION_MAJOR);
39 std::string ExeCand = T.getToolChain().GetProgramPath(VersionedTool.c_str());
40 if (!llvm::sys::fs::can_execute(ExeCand))
41 ExeCand = T.getToolChain().GetProgramPath(
"llvm-spirv");
43 const char *Exec =
C.getArgs().MakeArgString(ExeCand);
45 Exec, CmdArgs, Input, Output));
52 const llvm::opt::ArgStringList &Args) {
53 llvm::opt::ArgStringList CmdArgs(Args);
56 assert(Input.
getType() == types::TY_PP_Asm &&
"Unexpected input type");
62 using namespace std::string_literals;
63 auto VersionedTool =
"spirv-as-"s + std::to_string(LLVM_VERSION_MAJOR);
64 std::string ExeCand = T.getToolChain().GetProgramPath(VersionedTool.c_str());
65 if (!llvm::sys::fs::can_execute(ExeCand))
66 ExeCand = T.getToolChain().GetProgramPath(
"spirv-as");
68 if (!llvm::sys::fs::can_execute(ExeCand) &&
69 !
C.getArgs().hasArg(clang::options::OPT__HASH_HASH_HASH)) {
70 C.getDriver().Diag(clang::diag::err_drv_no_spv_tools) <<
"spirv-as";
73 const char *Exec =
C.getArgs().MakeArgString(ExeCand);
75 Exec, CmdArgs, Input, Output));
82 const llvm::opt::ArgList &Args) {
84 ArgStringList LlvmLinkArgs;
86 for (
auto Input : Inputs) {
87 if (Input.isFilename()) {
88 LlvmLinkArgs.push_back(Input.getFilename());
91 assert(Input.isInputArg() &&
"Unexpected linker input");
92 const llvm::opt::Arg &LinkerOpt = Input.getInputArg();
93 std::string LinkerOptStr = LinkerOpt.getAsString(Args);
94 const llvm::opt::Arg *EmitLLVM = Args.getLastArg(options::OPT_emit_llvm);
95 assert(EmitLLVM &&
"Unexpected linker input");
96 std::string EmitLLVMStr = EmitLLVM ? EmitLLVM->getAsString(Args) :
"";
97 llvm::Triple Triple(T.getToolChain().getTriple());
98 C.getDriver().Diag(clang::diag::warn_drv_input_file_unused)
99 << Triple.getTriple() << LinkerOptStr <<
false << EmitLLVMStr;
110 const char *LinkingOutput)
const {
112 if (Inputs.size() != 1)
113 llvm_unreachable(
"Invalid number of input files.");
121 const char *AssembleOutput)
const {
123 if (Inputs.size() != 1)
124 llvm_unreachable(
"Invalid number of input files.");
130 Assembler = std::make_unique<SPIRV::Assembler>(*
this);
144 return SPIRVToolChain::getAssembler();
156 const char *LinkingOutput)
const {
157 if (JA.
getType() == types::TY_LLVM_BC) {
163 ArgStringList CmdArgs;
166 CmdArgs.push_back(
"-o");
170 if (
C.getDriver().isUsingLTO()) {
172 if (Args.hasArg(options::OPT_sycl_link)) {
175 C.getDriver().Diag(clang::diag::err_drv_no_linker_llvm_support)
182 CmdArgs.push_back(
"-enable-lto-internalization=false");
183 }
else if (Args.hasArg(options::OPT_sycl_link)) {
187 }
else if (!llvm::sys::fs::can_execute(
Linker) &&
188 !
C.getArgs().hasArg(clang::options::OPT__HASH_HASH_HASH)) {
189 C.getDriver().Diag(clang::diag::err_drv_no_spv_tools) <<
getShortName();
193 Args.MakeArgString(
Linker), CmdArgs,
202 NativeLLVMSupport = Args.hasArg(options::OPT_sycl_link) || D.isUsingLTO();
__device__ __2f16 float __ockl_bool s
types::ID getType() const
ActionClass getKind() const
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
static constexpr ResponseFileSupport None()
Returns a ResponseFileSupport indicating that response files are not supported.