11#include "clang/Config/config.h"
17#include "llvm/Option/ArgList.h"
18#include "llvm/Support/FileSystem.h"
19#include "llvm/Support/Path.h"
27static const char *
makeArgString(
const ArgList &Args,
const char *Prefix,
28 const char *
Base,
const char *Suffix) {
30 return Args.MakeArgString(Twine(StringRef(Prefix),
Base) + Suffix);
34 ArgStringList &CmdArgs) {
38 if ((Args.hasFlag(options::OPT_fprofile_arcs, options::OPT_fno_profile_arcs,
40 Args.hasFlag(options::OPT_fprofile_generate,
41 options::OPT_fno_profile_generate,
false) ||
42 Args.hasFlag(options::OPT_fprofile_generate_EQ,
43 options::OPT_fno_profile_generate,
false) ||
44 Args.hasFlag(options::OPT_fprofile_instr_generate,
45 options::OPT_fno_profile_instr_generate,
false) ||
46 Args.hasFlag(options::OPT_fprofile_instr_generate_EQ,
47 options::OPT_fno_profile_instr_generate,
false) ||
48 Args.hasFlag(options::OPT_fcs_profile_generate,
49 options::OPT_fno_profile_generate,
false) ||
50 Args.hasFlag(options::OPT_fcs_profile_generate_EQ,
51 options::OPT_fno_profile_generate,
false) ||
52 Args.hasArg(options::OPT_fcreate_profile) ||
53 Args.hasArg(options::OPT_coverage)))
55 Args,
"--dependent-lib=", PSTC.getProfileRTLibName(),
""));
62 const char *LinkingOutput)
const {
65 ArgStringList CmdArgs;
67 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
69 CmdArgs.push_back(
"-o");
72 assert(Inputs.size() == 1 &&
"Unexpected number of inputs.");
74 assert(Input.
isFilename() &&
"Invalid input.");
77 std::string AsName = TC.qualifyPSCmdName(
"as");
78 const char *Exec = Args.MakeArgString(TC.
GetProgramPath(AsName.c_str()));
79 C.addCommand(std::make_unique<Command>(JA, *
this,
81 Exec, CmdArgs, Inputs, Output));
85 ArgStringList &CmdArgs) {
92 ArgStringList &CmdArgs,
94 const char *Suffix)
const {
95 auto arg = [&](
const char *Name) ->
const char * {
100 CmdArgs.push_back(arg(
"SceDbgUBSanitizer_stub_weak"));
102 CmdArgs.push_back(arg(
"SceDbgAddressSanitizer_stub_weak"));
106 ArgStringList &CmdArgs,
108 const char *Suffix)
const {
109 auto arg = [&](
const char *Name) ->
const char * {
114 CmdArgs.push_back(arg(
"SceUBSanitizer_nosubmission_stub_weak"));
116 CmdArgs.push_back(arg(
"SceAddressSanitizer_nosubmission_stub_weak"));
118 CmdArgs.push_back(arg(
"SceThreadSanitizer_nosubmission_stub_weak"));
125 const char *LinkingOutput)
const {
128 ArgStringList CmdArgs;
131 Args.ClaimAllArgs(options::OPT_g_Group);
133 Args.ClaimAllArgs(options::OPT_emit_llvm);
136 Args.ClaimAllArgs(options::OPT_w);
139 CmdArgs.push_back(Args.MakeArgString(
"--sysroot=" + D.
SysRoot));
141 if (Args.hasArg(options::OPT_pie))
142 CmdArgs.push_back(
"-pie");
144 if (Args.hasArg(options::OPT_rdynamic))
145 CmdArgs.push_back(
"-export-dynamic");
146 if (Args.hasArg(options::OPT_shared))
147 CmdArgs.push_back(
"--shared");
150 CmdArgs.push_back(
"-o");
153 assert(Output.
isNothing() &&
"Invalid output.");
158 Args.hasFlag(options::OPT_fjmc, options::OPT_fno_jmc,
false);
159 const bool IsPS4 = TC.
getTriple().isPS4();
161 const char *PS4LTOArgs =
"";
162 auto AddCodeGenFlag = [&](Twine Flag) {
164 PS4LTOArgs = Args.MakeArgString(Twine(PS4LTOArgs) +
" " + Flag);
166 CmdArgs.push_back(Args.MakeArgString(Twine(
"-plugin-opt=") + Flag));
172 AddCodeGenFlag(
"-generate-arange-section");
176 AddCodeGenFlag(
"-enable-jmc-instrument");
178 if (Arg *A = Args.getLastArg(options::OPT_fcrash_diagnostics_dir))
179 AddCodeGenFlag(Twine(
"-crash-diagnostics-dir=") + A->getValue());
182 if (!Parallelism.empty()) {
184 AddCodeGenFlag(Twine(
"-threads=") + Parallelism);
186 CmdArgs.push_back(Args.MakeArgString(Twine(
"-plugin-opt=jobs=") + Parallelism));
190 const char *Prefix =
nullptr;
192 Prefix =
"-lto-thin-debug-options=";
194 Prefix =
"-lto-debug-options=";
196 llvm_unreachable(
"new LTO mode?");
198 CmdArgs.push_back(Args.MakeArgString(Twine(Prefix) + PS4LTOArgs));
202 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs))
203 TC.addSanitizerArgs(Args, CmdArgs,
"-l",
"");
205 if (D.
isUsingLTO() && Args.hasArg(options::OPT_funified_lto)) {
207 CmdArgs.push_back(
"--lto=thin");
209 CmdArgs.push_back(
"--lto=full");
212 Args.AddAllArgs(CmdArgs, options::OPT_L);
213 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
214 Args.AddAllArgs(CmdArgs, options::OPT_s);
215 Args.AddAllArgs(CmdArgs, options::OPT_t);
216 Args.AddAllArgs(CmdArgs, options::OPT_r);
218 if (Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
219 CmdArgs.push_back(
"--no-demangle");
223 if (Args.hasArg(options::OPT_pthread)) {
224 CmdArgs.push_back(
"-lpthread");
228 CmdArgs.push_back(
"--whole-archive");
230 CmdArgs.push_back(
"-lSceDbgJmc");
232 CmdArgs.push_back(
"-lSceJmc_nosubmission");
233 CmdArgs.push_back(
"--no-whole-archive");
236 if (Args.hasArg(options::OPT_fuse_ld_EQ)) {
237 D.
Diag(diag::err_drv_unsupported_opt_for_target)
241 std::string LdName = TC.qualifyPSCmdName(TC.getLinkerBaseName());
242 const char *Exec = Args.MakeArgString(TC.
GetProgramPath(LdName.c_str()));
244 C.addCommand(std::make_unique<Command>(JA, *
this,
246 Exec, CmdArgs, Inputs, Output));
250 const ArgList &Args, StringRef Platform,
253 if (Args.hasArg(clang::driver::options::OPT_static))
254 D.
Diag(clang::diag::err_drv_unsupported_opt_for_target)
255 <<
"-static" << Platform;
262 if (
const Arg *A = Args.getLastArg(options::OPT_isysroot)) {
263 SDKRootDir = A->getValue();
264 if (!llvm::sys::fs::exists(SDKRootDir))
265 D.
Diag(clang::diag::warn_missing_sysroot) << SDKRootDir;
266 Whence = A->getSpelling();
267 }
else if (
const char *EnvValue = getenv(EnvVar)) {
268 SDKRootDir = EnvValue;
269 Whence = {
"environment variable '", EnvVar,
"'" };
271 SDKRootDir = D.
Dir +
"/../../";
272 Whence =
"compiler's location";
276 llvm::sys::path::append(SDKIncludeDir,
"target/include");
277 if (!Args.hasArg(options::OPT_nostdinc) &&
278 !Args.hasArg(options::OPT_nostdlibinc) &&
279 !Args.hasArg(options::OPT_isysroot) &&
280 !Args.hasArg(options::OPT__sysroot_EQ) &&
281 !llvm::sys::fs::exists(SDKIncludeDir)) {
282 D.
Diag(clang::diag::warn_drv_unable_to_find_directory_expected)
283 << Twine(Platform,
" system headers").str() << SDKIncludeDir << Whence;
287 llvm::sys::path::append(SDKLibDir,
"target/lib");
288 if (!Args.hasArg(options::OPT_nostdlib) &&
289 !Args.hasArg(options::OPT_nodefaultlibs) &&
290 !Args.hasArg(options::OPT__sysroot_EQ) && !Args.hasArg(options::OPT_E) &&
291 !Args.hasArg(options::OPT_c) && !Args.hasArg(options::OPT_S) &&
292 !Args.hasArg(options::OPT_emit_ast) &&
293 !llvm::sys::fs::exists(SDKLibDir)) {
294 D.
Diag(clang::diag::warn_drv_unable_to_find_directory_expected)
295 << Twine(Platform,
" system libraries").str() << SDKLibDir << Whence;
302 const ArgList &DriverArgs,
303 ArgStringList &CC1Args)
const {
304 const Driver &D = getDriver();
306 if (DriverArgs.hasArg(options::OPT_nostdinc))
309 if (!DriverArgs.hasArg(options::OPT_nobuiltininc)) {
311 llvm::sys::path::append(Dir,
"include");
312 addSystemInclude(DriverArgs, CC1Args, Dir.str());
315 if (DriverArgs.hasArg(options::OPT_nostdlibinc))
318 addExternCSystemInclude(DriverArgs, CC1Args,
319 SDKRootDir +
"/target/include");
320 addExternCSystemInclude(DriverArgs, CC1Args,
321 SDKRootDir +
"/target/include_common");
330 getDriver().Diag(clang::diag::err_no_external_assembler);
340 Res |= SanitizerKind::Address;
341 Res |= SanitizerKind::PointerCompare;
342 Res |= SanitizerKind::PointerSubtract;
343 Res |= SanitizerKind::Vptr;
349 Res |= SanitizerKind::Thread;
354 const ArgList &DriverArgs, ArgStringList &CC1Args,
357 if (DriverArgs.hasArg(options::OPT_fuse_init_array)) {
358 Arg *A = DriverArgs.getLastArg(options::OPT_fuse_init_array);
359 getDriver().Diag(clang::diag::err_drv_unsupported_opt_for_target)
360 << A->getAsString(DriverArgs) << getTriple().str();
363 CC1Args.push_back(
"-fno-use-init-array");
366 DriverArgs.getLastArg(options::OPT_fvisibility_from_dllstorageclass,
367 options::OPT_fno_visibility_from_dllstorageclass);
369 A->getOption().matches(options::OPT_fvisibility_from_dllstorageclass)) {
370 CC1Args.push_back(
"-fvisibility-from-dllstorageclass");
372 if (DriverArgs.hasArg(options::OPT_fvisibility_dllexport_EQ))
373 DriverArgs.AddLastArg(CC1Args, options::OPT_fvisibility_dllexport_EQ);
375 CC1Args.push_back(
"-fvisibility-dllexport=protected");
377 if (DriverArgs.hasArg(options::OPT_fvisibility_nodllstorageclass_EQ))
378 DriverArgs.AddLastArg(CC1Args,
379 options::OPT_fvisibility_nodllstorageclass_EQ);
381 CC1Args.push_back(
"-fvisibility-nodllstorageclass=hidden");
383 if (DriverArgs.hasArg(options::OPT_fvisibility_externs_dllimport_EQ))
384 DriverArgs.AddLastArg(CC1Args,
385 options::OPT_fvisibility_externs_dllimport_EQ);
387 CC1Args.push_back(
"-fvisibility-externs-dllimport=default");
389 if (DriverArgs.hasArg(
390 options::OPT_fvisibility_externs_nodllstorageclass_EQ))
391 DriverArgs.AddLastArg(
392 CC1Args, options::OPT_fvisibility_externs_nodllstorageclass_EQ);
394 CC1Args.push_back(
"-fvisibility-externs-nodllstorageclass=default");
400 const llvm::opt::ArgList &Args)
401 :
PS4PS5Base(D, Triple, Args,
"PS4",
"SCE_ORBIS_SDK_DIR") {}
405 const llvm::opt::ArgList &Args)
406 :
PS4PS5Base(D, Triple, Args,
"PS5",
"SCE_PROSPERO_SDK_DIR") {}
static const char * makeArgString(const ArgList &Args, const char *Prefix, const char *Base, const char *Suffix)
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...
std::string SysRoot
sysroot, if present
DiagnosticBuilder Diag(unsigned DiagID) const
LTOKind getLTOMode(bool IsOffload=false) const
Get the specific kind of LTO being performed.
std::string ResourceDir
The path to the compiler resource directory.
bool isUsingLTO(bool IsOffload=false) const
Returns true if we are performing any kind of LTO.
std::string Dir
The path the driver executable was in, as invoked from the command line.
bool needsUbsanRt() const
@ C
Languages that the frontend can parse and compile.
static constexpr ResponseFileSupport AtFileUTF8()