15#include "clang/Config/config.h"
21#include "llvm/ADT/StringSwitch.h"
22#include "llvm/Option/ArgList.h"
23#include "llvm/ProfileData/InstrProf.h"
24#include "llvm/Support/Path.h"
25#include "llvm/Support/ScopedPrinter.h"
26#include "llvm/Support/Threading.h"
27#include "llvm/Support/VirtualFileSystem.h"
28#include "llvm/TargetParser/TargetParser.h"
29#include "llvm/TargetParser/Triple.h"
39 return VersionTuple(13, 1);
55 return llvm::StringSwitch<llvm::Triple::ArchType>(Str)
56 .Cases(
"i386",
"i486",
"i486SX",
"i586",
"i686", llvm::Triple::x86)
57 .Cases(
"pentium",
"pentpro",
"pentIIm3",
"pentIIm5",
"pentium4",
59 .Cases(
"x86_64",
"x86_64h", llvm::Triple::x86_64)
61 .Cases(
"arm",
"armv4t",
"armv5",
"armv6",
"armv6m", llvm::Triple::arm)
62 .Cases(
"armv7",
"armv7em",
"armv7k",
"armv7m", llvm::Triple::arm)
63 .Cases(
"armv7s",
"xscale", llvm::Triple::arm)
64 .Cases(
"arm64",
"arm64e", llvm::Triple::aarch64)
65 .Case(
"arm64_32", llvm::Triple::aarch64_32)
66 .Case(
"r600", llvm::Triple::r600)
67 .Case(
"amdgcn", llvm::Triple::amdgcn)
68 .Case(
"nvptx", llvm::Triple::nvptx)
69 .Case(
"nvptx64", llvm::Triple::nvptx64)
70 .Case(
"amdil", llvm::Triple::amdil)
71 .Case(
"spir", llvm::Triple::spir)
72 .Default(llvm::Triple::UnknownArch);
76 const ArgList &Args) {
77 const llvm::Triple::ArchType Arch = getArchTypeForMachOArchName(Str);
78 llvm::ARM::ArchKind ArchKind = llvm::ARM::parseArch(Str);
80 if (Arch != llvm::Triple::UnknownArch)
83 if (ArchKind == llvm::ARM::ArchKind::ARMV6M ||
84 ArchKind == llvm::ARM::ArchKind::ARMV7M ||
85 ArchKind == llvm::ARM::ArchKind::ARMV7EM) {
87 if (
T.getOS() == llvm::Triple::IOS)
88 for (Arg *A : Args.filtered(options::OPT_mios_version_min_EQ))
89 A->ignoreTargetSpecific();
90 if (
T.getOS() == llvm::Triple::WatchOS)
91 for (Arg *A : Args.filtered(options::OPT_mwatchos_version_min_EQ))
92 A->ignoreTargetSpecific();
93 if (
T.getOS() == llvm::Triple::TvOS)
94 for (Arg *A : Args.filtered(options::OPT_mtvos_version_min_EQ))
95 A->ignoreTargetSpecific();
97 T.setOS(llvm::Triple::UnknownOS);
98 T.setObjectFormat(llvm::Triple::MachO);
106 const char *LinkingOutput)
const {
109 ArgStringList CmdArgs;
111 assert(Inputs.size() == 1 &&
"Unexpected number of inputs.");
115 const Action *SourceAction = &JA;
117 assert(!SourceAction->
getInputs().empty() &&
"unexpected root action!");
118 SourceAction = SourceAction->
getInputs()[0];
126 if (Args.hasArg(options::OPT_fno_integrated_as)) {
127 if (!(
T.isMacOSX() &&
T.isMacOSXVersionLT(10, 7)))
128 CmdArgs.push_back(
"-Q");
132 if (SourceAction->
getType() == types::TY_Asm ||
133 SourceAction->
getType() == types::TY_PP_Asm) {
134 if (Args.hasArg(options::OPT_gstabs))
135 CmdArgs.push_back(
"--gstabs");
136 else if (Args.hasArg(options::OPT_g_Group))
137 CmdArgs.push_back(
"-g");
144 if (
T.isX86() || Args.hasArg(options::OPT_force__cpusubtype__ALL))
145 CmdArgs.push_back(
"-force_cpusubtype_ALL");
148 (((Args.hasArg(options::OPT_mkernel) ||
149 Args.hasArg(options::OPT_fapple_kext)) &&
151 Args.hasArg(options::OPT_static)))
152 CmdArgs.push_back(
"-static");
154 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
156 assert(Output.
isFilename() &&
"Unexpected lipo output.");
157 CmdArgs.push_back(
"-o");
160 assert(Input.
isFilename() &&
"Invalid input.");
165 const char *Exec = Args.MakeArgString(
getToolChain().GetProgramPath(
"as"));
167 Exec, CmdArgs, Inputs, Output));
170void darwin::MachOTool::anchor() {}
173 ArgStringList &CmdArgs)
const {
174 StringRef ArchName = getMachOToolChain().getMachOArchName(Args);
177 CmdArgs.push_back(
"-arch");
178 CmdArgs.push_back(Args.MakeArgString(ArchName));
181 if (ArchName ==
"arm")
182 CmdArgs.push_back(
"-force_cpusubtype_ALL");
185bool darwin::Linker::NeedsTempPath(
const InputInfoList &Inputs)
const {
189 for (
const auto &Input : Inputs)
190 if (Input.getType() != types::TY_Object)
204 if (Arg *A = Args.getLastArg(options::OPT_O_Group)) {
205 if (A->getOption().matches(options::OPT_O0))
207 if (A->getOption().matches(options::OPT_O))
208 return llvm::StringSwitch<bool>(A->getValue())
214 if (!IsLinkerOnlyAction)
219void darwin::Linker::AddLinkArgs(
Compilation &
C,
const ArgList &Args,
220 ArgStringList &CmdArgs,
222 VersionTuple Version,
bool LinkerIsLLD,
223 bool UsePlatformVersion)
const {
224 const Driver &
D = getToolChain().getDriver();
229 if ((Version >= VersionTuple(100) || LinkerIsLLD) &&
230 !Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
231 CmdArgs.push_back(
"-demangle");
233 if (Args.hasArg(options::OPT_rdynamic) &&
234 (Version >= VersionTuple(137) || LinkerIsLLD))
235 CmdArgs.push_back(
"-export_dynamic");
239 if (Args.hasFlag(options::OPT_fapplication_extension,
240 options::OPT_fno_application_extension,
false))
241 CmdArgs.push_back(
"-application_extension");
243 if (
D.isUsingLTO() && (Version >= VersionTuple(116) || LinkerIsLLD) &&
244 NeedsTempPath(Inputs)) {
245 std::string TmpPathName;
254 TmpPathName =
D.GetTemporaryDirectory(
"thinlto");
256 if (!TmpPathName.empty()) {
257 auto *TmpPath =
C.getArgs().MakeArgString(TmpPathName);
258 C.addTempFile(TmpPath);
259 CmdArgs.push_back(
"-object_path_lto");
260 CmdArgs.push_back(TmpPath);
273 if (Version >= VersionTuple(133) && !LinkerIsLLD) {
275 StringRef
P = llvm::sys::path::parent_path(
D.Dir);
277 llvm::sys::path::append(LibLTOPath,
"lib");
278 llvm::sys::path::append(LibLTOPath,
"libLTO.dylib");
279 CmdArgs.push_back(
"-lto_library");
280 CmdArgs.push_back(
C.getArgs().MakeArgString(LibLTOPath));
286 if (Version >= VersionTuple(262) &&
288 CmdArgs.push_back(
"-no_deduplicate");
291 Args.AddAllArgs(CmdArgs, options::OPT_static);
292 if (!Args.hasArg(options::OPT_static))
293 CmdArgs.push_back(
"-dynamic");
294 if (Args.hasArg(options::OPT_fgnu_runtime)) {
299 if (!Args.hasArg(options::OPT_dynamiclib)) {
300 AddMachOArch(Args, CmdArgs);
302 Args.AddLastArg(CmdArgs, options::OPT_force__cpusubtype__ALL);
304 Args.AddLastArg(CmdArgs, options::OPT_bundle);
305 Args.AddAllArgs(CmdArgs, options::OPT_bundle__loader);
306 Args.AddAllArgs(CmdArgs, options::OPT_client__name);
309 if ((A = Args.getLastArg(options::OPT_compatibility__version)) ||
310 (A = Args.getLastArg(options::OPT_current__version)) ||
311 (A = Args.getLastArg(options::OPT_install__name)))
312 D.Diag(diag::err_drv_argument_only_allowed_with) << A->getAsString(Args)
315 Args.AddLastArg(CmdArgs, options::OPT_force__flat__namespace);
316 Args.AddLastArg(CmdArgs, options::OPT_keep__private__externs);
317 Args.AddLastArg(CmdArgs, options::OPT_private__bundle);
319 CmdArgs.push_back(
"-dylib");
322 if ((A = Args.getLastArg(options::OPT_bundle)) ||
323 (A = Args.getLastArg(options::OPT_bundle__loader)) ||
324 (A = Args.getLastArg(options::OPT_client__name)) ||
325 (A = Args.getLastArg(options::OPT_force__flat__namespace)) ||
326 (A = Args.getLastArg(options::OPT_keep__private__externs)) ||
327 (A = Args.getLastArg(options::OPT_private__bundle)))
328 D.Diag(diag::err_drv_argument_not_allowed_with) << A->getAsString(Args)
331 Args.AddAllArgsTranslated(CmdArgs, options::OPT_compatibility__version,
332 "-dylib_compatibility_version");
333 Args.AddAllArgsTranslated(CmdArgs, options::OPT_current__version,
334 "-dylib_current_version");
336 AddMachOArch(Args, CmdArgs);
338 Args.AddAllArgsTranslated(CmdArgs, options::OPT_install__name,
339 "-dylib_install_name");
342 Args.AddLastArg(CmdArgs, options::OPT_all__load);
343 Args.AddAllArgs(CmdArgs, options::OPT_allowable__client);
344 Args.AddLastArg(CmdArgs, options::OPT_bind__at__load);
346 Args.AddLastArg(CmdArgs, options::OPT_arch__errors__fatal);
347 Args.AddLastArg(CmdArgs, options::OPT_dead__strip);
348 Args.AddLastArg(CmdArgs, options::OPT_no__dead__strip__inits__and__terms);
349 Args.AddAllArgs(CmdArgs, options::OPT_dylib__file);
350 Args.AddLastArg(CmdArgs, options::OPT_dynamic);
351 Args.AddAllArgs(CmdArgs, options::OPT_exported__symbols__list);
352 Args.AddLastArg(CmdArgs, options::OPT_flat__namespace);
353 Args.AddAllArgs(CmdArgs, options::OPT_force__load);
354 Args.AddAllArgs(CmdArgs, options::OPT_headerpad__max__install__names);
355 Args.AddAllArgs(CmdArgs, options::OPT_image__base);
356 Args.AddAllArgs(CmdArgs, options::OPT_init);
359 if (Version >= VersionTuple(520) || LinkerIsLLD || UsePlatformVersion)
364 Args.AddLastArg(CmdArgs, options::OPT_nomultidefs);
365 Args.AddLastArg(CmdArgs, options::OPT_multi__module);
366 Args.AddLastArg(CmdArgs, options::OPT_single__module);
367 Args.AddAllArgs(CmdArgs, options::OPT_multiply__defined);
368 Args.AddAllArgs(CmdArgs, options::OPT_multiply__defined__unused);
371 Args.getLastArg(options::OPT_fpie, options::OPT_fPIE,
372 options::OPT_fno_pie, options::OPT_fno_PIE)) {
373 if (A->getOption().matches(options::OPT_fpie) ||
374 A->getOption().matches(options::OPT_fPIE))
375 CmdArgs.push_back(
"-pie");
377 CmdArgs.push_back(
"-no_pie");
381 if (
C.getDriver().embedBitcodeEnabled()) {
384 CmdArgs.push_back(
"-bitcode_bundle");
386 if (
C.getDriver().embedBitcodeMarkerOnly() &&
387 Version >= VersionTuple(278)) {
388 CmdArgs.push_back(
"-bitcode_process_mode");
389 CmdArgs.push_back(
"marker");
392 D.Diag(diag::err_drv_bitcode_unsupported_on_toolchain);
396 if (Arg *A = Args.getLastArg(options::OPT_fglobal_isel,
397 options::OPT_fno_global_isel)) {
398 if (A->getOption().matches(options::OPT_fglobal_isel)) {
399 CmdArgs.push_back(
"-mllvm");
400 CmdArgs.push_back(
"-global-isel");
402 CmdArgs.push_back(
"-mllvm");
403 CmdArgs.push_back(
"-global-isel-abort=0");
407 if (Args.hasArg(options::OPT_mkernel) ||
408 Args.hasArg(options::OPT_fapple_kext) ||
409 Args.hasArg(options::OPT_ffreestanding)) {
410 CmdArgs.push_back(
"-mllvm");
411 CmdArgs.push_back(
"-disable-atexit-based-global-dtor-lowering");
414 Args.AddLastArg(CmdArgs, options::OPT_prebind);
415 Args.AddLastArg(CmdArgs, options::OPT_noprebind);
416 Args.AddLastArg(CmdArgs, options::OPT_nofixprebinding);
417 Args.AddLastArg(CmdArgs, options::OPT_prebind__all__twolevel__modules);
418 Args.AddLastArg(CmdArgs, options::OPT_read__only__relocs);
419 Args.AddAllArgs(CmdArgs, options::OPT_sectcreate);
420 Args.AddAllArgs(CmdArgs, options::OPT_sectorder);
421 Args.AddAllArgs(CmdArgs, options::OPT_seg1addr);
422 Args.AddAllArgs(CmdArgs, options::OPT_segprot);
423 Args.AddAllArgs(CmdArgs, options::OPT_segaddr);
424 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__only__addr);
425 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__write__addr);
426 Args.AddAllArgs(CmdArgs, options::OPT_seg__addr__table);
427 Args.AddAllArgs(CmdArgs, options::OPT_seg__addr__table__filename);
428 Args.AddAllArgs(CmdArgs, options::OPT_sub__library);
429 Args.AddAllArgs(CmdArgs, options::OPT_sub__umbrella);
435 if (
const Arg *A = Args.getLastArg(options::OPT__sysroot_EQ)) {
436 CmdArgs.push_back(
"-syslibroot");
437 CmdArgs.push_back(A->getValue());
438 }
else if (
const Arg *A = Args.getLastArg(options::OPT_isysroot)) {
439 CmdArgs.push_back(
"-syslibroot");
440 CmdArgs.push_back(A->getValue());
441 }
else if (StringRef sysroot =
C.getSysRoot(); sysroot !=
"") {
442 CmdArgs.push_back(
"-syslibroot");
443 CmdArgs.push_back(
C.getArgs().MakeArgString(sysroot));
446 Args.AddLastArg(CmdArgs, options::OPT_twolevel__namespace);
447 Args.AddLastArg(CmdArgs, options::OPT_twolevel__namespace__hints);
448 Args.AddAllArgs(CmdArgs, options::OPT_umbrella);
449 Args.AddAllArgs(CmdArgs, options::OPT_undefined);
450 Args.AddAllArgs(CmdArgs, options::OPT_unexported__symbols__list);
451 Args.AddAllArgs(CmdArgs, options::OPT_weak__reference__mismatches);
452 Args.AddLastArg(CmdArgs, options::OPT_X_Flag);
453 Args.AddAllArgs(CmdArgs, options::OPT_y);
454 Args.AddLastArg(CmdArgs, options::OPT_w);
455 Args.AddAllArgs(CmdArgs, options::OPT_pagezero__size);
456 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__);
457 Args.AddLastArg(CmdArgs, options::OPT_seglinkedit);
458 Args.AddLastArg(CmdArgs, options::OPT_noseglinkedit);
459 Args.AddAllArgs(CmdArgs, options::OPT_sectalign);
460 Args.AddAllArgs(CmdArgs, options::OPT_sectobjectsymbols);
461 Args.AddAllArgs(CmdArgs, options::OPT_segcreate);
462 Args.AddLastArg(CmdArgs, options::OPT_why_load);
463 Args.AddLastArg(CmdArgs, options::OPT_whatsloaded);
464 Args.AddAllArgs(CmdArgs, options::OPT_dylinker__install__name);
465 Args.AddLastArg(CmdArgs, options::OPT_dylinker);
466 Args.AddLastArg(CmdArgs, options::OPT_Mach);
472 : CSPGOGenerateArg->getValue());
473 llvm::sys::path::append(
Path,
"default_%m.profraw");
474 CmdArgs.push_back(
"--cs-profile-generate");
475 CmdArgs.push_back(Args.MakeArgString(Twine(
"--cs-profile-path=") +
Path));
478 ProfileUseArg->getNumValues() == 0 ?
"" : ProfileUseArg->getValue());
479 if (
Path.empty() || llvm::sys::fs::is_directory(
Path))
480 llvm::sys::path::append(
Path,
"default.profdata");
481 CmdArgs.push_back(Args.MakeArgString(Twine(
"--cs-profile-path=") +
Path));
484 auto *CodeGenDataGenArg =
485 Args.getLastArg(options::OPT_fcodegen_data_generate_EQ);
486 if (CodeGenDataGenArg)
488 Args.MakeArgString(Twine(
"--codegen-data-generate-path=") +
489 CodeGenDataGenArg->getValue()));
496 Args.ClaimAllArgs(options::OPT_fobjc_link_runtime);
499 return Args.hasArg(options::OPT_fobjc_link_runtime);
503 const llvm::Triple &Triple) {
508 Args.getAllArgValues(options::OPT_arch).size() > 1;
509 bool hasExplicitOutputFile =
510 Args.getLastArg(options::OPT_foptimization_record_file_EQ);
512 D.Diag(diag::err_drv_invalid_output_with_multiple_archs)
513 <<
"-foptimization-record-file";
520 const llvm::Triple &Triple,
522 StringRef Format =
"yaml";
523 if (
const Arg *A = Args.getLastArg(options::OPT_fsave_optimization_record_EQ))
524 Format = A->getValue();
526 CmdArgs.push_back(
"-mllvm");
527 CmdArgs.push_back(
"-lto-pass-remarks-output");
528 CmdArgs.push_back(
"-mllvm");
530 const Arg *A = Args.getLastArg(options::OPT_foptimization_record_file_EQ);
532 CmdArgs.push_back(A->getValue());
534 assert(Output.
isFilename() &&
"Unexpected ld output.");
540 CmdArgs.push_back(Args.MakeArgString(F));
544 Args.getLastArg(options::OPT_foptimization_record_passes_EQ)) {
545 CmdArgs.push_back(
"-mllvm");
547 std::string(
"-lto-pass-remarks-filter=") + A->getValue();
548 CmdArgs.push_back(Args.MakeArgString(Passes));
551 if (!Format.empty()) {
552 CmdArgs.push_back(
"-mllvm");
553 Twine FormatArg = Twine(
"-lto-pass-remarks-format=") + Format;
554 CmdArgs.push_back(Args.MakeArgString(FormatArg));
558 CmdArgs.push_back(
"-mllvm");
559 CmdArgs.push_back(
"-lto-pass-remarks-with-hotness");
562 Args.getLastArg(options::OPT_fdiagnostics_hotness_threshold_EQ)) {
563 CmdArgs.push_back(
"-mllvm");
565 std::string(
"-lto-pass-remarks-hotness-threshold=") + A->getValue();
566 CmdArgs.push_back(Args.MakeArgString(Opt));
577 const char *LinkingOutput)
const {
578 assert(Output.
getType() == types::TY_Image &&
"Invalid linker output type.");
584 llvm::opt::ArgStringList InputFileList;
589 ArgStringList CmdArgs;
591 VersionTuple Version = getMachOToolChain().getLinkerVersion(Args);
595 Args.MakeArgString(getToolChain().GetLinkerPath(&LinkerIsLLD));
598 bool UsePlatformVersion = getToolChain().getTriple().isXROS();
602 AddLinkArgs(
C, Args, CmdArgs, Inputs, Version, LinkerIsLLD,
607 getToolChain().getTriple()))
612 Args.getLastArg(options::OPT_moutline, options::OPT_mno_outline)) {
613 if (A->getOption().matches(options::OPT_moutline)) {
614 if (getMachOToolChain().getMachOArchName(Args) ==
"arm64") {
615 CmdArgs.push_back(
"-mllvm");
616 CmdArgs.push_back(
"-enable-machine-outliner");
622 CmdArgs.push_back(
"-mllvm");
623 CmdArgs.push_back(
"-enable-machine-outliner=never");
630 CmdArgs.push_back(
"-mllvm");
631 CmdArgs.push_back(
"-enable-linkonceodr-outlining");
634 auto *CodeGenDataGenArg =
635 Args.getLastArg(options::OPT_fcodegen_data_generate_EQ);
636 auto *CodeGenDataUseArg = Args.getLastArg(options::OPT_fcodegen_data_use_EQ);
639 const Driver &
D = getToolChain().getDriver();
640 if (CodeGenDataGenArg && CodeGenDataUseArg)
641 D.Diag(diag::err_drv_argument_not_allowed_with)
642 << CodeGenDataGenArg->getAsString(Args)
643 << CodeGenDataUseArg->getAsString(Args);
647 if (CodeGenDataGenArg) {
648 CmdArgs.push_back(
"-mllvm");
649 CmdArgs.push_back(
"-codegen-data-generate");
653 if (CodeGenDataUseArg) {
654 CmdArgs.push_back(
"-mllvm");
655 CmdArgs.push_back(Args.MakeArgString(Twine(
"-codegen-data-use-path=") +
656 CodeGenDataUseArg->getValue()));
662 if (!StatsFile.empty()) {
663 CmdArgs.push_back(
"-mllvm");
664 CmdArgs.push_back(Args.MakeArgString(
"-lto-stats-file=" + StatsFile.str()));
669 Args.addAllArgs(CmdArgs, {options::OPT_d_Flag, options::OPT_s, options::OPT_t,
670 options::OPT_Z_Flag, options::OPT_u_Group});
675 if (Args.hasArg(options::OPT_ObjC) || Args.hasArg(options::OPT_ObjCXX))
676 CmdArgs.push_back(
"-ObjC");
678 CmdArgs.push_back(
"-o");
681 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles))
682 getMachOToolChain().addStartObjectFileArgs(Args, CmdArgs);
684 Args.AddAllArgs(CmdArgs, options::OPT_L);
689 for (
const auto &II : Inputs) {
690 if (!II.isFilename()) {
695 if (InputFileList.size() > 0)
701 InputFileList.push_back(II.getFilename());
706 if (getToolChain().getDriver().IsFlangMode() &&
707 !Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs)) {
712 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs))
716 !Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs)) {
718 getMachOToolChain().AddLinkARCArgs(Args, CmdArgs);
720 CmdArgs.push_back(
"-framework");
721 CmdArgs.push_back(
"Foundation");
723 CmdArgs.push_back(
"-lobjc");
727 CmdArgs.push_back(
"-arch_multiple");
728 CmdArgs.push_back(
"-final_output");
729 CmdArgs.push_back(LinkingOutput);
732 if (Args.hasArg(options::OPT_fnested_functions))
733 CmdArgs.push_back(
"-allow_stack_execute");
735 getMachOToolChain().addProfileRTLibs(Args, CmdArgs);
738 if (!Parallelism.empty()) {
739 CmdArgs.push_back(
"-mllvm");
740 unsigned NumThreads =
741 llvm::get_threadpool_strategy(Parallelism)->compute_thread_count();
742 CmdArgs.push_back(Args.MakeArgString(
"-threads=" + Twine(NumThreads)));
745 if (getToolChain().ShouldLinkCXXStdlib(Args))
746 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
748 bool NoStdOrDefaultLibs =
749 Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs);
750 bool ForceLinkBuiltins = Args.hasArg(options::OPT_fapple_link_rtlib);
751 if (!NoStdOrDefaultLibs || ForceLinkBuiltins) {
756 if (NoStdOrDefaultLibs && ForceLinkBuiltins) {
757 getMachOToolChain().AddLinkRuntimeLib(Args, CmdArgs,
"builtins");
760 getMachOToolChain().AddLinkRuntimeLibArgs(Args, CmdArgs,
764 Args.ClaimAllArgs(options::OPT_pthread);
765 Args.ClaimAllArgs(options::OPT_pthreads);
769 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) {
773 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
774 Args.AddAllArgs(CmdArgs, options::OPT_F);
777 for (
const Arg *A : Args.filtered(options::OPT_iframework))
778 CmdArgs.push_back(Args.MakeArgString(std::string(
"-F") + A->getValue()));
780 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs)) {
781 if (Arg *A = Args.getLastArg(options::OPT_fveclib)) {
782 if (A->getValue() == StringRef(
"Accelerate")) {
783 CmdArgs.push_back(
"-framework");
784 CmdArgs.push_back(
"Accelerate");
793 bool NonStandardSearchPath =
false;
794 const auto &Triple = getToolChain().getTriple();
795 if (Triple.isDriverKit()) {
797 NonStandardSearchPath =
798 Version.getMajor() < 605 ||
799 (Version.getMajor() == 605 && Version.getMinor().value_or(0) < 1);
802 if (NonStandardSearchPath) {
803 if (
auto *Sysroot = Args.getLastArg(options::OPT_isysroot)) {
804 auto AddSearchPath = [&](StringRef Flag, StringRef SearchPath) {
807 llvm::sys::path::append(
P, SearchPath);
808 if (getToolChain().getVFS().exists(
P)) {
809 CmdArgs.push_back(Args.MakeArgString(Flag +
P));
812 AddSearchPath(
"-L",
"/usr/lib");
813 AddSearchPath(
"-F",
"/System/Library/Frameworks");
819 if (Version >= VersionTuple(705) || LinkerIsLLD) {
827 std::unique_ptr<Command>
Cmd = std::make_unique<Command>(
828 JA, *
this, ResponseSupport, Exec, CmdArgs, Inputs, Output);
829 Cmd->setInputFileList(std::move(InputFileList));
830 C.addCommand(std::move(
Cmd));
837 const char *LinkingOutput)
const {
838 const Driver &
D = getToolChain().getDriver();
841 Args.ClaimAllArgs(options::OPT_g_Group);
843 Args.ClaimAllArgs(options::OPT_emit_llvm);
846 Args.ClaimAllArgs(options::OPT_w);
848 Args.ClaimAllArgs(options::OPT_stdlib_EQ);
851 ArgStringList CmdArgs;
853 CmdArgs.push_back(
"-static");
854 CmdArgs.push_back(
"-D");
855 CmdArgs.push_back(
"-no_warning_for_no_symbols");
856 CmdArgs.push_back(
"-o");
859 for (
const auto &II : Inputs) {
860 if (II.isFilename()) {
861 CmdArgs.push_back(II.getFilename());
868 if (Output.
isFilename() && llvm::sys::fs::exists(OutputFileName)) {
869 if (std::error_code EC = llvm::sys::fs::remove(OutputFileName)) {
870 D.Diag(diag::err_drv_unable_to_remove_file) << EC.message();
875 const char *Exec = Args.MakeArgString(getToolChain().GetStaticLibToolPath());
876 C.addCommand(std::make_unique<Command>(JA, *
this,
878 Exec, CmdArgs, Inputs, Output));
885 const char *LinkingOutput)
const {
886 ArgStringList CmdArgs;
888 CmdArgs.push_back(
"-create");
889 assert(Output.
isFilename() &&
"Unexpected lipo output.");
891 CmdArgs.push_back(
"-output");
894 for (
const auto &II : Inputs) {
895 assert(II.isFilename() &&
"Unexpected lipo input.");
896 CmdArgs.push_back(II.getFilename());
899 StringRef LipoName = Args.getLastArgValue(options::OPT_fuse_lipo_EQ,
"lipo");
901 Args.MakeArgString(getToolChain().GetProgramPath(LipoName.data()));
903 Exec, CmdArgs, Inputs, Output));
910 const char *LinkingOutput)
const {
911 ArgStringList CmdArgs;
913 CmdArgs.push_back(
"-o");
916 assert(Inputs.size() == 1 &&
"Unable to handle multiple inputs.");
918 assert(Input.
isFilename() &&
"Unexpected dsymutil input.");
922 Args.MakeArgString(getToolChain().GetProgramPath(
"dsymutil"));
924 Exec, CmdArgs, Inputs, Output));
931 const char *LinkingOutput)
const {
932 ArgStringList CmdArgs;
933 CmdArgs.push_back(
"--verify");
934 CmdArgs.push_back(
"--debug-info");
935 CmdArgs.push_back(
"--eh-frame");
936 CmdArgs.push_back(
"--quiet");
938 assert(Inputs.size() == 1 &&
"Unable to handle multiple inputs.");
940 assert(Input.
isFilename() &&
"Unexpected verify input");
946 Args.MakeArgString(getToolChain().GetProgramPath(
"dwarfdump"));
948 Exec, CmdArgs, Inputs, Output));
959 :
MachO(
D, Triple, Args), CudaInstallation(
D, Triple, Args),
960 RocmInstallation(
D, Triple, Args), SYCLInstallation(
D, Triple, Args) {}
970 if (Ty == types::TY_PP_Asm)
971 return types::TY_Asm;
991 auto T = llvm::Triple(Twine(
"arm64-apple-") +
992 llvm::Triple::getOSTypeName(llvm::Triple::XROS) +
1014 ArgStringList &CC1Args)
const {
1019 ArgStringList &CC1Args)
const {
1024 ArgStringList &CC1Args)
const {
1033 return llvm::StringSwitch<const char *>(Arch)
1034 .Case(
"armv6k",
"armv6")
1035 .Case(
"armv6m",
"armv6m")
1036 .Case(
"armv5tej",
"armv5")
1037 .Case(
"xscale",
"xscale")
1038 .Case(
"armv4t",
"armv4t")
1039 .Case(
"armv7",
"armv7")
1040 .Cases(
"armv7a",
"armv7-a",
"armv7")
1041 .Cases(
"armv7r",
"armv7-r",
"armv7")
1042 .Cases(
"armv7em",
"armv7e-m",
"armv7em")
1043 .Cases(
"armv7k",
"armv7-k",
"armv7k")
1044 .Cases(
"armv7m",
"armv7-m",
"armv7m")
1045 .Cases(
"armv7s",
"armv7-s",
"armv7s")
1050 llvm::ARM::ArchKind ArchKind = llvm::ARM::parseCPUArch(CPU);
1051 if (ArchKind == llvm::ARM::ArchKind::INVALID)
1053 StringRef Arch = llvm::ARM::getArchName(ArchKind);
1057 if (Arch.starts_with(
"armv5"))
1058 Arch = Arch.substr(0, 5);
1060 else if (Arch.starts_with(
"armv6") && !Arch.ends_with(
"6m"))
1061 Arch = Arch.substr(0, 5);
1063 else if (Arch.ends_with(
"v7a"))
1064 Arch = Arch.substr(0, 5);
1073 case llvm::Triple::aarch64_32:
1076 case llvm::Triple::aarch64: {
1082 case llvm::Triple::thumb:
1083 case llvm::Triple::arm:
1084 if (
const Arg *A = Args.getLastArg(clang::driver::options::OPT_march_EQ))
1088 if (
const Arg *A = Args.getLastArg(options::OPT_mcpu_EQ))
1097 if (LinkerVersion) {
1099 VersionTuple NewLinkerVersion;
1100 if (Arg *A = Args.getLastArg(options::OPT_mlinker_version_EQ))
1101 (void)NewLinkerVersion.tryParse(A->getValue());
1102 assert(NewLinkerVersion == LinkerVersion);
1104 return *LinkerVersion;
1107 VersionTuple NewLinkerVersion;
1108 if (Arg *A = Args.getLastArg(options::OPT_mlinker_version_EQ))
1109 if (NewLinkerVersion.tryParse(A->getValue()))
1111 << A->getAsString(Args);
1113 LinkerVersion = NewLinkerVersion;
1114 return *LinkerVersion;
1130 return Triple.getTriple();
1142 Str += llvm::Triple::getOSTypeName(llvm::Triple::XROS);
1146 Triple.setOSName(Str);
1148 return Triple.getTriple();
1160 return Dsymutil.get();
1164 return VerifyDebug.get();
1181 const ArgList &Args)
1186 CC1Args.push_back(
"-Wundef-prefix=TARGET_OS_");
1187 CC1Args.push_back(
"-Werror=undef-prefix");
1193 CC1Args.push_back(
"-Wdeprecated-objc-isa-usage");
1194 CC1Args.push_back(
"-Werror=deprecated-objc-isa-usage");
1199 CC1Args.push_back(
"-Werror=implicit-function-declaration");
1207 static constexpr llvm::StringLiteral XcodeAppSuffix(
1208 ".app/Contents/Developer");
1209 size_t Index = PathIntoXcode.find(XcodeAppSuffix);
1210 if (Index == StringRef::npos)
1212 return PathIntoXcode.take_front(Index + XcodeAppSuffix.size());
1216 ArgStringList &CmdArgs)
const {
1235 llvm::sys::path::remove_filename(
P);
1236 llvm::sys::path::remove_filename(
P);
1237 llvm::sys::path::append(
P,
"lib",
"arc");
1244 auto updatePath = [&](
const Arg *A) {
1248 if (XcodePathForSDK.empty())
1251 P = XcodePathForSDK;
1252 llvm::sys::path::append(
P,
"Toolchains/XcodeDefault.xctoolchain/usr",
1257 bool updated =
false;
1258 if (
const Arg *A = Args.getLastArg(options::OPT_isysroot))
1259 updated = updatePath(A);
1262 if (
const Arg *A = Args.getLastArg(options::OPT__sysroot_EQ))
1267 CmdArgs.push_back(
"-force_load");
1268 llvm::sys::path::append(
P,
"libarclite_");
1271 P +=
"watchsimulator";
1275 P +=
"appletvsimulator";
1279 P +=
"iphonesimulator";
1287 getDriver().
Diag(clang::diag::err_drv_darwin_sdk_missing_arclite) <<
P;
1289 CmdArgs.push_back(Args.MakeArgString(
P));
1311 bool IsShared)
const {
1319 const char *LibArg = Args.MakeArgString(
P);
1320 CmdArgs.push_back(LibArg);
1328 assert(StringRef(
P).ends_with(
".dylib") &&
"must be a dynamic library");
1332 CmdArgs.push_back(
"-rpath");
1333 CmdArgs.push_back(
"@executable_path");
1337 CmdArgs.push_back(
"-rpath");
1338 CmdArgs.push_back(Args.MakeArgString(llvm::sys::path::parent_path(
P)));
1345 "it doesn't make sense to ask for the compiler-rt library name as an "
1349 if (Component !=
"builtins") {
1350 MachOLibName +=
'.';
1351 MachOLibName += Component;
1356 llvm::sys::path::append(FullPath,
"lib",
"darwin",
"macho_embedded",
1358 return std::string(FullPath);
1364 "it doesn't make sense to ask for the compiler-rt library name as an "
1368 if (Component !=
"builtins") {
1369 DarwinLibName += Component;
1370 DarwinLibName +=
'_';
1376 llvm::sys::path::append(FullPath,
"lib",
"darwin", DarwinLibName);
1377 return std::string(FullPath);
1397 llvm_unreachable(
"Unsupported platform");
1402 auto BeginSDK = llvm::sys::path::rbegin(isysroot);
1403 auto EndSDK = llvm::sys::path::rend(isysroot);
1404 for (
auto IT = BeginSDK; IT != EndSDK; ++IT) {
1405 StringRef SDK = *IT;
1406 if (SDK.ends_with(
".sdk"))
1407 return SDK.slice(0, SDK.size() - 4);
1433 llvm_unreachable(
"Unsupported platform");
1438 for (Arg *A : Args) {
1439 if (A->getOption().matches(options::OPT_exported__symbols__list))
1441 if (!A->getOption().matches(options::OPT_Wl_COMMA) &&
1442 !A->getOption().matches(options::OPT_Xlinker))
1444 if (A->containsValue(
"-exported_symbols_list") ||
1445 A->containsValue(
"-exported_symbol"))
1453 CmdArgs.push_back(
"-exported_symbol");
1454 CmdArgs.push_back(Symbol);
1464 StringRef Segment, StringRef Section) {
1465 for (
const char *A : {
"-sectalign", Args.MakeArgString(Segment),
1466 Args.MakeArgString(Section),
"0x4000"})
1467 CmdArgs.push_back(A);
1471 ArgStringList &CmdArgs)
const {
1500 for (
auto IPSK : {llvm::IPSK_cnts, llvm::IPSK_bitmap, llvm::IPSK_data}) {
1502 Args, CmdArgs,
"__DATA",
1503 llvm::getInstrProfSectionName(IPSK, llvm::Triple::MachO,
1509void DarwinClang::AddLinkSanitizerLibArgs(
const ArgList &Args,
1510 ArgStringList &CmdArgs,
1511 StringRef Sanitizer,
1512 bool Shared)
const {
1518 const ArgList &Args)
const {
1519 if (Arg* A = Args.getLastArg(options::OPT_rtlib_EQ)) {
1520 StringRef
Value = A->getValue();
1521 if (
Value !=
"compiler-rt" &&
Value !=
"platform")
1522 getDriver().
Diag(clang::diag::err_drv_unsupported_rtlib_for_platform)
1523 <<
Value <<
"darwin";
1530 ArgStringList &CmdArgs,
1531 bool ForceLinkBuiltinRT)
const {
1537 if (Args.hasArg(options::OPT_static) ||
1538 Args.hasArg(options::OPT_fapple_kext) ||
1539 Args.hasArg(options::OPT_mkernel)) {
1540 if (ForceLinkBuiltinRT)
1548 if (
const Arg *A = Args.getLastArg(options::OPT_static_libgcc)) {
1549 getDriver().
Diag(diag::err_drv_unsupported_opt) << A->getAsString(Args);
1556 const char *sanitizer =
nullptr;
1558 sanitizer =
"UndefinedBehaviorSanitizer";
1560 sanitizer =
"RealtimeSanitizer";
1562 sanitizer =
"AddressSanitizer";
1564 sanitizer =
"ThreadSanitizer";
1567 getDriver().
Diag(diag::err_drv_unsupported_static_sanitizer_darwin)
1576 AddLinkSanitizerLibArgs(Args, CmdArgs,
"asan_abi",
false);
1579 "Static sanitizer runtimes not supported");
1580 AddLinkSanitizerLibArgs(Args, CmdArgs,
"asan");
1585 "Static sanitizer runtimes not supported");
1586 AddLinkSanitizerLibArgs(Args, CmdArgs,
"rtsan");
1589 AddLinkSanitizerLibArgs(Args, CmdArgs,
"lsan");
1592 "Static sanitizer runtimes not supported");
1593 AddLinkSanitizerLibArgs(
1599 "Static sanitizer runtimes not supported");
1600 AddLinkSanitizerLibArgs(Args, CmdArgs,
"tsan");
1603 AddLinkSanitizerLibArgs(Args, CmdArgs,
"tysan");
1604 if (Sanitize.
needsFuzzer() && !Args.hasArg(options::OPT_dynamiclib)) {
1605 AddLinkSanitizerLibArgs(Args, CmdArgs,
"fuzzer",
false);
1612 AddLinkSanitizerLibArgs(Args, CmdArgs,
"stats");
1624 CmdArgs.push_back(
"-framework");
1625 CmdArgs.push_back(
"DriverKit");
1631 CmdArgs.push_back(
"-lSystem");
1640 CmdArgs.push_back(
"-lgcc_s.1");
1650 llvm::Triple SystemTriple(llvm::sys::getProcessTriple());
1651 if (!SystemTriple.isMacOSX())
1652 return std::string(MacOSSDKVersion);
1653 VersionTuple SystemVersion;
1654 SystemTriple.getMacOSXVersion(SystemVersion);
1656 unsigned Major, Minor, Micro;
1660 return std::string(MacOSSDKVersion);
1661 VersionTuple SDKVersion(Major, Minor, Micro);
1663 if (SDKVersion > SystemVersion)
1664 return SystemVersion.getAsString();
1665 return std::string(MacOSSDKVersion);
1671struct DarwinPlatform {
1680 DeploymentTargetEnv,
1690 DarwinPlatformKind getPlatform()
const {
return Platform; }
1692 DarwinEnvironmentKind getEnvironment()
const {
return Environment; }
1694 void setEnvironment(DarwinEnvironmentKind
Kind) {
1696 InferSimulatorFromArch =
false;
1699 StringRef getOSVersion()
const {
1700 if (
Kind == OSVersionArg)
1701 return Argument->getValue();
1705 void setOSVersion(StringRef S) {
1706 assert(
Kind == TargetArg &&
"Unexpected kind!");
1707 OSVersion = std::string(S);
1710 bool hasOSVersion()
const {
return HasOSVersion; }
1712 VersionTuple getNativeTargetVersion()
const {
1713 assert(Environment == DarwinEnvironmentKind::MacCatalyst &&
1714 "native target version is specified only for Mac Catalyst");
1715 return NativeTargetVersion;
1719 bool isExplicitlySpecified()
const {
return Kind <= DeploymentTargetEnv; }
1722 bool canInferSimulatorFromArch()
const {
return InferSimulatorFromArch; }
1724 const std::optional<llvm::Triple> &getTargetVariantTriple()
const {
1725 return TargetVariantTriple;
1729 void addOSVersionMinArgument(DerivedArgList &Args,
const OptTable &Opts) {
1732 assert(
Kind != TargetArg &&
Kind != MTargetOSArg &&
Kind != OSVersionArg &&
1736 case DarwinPlatformKind::MacOS:
1737 Opt = options::OPT_mmacos_version_min_EQ;
1739 case DarwinPlatformKind::IPhoneOS:
1740 Opt = options::OPT_mios_version_min_EQ;
1742 case DarwinPlatformKind::TvOS:
1743 Opt = options::OPT_mtvos_version_min_EQ;
1745 case DarwinPlatformKind::WatchOS:
1746 Opt = options::OPT_mwatchos_version_min_EQ;
1748 case DarwinPlatformKind::XROS:
1751 case DarwinPlatformKind::DriverKit:
1755 Argument = Args.MakeJoinedArg(
nullptr, Opts.getOption(Opt), OSVersion);
1756 Args.append(Argument);
1761 std::string
getAsString(DerivedArgList &Args,
const OptTable &Opts) {
1766 case InferredFromSDK:
1767 case InferredFromArch:
1768 assert(Argument &&
"OS version argument not yet inferred");
1769 return Argument->getAsString(Args);
1770 case DeploymentTargetEnv:
1771 return (llvm::Twine(EnvVarName) +
"=" + OSVersion).str();
1773 llvm_unreachable(
"Unsupported Darwin Source Kind");
1776 void setEnvironment(llvm::Triple::EnvironmentType EnvType,
1777 const VersionTuple &OSVersion,
1778 const std::optional<DarwinSDKInfo> &SDKInfo) {
1780 case llvm::Triple::Simulator:
1781 Environment = DarwinEnvironmentKind::Simulator;
1783 case llvm::Triple::MacABI: {
1784 Environment = DarwinEnvironmentKind::MacCatalyst;
1786 NativeTargetVersion = VersionTuple(10, 15);
1787 if (HasOSVersion && SDKInfo) {
1788 if (
const auto *MacCatalystToMacOSMapping = SDKInfo->getVersionMapping(
1790 if (
auto MacOSVersion = MacCatalystToMacOSMapping->map(
1791 OSVersion, NativeTargetVersion, std::nullopt)) {
1792 NativeTargetVersion = *MacOSVersion;
1799 if (TargetVariantTriple) {
1800 auto TargetVariantVersion = TargetVariantTriple->getOSVersion();
1801 if (TargetVariantVersion.getMajor()) {
1802 if (TargetVariantVersion < NativeTargetVersion)
1803 NativeTargetVersion = TargetVariantVersion;
1813 static DarwinPlatform
1814 createFromTarget(
const llvm::Triple &TT, StringRef OSVersion, Arg *A,
1815 std::optional<llvm::Triple> TargetVariantTriple,
1816 const std::optional<DarwinSDKInfo> &SDKInfo) {
1817 DarwinPlatform Result(TargetArg, getPlatformFromOS(TT.getOS()), OSVersion,
1819 VersionTuple OsVersion = TT.getOSVersion();
1820 if (OsVersion.getMajor() == 0)
1821 Result.HasOSVersion =
false;
1822 Result.TargetVariantTriple = TargetVariantTriple;
1823 Result.setEnvironment(TT.getEnvironment(), OsVersion, SDKInfo);
1826 static DarwinPlatform
1827 createFromMTargetOS(llvm::Triple::OSType OS, VersionTuple OSVersion,
1828 llvm::Triple::EnvironmentType Environment, Arg *A,
1829 const std::optional<DarwinSDKInfo> &SDKInfo) {
1830 DarwinPlatform Result(MTargetOSArg, getPlatformFromOS(OS),
1831 OSVersion.getAsString(), A);
1832 Result.InferSimulatorFromArch =
false;
1833 Result.setEnvironment(Environment, OSVersion, SDKInfo);
1836 static DarwinPlatform createOSVersionArg(DarwinPlatformKind Platform, Arg *A,
1838 DarwinPlatform Result{OSVersionArg, Platform, A};
1840 Result.Environment = DarwinEnvironmentKind::Simulator;
1843 static DarwinPlatform createDeploymentTargetEnv(DarwinPlatformKind Platform,
1844 StringRef EnvVarName,
1846 DarwinPlatform Result(DeploymentTargetEnv, Platform,
Value);
1847 Result.EnvVarName = EnvVarName;
1850 static DarwinPlatform createFromSDK(DarwinPlatformKind Platform,
1852 bool IsSimulator =
false) {
1853 DarwinPlatform Result(InferredFromSDK, Platform,
Value);
1855 Result.Environment = DarwinEnvironmentKind::Simulator;
1856 Result.InferSimulatorFromArch =
false;
1859 static DarwinPlatform createFromArch(llvm::Triple::OSType OS,
1861 return DarwinPlatform(InferredFromArch, getPlatformFromOS(OS),
Value);
1868 assert(
Kind == InferredFromSDK &&
"can infer SDK info only");
1869 llvm::VersionTuple Version;
1870 bool IsValid = !Version.tryParse(OSVersion);
1872 assert(IsValid &&
"invalid SDK version");
1875 VersionTuple(Version.getMajor(), 0, 99));
1879 DarwinPlatform(SourceKind
Kind, DarwinPlatformKind Platform, Arg *Argument)
1880 :
Kind(
Kind), Platform(Platform), Argument(Argument) {}
1881 DarwinPlatform(SourceKind
Kind, DarwinPlatformKind Platform, StringRef
Value,
1882 Arg *Argument =
nullptr)
1883 :
Kind(
Kind), Platform(Platform), OSVersion(
Value), Argument(Argument) {}
1885 static DarwinPlatformKind getPlatformFromOS(llvm::Triple::OSType OS) {
1887 case llvm::Triple::Darwin:
1888 case llvm::Triple::MacOSX:
1889 return DarwinPlatformKind::MacOS;
1890 case llvm::Triple::IOS:
1891 return DarwinPlatformKind::IPhoneOS;
1892 case llvm::Triple::TvOS:
1893 return DarwinPlatformKind::TvOS;
1894 case llvm::Triple::WatchOS:
1895 return DarwinPlatformKind::WatchOS;
1896 case llvm::Triple::XROS:
1897 return DarwinPlatformKind::XROS;
1898 case llvm::Triple::DriverKit:
1899 return DarwinPlatformKind::DriverKit;
1901 llvm_unreachable(
"Unable to infer Darwin variant");
1906 DarwinPlatformKind Platform;
1907 DarwinEnvironmentKind Environment = DarwinEnvironmentKind::NativeEnvironment;
1908 VersionTuple NativeTargetVersion;
1909 std::string OSVersion;
1910 bool HasOSVersion =
true, InferSimulatorFromArch =
true;
1912 StringRef EnvVarName;
1913 std::optional<llvm::Triple> TargetVariantTriple;
1918std::optional<DarwinPlatform>
1919getDeploymentTargetFromOSVersionArg(DerivedArgList &Args,
1920 const Driver &TheDriver) {
1921 Arg *macOSVersion = Args.getLastArg(options::OPT_mmacos_version_min_EQ);
1922 Arg *iOSVersion = Args.getLastArg(options::OPT_mios_version_min_EQ,
1923 options::OPT_mios_simulator_version_min_EQ);
1925 Args.getLastArg(options::OPT_mtvos_version_min_EQ,
1926 options::OPT_mtvos_simulator_version_min_EQ);
1927 Arg *WatchOSVersion =
1928 Args.getLastArg(options::OPT_mwatchos_version_min_EQ,
1929 options::OPT_mwatchos_simulator_version_min_EQ);
1931 if (iOSVersion || TvOSVersion || WatchOSVersion) {
1932 TheDriver.
Diag(diag::err_drv_argument_not_allowed_with)
1933 << macOSVersion->getAsString(Args)
1934 << (iOSVersion ? iOSVersion
1935 : TvOSVersion ? TvOSVersion : WatchOSVersion)
1938 return DarwinPlatform::createOSVersionArg(
Darwin::MacOS, macOSVersion,
1940 }
else if (iOSVersion) {
1941 if (TvOSVersion || WatchOSVersion) {
1942 TheDriver.
Diag(diag::err_drv_argument_not_allowed_with)
1943 << iOSVersion->getAsString(Args)
1944 << (TvOSVersion ? TvOSVersion : WatchOSVersion)->
getAsString(Args);
1946 return DarwinPlatform::createOSVersionArg(
1948 iOSVersion->getOption().getID() ==
1949 options::OPT_mios_simulator_version_min_EQ);
1950 }
else if (TvOSVersion) {
1951 if (WatchOSVersion) {
1952 TheDriver.
Diag(diag::err_drv_argument_not_allowed_with)
1953 << TvOSVersion->getAsString(Args)
1954 << WatchOSVersion->getAsString(Args);
1956 return DarwinPlatform::createOSVersionArg(
1958 TvOSVersion->getOption().getID() ==
1959 options::OPT_mtvos_simulator_version_min_EQ);
1960 }
else if (WatchOSVersion)
1961 return DarwinPlatform::createOSVersionArg(
1963 WatchOSVersion->getOption().getID() ==
1964 options::OPT_mwatchos_simulator_version_min_EQ);
1965 return std::nullopt;
1970std::optional<DarwinPlatform>
1971getDeploymentTargetFromEnvironmentVariables(
const Driver &TheDriver,
1972 const llvm::Triple &Triple) {
1974 const char *EnvVars[] = {
1975 "MACOSX_DEPLOYMENT_TARGET",
1976 "IPHONEOS_DEPLOYMENT_TARGET",
1977 "TVOS_DEPLOYMENT_TARGET",
1978 "WATCHOS_DEPLOYMENT_TARGET",
1979 "DRIVERKIT_DEPLOYMENT_TARGET",
1980 "XROS_DEPLOYMENT_TARGET"
1983 "Missing platform");
1985 if (
char *
Env = ::getenv(I.value()))
1986 Targets[I.index()] =
Env;
1995 if (Triple.getArch() == llvm::Triple::arm ||
1996 Triple.getArch() == llvm::Triple::aarch64 ||
1997 Triple.getArch() == llvm::Triple::thumb)
2004 unsigned FirstTarget = std::size(Targets);
2005 for (
unsigned I = 0; I != std::size(Targets); ++I) {
2006 if (Targets[I].empty())
2008 if (FirstTarget == std::size(Targets))
2011 TheDriver.
Diag(diag::err_drv_conflicting_deployment_targets)
2012 << Targets[FirstTarget] << Targets[I];
2017 if (!
Target.value().empty())
2018 return DarwinPlatform::createDeploymentTargetEnv(
2022 return std::nullopt;
2027static StringRef dropSDKNamePrefix(StringRef SDKName) {
2028 size_t PrefixPos = SDKName.find(
'.');
2029 if (PrefixPos == StringRef::npos)
2031 return SDKName.substr(PrefixPos + 1);
2037std::optional<DarwinPlatform>
2038inferDeploymentTargetFromSDK(DerivedArgList &Args,
2039 const std::optional<DarwinSDKInfo> &SDKInfo) {
2040 const Arg *A = Args.getLastArg(options::OPT_isysroot);
2042 return std::nullopt;
2043 StringRef isysroot = A->getValue();
2046 return std::nullopt;
2048 std::string Version;
2051 Version = SDKInfo->getVersion().getAsString();
2055 size_t StartVer = SDK.find_first_of(
"0123456789");
2056 size_t EndVer = SDK.find_last_of(
"0123456789");
2057 if (StartVer != StringRef::npos && EndVer > StartVer)
2058 Version = std::string(SDK.slice(StartVer, EndVer + 1));
2060 if (Version.empty())
2061 return std::nullopt;
2063 auto CreatePlatformFromSDKName =
2064 [&](StringRef SDK) -> std::optional<DarwinPlatform> {
2065 if (SDK.starts_with(
"iPhoneOS") || SDK.starts_with(
"iPhoneSimulator"))
2066 return DarwinPlatform::createFromSDK(
2068 SDK.starts_with(
"iPhoneSimulator"));
2069 else if (SDK.starts_with(
"MacOSX"))
2072 else if (SDK.starts_with(
"WatchOS") || SDK.starts_with(
"WatchSimulator"))
2073 return DarwinPlatform::createFromSDK(
2075 SDK.starts_with(
"WatchSimulator"));
2076 else if (SDK.starts_with(
"AppleTVOS") ||
2077 SDK.starts_with(
"AppleTVSimulator"))
2078 return DarwinPlatform::createFromSDK(
2080 SDK.starts_with(
"AppleTVSimulator"));
2081 else if (SDK.starts_with(
"XR"))
2082 return DarwinPlatform::createFromSDK(
2084 SDK.contains(
"Simulator"));
2085 else if (SDK.starts_with(
"DriverKit"))
2087 return std::nullopt;
2089 if (
auto Result = CreatePlatformFromSDKName(SDK))
2092 return CreatePlatformFromSDKName(dropSDKNamePrefix(SDK));
2095std::string getOSVersion(llvm::Triple::OSType OS,
const llvm::Triple &Triple,
2096 const Driver &TheDriver) {
2097 VersionTuple OsVersion;
2098 llvm::Triple SystemTriple(llvm::sys::getProcessTriple());
2100 case llvm::Triple::Darwin:
2101 case llvm::Triple::MacOSX:
2104 if (Triple.isMacOSX() && SystemTriple.isMacOSX() &&
2105 !Triple.getOSMajorVersion())
2106 SystemTriple.getMacOSXVersion(OsVersion);
2107 else if (!Triple.getMacOSXVersion(OsVersion))
2108 TheDriver.
Diag(diag::err_drv_invalid_darwin_version)
2109 << Triple.getOSName();
2111 case llvm::Triple::IOS:
2112 if (Triple.isMacCatalystEnvironment() && !Triple.getOSMajorVersion()) {
2113 OsVersion = VersionTuple(13, 1);
2115 OsVersion = Triple.getiOSVersion();
2117 case llvm::Triple::TvOS:
2118 OsVersion = Triple.getOSVersion();
2120 case llvm::Triple::WatchOS:
2121 OsVersion = Triple.getWatchOSVersion();
2123 case llvm::Triple::XROS:
2124 OsVersion = Triple.getOSVersion();
2125 if (!OsVersion.getMajor())
2126 OsVersion = OsVersion.withMajorReplaced(1);
2128 case llvm::Triple::DriverKit:
2129 OsVersion = Triple.getDriverKitVersion();
2132 llvm_unreachable(
"Unexpected OS type");
2136 std::string OSVersion;
2137 llvm::raw_string_ostream(OSVersion)
2138 << OsVersion.getMajor() <<
'.' << OsVersion.getMinor().value_or(0) <<
'.'
2139 << OsVersion.getSubminor().value_or(0);
2144std::optional<DarwinPlatform>
2145inferDeploymentTargetFromArch(DerivedArgList &Args,
const Darwin &Toolchain,
2146 const llvm::Triple &Triple,
2147 const Driver &TheDriver) {
2148 llvm::Triple::OSType OSTy = llvm::Triple::UnknownOS;
2151 if (MachOArchName ==
"arm64" || MachOArchName ==
"arm64e")
2152 OSTy = llvm::Triple::MacOSX;
2153 else if (MachOArchName ==
"armv7" || MachOArchName ==
"armv7s" ||
2154 MachOArchName ==
"armv6")
2155 OSTy = llvm::Triple::IOS;
2156 else if (MachOArchName ==
"armv7k" || MachOArchName ==
"arm64_32")
2157 OSTy = llvm::Triple::WatchOS;
2158 else if (MachOArchName !=
"armv6m" && MachOArchName !=
"armv7m" &&
2159 MachOArchName !=
"armv7em")
2160 OSTy = llvm::Triple::MacOSX;
2161 if (OSTy == llvm::Triple::UnknownOS)
2162 return std::nullopt;
2163 return DarwinPlatform::createFromArch(OSTy,
2164 getOSVersion(OSTy, Triple, TheDriver));
2168std::optional<DarwinPlatform> getDeploymentTargetFromTargetArg(
2169 DerivedArgList &Args,
const llvm::Triple &Triple,
const Driver &TheDriver,
2170 const std::optional<DarwinSDKInfo> &SDKInfo) {
2171 if (!Args.hasArg(options::OPT_target))
2172 return std::nullopt;
2173 if (Triple.getOS() == llvm::Triple::Darwin ||
2174 Triple.getOS() == llvm::Triple::UnknownOS)
2175 return std::nullopt;
2176 std::string OSVersion = getOSVersion(Triple.getOS(), Triple, TheDriver);
2177 std::optional<llvm::Triple> TargetVariantTriple;
2178 for (
const Arg *A : Args.filtered(options::OPT_darwin_target_variant)) {
2179 llvm::Triple TVT(A->getValue());
2181 if ((Triple.getArch() == llvm::Triple::aarch64 ||
2182 TVT.getArchName() == Triple.getArchName()) &&
2183 TVT.getArch() == Triple.getArch() &&
2184 TVT.getSubArch() == Triple.getSubArch() &&
2185 TVT.getVendor() == Triple.getVendor()) {
2186 if (TargetVariantTriple)
2191 if ((Triple.isMacOSX() && TVT.getOS() == llvm::Triple::IOS &&
2192 TVT.isMacCatalystEnvironment()) ||
2193 (TVT.isMacOSX() && Triple.getOS() == llvm::Triple::IOS &&
2194 Triple.isMacCatalystEnvironment())) {
2195 TargetVariantTriple = TVT;
2198 TheDriver.
Diag(diag::err_drv_target_variant_invalid)
2199 << A->getSpelling() << A->getValue();
2202 return DarwinPlatform::createFromTarget(Triple, OSVersion,
2203 Args.getLastArg(options::OPT_target),
2204 TargetVariantTriple, SDKInfo);
2208std::optional<DarwinPlatform> getDeploymentTargetFromMTargetOSArg(
2209 DerivedArgList &Args,
const Driver &TheDriver,
2210 const std::optional<DarwinSDKInfo> &SDKInfo) {
2211 auto *A = Args.getLastArg(options::OPT_mtargetos_EQ);
2213 return std::nullopt;
2214 llvm::Triple TT(llvm::Twine(
"unknown-apple-") + A->getValue());
2215 switch (TT.getOS()) {
2216 case llvm::Triple::MacOSX:
2217 case llvm::Triple::IOS:
2218 case llvm::Triple::TvOS:
2219 case llvm::Triple::WatchOS:
2220 case llvm::Triple::XROS:
2223 TheDriver.
Diag(diag::err_drv_invalid_os_in_arg)
2224 << TT.getOSName() << A->getAsString(Args);
2225 return std::nullopt;
2228 VersionTuple Version = TT.getOSVersion();
2229 if (!Version.getMajor()) {
2230 TheDriver.
Diag(diag::err_drv_invalid_version_number)
2231 << A->getAsString(Args);
2232 return std::nullopt;
2234 return DarwinPlatform::createFromMTargetOS(TT.getOS(), Version,
2235 TT.getEnvironment(), A, SDKInfo);
2238std::optional<DarwinSDKInfo> parseSDKSettings(llvm::vfs::FileSystem &VFS,
2239 const ArgList &Args,
2240 const Driver &TheDriver) {
2241 const Arg *A = Args.getLastArg(options::OPT_isysroot);
2243 return std::nullopt;
2244 StringRef isysroot = A->getValue();
2246 if (!SDKInfoOrErr) {
2247 llvm::consumeError(SDKInfoOrErr.takeError());
2248 TheDriver.
Diag(diag::warn_drv_darwin_sdk_invalid_settings);
2249 return std::nullopt;
2251 return *SDKInfoOrErr;
2256void Darwin::AddDeploymentTarget(DerivedArgList &Args)
const {
2262 if (
const Arg *A = Args.getLastArg(options::OPT_isysroot)) {
2264 if (!
getVFS().exists(A->getValue()))
2265 getDriver().
Diag(clang::diag::warn_missing_sysroot) << A->getValue();
2267 if (
char *env = ::getenv(
"SDKROOT")) {
2270 if (llvm::sys::path::is_absolute(env) &&
getVFS().exists(env) &&
2271 StringRef(env) !=
"/") {
2272 Args.append(Args.MakeSeparateArg(
2273 nullptr, Opts.getOption(options::OPT_isysroot), env));
2283 std::optional<DarwinPlatform> OSTarget =
2287 if (
const auto *MTargetOSArg = Args.getLastArg(options::OPT_mtargetos_EQ)) {
2288 std::string TargetArgStr = OSTarget->getAsString(Args, Opts);
2289 std::string MTargetOSArgStr = MTargetOSArg->getAsString(Args);
2291 << TargetArgStr << MTargetOSArgStr;
2293 std::optional<DarwinPlatform> OSVersionArgTarget =
2294 getDeploymentTargetFromOSVersionArg(Args,
getDriver());
2295 if (OSVersionArgTarget) {
2296 unsigned TargetMajor, TargetMinor, TargetMicro;
2298 unsigned ArgMajor, ArgMinor, ArgMicro;
2300 if (OSTarget->getPlatform() != OSVersionArgTarget->getPlatform() ||
2302 TargetMinor, TargetMicro, TargetExtra) &&
2304 ArgMajor, ArgMinor, ArgMicro, ArgExtra) &&
2305 (VersionTuple(TargetMajor, TargetMinor, TargetMicro) !=
2306 VersionTuple(ArgMajor, ArgMinor, ArgMicro) ||
2307 TargetExtra != ArgExtra))) {
2310 if (OSTarget->getPlatform() == OSVersionArgTarget->getPlatform() &&
2311 !OSTarget->hasOSVersion()) {
2312 OSTarget->setOSVersion(OSVersionArgTarget->getOSVersion());
2316 std::string OSVersionArg =
2317 OSVersionArgTarget->getAsString(Args, Opts);
2318 std::string TargetArg = OSTarget->getAsString(Args, Opts);
2320 << OSVersionArg << TargetArg;
2324 }
else if ((OSTarget = getDeploymentTargetFromMTargetOSArg(Args,
getDriver(),
2328 std::optional<DarwinPlatform> OSVersionArgTarget =
2329 getDeploymentTargetFromOSVersionArg(Args,
getDriver());
2330 if (OSVersionArgTarget) {
2331 std::string MTargetOSArgStr = OSTarget->getAsString(Args, Opts);
2332 std::string OSVersionArgStr = OSVersionArgTarget->getAsString(Args, Opts);
2334 << MTargetOSArgStr << OSVersionArgStr;
2338 OSTarget = getDeploymentTargetFromOSVersionArg(Args,
getDriver());
2346 std::optional<DarwinPlatform> SDKTarget =
2347 inferDeploymentTargetFromSDK(Args,
SDKInfo);
2349 OSTarget->setEnvironment(SDKTarget->getEnvironment());
2356 OSTarget = inferDeploymentTargetFromSDK(Args,
SDKInfo);
2360 SDKInfo = OSTarget->inferSDKInfo();
2369 assert(OSTarget &&
"Unable to infer Darwin variant");
2370 OSTarget->addOSVersionMinArgument(Args, Opts);
2373 unsigned Major, Minor, Micro;
2376 const unsigned MajorVersionLimit = 1000;
2378 if (Platform ==
MacOS) {
2381 HadExtra || Major < 10 || Major >= MajorVersionLimit || Minor >= 100 ||
2384 << OSTarget->getAsString(Args, Opts);
2388 HadExtra || Major >= MajorVersionLimit || Minor >= 100 || Micro >= 100)
2390 << OSTarget->getAsString(Args, Opts);
2393 (Major < 13 || (Major == 13 && Minor < 1))) {
2395 << OSTarget->getAsString(Args, Opts);
2402 if (
getTriple().isArch32Bit() && Major >= 11) {
2404 if (OSTarget->isExplicitlySpecified()) {
2406 getDriver().
Diag(diag::err_invalid_macos_32bit_deployment_target);
2409 << OSTarget->getAsString(Args, Opts);
2417 }
else if (Platform ==
TvOS) {
2420 HadExtra || Major >= MajorVersionLimit || Minor >= 100 || Micro >= 100)
2422 << OSTarget->getAsString(Args, Opts);
2423 }
else if (Platform ==
WatchOS) {
2426 HadExtra || Major >= MajorVersionLimit || Minor >= 100 || Micro >= 100)
2428 << OSTarget->getAsString(Args, Opts);
2432 HadExtra || Major < 19 || Major >= MajorVersionLimit || Minor >= 100 ||
2435 << OSTarget->getAsString(Args, Opts);
2436 }
else if (Platform ==
XROS) {
2439 HadExtra || Major < 1 || Major >= MajorVersionLimit || Minor >= 100 ||
2442 << OSTarget->getAsString(Args, Opts);
2444 llvm_unreachable(
"unknown kind of Darwin platform");
2449 Platform !=
DriverKit && OSTarget->canInferSimulatorFromArch() &&
2453 VersionTuple NativeTargetVersion;
2455 NativeTargetVersion = OSTarget->getNativeTargetVersion();
2456 setTarget(Platform, Environment, Major, Minor, Micro, NativeTargetVersion);
2459 if (
const Arg *A = Args.getLastArg(options::OPT_isysroot)) {
2461 if (SDK.size() > 0) {
2462 size_t StartVer = SDK.find_first_of(
"0123456789");
2463 StringRef SDKName = SDK.slice(0, StartVer);
2476 const llvm::Triple &
T) {
2477 if (
T.isDriverKit()) {
2478 llvm::sys::path::append(
Path,
"System",
"DriverKit");
2487 if (DriverArgs.hasArg(options::OPT_isysroot))
2488 Path = DriverArgs.getLastArgValue(options::OPT_isysroot);
2499 const llvm::opt::ArgList &DriverArgs,
2500 llvm::opt::ArgStringList &CC1Args)
const {
2505 bool NoStdInc = DriverArgs.hasArg(options::OPT_nostdinc);
2506 bool NoStdlibInc = DriverArgs.hasArg(options::OPT_nostdlibinc);
2507 bool NoBuiltinInc = DriverArgs.hasFlag(
2508 options::OPT_nobuiltininc, options::OPT_ibuiltininc,
false);
2509 bool ForceBuiltinInc = DriverArgs.hasFlag(
2510 options::OPT_ibuiltininc, options::OPT_nobuiltininc,
false);
2513 if (!NoStdInc && !NoStdlibInc) {
2515 llvm::sys::path::append(
P,
"usr",
"local",
"include");
2520 if (!(NoStdInc && !ForceBuiltinInc) && !NoBuiltinInc) {
2522 llvm::sys::path::append(
P,
"include");
2526 if (NoStdInc || NoStdlibInc)
2530 llvm::StringRef CIncludeDirs(C_INCLUDE_DIRS);
2531 if (!CIncludeDirs.empty()) {
2533 CIncludeDirs.split(dirs,
":");
2534 for (llvm::StringRef dir : dirs) {
2535 llvm::StringRef Prefix =
2536 llvm::sys::path::is_absolute(dir) ?
"" : llvm::StringRef(Sysroot);
2542 llvm::sys::path::append(
P,
"usr",
"include");
2547bool DarwinClang::AddGnuCPlusPlusIncludePaths(
const llvm::opt::ArgList &DriverArgs,
2548 llvm::opt::ArgStringList &CC1Args,
2550 llvm::StringRef Version,
2551 llvm::StringRef ArchDir,
2552 llvm::StringRef BitDir)
const {
2553 llvm::sys::path::append(
Base, Version);
2561 if (!ArchDir.empty())
2562 llvm::sys::path::append(
P, ArchDir);
2563 if (!BitDir.empty())
2564 llvm::sys::path::append(
P, BitDir);
2571 llvm::sys::path::append(
P,
"backward");
2579 const llvm::opt::ArgList &DriverArgs,
2580 llvm::opt::ArgStringList &CC1Args)
const {
2588 if (DriverArgs.hasArg(options::OPT_nostdinc, options::OPT_nostdlibinc,
2589 options::OPT_nostdincxx))
2610 llvm::sys::path::append(InstallBin,
"..",
"include",
"c++",
"v1");
2611 if (
getVFS().exists(InstallBin)) {
2614 }
else if (DriverArgs.hasArg(options::OPT_v)) {
2615 llvm::errs() <<
"ignoring nonexistent directory \"" << InstallBin
2621 llvm::sys::path::append(SysrootUsr,
"usr",
"include",
"c++",
"v1");
2622 if (
getVFS().exists(SysrootUsr)) {
2625 }
else if (DriverArgs.hasArg(options::OPT_v)) {
2626 llvm::errs() <<
"ignoring nonexistent directory \"" << SysrootUsr
2635 AddGnuCPlusPlusIncludePaths(DriverArgs, CC1Args);
2640void AppleMachO::AddGnuCPlusPlusIncludePaths(
2641 const llvm::opt::ArgList &DriverArgs,
2642 llvm::opt::ArgStringList &CC1Args)
const {}
2644void DarwinClang::AddGnuCPlusPlusIncludePaths(
2645 const llvm::opt::ArgList &DriverArgs,
2646 llvm::opt::ArgStringList &CC1Args)
const {
2648 llvm::sys::path::append(UsrIncludeCxx,
"usr",
"include",
"c++");
2651 bool IsBaseFound =
true;
2656 case llvm::Triple::x86:
2657 case llvm::Triple::x86_64:
2658 IsBaseFound = AddGnuCPlusPlusIncludePaths(
2659 DriverArgs, CC1Args, UsrIncludeCxx,
"4.2.1",
"i686-apple-darwin10",
2660 arch == llvm::Triple::x86_64 ?
"x86_64" :
"");
2661 IsBaseFound |= AddGnuCPlusPlusIncludePaths(
2662 DriverArgs, CC1Args, UsrIncludeCxx,
"4.0.0",
"i686-apple-darwin8",
"");
2665 case llvm::Triple::arm:
2666 case llvm::Triple::thumb:
2668 AddGnuCPlusPlusIncludePaths(DriverArgs, CC1Args, UsrIncludeCxx,
"4.2.1",
2669 "arm-apple-darwin10",
"v7");
2671 AddGnuCPlusPlusIncludePaths(DriverArgs, CC1Args, UsrIncludeCxx,
"4.2.1",
2672 "arm-apple-darwin10",
"v6");
2675 case llvm::Triple::aarch64:
2677 AddGnuCPlusPlusIncludePaths(DriverArgs, CC1Args, UsrIncludeCxx,
"4.2.1",
2678 "arm64-apple-darwin10",
"");
2688 ArgStringList &CmdArgs)
const {
2693 CmdArgs.push_back(
"-lc++");
2694 if (Args.hasArg(options::OPT_fexperimental_library))
2695 CmdArgs.push_back(
"-lc++experimental");
2705 if (
const Arg *A = Args.getLastArg(options::OPT_isysroot)) {
2707 llvm::sys::path::append(
P,
"usr",
"lib",
"libstdc++.dylib");
2710 llvm::sys::path::remove_filename(
P);
2711 llvm::sys::path::append(
P,
"libstdc++.6.dylib");
2713 CmdArgs.push_back(Args.MakeArgString(
P));
2722 if (!
getVFS().exists(
"/usr/lib/libstdc++.dylib") &&
2723 getVFS().exists(
"/usr/lib/libstdc++.6.dylib")) {
2724 CmdArgs.push_back(
"/usr/lib/libstdc++.6.dylib");
2729 CmdArgs.push_back(
"-lstdc++");
2735 ArgStringList &CmdArgs)
const {
2741 llvm::sys::path::append(
P,
"lib",
"darwin");
2745 llvm::sys::path::append(
P,
"libclang_rt.cc_kext_watchos.a");
2747 llvm::sys::path::append(
P,
"libclang_rt.cc_kext_tvos.a");
2749 llvm::sys::path::append(
P,
"libclang_rt.cc_kext_ios.a");
2753 llvm::sys::path::append(
2754 P, llvm::Twine(
"libclang_rt.cc_kext_") +
2755 llvm::Triple::getOSTypeName(llvm::Triple::XROS) +
".a");
2757 llvm::sys::path::append(
P,
"libclang_rt.cc_kext.a");
2763 CmdArgs.push_back(Args.MakeArgString(
P));
2767 StringRef BoundArch,
2769 DerivedArgList *DAL =
new DerivedArgList(Args.getBaseArgs());
2779 for (Arg *A : Args) {
2780 if (A->getOption().matches(options::OPT_Xarch__)) {
2783 StringRef XarchArch = A->getValue(0);
2785 (!BoundArch.empty() && XarchArch == BoundArch)))
2788 Arg *OriginalArg = A;
2796 for (
const char *
Value : A->getValues()) {
2797 DAL->AddSeparateArg(
2798 OriginalArg, Opts.getOption(options::OPT_Zlinker_input),
Value);
2812 case options::OPT_mkernel:
2813 case options::OPT_fapple_kext:
2815 DAL->AddFlagArg(A, Opts.getOption(options::OPT_static));
2818 case options::OPT_dependency_file:
2819 DAL->AddSeparateArg(A, Opts.getOption(options::OPT_MF), A->getValue());
2822 case options::OPT_gfull:
2823 DAL->AddFlagArg(A, Opts.getOption(options::OPT_g_Flag));
2825 A, Opts.getOption(options::OPT_fno_eliminate_unused_debug_symbols));
2828 case options::OPT_gused:
2829 DAL->AddFlagArg(A, Opts.getOption(options::OPT_g_Flag));
2831 A, Opts.getOption(options::OPT_feliminate_unused_debug_symbols));
2834 case options::OPT_shared:
2835 DAL->AddFlagArg(A, Opts.getOption(options::OPT_dynamiclib));
2838 case options::OPT_fconstant_cfstrings:
2839 DAL->AddFlagArg(A, Opts.getOption(options::OPT_mconstant_cfstrings));
2842 case options::OPT_fno_constant_cfstrings:
2843 DAL->AddFlagArg(A, Opts.getOption(options::OPT_mno_constant_cfstrings));
2846 case options::OPT_Wnonportable_cfstrings:
2848 Opts.getOption(options::OPT_mwarn_nonportable_cfstrings));
2851 case options::OPT_Wno_nonportable_cfstrings:
2853 A, Opts.getOption(options::OPT_mno_warn_nonportable_cfstrings));
2860 if (!BoundArch.empty()) {
2861 StringRef Name = BoundArch;
2862 const Option MCpu = Opts.getOption(options::OPT_mcpu_EQ);
2863 const Option MArch = Opts.getOption(clang::driver::options::OPT_march_EQ);
2869 else if (Name ==
"ppc601")
2870 DAL->AddJoinedArg(
nullptr, MCpu,
"601");
2871 else if (Name ==
"ppc603")
2872 DAL->AddJoinedArg(
nullptr, MCpu,
"603");
2873 else if (Name ==
"ppc604")
2874 DAL->AddJoinedArg(
nullptr, MCpu,
"604");
2875 else if (Name ==
"ppc604e")
2876 DAL->AddJoinedArg(
nullptr, MCpu,
"604e");
2877 else if (Name ==
"ppc750")
2878 DAL->AddJoinedArg(
nullptr, MCpu,
"750");
2879 else if (Name ==
"ppc7400")
2880 DAL->AddJoinedArg(
nullptr, MCpu,
"7400");
2881 else if (Name ==
"ppc7450")
2882 DAL->AddJoinedArg(
nullptr, MCpu,
"7450");
2883 else if (Name ==
"ppc970")
2884 DAL->AddJoinedArg(
nullptr, MCpu,
"970");
2886 else if (Name ==
"ppc64" || Name ==
"ppc64le")
2887 DAL->AddFlagArg(
nullptr, Opts.getOption(options::OPT_m64));
2889 else if (Name ==
"i386")
2891 else if (Name ==
"i486")
2892 DAL->AddJoinedArg(
nullptr, MArch,
"i486");
2893 else if (Name ==
"i586")
2894 DAL->AddJoinedArg(
nullptr, MArch,
"i586");
2895 else if (Name ==
"i686")
2896 DAL->AddJoinedArg(
nullptr, MArch,
"i686");
2897 else if (Name ==
"pentium")
2898 DAL->AddJoinedArg(
nullptr, MArch,
"pentium");
2899 else if (Name ==
"pentium2")
2900 DAL->AddJoinedArg(
nullptr, MArch,
"pentium2");
2901 else if (Name ==
"pentpro")
2902 DAL->AddJoinedArg(
nullptr, MArch,
"pentiumpro");
2903 else if (Name ==
"pentIIm3")
2904 DAL->AddJoinedArg(
nullptr, MArch,
"pentium2");
2906 else if (Name ==
"x86_64" || Name ==
"x86_64h")
2907 DAL->AddFlagArg(
nullptr, Opts.getOption(options::OPT_m64));
2909 else if (Name ==
"arm")
2910 DAL->AddJoinedArg(
nullptr, MArch,
"armv4t");
2911 else if (Name ==
"armv4t")
2912 DAL->AddJoinedArg(
nullptr, MArch,
"armv4t");
2913 else if (Name ==
"armv5")
2914 DAL->AddJoinedArg(
nullptr, MArch,
"armv5tej");
2915 else if (Name ==
"xscale")
2916 DAL->AddJoinedArg(
nullptr, MArch,
"xscale");
2917 else if (Name ==
"armv6")
2918 DAL->AddJoinedArg(
nullptr, MArch,
"armv6k");
2919 else if (Name ==
"armv6m")
2920 DAL->AddJoinedArg(
nullptr, MArch,
"armv6m");
2921 else if (Name ==
"armv7")
2922 DAL->AddJoinedArg(
nullptr, MArch,
"armv7a");
2923 else if (Name ==
"armv7em")
2924 DAL->AddJoinedArg(
nullptr, MArch,
"armv7em");
2925 else if (Name ==
"armv7k")
2926 DAL->AddJoinedArg(
nullptr, MArch,
"armv7k");
2927 else if (Name ==
"armv7m")
2928 DAL->AddJoinedArg(
nullptr, MArch,
"armv7m");
2929 else if (Name ==
"armv7s")
2930 DAL->AddJoinedArg(
nullptr, MArch,
"armv7s");
2937 ArgStringList &CmdArgs,
2938 bool ForceLinkBuiltinRT)
const {
2947 CompilerRT += Args.hasArg(options::OPT_fPIC) ?
"_pic" :
"_static";
2953 llvm::Triple::OSType OS;
2959 OS = llvm::Triple::MacOSX;
2962 OS = llvm::Triple::IOS;
2965 OS = llvm::Triple::TvOS;
2968 OS = llvm::Triple::WatchOS;
2982 const std::optional<DarwinSDKInfo> &SDKInfo) {
3002 VersionTuple SDKVersion = SDKInfo->getVersion();
3003 switch (TargetPlatform) {
3007 return SDKVersion >= VersionTuple(15U);
3009 switch (TargetEnvironment) {
3014 return SDKVersion >= VersionTuple(15U);
3016 return SDKVersion >= VersionTuple(18U);
3019 return SDKVersion >= VersionTuple(18U);
3021 return SDKVersion >= VersionTuple(11U);
3023 return SDKVersion >= VersionTuple(2U);
3031static inline llvm::VersionTuple
3036 case llvm::Triple::Darwin:
3037 case llvm::Triple::MacOSX:
3038 return llvm::VersionTuple(10U, 12U);
3039 case llvm::Triple::IOS:
3040 case llvm::Triple::TvOS:
3041 return llvm::VersionTuple(10U);
3042 case llvm::Triple::WatchOS:
3043 return llvm::VersionTuple(3U);
3046 llvm_unreachable(
"Unexpected OS");
3050 llvm::Triple::OSType OS;
3056 OS = llvm::Triple::MacOSX;
3059 OS = llvm::Triple::IOS;
3062 OS = llvm::Triple::TvOS;
3065 OS = llvm::Triple::WatchOS;
3077 const llvm::opt::ArgList &DriverArgs, llvm::opt::ArgStringList &CC1Args,
3081 if (!DriverArgs.hasArgNoClaim(options::OPT_faligned_allocation,
3082 options::OPT_fno_aligned_allocation) &&
3084 CC1Args.push_back(
"-faligned-alloc-unavailable");
3088 if (!DriverArgs.hasArgNoClaim(options::OPT_fsized_deallocation,
3089 options::OPT_fno_sized_deallocation) &&
3091 CC1Args.push_back(
"-fno-sized-deallocation");
3097 CC1Args.push_back(
"-fcompatibility-qualified-id-block-type-checking");
3101 if (!DriverArgs.getLastArgNoClaim(
3102 options::OPT_fvisibility_inlines_hidden_static_local_var,
3103 options::OPT_fno_visibility_inlines_hidden_static_local_var))
3104 CC1Args.push_back(
"-fvisibility-inlines-hidden-static-local-var");
3118 CC1Args.push_back(
"-fbuiltin-headers-in-system-modules");
3120 if (!DriverArgs.hasArgNoClaim(options::OPT_fdefine_target_os_macros,
3121 options::OPT_fno_define_target_os_macros))
3122 CC1Args.push_back(
"-fdefine-target-os-macros");
3126 !DriverArgs.hasFlag(options::OPT_fmodulemap_allow_subdirectory_search,
3127 options::OPT_fno_modulemap_allow_subdirectory_search,
3129 bool RequiresSubdirectorySearch;
3130 VersionTuple SDKVersion =
SDKInfo->getVersion();
3133 RequiresSubdirectorySearch =
true;
3136 RequiresSubdirectorySearch = SDKVersion < VersionTuple(15, 0);
3140 RequiresSubdirectorySearch = SDKVersion < VersionTuple(18, 0);
3143 RequiresSubdirectorySearch = SDKVersion < VersionTuple(11, 0);
3146 RequiresSubdirectorySearch = SDKVersion < VersionTuple(2, 0);
3149 if (!RequiresSubdirectorySearch)
3150 CC1Args.push_back(
"-fno-modulemap-allow-subdirectory-search");
3155 const llvm::opt::ArgList &Args, llvm::opt::ArgStringList &CC1ASArgs)
const {
3157 CC1ASArgs.push_back(
"-darwin-target-variant-triple");
3164 auto EmitTargetSDKVersionArg = [&](
const VersionTuple &
V) {
3166 llvm::raw_string_ostream OS(Arg);
3167 OS <<
"-target-sdk-version=" <<
V;
3168 CC1ASArgs.push_back(Args.MakeArgString(Arg));
3172 if (
const auto *MacOStoMacCatalystMapping =
SDKInfo->getVersionMapping(
3174 std::optional<VersionTuple> SDKVersion = MacOStoMacCatalystMapping->map(
3177 EmitTargetSDKVersionArg(
3181 EmitTargetSDKVersionArg(
SDKInfo->getVersion());
3189 llvm::raw_string_ostream OS(Arg);
3190 OS <<
"-darwin-target-variant-sdk-version=" <<
SDKInfo->getVersion();
3191 CC1ASArgs.push_back(Args.MakeArgString(Arg));
3192 }
else if (
const auto *MacOStoMacCatalystMapping =
3195 if (std::optional<VersionTuple> SDKVersion =
3196 MacOStoMacCatalystMapping->map(
3200 llvm::raw_string_ostream OS(Arg);
3201 OS <<
"-darwin-target-variant-sdk-version=" << *SDKVersion;
3202 CC1ASArgs.push_back(Args.MakeArgString(Arg));
3213 DerivedArgList *DAL =
3217 if (BoundArch.empty())
3223 AddDeploymentTarget(*DAL);
3231 for (ArgList::iterator it = DAL->begin(), ie = DAL->end(); it != ie; ) {
3234 if (A->getOption().getID() != options::OPT_mkernel &&
3235 A->getOption().getID() != options::OPT_fapple_kext)
3237 assert(it != ie &&
"unexpected argument translation");
3239 assert(A->getOption().getID() == options::OPT_static &&
3240 "missing expected -static argument");
3247 if ((Arch == llvm::Triple::arm || Arch == llvm::Triple::thumb)) {
3248 if (Args.hasFlag(options::OPT_fomit_frame_pointer,
3249 options::OPT_fno_omit_frame_pointer,
false))
3250 getDriver().
Diag(clang::diag::warn_drv_unsupported_opt_for_target)
3251 <<
"-fomit-frame-pointer" << BoundArch;
3260 if (
getArch() == llvm::Triple::x86_64 ||
3262 Args.hasFlag(options::OPT_fexceptions, options::OPT_fno_exceptions,
3264 return (
getArch() == llvm::Triple::aarch64 ||
3265 getArch() == llvm::Triple::aarch64_32)
3273 if (
const char *S = ::getenv(
"RC_DEBUG_OPTIONS"))
3274 return S[0] !=
'\0';
3279 if (
const char *S = ::getenv(
"RC_DEBUG_PREFIX_MAP"))
3288 return llvm::ExceptionHandling::None;
3292 if (Triple.isWatchABI())
3293 return llvm::ExceptionHandling::DwarfCFI;
3295 return llvm::ExceptionHandling::SjLj;
3310 return (
getArch() == llvm::Triple::x86_64 ||
3311 getArch() == llvm::Triple::aarch64);
3320 ArgStringList &CmdArgs)
const {
3323 assert(!
isTargetXROS() &&
"xrOS always uses -platform-version");
3326 CmdArgs.push_back(
"-watchos_version_min");
3328 CmdArgs.push_back(
"-watchos_simulator_version_min");
3330 CmdArgs.push_back(
"-tvos_version_min");
3332 CmdArgs.push_back(
"-tvos_simulator_version_min");
3334 CmdArgs.push_back(
"-driverkit_version_min");
3336 CmdArgs.push_back(
"-ios_simulator_version_min");
3338 CmdArgs.push_back(
"-iphoneos_version_min");
3340 CmdArgs.push_back(
"-maccatalyst_version_min");
3343 CmdArgs.push_back(
"-macosx_version_min");
3349 CmdArgs.push_back(Args.MakeArgString(
TargetVersion.getAsString()));
3352 VersionTuple VariantTargetVersion;
3354 CmdArgs.push_back(
"-macosx_version_min");
3359 "unexpected target variant triple");
3360 CmdArgs.push_back(
"-maccatalyst_version_min");
3363 VersionTuple MinTgtVers =
3365 if (MinTgtVers.getMajor() && MinTgtVers > VariantTargetVersion)
3366 VariantTargetVersion = MinTgtVers;
3367 CmdArgs.push_back(Args.MakeArgString(VariantTargetVersion.getAsString()));
3378 return "mac catalyst";
3389 llvm_unreachable(
"invalid platform");
3393 llvm::opt::ArgStringList &CmdArgs)
const {
3394 auto EmitPlatformVersionArg =
3397 const llvm::Triple &TT) {
3400 CmdArgs.push_back(
"-platform_version");
3401 std::string PlatformName =
3404 PlatformName +=
"-simulator";
3405 CmdArgs.push_back(Args.MakeArgString(PlatformName));
3414 VersionTuple MinTgtVers = TT.getMinimumSupportedOSVersion();
3417 CmdArgs.push_back(Args.MakeArgString(
TargetVersion.getAsString()));
3422 std::optional<VersionTuple> iOSSDKVersion;
3424 if (
const auto *MacOStoMacCatalystMapping =
3427 iOSSDKVersion = MacOStoMacCatalystMapping->map(
3428 SDKInfo->getVersion().withoutBuild(),
3432 CmdArgs.push_back(Args.MakeArgString(
3433 (iOSSDKVersion ? *iOSSDKVersion
3440 VersionTuple SDKVersion =
SDKInfo->getVersion().withoutBuild();
3441 if (!SDKVersion.getMinor())
3442 SDKVersion = VersionTuple(SDKVersion.getMajor(), 0);
3443 CmdArgs.push_back(Args.MakeArgString(SDKVersion.getAsString()));
3454 CmdArgs.push_back(Args.MakeArgString(
TargetVersion.getAsString()));
3463 VersionTuple TargetVariantVersion;
3471 "unexpected target variant triple");
3476 EmitPlatformVersionArg(TargetVariantVersion, Platform, Environment,
3482 ArgStringList &CmdArgs) {
3484 if (
D.isTargetIPhoneOS()) {
3485 if (
D.isIPhoneOSVersionLT(3, 1))
3486 CmdArgs.push_back(
"-ldylib1.o");
3490 if (!
D.isTargetMacOS())
3492 if (
D.isMacosxVersionLT(10, 5))
3493 CmdArgs.push_back(
"-ldylib1.o");
3494 else if (
D.isMacosxVersionLT(10, 6))
3495 CmdArgs.push_back(
"-ldylib1.10.5.o");
3500 ArgStringList &CmdArgs) {
3501 if (Args.hasArg(options::OPT_static))
3504 if ((
D.isTargetIPhoneOS() &&
D.isIPhoneOSVersionLT(3, 1)) ||
3505 (
D.isTargetMacOS() &&
D.isMacosxVersionLT(10, 6)))
3506 CmdArgs.push_back(
"-lbundle1.o");
3511 ArgStringList &CmdArgs) {
3512 if (
D.isTargetMacOS() &&
D.isMacosxVersionLT(10, 9)) {
3513 if (Args.hasArg(options::OPT_static) || Args.hasArg(options::OPT_object) ||
3514 Args.hasArg(options::OPT_preload)) {
3515 CmdArgs.push_back(
"-lgcrt0.o");
3517 CmdArgs.push_back(
"-lgcrt1.o");
3526 if (!
D.isMacosxVersionLT(10, 8))
3527 CmdArgs.push_back(
"-no_new_main");
3529 D.getDriver().Diag(diag::err_drv_clang_unsupported_opt_pg_darwin)
3530 <<
D.isTargetMacOSBased();
3535 ArgStringList &CmdArgs) {
3537 if (
D.isTargetIPhoneOS()) {
3538 if (
D.getArch() == llvm::Triple::aarch64)
3540 else if (
D.isIPhoneOSVersionLT(3, 1))
3541 CmdArgs.push_back(
"-lcrt1.o");
3542 else if (
D.isIPhoneOSVersionLT(6, 0))
3543 CmdArgs.push_back(
"-lcrt1.3.1.o");
3547 if (!
D.isTargetMacOS())
3549 if (
D.isMacosxVersionLT(10, 5))
3550 CmdArgs.push_back(
"-lcrt1.o");
3551 else if (
D.isMacosxVersionLT(10, 6))
3552 CmdArgs.push_back(
"-lcrt1.10.5.o");
3553 else if (
D.isMacosxVersionLT(10, 8))
3554 CmdArgs.push_back(
"-lcrt1.10.6.o");
3559 ArgStringList &CmdArgs)
const {
3561 if (Args.hasArg(options::OPT_dynamiclib))
3563 else if (Args.hasArg(options::OPT_bundle))
3567 else if (Args.hasArg(options::OPT_static) ||
3568 Args.hasArg(options::OPT_object) ||
3569 Args.hasArg(options::OPT_preload))
3570 CmdArgs.push_back(
"-lcrt0.o");
3574 if (
isTargetMacOS() && Args.hasArg(options::OPT_shared_libgcc) &&
3576 const char *Str = Args.MakeArgString(
GetFilePath(
"crt3.o"));
3577 CmdArgs.push_back(Str);
3589 const bool IsX86_64 =
getTriple().getArch() == llvm::Triple::x86_64;
3590 const bool IsAArch64 =
getTriple().getArch() == llvm::Triple::aarch64;
3592 Res |= SanitizerKind::Address;
3593 Res |= SanitizerKind::PointerCompare;
3594 Res |= SanitizerKind::PointerSubtract;
3595 Res |= SanitizerKind::Realtime;
3596 Res |= SanitizerKind::Leak;
3597 Res |= SanitizerKind::Fuzzer;
3598 Res |= SanitizerKind::FuzzerNoLink;
3599 Res |= SanitizerKind::ObjCCast;
3606 Res |= SanitizerKind::Vptr;
3608 if ((IsX86_64 || IsAArch64) &&
3611 Res |= SanitizerKind::Thread;
3615 Res |= SanitizerKind::Type;
3619 Res |= SanitizerKind::NumericalStability;
Defines a function that returns the minimum OS versions supporting C++17's aligned allocation functio...
enum clang::sema::@1704::IndirectLocalPathEntry::EntryKind Kind
static bool hasMultipleInvocations(const llvm::Triple &Triple, const ArgList &Args)
static bool checkRemarksOptions(const Driver &D, const ArgList &Args, const llvm::Triple &Triple)
static void renderRemarksOptions(const ArgList &Args, ArgStringList &CmdArgs, const llvm::Triple &Triple, const InputInfo &Input, const InputInfo &Output, const JobAction &JA)
static void addPgProfilingLinkArgs(const Darwin &D, const ArgList &Args, ArgStringList &CmdArgs)
static const char * ArmMachOArchName(StringRef Arch)
static bool shouldLinkerNotDedup(bool IsLinkerOnlyAction, const ArgList &Args)
Pass -no_deduplicate to ld64 under certain conditions:
static bool hasExportSymbolDirective(const ArgList &Args)
Check if the link command contains a symbol export directive.
static void addDefaultCRTLinkArgs(const Darwin &D, const ArgList &Args, ArgStringList &CmdArgs)
static void addBundleLinkArgs(const Darwin &D, const ArgList &Args, ArgStringList &CmdArgs)
static llvm::VersionTuple sizedDeallocMinVersion(llvm::Triple::OSType OS)
static VersionTuple minimumMacCatalystDeploymentTarget()
static std::string getSystemOrSDKMacOSVersion(StringRef MacOSSDKVersion)
Returns the most appropriate macOS target version for the current process.
static bool sdkSupportsBuiltinModules(const Darwin::DarwinPlatformKind &TargetPlatform, const Darwin::DarwinEnvironmentKind &TargetEnvironment, const std::optional< DarwinSDKInfo > &SDKInfo)
static void addDynamicLibLinkArgs(const Darwin &D, const ArgList &Args, ArgStringList &CmdArgs)
static void AppendPlatformPrefix(SmallString< 128 > &Path, const llvm::Triple &T)
static bool isObjCRuntimeLinked(const ArgList &Args)
Determine whether we are linking the ObjC runtime.
static const char * getPlatformName(Darwin::DarwinPlatformKind Platform, Darwin::DarwinEnvironmentKind Environment)
static const char * ArmMachOArchNameCPU(StringRef CPU)
static void addExportedSymbol(ArgStringList &CmdArgs, const char *Symbol)
Add an export directive for Symbol to the link command.
static StringRef getXcodeDeveloperPath(StringRef PathIntoXcode)
Take a path that speculatively points into Xcode and return the XCODE/Contents/Developer path if it i...
static void addSectalignToPage(const ArgList &Args, ArgStringList &CmdArgs, StringRef Segment, StringRef Section)
Add a sectalign directive for Segment and Section to the maximum expected page size for Darwin.
llvm::MachO::Target Target
Defines types useful for describing an Objective-C runtime.
The information about the darwin SDK that was used during this compilation.
The basic abstraction for the target Objective-C runtime.
bool hasNativeARC() const
Does this runtime natively provide the ARC entrypoints?
bool hasSubscripting() const
Does this runtime directly support the subscripting methods?
@ MacOSX
'macosx' is the Apple-provided NeXT-derived runtime on Mac OS X platforms that use the non-fragile AB...
@ FragileMacOSX
'macosx-fragile' is the Apple-provided NeXT-derived runtime on Mac OS X platforms that use the fragil...
@ iOS
'ios' is the Apple-provided NeXT-derived runtime on iOS or the iOS simulator; it is always non-fragil...
@ WatchOS
'watchos' is a variant of iOS for Apple's watchOS.
The base class of the type hierarchy.
Action - Represent an abstract compilation step to perform.
types::ID getType() const
ActionClass getKind() const
@ VerifyDebugInfoJobClass
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
static bool GetReleaseVersion(StringRef Str, unsigned &Major, unsigned &Minor, unsigned &Micro, bool &HadExtra)
GetReleaseVersion - Parse (([0-9]+)(.
const llvm::opt::OptTable & getOpts() const
bool needsStatsRt() const
bool linkRuntimes() const
bool needsUbsanRt() const
bool needsRtsanRt() const
bool requiresMinimalRuntime() const
bool needsSharedRt() const
bool needsTysanRt() const
bool needsStableAbi() const
const char * getTypeTempSuffix(ID Id, bool CLStyle=false)
getTypeTempSuffix - Return the suffix to use when creating a temp file of this type,...
bool willEmitRemarks(const llvm::opt::ArgList &Args)
The JSON file list parser is used to communicate input to InstallAPI.
Expected< std::optional< DarwinSDKInfo > > parseDarwinSDKInfo(llvm::vfs::FileSystem &VFS, StringRef SDKRootPath)
Parse the SDK information from the SDKSettings.json file.
@ Result
The result type of a method or function.
llvm::VersionTuple alignedAllocMinVersion(llvm::Triple::OSType OS)
const FunctionProtoType * T
llvm::StringRef getAsString(SyncScope S)
static constexpr OSEnvPair macCatalystToMacOSPair()
Returns the os-environment mapping pair that's used to represent the Mac Catalyst -> macOS version ma...
static constexpr OSEnvPair macOStoMacCatalystPair()
Returns the os-environment mapping pair that's used to represent the macOS -> Mac Catalyst version ma...
static constexpr ResponseFileSupport None()
Returns a ResponseFileSupport indicating that response files are not supported.
static constexpr ResponseFileSupport AtFileUTF8()