19#include "clang/Config/config.h"
28#include "llvm/ADT/SmallString.h"
29#include "llvm/ADT/StringExtras.h"
30#include "llvm/ADT/StringRef.h"
31#include "llvm/ADT/Twine.h"
32#include "llvm/Config/llvm-config.h"
33#include "llvm/MC/MCTargetOptions.h"
34#include "llvm/MC/TargetRegistry.h"
35#include "llvm/Option/Arg.h"
36#include "llvm/Option/ArgList.h"
37#include "llvm/Option/OptTable.h"
38#include "llvm/Option/Option.h"
39#include "llvm/Support/ErrorHandling.h"
40#include "llvm/Support/FileSystem.h"
41#include "llvm/Support/FileUtilities.h"
42#include "llvm/Support/MemoryBuffer.h"
43#include "llvm/Support/Path.h"
44#include "llvm/Support/Process.h"
45#include "llvm/Support/VersionTuple.h"
46#include "llvm/Support/VirtualFileSystem.h"
47#include "llvm/TargetParser/AArch64TargetParser.h"
48#include "llvm/TargetParser/RISCVISAInfo.h"
49#include "llvm/TargetParser/TargetParser.h"
50#include "llvm/TargetParser/Triple.h"
63 return Args.getLastArg(options::OPT_mkernel, options::OPT_fapple_kext,
64 options::OPT_fno_rtti, options::OPT_frtti);
68 const llvm::Triple &Triple,
69 const Arg *CachedRTTIArg) {
72 if (CachedRTTIArg->getOption().matches(options::OPT_frtti))
79 bool NoRTTI = Triple.isPS() || Triple.isDriverKit();
84 if (Args.hasFlag(options::OPT_fexceptions, options::OPT_fno_exceptions,
96 assert(T.str() == T.normalize() &&
"triple should be normalized");
97 auto addIfExists = [
this](
path_list &List,
const std::string &Path) {
119 const Driver &D, StringRef Fallback) {
120 std::optional<std::string> MultilibPath =
124 llvm::ErrorOr<std::unique_ptr<llvm::MemoryBuffer>> MB =
125 D.getVFS().getBufferForFile(*MultilibPath);
130 llvm::ErrorOr<MultilibSet> ErrorOrMultilibSet =
132 if (ErrorOrMultilibSet.getError())
135 Multilibs = std::move(ErrorOrMultilibSet.get());
144 for (StringRef Define : CustomFlagMacroDefines)
148 D.Diag(clang::diag::warn_drv_missing_multilib) << llvm::join(Flags,
" ");
150 raw_svector_ostream OS(
Data);
153 OS <<
"\n" << llvm::join(M.flags(),
" ");
154 D.Diag(clang::diag::note_drv_available_multilibs) << OS.str();
158 D.Diag(clang::diag::err_drv_multilib_custom_error)
159 << M.getErrorMessage();
167 StringRef YAMLBase = llvm::sys::path::parent_path(*MultilibPath);
169 size_t FileInsertPos = 0;
170 size_t LibInsertPos = 0;
175 llvm::sys::path::append(FilePath, M.gccSuffix());
177 std::string(FilePath));
181 llvm::sys::path::append(LibPath, M.gccSuffix());
183 std::string(LibPath));
191std::optional<std::string>
193 StringRef FallbackDir) {
194 if (Arg *A = Args.getLastArg(options::OPT_multi_lib_config)) {
196 if (!D.getVFS().exists(MultilibPath)) {
197 D.Diag(clang::diag::err_drv_no_such_file) << MultilibPath.str();
200 return std::string(MultilibPath);
204 if (!FallbackDir.empty())
205 MultilibPath = FallbackDir;
206 else if (std::optional<std::string> StdlibDir =
getStdlibPath())
207 MultilibPath = *StdlibDir;
210 llvm::sys::path::append(MultilibPath,
"multilib.yaml");
211 if (!D.getVFS().exists(MultilibPath))
213 return std::string(MultilibPath);
217 Triple.setEnvironment(Env);
218 if (EffectiveTriple != llvm::Triple())
219 EffectiveTriple.setEnvironment(Env);
229 return Args.hasFlag(options::OPT_fintegrated_as,
230 options::OPT_fno_integrated_as,
238 "(Non-)integrated backend set incorrectly!");
240 bool IBackend = Args.hasFlag(options::OPT_fintegrated_objemitter,
241 options::OPT_fno_integrated_objemitter,
249 DiagID = clang::diag::err_drv_unsupported_opt_for_target;
251 DiagID = clang::diag::warn_drv_unsupported_opt_for_target;
252 Arg *A = Args.getLastArg(options::OPT_fno_integrated_objemitter);
254 D.Diag(DiagID) << A->getAsString(Args) << Triple.getTriple();
255 A = Args.getLastArg(options::OPT_fintegrated_objemitter);
257 D.Diag(DiagID) << A->getAsString(Args) << Triple.getTriple();
263 return ENABLE_X86_RELAX_RELOCATIONS;
267 return PPC_LINUX_DEFAULT_IEEELONGDOUBLE &&
getTriple().isOSLinux();
271 const llvm::opt::ArgList &Args) {
272 for (
const Arg *MultilibFlagArg :
273 Args.filtered(options::OPT_fmultilib_flag)) {
274 List.push_back(MultilibFlagArg->getAsString(Args));
275 MultilibFlagArg->claim();
280 const llvm::Triple &Triple,
281 const llvm::opt::ArgList &Args,
283 std::vector<StringRef> Features;
288 llvm::DenseSet<StringRef> FeatureSet(UnifiedFeatures.begin(),
289 UnifiedFeatures.end());
290 std::vector<std::string> MArch;
291 for (
const auto &Ext : AArch64::Extensions)
292 if (Ext.UserVisibleName.value())
293 if (FeatureSet.contains(AArch64::StrTab[Ext.PosTargetFeature]))
294 MArch.push_back(AArch64::StrTab[Ext.UserVisibleName].str());
295 for (
const auto &Ext : AArch64::Extensions)
296 if (Ext.UserVisibleName.value())
297 if (FeatureSet.contains(AArch64::StrTab[Ext.NegTargetFeature]))
298 MArch.push_back((
"no" + AArch64::StrTab[Ext.UserVisibleName]).str());
300 for (
const auto &ArchInfo : AArch64::ArchInfos)
301 if (FeatureSet.contains(AArch64::StrTab[ArchInfo.ArchFeature]))
302 ArchName = AArch64::StrTab[ArchInfo.Name];
303 if (!ArchName.empty()) {
304 MArch.insert(MArch.begin(), (
"-march=" + ArchName).str());
305 Result.push_back(llvm::join(MArch,
"+"));
308 const Arg *BranchProtectionArg =
309 Args.getLastArgNoClaim(options::OPT_mbranch_protection_EQ);
310 if (BranchProtectionArg) {
311 Result.push_back(BranchProtectionArg->getAsString(Args));
314 if (FeatureSet.contains(
"+strict-align"))
315 Result.push_back(
"-mno-unaligned-access");
317 Result.push_back(
"-munaligned-access");
319 if (Arg *Endian = Args.getLastArg(options::OPT_mbig_endian,
320 options::OPT_mlittle_endian)) {
321 if (Endian->getOption().matches(options::OPT_mbig_endian))
322 Result.push_back(Endian->getAsString(Args));
325 const Arg *ABIArg = Args.getLastArgNoClaim(options::OPT_mabi_EQ);
327 Result.push_back(ABIArg->getAsString(Args));
330 if (
const Arg *A = Args.getLastArg(options::OPT_O_Group);
331 A && A->getOption().matches(options::OPT_O)) {
332 switch (A->getValue()[0]) {
344 llvm::Reloc::Model RelocationModel,
345 const llvm::opt::ArgList &Args,
347 std::vector<StringRef> Features;
349 D, Triple, Args, Features,
false ,
true );
351 llvm::DenseSet<StringRef> FeatureSet(UnifiedFeatures.begin(),
352 UnifiedFeatures.end());
353 std::vector<std::string> MArch;
354 for (
const auto &Ext : ARM::ARCHExtNames)
355 if (!Ext.Name.empty())
356 if (FeatureSet.contains(Ext.Feature))
357 MArch.push_back(Ext.Name.str());
358 for (
const auto &Ext : ARM::ARCHExtNames)
359 if (!Ext.Name.empty())
360 if (FeatureSet.contains(Ext.NegFeature))
361 MArch.push_back((
"no" + Ext.Name).str());
362 MArch.insert(MArch.begin(), (
"-march=" + Triple.getArchName()).str());
363 Result.push_back(llvm::join(MArch,
"+"));
366#define ARM_FPU(NAME, KIND, VERSION, NEON_SUPPORT, RESTRICTION) \
367 case llvm::ARM::KIND: \
368 Result.push_back("-mfpu=" NAME); \
370#include "llvm/TargetParser/ARMTargetParser.def"
372 llvm_unreachable(
"Invalid FPUKind");
376 case arm::FloatABI::Soft:
377 Result.push_back(
"-mfloat-abi=soft");
379 case arm::FloatABI::SoftFP:
380 Result.push_back(
"-mfloat-abi=softfp");
382 case arm::FloatABI::Hard:
383 Result.push_back(
"-mfloat-abi=hard");
385 case arm::FloatABI::Invalid:
386 llvm_unreachable(
"Invalid float ABI");
389 if (RelocationModel == llvm::Reloc::ROPI ||
390 RelocationModel == llvm::Reloc::ROPI_RWPI)
391 Result.push_back(
"-fropi");
393 Result.push_back(
"-fno-ropi");
395 if (RelocationModel == llvm::Reloc::RWPI ||
396 RelocationModel == llvm::Reloc::ROPI_RWPI)
397 Result.push_back(
"-frwpi");
399 Result.push_back(
"-fno-rwpi");
401 const Arg *BranchProtectionArg =
402 Args.getLastArgNoClaim(options::OPT_mbranch_protection_EQ);
403 if (BranchProtectionArg) {
404 Result.push_back(BranchProtectionArg->getAsString(Args));
407 if (FeatureSet.contains(
"+strict-align"))
408 Result.push_back(
"-mno-unaligned-access");
410 Result.push_back(
"-munaligned-access");
412 if (Arg *Endian = Args.getLastArg(options::OPT_mbig_endian,
413 options::OPT_mlittle_endian)) {
414 if (Endian->getOption().matches(options::OPT_mbig_endian))
415 Result.push_back(Endian->getAsString(Args));
418 if (
const Arg *A = Args.getLastArg(options::OPT_O_Group);
419 A && A->getOption().matches(options::OPT_O)) {
420 switch (A->getValue()[0]) {
432 const llvm::opt::ArgList &Args,
434 bool hasShadowCallStack) {
437 auto ISAInfo = llvm::RISCVISAInfo::parseArchString(
439 if (!llvm::errorToBool(ISAInfo.takeError()))
440 Result.push_back(
"-march=" + (*ISAInfo)->toString());
444 if (hasShadowCallStack)
445 Result.push_back(
"-fsanitize=shadow-call-stack");
447 Result.push_back(
"-fno-sanitize=shadow-call-stack");
449 const Arg *CFProtectionArg =
450 Args.getLastArgNoClaim(options::OPT_fcf_protection_EQ);
451 StringRef CFProtectionVal =
452 CFProtectionArg ? CFProtectionArg->getValue() :
"none";
453 Result.push_back((
"-fcf-protection=" + CFProtectionVal).str());
455 if (CFProtectionVal ==
"branch" || CFProtectionVal ==
"full") {
456 if (
const Arg *SchemeArg =
457 Args.getLastArgNoClaim(options::OPT_mcf_branch_label_scheme_EQ))
458 Result.push_back(SchemeArg->getAsString(Args));
466 std::vector<std::string>
Result;
468 Result.push_back(
"--target=" + Triple.str());
474 llvm::Reloc::Model RelocationModel;
479 std::tie(RelocationModel, PICLevel, IsPIE) =
ParsePICArgs(*
this, Args);
482 switch (Triple.getArch()) {
483 case llvm::Triple::aarch64:
484 case llvm::Triple::aarch64_32:
485 case llvm::Triple::aarch64_be:
488 case llvm::Triple::arm:
489 case llvm::Triple::armeb:
490 case llvm::Triple::thumb:
491 case llvm::Triple::thumbeb:
494 case llvm::Triple::riscv32:
495 case llvm::Triple::riscv64:
496 case llvm::Triple::riscv32be:
497 case llvm::Triple::riscv64be:
507 if (Arg *CStdLibArg = Args.getLastArg(options::OPT_cstdlib_EQ))
508 Result.push_back(std::string(CStdLibArg->getOption().getPrefixedName()) +
509 CStdLibArg->getValue());
514 Result.push_back(
"-fno-rtti");
516 Result.push_back(
"-frtti");
519 Result.push_back(
"-fno-exceptions");
521 Result.push_back(
"-fexceptions");
523 if (RelocationModel == llvm::Reloc::PIC_)
524 Result.push_back(IsPIE ? (PICLevel > 1 ?
"-fPIE" :
"-fpie")
525 : (PICLevel > 1 ?
"-fPIC" :
"-fpic"));
527 Result.push_back(
"-fno-pic");
541 bool DiagnoseBoundArchErrors =
542 BoundArchSanitizerArgsChecked.insert(BA.
ArchName).second;
544 !JobArgs.hasFlag(options::OPT_fgpu_sanitize,
545 options::OPT_fno_gpu_sanitize,
true)) {
546 DiagnoseBoundArchErrors =
false;
550 !SanitizerArgsChecked,
551 DiagnoseBoundArchErrors, BA, DeviceOffloadKind);
553 SanitizerArgsChecked =
true;
558 XRayArgs XRayArguments(*
this, JobArgs);
559 return XRayArguments;
566 const char *ModeFlag;
575 static const DriverSuffix DriverSuffixes[] = {
577 {
"clang++",
"--driver-mode=g++"},
578 {
"clang-c++",
"--driver-mode=g++"},
579 {
"clang-cc",
nullptr},
580 {
"clang-cpp",
"--driver-mode=cpp"},
581 {
"clang-g++",
"--driver-mode=g++"},
582 {
"clang-gcc",
nullptr},
583 {
"clang-cl",
"--driver-mode=cl"},
585 {
"cpp",
"--driver-mode=cpp"},
586 {
"cl",
"--driver-mode=cl"},
587 {
"++",
"--driver-mode=g++"},
588 {
"flang",
"--driver-mode=flang"},
591 {
"flang-new",
"--driver-mode=flang"},
592 {
"clang-dxc",
"--driver-mode=dxc"},
595 for (
const auto &DS : DriverSuffixes) {
596 StringRef Suffix(DS.Suffix);
597 if (ProgName.ends_with(Suffix)) {
598 Pos = ProgName.size() - Suffix.size();
608 std::string ProgName = std::string(llvm::sys::path::filename(Argv0));
609 if (is_style_windows(llvm::sys::path::Style::native)) {
611 std::transform(ProgName.begin(), ProgName.end(), ProgName.begin(),
627 if (!DS && ProgName.ends_with(
".exe")) {
630 ProgName = ProgName.drop_back(StringRef(
".exe").size());
637 ProgName = ProgName.rtrim(
"0123456789.");
644 ProgName = ProgName.slice(0, ProgName.rfind(
'-'));
657 size_t SuffixEnd = SuffixPos + strlen(DS->Suffix);
659 size_t LastComponent = ProgName.rfind(
'-', SuffixPos);
660 if (LastComponent == std::string::npos)
662 std::string ModeSuffix = ProgName.substr(LastComponent + 1,
663 SuffixEnd - LastComponent - 1);
666 StringRef Prefix(ProgName);
667 Prefix = Prefix.slice(0, LastComponent);
668 std::string IgnoredError;
670 llvm::Triple Triple(Prefix);
671 bool IsRegistered = llvm::TargetRegistry::lookupTarget(Triple, IgnoredError);
680 switch (Triple.getArch()) {
681 case llvm::Triple::aarch64: {
686 case llvm::Triple::aarch64_32:
688 case llvm::Triple::ppc:
690 case llvm::Triple::ppcle:
692 case llvm::Triple::ppc64:
694 case llvm::Triple::ppc64le:
697 return Triple.getArchName();
710Tool *ToolChain::getClang()
const {
716Tool *ToolChain::getFlang()
const {
727 llvm_unreachable(
"Linking is not supported by this toolchain");
731 llvm_unreachable(
"Creating static lib is not supported by this toolchain");
734Tool *ToolChain::getAssemble()
const {
737 return Assemble.get();
740Tool *ToolChain::getClangAs()
const {
743 return Assemble.get();
746Tool *ToolChain::getLink()
const {
752Tool *ToolChain::getStaticLibTool()
const {
755 return StaticLibTool.get();
758Tool *ToolChain::getIfsMerge()
const {
760 IfsMerge.reset(
new tools::ifstool::Merger(*
this));
761 return IfsMerge.get();
764Tool *ToolChain::getOffloadBundler()
const {
766 OffloadBundler.reset(
new tools::OffloadBundler(*
this));
767 return OffloadBundler.get();
770Tool *ToolChain::getOffloadPackager()
const {
771 if (!OffloadPackager)
772 OffloadPackager.reset(
new tools::OffloadPackager(*
this));
773 return OffloadPackager.get();
776Tool *ToolChain::getLinkerWrapper()
const {
778 LinkerWrapper.reset(
new tools::LinkerWrapper(*
this, getLink()));
779 return LinkerWrapper.get();
785 return getAssemble();
788 return getIfsMerge();
794 return getStaticLibTool();
805 llvm_unreachable(
"Invalid tool kind.");
818 return getOffloadBundler();
821 return getOffloadPackager();
823 return getLinkerWrapper();
826 llvm_unreachable(
"Invalid tool kind.");
830 const ArgList &Args) {
831 const llvm::Triple &Triple = TC.
getTriple();
832 bool IsWindows = Triple.isOSWindows();
835 return Triple.getArchName();
837 if (TC.
getArch() == llvm::Triple::arm || TC.
getArch() == llvm::Triple::armeb)
843 if (TC.
getArch() == llvm::Triple::x86 && Triple.isAndroid())
846 if (TC.
getArch() == llvm::Triple::x86_64 && Triple.isX32())
849 return llvm::Triple::getArchTypeName(TC.
getArch());
853 if (Triple.isOSDarwin())
856 switch (Triple.getOS()) {
857 case llvm::Triple::FreeBSD:
859 case llvm::Triple::NetBSD:
861 case llvm::Triple::OpenBSD:
863 case llvm::Triple::Solaris:
865 case llvm::Triple::AIX:
867 case llvm::Triple::Serenity:
881 }
else if (Triple.isOSUnknown()) {
882 llvm::sys::path::append(Path,
"lib");
886 return std::string(Path);
893 return llvm::sys::path::filename(CRTAbsolutePath).str();
899 bool IsFortran)
const {
901 bool IsITANMSVCWindows =
902 TT.isWindowsMSVCEnvironment() || TT.isWindowsItaniumEnvironment();
909 Suffix = IsITANMSVCWindows ?
".obj" :
".o";
912 Suffix = IsITANMSVCWindows ?
".lib" :
".a";
915 if (TT.isOSWindows())
916 Suffix = TT.isOSCygMing() ?
".dll.a" :
".lib";
917 else if (TT.isOSAIX())
924 std::string ArchAndEnv;
927 const char *Env = TT.isAndroid() ?
"-android" :
"";
928 ArchAndEnv = (
"-" +
Arch + Env).str();
931 std::string LibName = IsFortran ?
"flang_rt." :
"clang_rt.";
932 return (Prefix + Twine(LibName) + Component + ArchAndEnv + Suffix).str();
939 Args, Component,
Type,
false, IsFortran);
943 llvm::sys::path::append(P, CRTBasename);
945 return std::string(P);
952 !IsFortran, IsFortran);
954 llvm::sys::path::append(OldPath, CRTBasename);
955 if (Path.empty() ||
getVFS().exists(OldPath))
956 return std::string(OldPath);
961 return std::string(Path);
967 bool isFortran)
const {
973 llvm::opt::ArgStringList &CmdArgs)
const {
978 if (!
getTriple().isKnownWindowsMSVCEnvironment()) {
980 F128LibName.consume_front_insensitive(
"lib");
981 if (!F128LibName.empty()) {
983 CmdArgs.push_back(
"-lflang_rt.quadmath");
986 CmdArgs.push_back(Args.MakeArgString(
"-l" + F128LibName));
995 CmdArgs.push_back(
"-lexecinfo");
999 if (Args.hasFlag(options::OPT_fopenmp, options::OPT_fopenmp_EQ,
1000 options::OPT_fno_openmp,
false)) {
1005 !
getTriple().isKnownWindowsMSVCEnvironment()) {
1007 CmdArgs.push_back(
"-lcompiler_rt");
1009 CmdArgs.push_back(
"-latomic");
1015 ArgStringList &CmdArgs)
const {
1016 auto AddLibSearchPathIfExists = [&](
const Twine &Path) {
1018 if (!llvm::sys::fs::is_directory(Path))
1021 if (
getTriple().isKnownWindowsMSVCEnvironment())
1022 CmdArgs.push_back(Args.MakeArgString(
"-libpath:" + Path));
1024 CmdArgs.push_back(Args.MakeArgString(
"-L" + Path));
1037 llvm::sys::path::parent_path(
getDriver().Dir);
1038 llvm::sys::path::append(DefaultLibPath,
"lib");
1039 AddLibSearchPathIfExists(DefaultLibPath);
1043 llvm::opt::ArgStringList &CmdArgs)
const {
1046 if (Args.hasFlag(options::OPT_static_libflangrt,
1047 options::OPT_shared_libflangrt,
getTriple().isOSAIX()))
1051 CmdArgs.push_back(
"-lflang_rt.runtime");
1059std::optional<std::string>
1060ToolChain::getFallbackAndroidTargetPath(StringRef BaseDir)
const {
1061 llvm::Triple TripleWithoutLevel(
getTriple());
1062 TripleWithoutLevel.setEnvironmentName(
"android");
1063 const std::string &TripleWithoutLevelStr = TripleWithoutLevel.str();
1064 unsigned TripleVersion =
getTriple().getEnvironmentVersion().getMajor();
1065 unsigned BestVersion = 0;
1068 bool UsingUnversionedDir =
false;
1070 for (llvm::vfs::directory_iterator LI =
getVFS().dir_begin(BaseDir, EC), LE;
1071 !EC && LI != LE; LI = LI.increment(EC)) {
1072 StringRef DirName = llvm::sys::path::filename(LI->path());
1073 StringRef DirNameSuffix = DirName;
1074 if (DirNameSuffix.consume_front(TripleWithoutLevelStr)) {
1075 if (DirNameSuffix.empty() && TripleDir.empty()) {
1076 TripleDir = DirName;
1077 UsingUnversionedDir =
true;
1080 if (!DirNameSuffix.getAsInteger(10, Version) && Version > BestVersion &&
1081 Version < TripleVersion) {
1082 BestVersion = Version;
1083 TripleDir = DirName;
1084 UsingUnversionedDir =
false;
1090 if (TripleDir.empty())
1093 SmallString<128> P(BaseDir);
1094 llvm::sys::path::append(P, TripleDir);
1095 if (UsingUnversionedDir)
1096 D.Diag(diag::warn_android_unversioned_fallback) << P <<
getTripleString();
1097 return std::string(P);
1101 return (Triple.hasEnvironment()
1102 ? llvm::Triple(Triple.getArchName(), Triple.getVendorName(),
1103 llvm::Triple::getOSTypeName(Triple.getOS()),
1104 llvm::Triple::getEnvironmentTypeName(
1105 Triple.getEnvironment()))
1106 : llvm::Triple(Triple.getArchName(), Triple.getVendorName(),
1107 llvm::Triple::getOSTypeName(Triple.getOS())));
1110std::optional<std::string>
1112 auto getPathForTriple =
1113 [&](
const llvm::Triple &Triple) -> std::optional<std::string> {
1115 llvm::sys::path::append(P, Triple.str());
1117 return std::string(P);
1122 if (
auto Path = getPathForTriple(T))
1126 llvm::Triple AIXTriple;
1127 if (T.getEnvironment() == Triple::UnknownEnvironment) {
1129 AIXTriple = llvm::Triple(T.getArchName(), T.getVendorName(),
1130 llvm::Triple::getOSTypeName(T.getOS()));
1135 if (
auto Path = getPathForTriple(AIXTriple))
1140 (!T.getOSVersion().empty() || !T.getEnvironmentVersion().empty())) {
1143 if (
auto Path = getPathForTriple(TripleWithoutVersion))
1162 if (T.getArch() == Triple::arm && !T.isArmMClass()) {
1163 llvm::Triple ArmTriple = T;
1164 ArmTriple.setArch(Triple::arm);
1165 if (
auto Path = getPathForTriple(ArmTriple))
1170 return getFallbackAndroidTargetPath(BaseDir);
1177 llvm::sys::path::append(P,
"finclude",
"flang");
1183 llvm::sys::path::append(P,
"lib");
1187 if (Triple.isOSDarwin())
1190 llvm::sys::path::append(P, Triple.str());
1191 return std::string(P);
1196 llvm::sys::path::append(P,
"..",
"lib");
1202 llvm::sys::path::append(P,
"..",
"include");
1211 llvm::sys::path::append(Path,
"lib");
1213 llvm::sys::path::append(Path, S);
1214 Paths.push_back(std::string(Path));
1223 if (Args.hasArg(options::OPT_noprofilelib))
1226 return Args.hasArg(options::OPT_fprofile_generate) ||
1227 Args.hasArg(options::OPT_fprofile_generate_EQ) ||
1228 Args.hasArg(options::OPT_fcs_profile_generate) ||
1229 Args.hasArg(options::OPT_fcs_profile_generate_EQ) ||
1230 Args.hasArg(options::OPT_fprofile_instr_generate) ||
1231 Args.hasArg(options::OPT_fprofile_instr_generate_EQ) ||
1232 Args.hasArg(options::OPT_fcreate_profile) ||
1233 Args.hasArg(options::OPT_fprofile_generate_cold_function_coverage) ||
1234 Args.hasArg(options::OPT_fprofile_generate_cold_function_coverage_EQ);
1238 return Args.hasArg(options::OPT_coverage) ||
1239 Args.hasFlag(options::OPT_fprofile_arcs, options::OPT_fno_profile_arcs,
1244 if (D.IsFlangMode() &&
getDriver().ShouldUseFlangCompiler(JA))
return getFlang();
1245 if (
getDriver().ShouldUseClangCompiler(JA))
return getClang();
1249 return getClangAs();
1254 return D.GetFilePath(Name, *
this);
1258 return D.GetProgramPath(Name, *
this);
1263 *LinkerIsLLD =
false;
1267 const Arg* A = Args.getLastArg(options::OPT_fuse_ld_EQ);
1275 if (
const Arg *A = Args.getLastArg(options::OPT_ld_path_EQ)) {
1276 std::string Path(A->getValue());
1277 if (!Path.empty()) {
1278 if (llvm::sys::path::parent_path(Path).empty())
1280 if (llvm::sys::fs::can_execute(Path)) {
1282 *LinkerIsLLD = UseLinker ==
"lld";
1283 return std::string(Path);
1286 getDriver().
Diag(diag::err_drv_invalid_linker_name) << A->getAsString(Args);
1291 if (UseLinker.empty() || UseLinker ==
"ld") {
1293 if (llvm::sys::path::is_absolute(DefaultLinker))
1294 return std::string(DefaultLinker);
1303 if (UseLinker.contains(
'/'))
1306 if (llvm::sys::path::is_absolute(UseLinker)) {
1309 if (llvm::sys::fs::can_execute(UseLinker))
1310 return std::string(UseLinker);
1313 if (Triple.isOSDarwin())
1314 LinkerName.append(
"ld64.");
1316 LinkerName.append(
"ld.");
1317 LinkerName.append(UseLinker);
1320 if (llvm::sys::fs::can_execute(LinkerPath)) {
1322 *LinkerIsLLD = UseLinker ==
"lld";
1328 getDriver().
Diag(diag::err_drv_invalid_linker_name) << A->getAsString(Args);
1335 if (Triple.isOSDarwin())
1346 if (D.IsFlangMode() &&
id == types::TY_PP_Fortran)
1347 id = types::TY_Fortran;
1364 llvm::opt::OptSpecifier OptEq,
1365 llvm::opt::OptSpecifier OptNeg) {
1366 if (!Args.hasFlag(OptEq, OptNeg,
false))
1369 const Arg *A = Args.getLastArg(OptEq);
1370 StringRef LTOName = A->getValue();
1372 return llvm::StringSwitch<LTOKind>(LTOName)
1382 auto OptEq = IsOffload ? options::OPT_foffload_lto_EQ : options::OPT_flto_EQ;
1383 auto OptNeg = IsOffload ? options::OPT_fno_offload_lto : options::OPT_fno_lto;
1387 if (IsOffload && Args.hasFlag(options::OPT_fopenmp_target_jit,
1388 options::OPT_fno_openmp_target_jit,
false)) {
1389 if (Arg *A = Args.getLastArg(OptEq, OptNeg))
1392 << A->getSpelling() <<
"-fopenmp-target-jit";
1396 if (!Args.hasArg(OptEq, OptNeg))
1402 const Arg *A = Args.getLastArg(OptEq);
1404 << A->getSpelling() << A->getValue();
1411 llvm::Triple HostTriple(LLVM_HOST_TRIPLE);
1412 switch (HostTriple.getArch()) {
1415 case llvm::Triple::arm:
1416 case llvm::Triple::armeb:
1417 case llvm::Triple::thumb:
1418 case llvm::Triple::thumbeb:
1419 return getArch() != llvm::Triple::arm &&
getArch() != llvm::Triple::thumb &&
1420 getArch() != llvm::Triple::armeb &&
getArch() != llvm::Triple::thumbeb;
1422 return HostTriple.getArch() !=
getArch();
1431llvm::ExceptionHandling
1433 return llvm::ExceptionHandling::None;
1437 if (Model ==
"single") {
1439 return Triple.getArch() == llvm::Triple::arm ||
1440 Triple.getArch() == llvm::Triple::armeb ||
1441 Triple.getArch() == llvm::Triple::thumb ||
1442 Triple.getArch() == llvm::Triple::thumbeb || Triple.isWasm();
1443 }
else if (Model ==
"posix")
1455 case llvm::Triple::x86_64: {
1457 if (!Triple.isOSBinFormatMachO())
1460 if (Arg *A = Args.getLastArg(options::OPT_march_EQ)) {
1463 StringRef MArch = A->getValue();
1464 if (MArch ==
"x86_64h")
1465 Triple.setArchName(MArch);
1467 return Triple.getTriple();
1469 case llvm::Triple::aarch64: {
1471 if (!Triple.isOSBinFormatMachO())
1472 return Triple.getTriple();
1474 if (Triple.isArm64e())
1475 return Triple.getTriple();
1480 Triple.setArchName(
"arm64");
1481 return Triple.getTriple();
1483 case llvm::Triple::aarch64_32:
1485 case llvm::Triple::amdgcn: {
1488 return Triple.getTriple();
1490 case llvm::Triple::arm:
1491 case llvm::Triple::armeb:
1492 case llvm::Triple::thumb:
1493 case llvm::Triple::thumbeb: {
1497 return Triple.getTriple();
1513 ArgStringList &CC1Args)
const {
1518 const ArgList &DriverArgs, ArgStringList &CC1Args,
BoundArch BA,
1522 ArgStringList &CC1ASArgs)
const {}
1527 llvm::opt::ArgStringList &CmdArgs)
const {
1535 const ArgList &Args)
const {
1537 return *runtimeLibType;
1539 const Arg* A = Args.getLastArg(options::OPT_rtlib_EQ);
1540 StringRef LibName = A ? A->getValue() : CLANG_DEFAULT_RTLIB;
1543 if (LibName ==
"compiler-rt")
1545 else if (LibName ==
"libgcc")
1547 else if (LibName ==
"platform")
1552 << A->getAsString(Args);
1557 return *runtimeLibType;
1561 const ArgList &Args)
const {
1563 return *unwindLibType;
1565 const Arg *A = Args.getLastArg(options::OPT_unwindlib_EQ);
1566 StringRef LibName = A ? A->getValue() : CLANG_DEFAULT_UNWINDLIB;
1568 if (LibName ==
"none")
1570 else if (LibName ==
"platform" || LibName ==
"") {
1580 }
else if (LibName ==
"libunwind") {
1584 }
else if (LibName ==
"libgcc")
1589 << A->getAsString(Args);
1594 return *unwindLibType;
1599 return *cxxStdlibType;
1601 const Arg *A = Args.getLastArg(options::OPT_stdlib_EQ);
1602 StringRef LibName = A ? A->getValue() : CLANG_DEFAULT_CXX_STDLIB;
1605 if (LibName ==
"libc++")
1607 else if (LibName ==
"libstdc++")
1609 else if (LibName ==
"platform")
1614 << A->getAsString(Args);
1619 return *cxxStdlibType;
1624 return *cStdlibType;
1626 const Arg *A = Args.getLastArg(options::OPT_cstdlib_EQ);
1627 StringRef LibName = A ? A->getValue() :
"system";
1629 if (LibName ==
"newlib")
1631 else if (LibName ==
"picolibc")
1633 else if (LibName ==
"llvm-libc")
1635 else if (LibName ==
"system")
1640 << A->getAsString(Args);
1644 return *cStdlibType;
1649 llvm::opt::ArgStringList &CC1Args,
1650 const Twine &Path) {
1651 CC1Args.push_back(
"-internal-iframework");
1652 CC1Args.push_back(DriverArgs.MakeArgString(Path));
1664 ArgStringList &CC1Args,
1665 const Twine &Path) {
1666 CC1Args.push_back(
"-internal-externc-isystem");
1667 CC1Args.push_back(DriverArgs.MakeArgString(Path));
1671 ArgStringList &CC1Args,
1672 const Twine &Path) {
1673 if (llvm::sys::fs::exists(Path))
1679 ArgStringList &CC1Args,
1680 const Twine &Path) {
1681 CC1Args.push_back(
"-internal-isystem");
1682 CC1Args.push_back(DriverArgs.MakeArgString(Path));
1687 ArgStringList &CC1Args,
1689 for (
const auto &Path : Paths) {
1690 CC1Args.push_back(
"-internal-iframework");
1691 CC1Args.push_back(DriverArgs.MakeArgString(Path));
1697 ArgStringList &CC1Args,
1699 for (
const auto &Path : Paths) {
1700 CC1Args.push_back(
"-internal-isystem");
1701 CC1Args.push_back(DriverArgs.MakeArgString(Path));
1706 const Twine &
C,
const Twine &D) {
1708 llvm::sys::path::append(
Result, llvm::sys::path::Style::posix, A, B,
C, D);
1709 return std::string(
Result);
1715 std::string MaxVersionString;
1717 llvm::sys::path::append(Path,
"c++");
1718 for (llvm::vfs::directory_iterator LI =
getVFS().dir_begin(Path, EC), LE;
1719 !EC && LI != LE; LI = LI.increment(EC)) {
1720 StringRef VersionText = llvm::sys::path::filename(LI->path());
1722 if (VersionText[0] ==
'v' &&
1723 !VersionText.substr(1).getAsInteger(10, Version)) {
1724 if (Version > MaxVersion) {
1725 MaxVersion = Version;
1726 MaxVersionString = std::string(VersionText);
1732 return MaxVersionString;
1736 ArgStringList &CC1Args)
const {
1746 DriverArgs.AddAllArgs(CC1Args, options::OPT_stdlib_EQ);
1750 const llvm::opt::ArgList &DriverArgs,
1751 llvm::opt::ArgStringList &CC1Args)
const {
1752 DriverArgs.ClaimAllArgs(options::OPT_stdlibxx_isystem);
1761 if (!DriverArgs.hasArg(options::OPT_nostdincxx))
1762 for (
const auto &P :
1763 DriverArgs.getAllArgValues(options::OPT_stdlibxx_isystem))
1769 !Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs,
1770 options::OPT_nostdlibxx);
1774 ArgStringList &CmdArgs)
const {
1775 assert(!Args.hasArg(options::OPT_nostdlibxx) &&
1776 "should not have called this");
1781 CmdArgs.push_back(
"-lc++");
1782 if (Args.hasArg(options::OPT_fexperimental_library))
1783 CmdArgs.push_back(
"-lc++experimental");
1787 CmdArgs.push_back(
"-lstdc++");
1793 ArgStringList &CmdArgs)
const {
1795 if(LibPath.length() > 0)
1796 CmdArgs.push_back(Args.MakeArgString(StringRef(
"-L") + LibPath));
1800 ArgStringList &CmdArgs)
const {
1801 CmdArgs.push_back(
"-lcc_kext");
1805 std::string &Path)
const {
1809 bool Default = !Args.hasArgNoClaim(options::OPT_shared);
1815 Arg *A = Args.getLastArg(
1816 options::OPT_ffast_math, options::OPT_fno_fast_math,
1817 options::OPT_funsafe_math_optimizations,
1818 options::OPT_fno_unsafe_math_optimizations, options::OPT_ffp_model_EQ);
1820 if (!A || A->getOption().getID() == options::OPT_fno_fast_math ||
1821 A->getOption().getID() == options::OPT_fno_unsafe_math_optimizations)
1823 if (A && A->getOption().getID() == options::OPT_ffp_model_EQ) {
1824 StringRef Model = A->getValue();
1825 if (Model !=
"fast" && Model !=
"aggressive")
1832 if (!Args.hasFlag(options::OPT_mdaz_ftz, options::OPT_mno_daz_ftz,
Default))
1837 return (Path !=
"crtfastmath.o");
1841 ArgStringList &CmdArgs)
const {
1844 CmdArgs.push_back(Args.MakeArgString(Path));
1864 (SanitizerKind::CFI & ~SanitizerKind::CFIICall) |
1865 SanitizerKind::CFICastStrict | SanitizerKind::FloatDivideByZero |
1866 SanitizerKind::KCFI | SanitizerKind::UnsignedIntegerOverflow |
1867 SanitizerKind::UnsignedShiftBase | SanitizerKind::ImplicitConversion |
1868 SanitizerKind::Nullability | SanitizerKind::LocalBounds |
1869 SanitizerKind::AllocToken;
1877 Res |= SanitizerKind::CFIICall;
1880 Res |= SanitizerKind::ShadowCallStack;
1882 Res |= SanitizerKind::MemTag;
1884 Res |= SanitizerKind::KernelAddress;
1889 ArgStringList &CC1Args)
const {}
1892 ArgStringList &CC1Args)
const {}
1895 ArgStringList &CC1Args)
const {}
1904 ArgStringList &CC1Args)
const {}
1908 return VersionTuple(Version);
1910 if (Version < 10000)
1911 return VersionTuple(Version / 100, Version % 100);
1913 unsigned Build = 0, Factor = 1;
1914 for (; Version > 10000; Version = Version / 10, Factor = Factor * 10)
1915 Build = Build + (Version % 10) * Factor;
1916 return VersionTuple(Version / 100, Version % 100, Build);
1921 const llvm::opt::ArgList &Args)
const {
1922 const Arg *MSCVersion = Args.getLastArg(options::OPT_fmsc_version);
1923 const Arg *MSCompatibilityVersion =
1924 Args.getLastArg(options::OPT_fms_compatibility_version);
1926 if (MSCVersion && MSCompatibilityVersion) {
1928 D->Diag(diag::err_drv_argument_not_allowed_with)
1929 << MSCVersion->getAsString(Args)
1930 << MSCompatibilityVersion->getAsString(Args);
1931 return VersionTuple();
1934 if (MSCompatibilityVersion) {
1936 if (MSVT.tryParse(MSCompatibilityVersion->getValue())) {
1938 D->Diag(diag::err_drv_invalid_value)
1939 << MSCompatibilityVersion->getAsString(Args)
1940 << MSCompatibilityVersion->getValue();
1947 unsigned Version = 0;
1948 if (StringRef(MSCVersion->getValue()).getAsInteger(10, Version)) {
1950 D->Diag(diag::err_drv_invalid_value)
1951 << MSCVersion->getAsString(Args) << MSCVersion->getValue();
1957 return VersionTuple();
1961 const llvm::opt::DerivedArgList &Args,
bool SameTripleAsHost,
1963 DerivedArgList *DAL =
new DerivedArgList(Args.getBaseArgs());
1965 bool Modified =
false;
1968 for (
auto *A : Args) {
1973 if (A->getOption().matches(options::OPT_m_Group)) {
1980 if (SameTripleAsHost ||
1981 A->getOption().matches(options::OPT_mcode_object_version_EQ) ||
1982 A->getOption().matches(options::OPT_mlinker_version_EQ))
1991 bool XOpenMPTargetNoTriple =
1992 A->getOption().matches(options::OPT_Xopenmp_target);
1994 if (A->getOption().matches(options::OPT_Xopenmp_target_EQ)) {
1999 Index = Args.getBaseArgs().MakeIndex(A->getValue(1));
2002 }
else if (XOpenMPTargetNoTriple) {
2004 Index = Args.getBaseArgs().MakeIndex(A->getValue(0));
2012 std::unique_ptr<Arg> XOpenMPTargetArg(Opts.ParseOneArg(Args, Index));
2013 if (!XOpenMPTargetArg || Index > Prev + 1) {
2014 if (!A->isClaimed()) {
2015 getDriver().
Diag(diag::err_drv_invalid_Xopenmp_target_with_args)
2016 << A->getAsString(Args);
2020 if (XOpenMPTargetNoTriple && XOpenMPTargetArg &&
2021 Args.getAllArgValues(options::OPT_offload_targets_EQ).size() != 1) {
2022 getDriver().
Diag(diag::err_drv_Xopenmp_target_missing_triple);
2025 XOpenMPTargetArg->setBaseArg(A);
2026 A = XOpenMPTargetArg.release();
2027 AllocatedArgs.push_back(A);
2043 const llvm::opt::DerivedArgList &Args, llvm::opt::Arg *&A,
2044 llvm::opt::DerivedArgList *DAL,
2047 unsigned ValuePos = 1;
2048 if (A->getOption().matches(options::OPT_Xarch_device) ||
2049 A->getOption().matches(options::OPT_Xarch_host))
2052 const InputArgList &BaseArgs = Args.getBaseArgs();
2053 unsigned Index = BaseArgs.MakeIndex(A->getValue(ValuePos));
2054 unsigned Prev = Index;
2055 std::unique_ptr<llvm::opt::Arg> XarchArg(Opts.ParseOneArg(
2065 if (!XarchArg || Index > Prev + 1) {
2066 getDriver().
Diag(diag::err_drv_invalid_Xarch_argument_with_args)
2067 << A->getAsString(Args);
2073 "invalid Xarch argument: '%0', not all driver "
2074 "options can be forwared via Xarch argument");
2075 Diags.Report(DiagID) << A->getAsString(Args);
2079 XarchArg->setBaseArg(A);
2080 A = XarchArg.release();
2088 for (
const char *
Value : A->getValues()) {
2089 auto Opt = Opts.getOption(options::OPT_Zlinker_input);
2090 unsigned Index = BaseArgs.MakeIndex(Opt.getName(),
Value);
2092 new Arg(Opt, BaseArgs.MakeArgString(Opt.getPrefix() + Opt.getName()),
2093 Index, BaseArgs.getArgString(Index + 1), A);
2095 DAL->append(NewArg);
2097 DAL->AddSynthesizedArg(NewArg);
2099 AllocatedArgs->push_back(NewArg);
2104 DAL->AddSynthesizedArg(A);
2106 AllocatedArgs->push_back(A);
2111 StringRef XArchVal) {
2112 llvm::Triple ParsedTriple(XArchVal);
2113 return TT.getArch() == ParsedTriple.getArch() &&
2114 TT.getSubArch() == ParsedTriple.getSubArch();
2118 const llvm::opt::DerivedArgList &Args,
BoundArch BA,
2121 DerivedArgList *DAL =
new DerivedArgList(Args.getBaseArgs());
2122 bool Modified =
false;
2125 for (Arg *A : Args) {
2126 bool NeedTrans =
false;
2128 if (A->getOption().matches(options::OPT_Xarch_device)) {
2129 NeedTrans = IsDevice;
2131 }
else if (A->getOption().matches(options::OPT_Xarch_host)) {
2132 NeedTrans = !IsDevice;
2134 }
else if (A->getOption().matches(options::OPT_Xarch__)) {
2135 StringRef Val = A->getValue();
2140 if (NeedTrans ||
Skip)
Result
Implement __builtin_bit_cast and related operations.
Defines types useful for describing an Objective-C runtime.
Defines the clang::SanitizerKind enum.
unsigned getCustomDiagID(Level L, const char(&FormatString)[N])
Return an ID for a diagnostic with the specified format string and level.
The basic abstraction for the target Objective-C runtime.
@ GNUstep
'gnustep' is the modern non-fragile GNUstep runtime.
@ GCC
'gcc' is the Objective-C runtime shipped with GCC, implementing a fragile Objective-C ABI
The base class of the type hierarchy.
ActionClass getKind() const
@ OffloadUnbundlingJobClass
@ BinaryTranslatorJobClass
@ OffloadBundlingJobClass
@ VerifyDebugInfoJobClass
@ OffloadPackagerJobClass
Driver - Encapsulate logic for constructing compilation processes from a set of gcc-driver-like comma...
DiagnosticsEngine & getDiags() const
OpenMPRuntimeKind getOpenMPRuntime(const llvm::opt::ArgList &Args) const
Compute the desired OpenMP runtime from the flags provided.
DiagnosticBuilder Diag(unsigned DiagID) const
StringRef getFlangF128MathLibrary() const
const llvm::opt::OptTable & getOpts() const
llvm::vfs::FileSystem & getVFS() const
@ OMPRT_OMP
The LLVM OpenMP runtime.
StringRef getPreferredLinker() const
bool CCCIsCXX() const
Whether the driver should follow g++ like behavior.
static llvm::ErrorOr< MultilibSet > parseYaml(llvm::MemoryBufferRef, llvm::SourceMgr::DiagHandlerTy=nullptr, void *DiagHandlerCtxt=nullptr)
This corresponds to a single GCC Multilib, or a segment of one controlled by a command line flag.
std::vector< std::string > flags_list
ID lookupTypeForExtension(llvm::StringRef Ext)
lookupTypeForExtension - Lookup the type to use for the file extension Ext.
LTOKind
Describes the kind of LTO mode selected via -f(no-)?lto(=.*)? options.
bool isOptimizationLevelFast(const llvm::opt::ArgList &Args)
The JSON file list parser is used to communicate input to InstallAPI.
@ Link
'link' clause, allowed on 'declare' construct.
@ Default
Set to the current date and time.
@ Result
The result type of a method or function.
Diagnostic wrappers for TextAPI types for error reporting.
Represents a bound architecture for offload / multiple architecture compilation.
Helper structure used to pass information extracted from clang executable name such as i686-linux-and...