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);
138 if (!
D.SysRoot.empty())
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_static))
145 CmdArgs.push_back(
"-static");
146 if (Args.hasArg(options::OPT_rdynamic))
147 CmdArgs.push_back(
"-export-dynamic");
148 if (Args.hasArg(options::OPT_shared))
149 CmdArgs.push_back(
"--shared");
153 CmdArgs.push_back(
"-o");
158 Args.hasFlag(options::OPT_fjmc, options::OPT_fno_jmc,
false);
160 const char *LTOArgs =
"";
161 auto AddLTOFlag = [&](Twine Flag) {
162 LTOArgs = Args.MakeArgString(Twine(LTOArgs) +
" " + Flag);
169 if (Args.hasFlag(options::OPT_funified_lto, options::OPT_fno_unified_lto,
171 CmdArgs.push_back(
D.getLTOMode() ==
LTOK_Thin ?
"--lto=thin"
174 AddLTOFlag(
"-enable-jmc-instrument");
176 if (Arg *A = Args.getLastArg(options::OPT_fcrash_diagnostics_dir))
177 AddLTOFlag(Twine(
"-crash-diagnostics-dir=") + A->getValue());
180 AddLTOFlag(Twine(
"-threads=") + Threads);
184 Args.MakeArgString(Twine(
"-lto-debug-options=") + LTOArgs));
186 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs))
187 TC.addSanitizerArgs(Args, CmdArgs,
"-l",
"");
189 Args.addAllArgs(CmdArgs, {options::OPT_L, options::OPT_T_Group,
190 options::OPT_s, options::OPT_t});
192 if (Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
193 CmdArgs.push_back(
"--no-demangle");
197 if (Args.hasArg(options::OPT_pthread)) {
198 CmdArgs.push_back(
"-lpthread");
202 CmdArgs.push_back(
"--whole-archive");
203 CmdArgs.push_back(
"-lSceDbgJmc");
204 CmdArgs.push_back(
"--no-whole-archive");
207 if (Args.hasArg(options::OPT_fuse_ld_EQ)) {
208 D.Diag(diag::err_drv_unsupported_opt_for_target)
212 std::string LdName = TC.qualifyPSCmdName(TC.getLinkerBaseName());
213 const char *Exec = Args.MakeArgString(TC.
GetProgramPath(LdName.c_str()));
215 C.addCommand(std::make_unique<Command>(JA, *
this,
217 Exec, CmdArgs, Inputs, Output));
224 const char *LinkingOutput)
const {
227 ArgStringList CmdArgs;
230 Args.ClaimAllArgs(options::OPT_g_Group);
232 Args.ClaimAllArgs(options::OPT_emit_llvm);
235 Args.ClaimAllArgs(options::OPT_w);
237 if (!
D.SysRoot.empty())
238 CmdArgs.push_back(Args.MakeArgString(
"--sysroot=" +
D.SysRoot));
242 !Args.hasArg(options::OPT_r, options::OPT_shared, options::OPT_static);
243 if (Args.hasFlag(options::OPT_pie, options::OPT_no_pie, PIE))
244 CmdArgs.push_back(
"-pie");
246 if (Args.hasArg(options::OPT_static))
247 CmdArgs.push_back(
"-static");
248 if (Args.hasArg(options::OPT_rdynamic))
249 CmdArgs.push_back(
"-export-dynamic");
250 if (Args.hasArg(options::OPT_shared))
251 CmdArgs.push_back(
"--shared");
255 CmdArgs.push_back(
"-o");
260 Args.hasFlag(options::OPT_fjmc, options::OPT_fno_jmc,
false);
262 auto AddLTOFlag = [&](Twine Flag) {
263 CmdArgs.push_back(Args.MakeArgString(Twine(
"-plugin-opt=") + Flag));
270 if (Args.hasFlag(options::OPT_funified_lto, options::OPT_fno_unified_lto,
272 CmdArgs.push_back(
D.getLTOMode() ==
LTOK_Thin ?
"--lto=thin"
276 AddLTOFlag(
"-enable-jmc-instrument");
278 if (Args.hasFlag(options::OPT_fstack_size_section,
279 options::OPT_fno_stack_size_section,
false))
280 AddLTOFlag(
"-stack-size-section");
282 if (Arg *A = Args.getLastArg(options::OPT_fcrash_diagnostics_dir))
283 AddLTOFlag(Twine(
"-crash-diagnostics-dir=") + A->getValue());
286 AddLTOFlag(Twine(
"jobs=") + Jobs);
288 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs))
289 TC.addSanitizerArgs(Args, CmdArgs,
"-l",
"");
291 Args.addAllArgs(CmdArgs, {options::OPT_L, options::OPT_T_Group,
292 options::OPT_s, options::OPT_t});
294 if (Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
295 CmdArgs.push_back(
"--no-demangle");
299 if (Args.hasArg(options::OPT_pthread)) {
300 CmdArgs.push_back(
"-lpthread");
304 CmdArgs.push_back(
"--whole-archive");
305 CmdArgs.push_back(
"-lSceJmc_nosubmission");
306 CmdArgs.push_back(
"--no-whole-archive");
309 if (Args.hasArg(options::OPT_fuse_ld_EQ)) {
310 D.Diag(diag::err_drv_unsupported_opt_for_target)
314 std::string LdName = TC.qualifyPSCmdName(TC.getLinkerBaseName());
315 const char *Exec = Args.MakeArgString(TC.
GetProgramPath(LdName.c_str()));
317 C.addCommand(std::make_unique<Command>(JA, *
this,
319 Exec, CmdArgs, Inputs, Output));
323 const ArgList &Args, StringRef Platform,
331 if (
const Arg *A = Args.getLastArg(options::OPT_isysroot)) {
332 SDKRootDir = A->getValue();
333 if (!llvm::sys::fs::exists(SDKRootDir))
334 D.Diag(clang::diag::warn_missing_sysroot) << SDKRootDir;
335 Whence = A->getSpelling();
336 }
else if (
const char *EnvValue = getenv(EnvVar)) {
337 SDKRootDir = EnvValue;
338 Whence = {
"environment variable '", EnvVar,
"'" };
340 SDKRootDir =
D.Dir +
"/../../";
341 Whence =
"compiler's location";
345 llvm::sys::path::append(SDKIncludeDir,
"target/include");
346 if (!Args.hasArg(options::OPT_nostdinc) &&
347 !Args.hasArg(options::OPT_nostdlibinc) &&
348 !Args.hasArg(options::OPT_isysroot) &&
349 !Args.hasArg(options::OPT__sysroot_EQ) &&
350 !llvm::sys::fs::exists(SDKIncludeDir)) {
351 D.Diag(clang::diag::warn_drv_unable_to_find_directory_expected)
352 << Twine(Platform,
" system headers").str() << SDKIncludeDir << Whence;
356 llvm::sys::path::append(SDKLibDir,
"target/lib");
357 if (!Args.hasArg(options::OPT_nostdlib) &&
358 !Args.hasArg(options::OPT_nodefaultlibs) &&
359 !Args.hasArg(options::OPT__sysroot_EQ) && !Args.hasArg(options::OPT_E) &&
360 !Args.hasArg(options::OPT_c) && !Args.hasArg(options::OPT_S) &&
361 !Args.hasArg(options::OPT_emit_ast) &&
362 !llvm::sys::fs::exists(SDKLibDir)) {
363 D.Diag(clang::diag::warn_drv_unable_to_find_directory_expected)
364 << Twine(Platform,
" system libraries").str() << SDKLibDir << Whence;
371 const ArgList &DriverArgs,
372 ArgStringList &CC1Args)
const {
375 if (DriverArgs.hasArg(options::OPT_nostdinc))
378 if (!DriverArgs.hasArg(options::OPT_nobuiltininc)) {
380 llvm::sys::path::append(Dir,
"include");
381 addSystemInclude(DriverArgs, CC1Args, Dir.str());
384 if (DriverArgs.hasArg(options::OPT_nostdlibinc))
387 addExternCSystemInclude(DriverArgs, CC1Args,
388 SDKRootDir +
"/target/include");
389 addExternCSystemInclude(DriverArgs, CC1Args,
390 SDKRootDir +
"/target/include_common");
403 getDriver().Diag(clang::diag::err_no_external_assembler);
413 Res |= SanitizerKind::Address;
414 Res |= SanitizerKind::PointerCompare;
415 Res |= SanitizerKind::PointerSubtract;
416 Res |= SanitizerKind::Vptr;
422 Res |= SanitizerKind::Thread;
427 const ArgList &DriverArgs, ArgStringList &CC1Args,
430 if (DriverArgs.hasArg(options::OPT_fuse_init_array)) {
431 Arg *A = DriverArgs.getLastArg(options::OPT_fuse_init_array);
432 getDriver().Diag(clang::diag::err_drv_unsupported_opt_for_target)
433 << A->getAsString(DriverArgs) << getTriple().str();
436 CC1Args.push_back(
"-fno-use-init-array");
439 if (getTriple().isPS5() &&
440 !DriverArgs.hasArg(options::OPT_fvisibility_EQ,
441 options::OPT_fvisibility_ms_compat))
442 CC1Args.push_back(
"-fvisibility=hidden");
445 if (getTriple().isPS5() &&
446 !DriverArgs.hasArg(options::OPT_fvisibility_global_new_delete_EQ,
447 options::OPT_fvisibility_global_new_delete_hidden))
448 CC1Args.push_back(
"-fvisibility-global-new-delete=source");
451 DriverArgs.getLastArg(options::OPT_fvisibility_from_dllstorageclass,
452 options::OPT_fno_visibility_from_dllstorageclass);
454 A->getOption().matches(options::OPT_fvisibility_from_dllstorageclass)) {
455 CC1Args.push_back(
"-fvisibility-from-dllstorageclass");
457 if (DriverArgs.hasArg(options::OPT_fvisibility_dllexport_EQ))
458 DriverArgs.AddLastArg(CC1Args, options::OPT_fvisibility_dllexport_EQ);
460 CC1Args.push_back(
"-fvisibility-dllexport=protected");
464 if (DriverArgs.hasArg(options::OPT_fvisibility_nodllstorageclass_EQ))
465 DriverArgs.AddLastArg(CC1Args,
466 options::OPT_fvisibility_nodllstorageclass_EQ);
467 else if (getTriple().isPS4())
468 CC1Args.push_back(
"-fvisibility-nodllstorageclass=hidden");
470 CC1Args.push_back(
"-fvisibility-nodllstorageclass=keep");
472 if (DriverArgs.hasArg(options::OPT_fvisibility_externs_dllimport_EQ))
473 DriverArgs.AddLastArg(CC1Args,
474 options::OPT_fvisibility_externs_dllimport_EQ);
476 CC1Args.push_back(
"-fvisibility-externs-dllimport=default");
480 if (DriverArgs.hasArg(
481 options::OPT_fvisibility_externs_nodllstorageclass_EQ))
482 DriverArgs.AddLastArg(
483 CC1Args, options::OPT_fvisibility_externs_nodllstorageclass_EQ);
484 else if (getTriple().isPS4())
485 CC1Args.push_back(
"-fvisibility-externs-nodllstorageclass=default");
487 CC1Args.push_back(
"-fvisibility-externs-nodllstorageclass=keep");
493 const llvm::opt::ArgList &Args)
494 :
PS4PS5Base(
D, Triple, Args,
"PS4",
"SCE_ORBIS_SDK_DIR") {}
498 const llvm::opt::ArgList &Args)
499 :
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...
bool needsUbsanRt() const
The JSON file list parser is used to communicate input to InstallAPI.
static constexpr ResponseFileSupport AtFileUTF8()