1 //===--- Gnu.cpp - Gnu Tool and ToolChain Implementations -------*- C++ -*-===// 2 // 3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4 // See https://llvm.org/LICENSE.txt for license information. 5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6 // 7 //===----------------------------------------------------------------------===// 8 9 #include "Gnu.h" 10 #include "Arch/ARM.h" 11 #include "Arch/Mips.h" 12 #include "Arch/PPC.h" 13 #include "Arch/RISCV.h" 14 #include "Arch/Sparc.h" 15 #include "Arch/SystemZ.h" 16 #include "CommonArgs.h" 17 #include "Linux.h" 18 #include "clang/Config/config.h" // for GCC_INSTALL_PREFIX 19 #include "clang/Driver/Compilation.h" 20 #include "clang/Driver/Driver.h" 21 #include "clang/Driver/DriverDiagnostic.h" 22 #include "clang/Driver/Options.h" 23 #include "clang/Driver/Tool.h" 24 #include "clang/Driver/ToolChain.h" 25 #include "llvm/Option/ArgList.h" 26 #include "llvm/Support/CodeGen.h" 27 #include "llvm/Support/Path.h" 28 #include "llvm/Support/TargetParser.h" 29 #include "llvm/Support/VirtualFileSystem.h" 30 #include <system_error> 31 32 using namespace clang::driver; 33 using namespace clang::driver::toolchains; 34 using namespace clang; 35 using namespace llvm::opt; 36 37 using tools::addMultilibFlag; 38 39 void tools::GnuTool::anchor() {} 40 41 static bool forwardToGCC(const Option &O) { 42 // Don't forward inputs from the original command line. They are added from 43 // InputInfoList. 44 return O.getKind() != Option::InputClass && 45 !O.hasFlag(options::DriverOption) && !O.hasFlag(options::LinkerInput); 46 } 47 48 // Switch CPU names not recognized by GNU assembler to a close CPU that it does 49 // recognize, instead of a lower march from being picked in the absence of a cpu 50 // flag. 51 static void normalizeCPUNamesForAssembler(const ArgList &Args, 52 ArgStringList &CmdArgs) { 53 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ)) { 54 StringRef CPUArg(A->getValue()); 55 if (CPUArg.equals_lower("krait")) 56 CmdArgs.push_back("-mcpu=cortex-a15"); 57 else if(CPUArg.equals_lower("kryo")) 58 CmdArgs.push_back("-mcpu=cortex-a57"); 59 else 60 Args.AddLastArg(CmdArgs, options::OPT_mcpu_EQ); 61 } 62 } 63 64 void tools::gcc::Common::ConstructJob(Compilation &C, const JobAction &JA, 65 const InputInfo &Output, 66 const InputInfoList &Inputs, 67 const ArgList &Args, 68 const char *LinkingOutput) const { 69 const Driver &D = getToolChain().getDriver(); 70 ArgStringList CmdArgs; 71 72 for (const auto &A : Args) { 73 if (forwardToGCC(A->getOption())) { 74 // It is unfortunate that we have to claim here, as this means 75 // we will basically never report anything interesting for 76 // platforms using a generic gcc, even if we are just using gcc 77 // to get to the assembler. 78 A->claim(); 79 80 // Don't forward any -g arguments to assembly steps. 81 if (isa<AssembleJobAction>(JA) && 82 A->getOption().matches(options::OPT_g_Group)) 83 continue; 84 85 // Don't forward any -W arguments to assembly and link steps. 86 if ((isa<AssembleJobAction>(JA) || isa<LinkJobAction>(JA)) && 87 A->getOption().matches(options::OPT_W_Group)) 88 continue; 89 90 // Don't forward -mno-unaligned-access since GCC doesn't understand 91 // it and because it doesn't affect the assembly or link steps. 92 if ((isa<AssembleJobAction>(JA) || isa<LinkJobAction>(JA)) && 93 (A->getOption().matches(options::OPT_munaligned_access) || 94 A->getOption().matches(options::OPT_mno_unaligned_access))) 95 continue; 96 97 A->render(Args, CmdArgs); 98 } 99 } 100 101 RenderExtraToolArgs(JA, CmdArgs); 102 103 // If using a driver driver, force the arch. 104 if (getToolChain().getTriple().isOSDarwin()) { 105 CmdArgs.push_back("-arch"); 106 CmdArgs.push_back( 107 Args.MakeArgString(getToolChain().getDefaultUniversalArchName())); 108 } 109 110 // Try to force gcc to match the tool chain we want, if we recognize 111 // the arch. 112 // 113 // FIXME: The triple class should directly provide the information we want 114 // here. 115 switch (getToolChain().getArch()) { 116 default: 117 break; 118 case llvm::Triple::x86: 119 case llvm::Triple::ppc: 120 CmdArgs.push_back("-m32"); 121 break; 122 case llvm::Triple::x86_64: 123 case llvm::Triple::ppc64: 124 case llvm::Triple::ppc64le: 125 CmdArgs.push_back("-m64"); 126 break; 127 case llvm::Triple::sparcel: 128 CmdArgs.push_back("-EL"); 129 break; 130 } 131 132 if (Output.isFilename()) { 133 CmdArgs.push_back("-o"); 134 CmdArgs.push_back(Output.getFilename()); 135 } else { 136 assert(Output.isNothing() && "Unexpected output"); 137 CmdArgs.push_back("-fsyntax-only"); 138 } 139 140 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler); 141 142 // Only pass -x if gcc will understand it; otherwise hope gcc 143 // understands the suffix correctly. The main use case this would go 144 // wrong in is for linker inputs if they happened to have an odd 145 // suffix; really the only way to get this to happen is a command 146 // like '-x foobar a.c' which will treat a.c like a linker input. 147 // 148 // FIXME: For the linker case specifically, can we safely convert 149 // inputs into '-Wl,' options? 150 for (const auto &II : Inputs) { 151 // Don't try to pass LLVM or AST inputs to a generic gcc. 152 if (types::isLLVMIR(II.getType())) 153 D.Diag(clang::diag::err_drv_no_linker_llvm_support) 154 << getToolChain().getTripleString(); 155 else if (II.getType() == types::TY_AST) 156 D.Diag(diag::err_drv_no_ast_support) << getToolChain().getTripleString(); 157 else if (II.getType() == types::TY_ModuleFile) 158 D.Diag(diag::err_drv_no_module_support) 159 << getToolChain().getTripleString(); 160 161 if (types::canTypeBeUserSpecified(II.getType())) { 162 CmdArgs.push_back("-x"); 163 CmdArgs.push_back(types::getTypeName(II.getType())); 164 } 165 166 if (II.isFilename()) 167 CmdArgs.push_back(II.getFilename()); 168 else { 169 const Arg &A = II.getInputArg(); 170 171 // Reverse translate some rewritten options. 172 if (A.getOption().matches(options::OPT_Z_reserved_lib_stdcxx)) { 173 CmdArgs.push_back("-lstdc++"); 174 continue; 175 } 176 177 // Don't render as input, we need gcc to do the translations. 178 A.render(Args, CmdArgs); 179 } 180 } 181 182 const std::string &customGCCName = D.getCCCGenericGCCName(); 183 const char *GCCName; 184 if (!customGCCName.empty()) 185 GCCName = customGCCName.c_str(); 186 else if (D.CCCIsCXX()) { 187 GCCName = "g++"; 188 } else 189 GCCName = "gcc"; 190 191 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath(GCCName)); 192 C.addCommand(std::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs)); 193 } 194 195 void tools::gcc::Preprocessor::RenderExtraToolArgs( 196 const JobAction &JA, ArgStringList &CmdArgs) const { 197 CmdArgs.push_back("-E"); 198 } 199 200 void tools::gcc::Compiler::RenderExtraToolArgs(const JobAction &JA, 201 ArgStringList &CmdArgs) const { 202 const Driver &D = getToolChain().getDriver(); 203 204 switch (JA.getType()) { 205 // If -flto, etc. are present then make sure not to force assembly output. 206 case types::TY_LLVM_IR: 207 case types::TY_LTO_IR: 208 case types::TY_LLVM_BC: 209 case types::TY_LTO_BC: 210 CmdArgs.push_back("-c"); 211 break; 212 // We assume we've got an "integrated" assembler in that gcc will produce an 213 // object file itself. 214 case types::TY_Object: 215 CmdArgs.push_back("-c"); 216 break; 217 case types::TY_PP_Asm: 218 CmdArgs.push_back("-S"); 219 break; 220 case types::TY_Nothing: 221 CmdArgs.push_back("-fsyntax-only"); 222 break; 223 default: 224 D.Diag(diag::err_drv_invalid_gcc_output_type) << getTypeName(JA.getType()); 225 } 226 } 227 228 void tools::gcc::Linker::RenderExtraToolArgs(const JobAction &JA, 229 ArgStringList &CmdArgs) const { 230 // The types are (hopefully) good enough. 231 } 232 233 // On Arm the endianness of the output file is determined by the target and 234 // can be overridden by the pseudo-target flags '-mlittle-endian'/'-EL' and 235 // '-mbig-endian'/'-EB'. Unlike other targets the flag does not result in a 236 // normalized triple so we must handle the flag here. 237 static bool isArmBigEndian(const llvm::Triple &Triple, 238 const ArgList &Args) { 239 bool IsBigEndian = false; 240 switch (Triple.getArch()) { 241 case llvm::Triple::armeb: 242 case llvm::Triple::thumbeb: 243 IsBigEndian = true; 244 LLVM_FALLTHROUGH; 245 case llvm::Triple::arm: 246 case llvm::Triple::thumb: 247 if (Arg *A = Args.getLastArg(options::OPT_mlittle_endian, 248 options::OPT_mbig_endian)) 249 IsBigEndian = !A->getOption().matches(options::OPT_mlittle_endian); 250 break; 251 default: 252 break; 253 } 254 return IsBigEndian; 255 } 256 257 static const char *getLDMOption(const llvm::Triple &T, const ArgList &Args) { 258 switch (T.getArch()) { 259 case llvm::Triple::x86: 260 if (T.isOSIAMCU()) 261 return "elf_iamcu"; 262 return "elf_i386"; 263 case llvm::Triple::aarch64: 264 return "aarch64linux"; 265 case llvm::Triple::aarch64_be: 266 return "aarch64linuxb"; 267 case llvm::Triple::arm: 268 case llvm::Triple::thumb: 269 case llvm::Triple::armeb: 270 case llvm::Triple::thumbeb: 271 return isArmBigEndian(T, Args) ? "armelfb_linux_eabi" : "armelf_linux_eabi"; 272 case llvm::Triple::ppc: 273 return "elf32ppclinux"; 274 case llvm::Triple::ppc64: 275 return "elf64ppc"; 276 case llvm::Triple::ppc64le: 277 return "elf64lppc"; 278 case llvm::Triple::riscv32: 279 return "elf32lriscv"; 280 case llvm::Triple::riscv64: 281 return "elf64lriscv"; 282 case llvm::Triple::sparc: 283 case llvm::Triple::sparcel: 284 return "elf32_sparc"; 285 case llvm::Triple::sparcv9: 286 return "elf64_sparc"; 287 case llvm::Triple::mips: 288 return "elf32btsmip"; 289 case llvm::Triple::mipsel: 290 return "elf32ltsmip"; 291 case llvm::Triple::mips64: 292 if (tools::mips::hasMipsAbiArg(Args, "n32") || 293 T.getEnvironment() == llvm::Triple::GNUABIN32) 294 return "elf32btsmipn32"; 295 return "elf64btsmip"; 296 case llvm::Triple::mips64el: 297 if (tools::mips::hasMipsAbiArg(Args, "n32") || 298 T.getEnvironment() == llvm::Triple::GNUABIN32) 299 return "elf32ltsmipn32"; 300 return "elf64ltsmip"; 301 case llvm::Triple::systemz: 302 return "elf64_s390"; 303 case llvm::Triple::x86_64: 304 if (T.getEnvironment() == llvm::Triple::GNUX32) 305 return "elf32_x86_64"; 306 return "elf_x86_64"; 307 default: 308 return nullptr; 309 } 310 } 311 312 static bool getPIE(const ArgList &Args, const toolchains::Linux &ToolChain) { 313 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_static) || 314 Args.hasArg(options::OPT_r) || Args.hasArg(options::OPT_static_pie)) 315 return false; 316 317 Arg *A = Args.getLastArg(options::OPT_pie, options::OPT_no_pie, 318 options::OPT_nopie); 319 if (!A) 320 return ToolChain.isPIEDefault(); 321 return A->getOption().matches(options::OPT_pie); 322 } 323 324 static bool getStaticPIE(const ArgList &Args, 325 const toolchains::Linux &ToolChain) { 326 bool HasStaticPIE = Args.hasArg(options::OPT_static_pie); 327 // -no-pie is an alias for -nopie. So, handling -nopie takes care of 328 // -no-pie as well. 329 if (HasStaticPIE && Args.hasArg(options::OPT_nopie)) { 330 const Driver &D = ToolChain.getDriver(); 331 const llvm::opt::OptTable &Opts = D.getOpts(); 332 const char *StaticPIEName = Opts.getOptionName(options::OPT_static_pie); 333 const char *NoPIEName = Opts.getOptionName(options::OPT_nopie); 334 D.Diag(diag::err_drv_cannot_mix_options) << StaticPIEName << NoPIEName; 335 } 336 return HasStaticPIE; 337 } 338 339 static bool getStatic(const ArgList &Args) { 340 return Args.hasArg(options::OPT_static) && 341 !Args.hasArg(options::OPT_static_pie); 342 } 343 344 void tools::gnutools::Linker::ConstructJob(Compilation &C, const JobAction &JA, 345 const InputInfo &Output, 346 const InputInfoList &Inputs, 347 const ArgList &Args, 348 const char *LinkingOutput) const { 349 const toolchains::Linux &ToolChain = 350 static_cast<const toolchains::Linux &>(getToolChain()); 351 const Driver &D = ToolChain.getDriver(); 352 353 const llvm::Triple &Triple = getToolChain().getEffectiveTriple(); 354 355 const llvm::Triple::ArchType Arch = ToolChain.getArch(); 356 const bool isAndroid = ToolChain.getTriple().isAndroid(); 357 const bool IsIAMCU = ToolChain.getTriple().isOSIAMCU(); 358 const bool IsPIE = getPIE(Args, ToolChain); 359 const bool IsStaticPIE = getStaticPIE(Args, ToolChain); 360 const bool IsStatic = getStatic(Args); 361 const bool HasCRTBeginEndFiles = 362 ToolChain.getTriple().hasEnvironment() || 363 (ToolChain.getTriple().getVendor() != llvm::Triple::MipsTechnologies); 364 365 ArgStringList CmdArgs; 366 367 // Silence warning for "clang -g foo.o -o foo" 368 Args.ClaimAllArgs(options::OPT_g_Group); 369 // and "clang -emit-llvm foo.o -o foo" 370 Args.ClaimAllArgs(options::OPT_emit_llvm); 371 // and for "clang -w foo.o -o foo". Other warning options are already 372 // handled somewhere else. 373 Args.ClaimAllArgs(options::OPT_w); 374 375 if (!D.SysRoot.empty()) 376 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot)); 377 378 if (IsPIE) 379 CmdArgs.push_back("-pie"); 380 381 if (IsStaticPIE) { 382 CmdArgs.push_back("-static"); 383 CmdArgs.push_back("-pie"); 384 CmdArgs.push_back("--no-dynamic-linker"); 385 CmdArgs.push_back("-z"); 386 CmdArgs.push_back("text"); 387 } 388 389 if (ToolChain.isNoExecStackDefault()) { 390 CmdArgs.push_back("-z"); 391 CmdArgs.push_back("noexecstack"); 392 } 393 394 if (Args.hasArg(options::OPT_rdynamic)) 395 CmdArgs.push_back("-export-dynamic"); 396 397 if (Args.hasArg(options::OPT_s)) 398 CmdArgs.push_back("-s"); 399 400 if (Triple.isARM() || Triple.isThumb() || Triple.isAArch64()) { 401 bool IsBigEndian = isArmBigEndian(Triple, Args); 402 if (IsBigEndian) 403 arm::appendBE8LinkFlag(Args, CmdArgs, Triple); 404 IsBigEndian = IsBigEndian || Arch == llvm::Triple::aarch64_be; 405 CmdArgs.push_back(IsBigEndian ? "-EB" : "-EL"); 406 } 407 408 // Most Android ARM64 targets should enable the linker fix for erratum 409 // 843419. Only non-Cortex-A53 devices are allowed to skip this flag. 410 if (Arch == llvm::Triple::aarch64 && isAndroid) { 411 std::string CPU = getCPUName(Args, Triple); 412 if (CPU.empty() || CPU == "generic" || CPU == "cortex-a53") 413 CmdArgs.push_back("--fix-cortex-a53-843419"); 414 } 415 416 // Android does not allow shared text relocations. Emit a warning if the 417 // user's code contains any. 418 if (isAndroid) 419 CmdArgs.push_back("--warn-shared-textrel"); 420 421 for (const auto &Opt : ToolChain.ExtraOpts) 422 CmdArgs.push_back(Opt.c_str()); 423 424 CmdArgs.push_back("--eh-frame-hdr"); 425 426 if (const char *LDMOption = getLDMOption(ToolChain.getTriple(), Args)) { 427 CmdArgs.push_back("-m"); 428 CmdArgs.push_back(LDMOption); 429 } else { 430 D.Diag(diag::err_target_unknown_triple) << Triple.str(); 431 return; 432 } 433 434 if (IsStatic) { 435 if (Arch == llvm::Triple::arm || Arch == llvm::Triple::armeb || 436 Arch == llvm::Triple::thumb || Arch == llvm::Triple::thumbeb) 437 CmdArgs.push_back("-Bstatic"); 438 else 439 CmdArgs.push_back("-static"); 440 } else if (Args.hasArg(options::OPT_shared)) { 441 CmdArgs.push_back("-shared"); 442 } 443 444 if (!IsStatic) { 445 if (Args.hasArg(options::OPT_rdynamic)) 446 CmdArgs.push_back("-export-dynamic"); 447 448 if (!Args.hasArg(options::OPT_shared) && !IsStaticPIE) { 449 const std::string Loader = 450 D.DyldPrefix + ToolChain.getDynamicLinker(Args); 451 CmdArgs.push_back("-dynamic-linker"); 452 CmdArgs.push_back(Args.MakeArgString(Loader)); 453 } 454 } 455 456 CmdArgs.push_back("-o"); 457 CmdArgs.push_back(Output.getFilename()); 458 459 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) { 460 if (!isAndroid && !IsIAMCU) { 461 const char *crt1 = nullptr; 462 if (!Args.hasArg(options::OPT_shared)) { 463 if (Args.hasArg(options::OPT_pg)) 464 crt1 = "gcrt1.o"; 465 else if (IsPIE) 466 crt1 = "Scrt1.o"; 467 else if (IsStaticPIE) 468 crt1 = "rcrt1.o"; 469 else 470 crt1 = "crt1.o"; 471 } 472 if (crt1) 473 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crt1))); 474 475 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o"))); 476 } 477 478 if (IsIAMCU) 479 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crt0.o"))); 480 else if (HasCRTBeginEndFiles) { 481 std::string P; 482 if (ToolChain.GetRuntimeLibType(Args) == ToolChain::RLT_CompilerRT && 483 !isAndroid) { 484 std::string crtbegin = ToolChain.getCompilerRT(Args, "crtbegin", 485 ToolChain::FT_Object); 486 if (ToolChain.getVFS().exists(crtbegin)) 487 P = crtbegin; 488 } 489 if (P.empty()) { 490 const char *crtbegin; 491 if (IsStatic) 492 crtbegin = isAndroid ? "crtbegin_static.o" : "crtbeginT.o"; 493 else if (Args.hasArg(options::OPT_shared)) 494 crtbegin = isAndroid ? "crtbegin_so.o" : "crtbeginS.o"; 495 else if (IsPIE || IsStaticPIE) 496 crtbegin = isAndroid ? "crtbegin_dynamic.o" : "crtbeginS.o"; 497 else 498 crtbegin = isAndroid ? "crtbegin_dynamic.o" : "crtbegin.o"; 499 P = ToolChain.GetFilePath(crtbegin); 500 } 501 CmdArgs.push_back(Args.MakeArgString(P)); 502 } 503 504 // Add crtfastmath.o if available and fast math is enabled. 505 ToolChain.AddFastMathRuntimeIfAvailable(Args, CmdArgs); 506 } 507 508 Args.AddAllArgs(CmdArgs, options::OPT_L); 509 Args.AddAllArgs(CmdArgs, options::OPT_u); 510 511 ToolChain.AddFilePathLibArgs(Args, CmdArgs); 512 513 if (D.isUsingLTO()) { 514 assert(!Inputs.empty() && "Must have at least one input."); 515 AddGoldPlugin(ToolChain, Args, CmdArgs, Output, Inputs[0], 516 D.getLTOMode() == LTOK_Thin); 517 } 518 519 if (Args.hasArg(options::OPT_Z_Xlinker__no_demangle)) 520 CmdArgs.push_back("--no-demangle"); 521 522 bool NeedsSanitizerDeps = addSanitizerRuntimes(ToolChain, Args, CmdArgs); 523 bool NeedsXRayDeps = addXRayRuntime(ToolChain, Args, CmdArgs); 524 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs, JA); 525 // The profile runtime also needs access to system libraries. 526 getToolChain().addProfileRTLibs(Args, CmdArgs); 527 528 if (D.CCCIsCXX() && 529 !Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs)) { 530 if (ToolChain.ShouldLinkCXXStdlib(Args)) { 531 bool OnlyLibstdcxxStatic = Args.hasArg(options::OPT_static_libstdcxx) && 532 !Args.hasArg(options::OPT_static); 533 if (OnlyLibstdcxxStatic) 534 CmdArgs.push_back("-Bstatic"); 535 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs); 536 if (OnlyLibstdcxxStatic) 537 CmdArgs.push_back("-Bdynamic"); 538 } 539 CmdArgs.push_back("-lm"); 540 } 541 // Silence warnings when linking C code with a C++ '-stdlib' argument. 542 Args.ClaimAllArgs(options::OPT_stdlib_EQ); 543 544 if (!Args.hasArg(options::OPT_nostdlib)) { 545 if (!Args.hasArg(options::OPT_nodefaultlibs)) { 546 if (IsStatic || IsStaticPIE) 547 CmdArgs.push_back("--start-group"); 548 549 if (NeedsSanitizerDeps) 550 linkSanitizerRuntimeDeps(ToolChain, CmdArgs); 551 552 if (NeedsXRayDeps) 553 linkXRayRuntimeDeps(ToolChain, CmdArgs); 554 555 bool WantPthread = Args.hasArg(options::OPT_pthread) || 556 Args.hasArg(options::OPT_pthreads); 557 558 // Use the static OpenMP runtime with -static-openmp 559 bool StaticOpenMP = Args.hasArg(options::OPT_static_openmp) && 560 !Args.hasArg(options::OPT_static); 561 562 // FIXME: Only pass GompNeedsRT = true for platforms with libgomp that 563 // require librt. Most modern Linux platforms do, but some may not. 564 if (addOpenMPRuntime(CmdArgs, ToolChain, Args, StaticOpenMP, 565 JA.isHostOffloading(Action::OFK_OpenMP), 566 /* GompNeedsRT= */ true)) 567 // OpenMP runtimes implies pthreads when using the GNU toolchain. 568 // FIXME: Does this really make sense for all GNU toolchains? 569 WantPthread = true; 570 571 AddRunTimeLibs(ToolChain, D, CmdArgs, Args); 572 573 if (WantPthread && !isAndroid) 574 CmdArgs.push_back("-lpthread"); 575 576 if (Args.hasArg(options::OPT_fsplit_stack)) 577 CmdArgs.push_back("--wrap=pthread_create"); 578 579 if (!Args.hasArg(options::OPT_nolibc)) 580 CmdArgs.push_back("-lc"); 581 582 // Add IAMCU specific libs, if needed. 583 if (IsIAMCU) 584 CmdArgs.push_back("-lgloss"); 585 586 if (IsStatic || IsStaticPIE) 587 CmdArgs.push_back("--end-group"); 588 else 589 AddRunTimeLibs(ToolChain, D, CmdArgs, Args); 590 591 // Add IAMCU specific libs (outside the group), if needed. 592 if (IsIAMCU) { 593 CmdArgs.push_back("--as-needed"); 594 CmdArgs.push_back("-lsoftfp"); 595 CmdArgs.push_back("--no-as-needed"); 596 } 597 } 598 599 if (!Args.hasArg(options::OPT_nostartfiles) && !IsIAMCU) { 600 if (HasCRTBeginEndFiles) { 601 std::string P; 602 if (ToolChain.GetRuntimeLibType(Args) == ToolChain::RLT_CompilerRT && 603 !isAndroid) { 604 std::string crtend = ToolChain.getCompilerRT(Args, "crtend", 605 ToolChain::FT_Object); 606 if (ToolChain.getVFS().exists(crtend)) 607 P = crtend; 608 } 609 if (P.empty()) { 610 const char *crtend; 611 if (Args.hasArg(options::OPT_shared)) 612 crtend = isAndroid ? "crtend_so.o" : "crtendS.o"; 613 else if (IsPIE || IsStaticPIE) 614 crtend = isAndroid ? "crtend_android.o" : "crtendS.o"; 615 else 616 crtend = isAndroid ? "crtend_android.o" : "crtend.o"; 617 P = ToolChain.GetFilePath(crtend); 618 } 619 CmdArgs.push_back(Args.MakeArgString(P)); 620 } 621 if (!isAndroid) 622 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o"))); 623 } 624 } 625 626 // Add HIP offloading linker script args if required. 627 AddHIPLinkerScript(getToolChain(), C, Output, Inputs, Args, CmdArgs, JA, 628 *this); 629 630 const char *Exec = Args.MakeArgString(ToolChain.GetLinkerPath()); 631 C.addCommand(std::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs)); 632 } 633 634 void tools::gnutools::Assembler::ConstructJob(Compilation &C, 635 const JobAction &JA, 636 const InputInfo &Output, 637 const InputInfoList &Inputs, 638 const ArgList &Args, 639 const char *LinkingOutput) const { 640 const auto &D = getToolChain().getDriver(); 641 642 claimNoWarnArgs(Args); 643 644 ArgStringList CmdArgs; 645 646 llvm::Reloc::Model RelocationModel; 647 unsigned PICLevel; 648 bool IsPIE; 649 std::tie(RelocationModel, PICLevel, IsPIE) = 650 ParsePICArgs(getToolChain(), Args); 651 652 if (const Arg *A = Args.getLastArg(options::OPT_gz, options::OPT_gz_EQ)) { 653 if (A->getOption().getID() == options::OPT_gz) { 654 CmdArgs.push_back("--compress-debug-sections"); 655 } else { 656 StringRef Value = A->getValue(); 657 if (Value == "none" || Value == "zlib" || Value == "zlib-gnu") { 658 CmdArgs.push_back( 659 Args.MakeArgString("--compress-debug-sections=" + Twine(Value))); 660 } else { 661 D.Diag(diag::err_drv_unsupported_option_argument) 662 << A->getOption().getName() << Value; 663 } 664 } 665 } 666 667 if (getToolChain().isNoExecStackDefault()) { 668 CmdArgs.push_back("--noexecstack"); 669 } 670 671 switch (getToolChain().getArch()) { 672 default: 673 break; 674 // Add --32/--64 to make sure we get the format we want. 675 // This is incomplete 676 case llvm::Triple::x86: 677 CmdArgs.push_back("--32"); 678 break; 679 case llvm::Triple::x86_64: 680 if (getToolChain().getTriple().getEnvironment() == llvm::Triple::GNUX32) 681 CmdArgs.push_back("--x32"); 682 else 683 CmdArgs.push_back("--64"); 684 break; 685 case llvm::Triple::ppc: { 686 CmdArgs.push_back("-a32"); 687 CmdArgs.push_back("-mppc"); 688 CmdArgs.push_back( 689 ppc::getPPCAsmModeForCPU(getCPUName(Args, getToolChain().getTriple()))); 690 break; 691 } 692 case llvm::Triple::ppc64: { 693 CmdArgs.push_back("-a64"); 694 CmdArgs.push_back("-mppc64"); 695 CmdArgs.push_back( 696 ppc::getPPCAsmModeForCPU(getCPUName(Args, getToolChain().getTriple()))); 697 break; 698 } 699 case llvm::Triple::ppc64le: { 700 CmdArgs.push_back("-a64"); 701 CmdArgs.push_back("-mppc64"); 702 CmdArgs.push_back("-mlittle-endian"); 703 CmdArgs.push_back( 704 ppc::getPPCAsmModeForCPU(getCPUName(Args, getToolChain().getTriple()))); 705 break; 706 } 707 case llvm::Triple::riscv32: 708 case llvm::Triple::riscv64: { 709 StringRef ABIName = riscv::getRISCVABI(Args, getToolChain().getTriple()); 710 CmdArgs.push_back("-mabi"); 711 CmdArgs.push_back(ABIName.data()); 712 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ)) { 713 StringRef MArch = A->getValue(); 714 CmdArgs.push_back("-march"); 715 CmdArgs.push_back(MArch.data()); 716 } 717 break; 718 } 719 case llvm::Triple::sparc: 720 case llvm::Triple::sparcel: { 721 CmdArgs.push_back("-32"); 722 std::string CPU = getCPUName(Args, getToolChain().getTriple()); 723 CmdArgs.push_back( 724 sparc::getSparcAsmModeForCPU(CPU, getToolChain().getTriple())); 725 AddAssemblerKPIC(getToolChain(), Args, CmdArgs); 726 break; 727 } 728 case llvm::Triple::sparcv9: { 729 CmdArgs.push_back("-64"); 730 std::string CPU = getCPUName(Args, getToolChain().getTriple()); 731 CmdArgs.push_back( 732 sparc::getSparcAsmModeForCPU(CPU, getToolChain().getTriple())); 733 AddAssemblerKPIC(getToolChain(), Args, CmdArgs); 734 break; 735 } 736 case llvm::Triple::arm: 737 case llvm::Triple::armeb: 738 case llvm::Triple::thumb: 739 case llvm::Triple::thumbeb: { 740 const llvm::Triple &Triple2 = getToolChain().getTriple(); 741 CmdArgs.push_back(isArmBigEndian(Triple2, Args) ? "-EB" : "-EL"); 742 switch (Triple2.getSubArch()) { 743 case llvm::Triple::ARMSubArch_v7: 744 CmdArgs.push_back("-mfpu=neon"); 745 break; 746 case llvm::Triple::ARMSubArch_v8: 747 CmdArgs.push_back("-mfpu=crypto-neon-fp-armv8"); 748 break; 749 default: 750 break; 751 } 752 753 switch (arm::getARMFloatABI(getToolChain(), Args)) { 754 case arm::FloatABI::Invalid: llvm_unreachable("must have an ABI!"); 755 case arm::FloatABI::Soft: 756 CmdArgs.push_back(Args.MakeArgString("-mfloat-abi=soft")); 757 break; 758 case arm::FloatABI::SoftFP: 759 CmdArgs.push_back(Args.MakeArgString("-mfloat-abi=softfp")); 760 break; 761 case arm::FloatABI::Hard: 762 CmdArgs.push_back(Args.MakeArgString("-mfloat-abi=hard")); 763 break; 764 } 765 766 Args.AddLastArg(CmdArgs, options::OPT_march_EQ); 767 normalizeCPUNamesForAssembler(Args, CmdArgs); 768 769 Args.AddLastArg(CmdArgs, options::OPT_mfpu_EQ); 770 break; 771 } 772 case llvm::Triple::aarch64: 773 case llvm::Triple::aarch64_be: { 774 CmdArgs.push_back( 775 getToolChain().getArch() == llvm::Triple::aarch64_be ? "-EB" : "-EL"); 776 Args.AddLastArg(CmdArgs, options::OPT_march_EQ); 777 normalizeCPUNamesForAssembler(Args, CmdArgs); 778 779 break; 780 } 781 case llvm::Triple::mips: 782 case llvm::Triple::mipsel: 783 case llvm::Triple::mips64: 784 case llvm::Triple::mips64el: { 785 StringRef CPUName; 786 StringRef ABIName; 787 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName); 788 ABIName = mips::getGnuCompatibleMipsABIName(ABIName); 789 790 CmdArgs.push_back("-march"); 791 CmdArgs.push_back(CPUName.data()); 792 793 CmdArgs.push_back("-mabi"); 794 CmdArgs.push_back(ABIName.data()); 795 796 // -mno-shared should be emitted unless -fpic, -fpie, -fPIC, -fPIE, 797 // or -mshared (not implemented) is in effect. 798 if (RelocationModel == llvm::Reloc::Static) 799 CmdArgs.push_back("-mno-shared"); 800 801 // LLVM doesn't support -mplt yet and acts as if it is always given. 802 // However, -mplt has no effect with the N64 ABI. 803 if (ABIName != "64" && !Args.hasArg(options::OPT_mno_abicalls)) 804 CmdArgs.push_back("-call_nonpic"); 805 806 if (getToolChain().getTriple().isLittleEndian()) 807 CmdArgs.push_back("-EL"); 808 else 809 CmdArgs.push_back("-EB"); 810 811 if (Arg *A = Args.getLastArg(options::OPT_mnan_EQ)) { 812 if (StringRef(A->getValue()) == "2008") 813 CmdArgs.push_back(Args.MakeArgString("-mnan=2008")); 814 } 815 816 // Add the last -mfp32/-mfpxx/-mfp64 or -mfpxx if it is enabled by default. 817 if (Arg *A = Args.getLastArg(options::OPT_mfp32, options::OPT_mfpxx, 818 options::OPT_mfp64)) { 819 A->claim(); 820 A->render(Args, CmdArgs); 821 } else if (mips::shouldUseFPXX( 822 Args, getToolChain().getTriple(), CPUName, ABIName, 823 mips::getMipsFloatABI(getToolChain().getDriver(), Args, 824 getToolChain().getTriple()))) 825 CmdArgs.push_back("-mfpxx"); 826 827 // Pass on -mmips16 or -mno-mips16. However, the assembler equivalent of 828 // -mno-mips16 is actually -no-mips16. 829 if (Arg *A = 830 Args.getLastArg(options::OPT_mips16, options::OPT_mno_mips16)) { 831 if (A->getOption().matches(options::OPT_mips16)) { 832 A->claim(); 833 A->render(Args, CmdArgs); 834 } else { 835 A->claim(); 836 CmdArgs.push_back("-no-mips16"); 837 } 838 } 839 840 Args.AddLastArg(CmdArgs, options::OPT_mmicromips, 841 options::OPT_mno_micromips); 842 Args.AddLastArg(CmdArgs, options::OPT_mdsp, options::OPT_mno_dsp); 843 Args.AddLastArg(CmdArgs, options::OPT_mdspr2, options::OPT_mno_dspr2); 844 845 if (Arg *A = Args.getLastArg(options::OPT_mmsa, options::OPT_mno_msa)) { 846 // Do not use AddLastArg because not all versions of MIPS assembler 847 // support -mmsa / -mno-msa options. 848 if (A->getOption().matches(options::OPT_mmsa)) 849 CmdArgs.push_back(Args.MakeArgString("-mmsa")); 850 } 851 852 Args.AddLastArg(CmdArgs, options::OPT_mhard_float, 853 options::OPT_msoft_float); 854 855 Args.AddLastArg(CmdArgs, options::OPT_mdouble_float, 856 options::OPT_msingle_float); 857 858 Args.AddLastArg(CmdArgs, options::OPT_modd_spreg, 859 options::OPT_mno_odd_spreg); 860 861 AddAssemblerKPIC(getToolChain(), Args, CmdArgs); 862 break; 863 } 864 case llvm::Triple::systemz: { 865 // Always pass an -march option, since our default of z10 is later 866 // than the GNU assembler's default. 867 StringRef CPUName = systemz::getSystemZTargetCPU(Args); 868 CmdArgs.push_back(Args.MakeArgString("-march=" + CPUName)); 869 break; 870 } 871 } 872 873 Args.AddAllArgs(CmdArgs, options::OPT_I); 874 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler); 875 876 CmdArgs.push_back("-o"); 877 CmdArgs.push_back(Output.getFilename()); 878 879 for (const auto &II : Inputs) 880 CmdArgs.push_back(II.getFilename()); 881 882 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as")); 883 C.addCommand(std::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs)); 884 885 // Handle the debug info splitting at object creation time if we're 886 // creating an object. 887 // TODO: Currently only works on linux with newer objcopy. 888 if (Args.hasArg(options::OPT_gsplit_dwarf) && 889 getToolChain().getTriple().isOSLinux()) 890 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output, 891 SplitDebugName(Args, Inputs[0], Output)); 892 } 893 894 namespace { 895 // Filter to remove Multilibs that don't exist as a suffix to Path 896 class FilterNonExistent { 897 StringRef Base, File; 898 llvm::vfs::FileSystem &VFS; 899 900 public: 901 FilterNonExistent(StringRef Base, StringRef File, llvm::vfs::FileSystem &VFS) 902 : Base(Base), File(File), VFS(VFS) {} 903 bool operator()(const Multilib &M) { 904 return !VFS.exists(Base + M.gccSuffix() + File); 905 } 906 }; 907 } // end anonymous namespace 908 909 static bool isSoftFloatABI(const ArgList &Args) { 910 Arg *A = Args.getLastArg(options::OPT_msoft_float, options::OPT_mhard_float, 911 options::OPT_mfloat_abi_EQ); 912 if (!A) 913 return false; 914 915 return A->getOption().matches(options::OPT_msoft_float) || 916 (A->getOption().matches(options::OPT_mfloat_abi_EQ) && 917 A->getValue() == StringRef("soft")); 918 } 919 920 static bool isArmOrThumbArch(llvm::Triple::ArchType Arch) { 921 return Arch == llvm::Triple::arm || Arch == llvm::Triple::thumb; 922 } 923 924 static bool isMipsEL(llvm::Triple::ArchType Arch) { 925 return Arch == llvm::Triple::mipsel || Arch == llvm::Triple::mips64el; 926 } 927 928 static bool isMips16(const ArgList &Args) { 929 Arg *A = Args.getLastArg(options::OPT_mips16, options::OPT_mno_mips16); 930 return A && A->getOption().matches(options::OPT_mips16); 931 } 932 933 static bool isMicroMips(const ArgList &Args) { 934 Arg *A = Args.getLastArg(options::OPT_mmicromips, options::OPT_mno_micromips); 935 return A && A->getOption().matches(options::OPT_mmicromips); 936 } 937 938 static bool isMSP430(llvm::Triple::ArchType Arch) { 939 return Arch == llvm::Triple::msp430; 940 } 941 942 static Multilib makeMultilib(StringRef commonSuffix) { 943 return Multilib(commonSuffix, commonSuffix, commonSuffix); 944 } 945 946 static bool findMipsCsMultilibs(const Multilib::flags_list &Flags, 947 FilterNonExistent &NonExistent, 948 DetectedMultilibs &Result) { 949 // Check for Code Sourcery toolchain multilibs 950 MultilibSet CSMipsMultilibs; 951 { 952 auto MArchMips16 = makeMultilib("/mips16").flag("+m32").flag("+mips16"); 953 954 auto MArchMicroMips = 955 makeMultilib("/micromips").flag("+m32").flag("+mmicromips"); 956 957 auto MArchDefault = makeMultilib("").flag("-mips16").flag("-mmicromips"); 958 959 auto UCLibc = makeMultilib("/uclibc").flag("+muclibc"); 960 961 auto SoftFloat = makeMultilib("/soft-float").flag("+msoft-float"); 962 963 auto Nan2008 = makeMultilib("/nan2008").flag("+mnan=2008"); 964 965 auto DefaultFloat = 966 makeMultilib("").flag("-msoft-float").flag("-mnan=2008"); 967 968 auto BigEndian = makeMultilib("").flag("+EB").flag("-EL"); 969 970 auto LittleEndian = makeMultilib("/el").flag("+EL").flag("-EB"); 971 972 // Note that this one's osSuffix is "" 973 auto MAbi64 = makeMultilib("") 974 .gccSuffix("/64") 975 .includeSuffix("/64") 976 .flag("+mabi=n64") 977 .flag("-mabi=n32") 978 .flag("-m32"); 979 980 CSMipsMultilibs = 981 MultilibSet() 982 .Either(MArchMips16, MArchMicroMips, MArchDefault) 983 .Maybe(UCLibc) 984 .Either(SoftFloat, Nan2008, DefaultFloat) 985 .FilterOut("/micromips/nan2008") 986 .FilterOut("/mips16/nan2008") 987 .Either(BigEndian, LittleEndian) 988 .Maybe(MAbi64) 989 .FilterOut("/mips16.*/64") 990 .FilterOut("/micromips.*/64") 991 .FilterOut(NonExistent) 992 .setIncludeDirsCallback([](const Multilib &M) { 993 std::vector<std::string> Dirs({"/include"}); 994 if (StringRef(M.includeSuffix()).startswith("/uclibc")) 995 Dirs.push_back( 996 "/../../../../mips-linux-gnu/libc/uclibc/usr/include"); 997 else 998 Dirs.push_back("/../../../../mips-linux-gnu/libc/usr/include"); 999 return Dirs; 1000 }); 1001 } 1002 1003 MultilibSet DebianMipsMultilibs; 1004 { 1005 Multilib MAbiN32 = 1006 Multilib().gccSuffix("/n32").includeSuffix("/n32").flag("+mabi=n32"); 1007 1008 Multilib M64 = Multilib() 1009 .gccSuffix("/64") 1010 .includeSuffix("/64") 1011 .flag("+m64") 1012 .flag("-m32") 1013 .flag("-mabi=n32"); 1014 1015 Multilib M32 = Multilib().flag("-m64").flag("+m32").flag("-mabi=n32"); 1016 1017 DebianMipsMultilibs = 1018 MultilibSet().Either(M32, M64, MAbiN32).FilterOut(NonExistent); 1019 } 1020 1021 // Sort candidates. Toolchain that best meets the directories tree goes first. 1022 // Then select the first toolchains matches command line flags. 1023 MultilibSet *Candidates[] = {&CSMipsMultilibs, &DebianMipsMultilibs}; 1024 if (CSMipsMultilibs.size() < DebianMipsMultilibs.size()) 1025 std::iter_swap(Candidates, Candidates + 1); 1026 for (const MultilibSet *Candidate : Candidates) { 1027 if (Candidate->select(Flags, Result.SelectedMultilib)) { 1028 if (Candidate == &DebianMipsMultilibs) 1029 Result.BiarchSibling = Multilib(); 1030 Result.Multilibs = *Candidate; 1031 return true; 1032 } 1033 } 1034 return false; 1035 } 1036 1037 static bool findMipsAndroidMultilibs(llvm::vfs::FileSystem &VFS, StringRef Path, 1038 const Multilib::flags_list &Flags, 1039 FilterNonExistent &NonExistent, 1040 DetectedMultilibs &Result) { 1041 1042 MultilibSet AndroidMipsMultilibs = 1043 MultilibSet() 1044 .Maybe(Multilib("/mips-r2").flag("+march=mips32r2")) 1045 .Maybe(Multilib("/mips-r6").flag("+march=mips32r6")) 1046 .FilterOut(NonExistent); 1047 1048 MultilibSet AndroidMipselMultilibs = 1049 MultilibSet() 1050 .Either(Multilib().flag("+march=mips32"), 1051 Multilib("/mips-r2", "", "/mips-r2").flag("+march=mips32r2"), 1052 Multilib("/mips-r6", "", "/mips-r6").flag("+march=mips32r6")) 1053 .FilterOut(NonExistent); 1054 1055 MultilibSet AndroidMips64elMultilibs = 1056 MultilibSet() 1057 .Either( 1058 Multilib().flag("+march=mips64r6"), 1059 Multilib("/32/mips-r1", "", "/mips-r1").flag("+march=mips32"), 1060 Multilib("/32/mips-r2", "", "/mips-r2").flag("+march=mips32r2"), 1061 Multilib("/32/mips-r6", "", "/mips-r6").flag("+march=mips32r6")) 1062 .FilterOut(NonExistent); 1063 1064 MultilibSet *MS = &AndroidMipsMultilibs; 1065 if (VFS.exists(Path + "/mips-r6")) 1066 MS = &AndroidMipselMultilibs; 1067 else if (VFS.exists(Path + "/32")) 1068 MS = &AndroidMips64elMultilibs; 1069 if (MS->select(Flags, Result.SelectedMultilib)) { 1070 Result.Multilibs = *MS; 1071 return true; 1072 } 1073 return false; 1074 } 1075 1076 static bool findMipsMuslMultilibs(const Multilib::flags_list &Flags, 1077 FilterNonExistent &NonExistent, 1078 DetectedMultilibs &Result) { 1079 // Musl toolchain multilibs 1080 MultilibSet MuslMipsMultilibs; 1081 { 1082 auto MArchMipsR2 = makeMultilib("") 1083 .osSuffix("/mips-r2-hard-musl") 1084 .flag("+EB") 1085 .flag("-EL") 1086 .flag("+march=mips32r2"); 1087 1088 auto MArchMipselR2 = makeMultilib("/mipsel-r2-hard-musl") 1089 .flag("-EB") 1090 .flag("+EL") 1091 .flag("+march=mips32r2"); 1092 1093 MuslMipsMultilibs = MultilibSet().Either(MArchMipsR2, MArchMipselR2); 1094 1095 // Specify the callback that computes the include directories. 1096 MuslMipsMultilibs.setIncludeDirsCallback([](const Multilib &M) { 1097 return std::vector<std::string>( 1098 {"/../sysroot" + M.osSuffix() + "/usr/include"}); 1099 }); 1100 } 1101 if (MuslMipsMultilibs.select(Flags, Result.SelectedMultilib)) { 1102 Result.Multilibs = MuslMipsMultilibs; 1103 return true; 1104 } 1105 return false; 1106 } 1107 1108 static bool findMipsMtiMultilibs(const Multilib::flags_list &Flags, 1109 FilterNonExistent &NonExistent, 1110 DetectedMultilibs &Result) { 1111 // CodeScape MTI toolchain v1.2 and early. 1112 MultilibSet MtiMipsMultilibsV1; 1113 { 1114 auto MArchMips32 = makeMultilib("/mips32") 1115 .flag("+m32") 1116 .flag("-m64") 1117 .flag("-mmicromips") 1118 .flag("+march=mips32"); 1119 1120 auto MArchMicroMips = makeMultilib("/micromips") 1121 .flag("+m32") 1122 .flag("-m64") 1123 .flag("+mmicromips"); 1124 1125 auto MArchMips64r2 = makeMultilib("/mips64r2") 1126 .flag("-m32") 1127 .flag("+m64") 1128 .flag("+march=mips64r2"); 1129 1130 auto MArchMips64 = makeMultilib("/mips64").flag("-m32").flag("+m64").flag( 1131 "-march=mips64r2"); 1132 1133 auto MArchDefault = makeMultilib("") 1134 .flag("+m32") 1135 .flag("-m64") 1136 .flag("-mmicromips") 1137 .flag("+march=mips32r2"); 1138 1139 auto Mips16 = makeMultilib("/mips16").flag("+mips16"); 1140 1141 auto UCLibc = makeMultilib("/uclibc").flag("+muclibc"); 1142 1143 auto MAbi64 = 1144 makeMultilib("/64").flag("+mabi=n64").flag("-mabi=n32").flag("-m32"); 1145 1146 auto BigEndian = makeMultilib("").flag("+EB").flag("-EL"); 1147 1148 auto LittleEndian = makeMultilib("/el").flag("+EL").flag("-EB"); 1149 1150 auto SoftFloat = makeMultilib("/sof").flag("+msoft-float"); 1151 1152 auto Nan2008 = makeMultilib("/nan2008").flag("+mnan=2008"); 1153 1154 MtiMipsMultilibsV1 = 1155 MultilibSet() 1156 .Either(MArchMips32, MArchMicroMips, MArchMips64r2, MArchMips64, 1157 MArchDefault) 1158 .Maybe(UCLibc) 1159 .Maybe(Mips16) 1160 .FilterOut("/mips64/mips16") 1161 .FilterOut("/mips64r2/mips16") 1162 .FilterOut("/micromips/mips16") 1163 .Maybe(MAbi64) 1164 .FilterOut("/micromips/64") 1165 .FilterOut("/mips32/64") 1166 .FilterOut("^/64") 1167 .FilterOut("/mips16/64") 1168 .Either(BigEndian, LittleEndian) 1169 .Maybe(SoftFloat) 1170 .Maybe(Nan2008) 1171 .FilterOut(".*sof/nan2008") 1172 .FilterOut(NonExistent) 1173 .setIncludeDirsCallback([](const Multilib &M) { 1174 std::vector<std::string> Dirs({"/include"}); 1175 if (StringRef(M.includeSuffix()).startswith("/uclibc")) 1176 Dirs.push_back("/../../../../sysroot/uclibc/usr/include"); 1177 else 1178 Dirs.push_back("/../../../../sysroot/usr/include"); 1179 return Dirs; 1180 }); 1181 } 1182 1183 // CodeScape IMG toolchain starting from v1.3. 1184 MultilibSet MtiMipsMultilibsV2; 1185 { 1186 auto BeHard = makeMultilib("/mips-r2-hard") 1187 .flag("+EB") 1188 .flag("-msoft-float") 1189 .flag("-mnan=2008") 1190 .flag("-muclibc"); 1191 auto BeSoft = makeMultilib("/mips-r2-soft") 1192 .flag("+EB") 1193 .flag("+msoft-float") 1194 .flag("-mnan=2008"); 1195 auto ElHard = makeMultilib("/mipsel-r2-hard") 1196 .flag("+EL") 1197 .flag("-msoft-float") 1198 .flag("-mnan=2008") 1199 .flag("-muclibc"); 1200 auto ElSoft = makeMultilib("/mipsel-r2-soft") 1201 .flag("+EL") 1202 .flag("+msoft-float") 1203 .flag("-mnan=2008") 1204 .flag("-mmicromips"); 1205 auto BeHardNan = makeMultilib("/mips-r2-hard-nan2008") 1206 .flag("+EB") 1207 .flag("-msoft-float") 1208 .flag("+mnan=2008") 1209 .flag("-muclibc"); 1210 auto ElHardNan = makeMultilib("/mipsel-r2-hard-nan2008") 1211 .flag("+EL") 1212 .flag("-msoft-float") 1213 .flag("+mnan=2008") 1214 .flag("-muclibc") 1215 .flag("-mmicromips"); 1216 auto BeHardNanUclibc = makeMultilib("/mips-r2-hard-nan2008-uclibc") 1217 .flag("+EB") 1218 .flag("-msoft-float") 1219 .flag("+mnan=2008") 1220 .flag("+muclibc"); 1221 auto ElHardNanUclibc = makeMultilib("/mipsel-r2-hard-nan2008-uclibc") 1222 .flag("+EL") 1223 .flag("-msoft-float") 1224 .flag("+mnan=2008") 1225 .flag("+muclibc"); 1226 auto BeHardUclibc = makeMultilib("/mips-r2-hard-uclibc") 1227 .flag("+EB") 1228 .flag("-msoft-float") 1229 .flag("-mnan=2008") 1230 .flag("+muclibc"); 1231 auto ElHardUclibc = makeMultilib("/mipsel-r2-hard-uclibc") 1232 .flag("+EL") 1233 .flag("-msoft-float") 1234 .flag("-mnan=2008") 1235 .flag("+muclibc"); 1236 auto ElMicroHardNan = makeMultilib("/micromipsel-r2-hard-nan2008") 1237 .flag("+EL") 1238 .flag("-msoft-float") 1239 .flag("+mnan=2008") 1240 .flag("+mmicromips"); 1241 auto ElMicroSoft = makeMultilib("/micromipsel-r2-soft") 1242 .flag("+EL") 1243 .flag("+msoft-float") 1244 .flag("-mnan=2008") 1245 .flag("+mmicromips"); 1246 1247 auto O32 = 1248 makeMultilib("/lib").osSuffix("").flag("-mabi=n32").flag("-mabi=n64"); 1249 auto N32 = 1250 makeMultilib("/lib32").osSuffix("").flag("+mabi=n32").flag("-mabi=n64"); 1251 auto N64 = 1252 makeMultilib("/lib64").osSuffix("").flag("-mabi=n32").flag("+mabi=n64"); 1253 1254 MtiMipsMultilibsV2 = 1255 MultilibSet() 1256 .Either({BeHard, BeSoft, ElHard, ElSoft, BeHardNan, ElHardNan, 1257 BeHardNanUclibc, ElHardNanUclibc, BeHardUclibc, 1258 ElHardUclibc, ElMicroHardNan, ElMicroSoft}) 1259 .Either(O32, N32, N64) 1260 .FilterOut(NonExistent) 1261 .setIncludeDirsCallback([](const Multilib &M) { 1262 return std::vector<std::string>({"/../../../../sysroot" + 1263 M.includeSuffix() + 1264 "/../usr/include"}); 1265 }) 1266 .setFilePathsCallback([](const Multilib &M) { 1267 return std::vector<std::string>( 1268 {"/../../../../mips-mti-linux-gnu/lib" + M.gccSuffix()}); 1269 }); 1270 } 1271 for (auto Candidate : {&MtiMipsMultilibsV1, &MtiMipsMultilibsV2}) { 1272 if (Candidate->select(Flags, Result.SelectedMultilib)) { 1273 Result.Multilibs = *Candidate; 1274 return true; 1275 } 1276 } 1277 return false; 1278 } 1279 1280 static bool findMipsImgMultilibs(const Multilib::flags_list &Flags, 1281 FilterNonExistent &NonExistent, 1282 DetectedMultilibs &Result) { 1283 // CodeScape IMG toolchain v1.2 and early. 1284 MultilibSet ImgMultilibsV1; 1285 { 1286 auto Mips64r6 = makeMultilib("/mips64r6").flag("+m64").flag("-m32"); 1287 1288 auto LittleEndian = makeMultilib("/el").flag("+EL").flag("-EB"); 1289 1290 auto MAbi64 = 1291 makeMultilib("/64").flag("+mabi=n64").flag("-mabi=n32").flag("-m32"); 1292 1293 ImgMultilibsV1 = 1294 MultilibSet() 1295 .Maybe(Mips64r6) 1296 .Maybe(MAbi64) 1297 .Maybe(LittleEndian) 1298 .FilterOut(NonExistent) 1299 .setIncludeDirsCallback([](const Multilib &M) { 1300 return std::vector<std::string>( 1301 {"/include", "/../../../../sysroot/usr/include"}); 1302 }); 1303 } 1304 1305 // CodeScape IMG toolchain starting from v1.3. 1306 MultilibSet ImgMultilibsV2; 1307 { 1308 auto BeHard = makeMultilib("/mips-r6-hard") 1309 .flag("+EB") 1310 .flag("-msoft-float") 1311 .flag("-mmicromips"); 1312 auto BeSoft = makeMultilib("/mips-r6-soft") 1313 .flag("+EB") 1314 .flag("+msoft-float") 1315 .flag("-mmicromips"); 1316 auto ElHard = makeMultilib("/mipsel-r6-hard") 1317 .flag("+EL") 1318 .flag("-msoft-float") 1319 .flag("-mmicromips"); 1320 auto ElSoft = makeMultilib("/mipsel-r6-soft") 1321 .flag("+EL") 1322 .flag("+msoft-float") 1323 .flag("-mmicromips"); 1324 auto BeMicroHard = makeMultilib("/micromips-r6-hard") 1325 .flag("+EB") 1326 .flag("-msoft-float") 1327 .flag("+mmicromips"); 1328 auto BeMicroSoft = makeMultilib("/micromips-r6-soft") 1329 .flag("+EB") 1330 .flag("+msoft-float") 1331 .flag("+mmicromips"); 1332 auto ElMicroHard = makeMultilib("/micromipsel-r6-hard") 1333 .flag("+EL") 1334 .flag("-msoft-float") 1335 .flag("+mmicromips"); 1336 auto ElMicroSoft = makeMultilib("/micromipsel-r6-soft") 1337 .flag("+EL") 1338 .flag("+msoft-float") 1339 .flag("+mmicromips"); 1340 1341 auto O32 = 1342 makeMultilib("/lib").osSuffix("").flag("-mabi=n32").flag("-mabi=n64"); 1343 auto N32 = 1344 makeMultilib("/lib32").osSuffix("").flag("+mabi=n32").flag("-mabi=n64"); 1345 auto N64 = 1346 makeMultilib("/lib64").osSuffix("").flag("-mabi=n32").flag("+mabi=n64"); 1347 1348 ImgMultilibsV2 = 1349 MultilibSet() 1350 .Either({BeHard, BeSoft, ElHard, ElSoft, BeMicroHard, BeMicroSoft, 1351 ElMicroHard, ElMicroSoft}) 1352 .Either(O32, N32, N64) 1353 .FilterOut(NonExistent) 1354 .setIncludeDirsCallback([](const Multilib &M) { 1355 return std::vector<std::string>({"/../../../../sysroot" + 1356 M.includeSuffix() + 1357 "/../usr/include"}); 1358 }) 1359 .setFilePathsCallback([](const Multilib &M) { 1360 return std::vector<std::string>( 1361 {"/../../../../mips-img-linux-gnu/lib" + M.gccSuffix()}); 1362 }); 1363 } 1364 for (auto Candidate : {&ImgMultilibsV1, &ImgMultilibsV2}) { 1365 if (Candidate->select(Flags, Result.SelectedMultilib)) { 1366 Result.Multilibs = *Candidate; 1367 return true; 1368 } 1369 } 1370 return false; 1371 } 1372 1373 bool clang::driver::findMIPSMultilibs(const Driver &D, 1374 const llvm::Triple &TargetTriple, 1375 StringRef Path, const ArgList &Args, 1376 DetectedMultilibs &Result) { 1377 FilterNonExistent NonExistent(Path, "/crtbegin.o", D.getVFS()); 1378 1379 StringRef CPUName; 1380 StringRef ABIName; 1381 tools::mips::getMipsCPUAndABI(Args, TargetTriple, CPUName, ABIName); 1382 1383 llvm::Triple::ArchType TargetArch = TargetTriple.getArch(); 1384 1385 Multilib::flags_list Flags; 1386 addMultilibFlag(TargetTriple.isMIPS32(), "m32", Flags); 1387 addMultilibFlag(TargetTriple.isMIPS64(), "m64", Flags); 1388 addMultilibFlag(isMips16(Args), "mips16", Flags); 1389 addMultilibFlag(CPUName == "mips32", "march=mips32", Flags); 1390 addMultilibFlag(CPUName == "mips32r2" || CPUName == "mips32r3" || 1391 CPUName == "mips32r5" || CPUName == "p5600", 1392 "march=mips32r2", Flags); 1393 addMultilibFlag(CPUName == "mips32r6", "march=mips32r6", Flags); 1394 addMultilibFlag(CPUName == "mips64", "march=mips64", Flags); 1395 addMultilibFlag(CPUName == "mips64r2" || CPUName == "mips64r3" || 1396 CPUName == "mips64r5" || CPUName == "octeon" || 1397 CPUName == "octeon+", 1398 "march=mips64r2", Flags); 1399 addMultilibFlag(CPUName == "mips64r6", "march=mips64r6", Flags); 1400 addMultilibFlag(isMicroMips(Args), "mmicromips", Flags); 1401 addMultilibFlag(tools::mips::isUCLibc(Args), "muclibc", Flags); 1402 addMultilibFlag(tools::mips::isNaN2008(Args, TargetTriple), "mnan=2008", 1403 Flags); 1404 addMultilibFlag(ABIName == "n32", "mabi=n32", Flags); 1405 addMultilibFlag(ABIName == "n64", "mabi=n64", Flags); 1406 addMultilibFlag(isSoftFloatABI(Args), "msoft-float", Flags); 1407 addMultilibFlag(!isSoftFloatABI(Args), "mhard-float", Flags); 1408 addMultilibFlag(isMipsEL(TargetArch), "EL", Flags); 1409 addMultilibFlag(!isMipsEL(TargetArch), "EB", Flags); 1410 1411 if (TargetTriple.isAndroid()) 1412 return findMipsAndroidMultilibs(D.getVFS(), Path, Flags, NonExistent, 1413 Result); 1414 1415 if (TargetTriple.getVendor() == llvm::Triple::MipsTechnologies && 1416 TargetTriple.getOS() == llvm::Triple::Linux && 1417 TargetTriple.getEnvironment() == llvm::Triple::UnknownEnvironment) 1418 return findMipsMuslMultilibs(Flags, NonExistent, Result); 1419 1420 if (TargetTriple.getVendor() == llvm::Triple::MipsTechnologies && 1421 TargetTriple.getOS() == llvm::Triple::Linux && 1422 TargetTriple.isGNUEnvironment()) 1423 return findMipsMtiMultilibs(Flags, NonExistent, Result); 1424 1425 if (TargetTriple.getVendor() == llvm::Triple::ImaginationTechnologies && 1426 TargetTriple.getOS() == llvm::Triple::Linux && 1427 TargetTriple.isGNUEnvironment()) 1428 return findMipsImgMultilibs(Flags, NonExistent, Result); 1429 1430 if (findMipsCsMultilibs(Flags, NonExistent, Result)) 1431 return true; 1432 1433 // Fallback to the regular toolchain-tree structure. 1434 Multilib Default; 1435 Result.Multilibs.push_back(Default); 1436 Result.Multilibs.FilterOut(NonExistent); 1437 1438 if (Result.Multilibs.select(Flags, Result.SelectedMultilib)) { 1439 Result.BiarchSibling = Multilib(); 1440 return true; 1441 } 1442 1443 return false; 1444 } 1445 1446 static void findAndroidArmMultilibs(const Driver &D, 1447 const llvm::Triple &TargetTriple, 1448 StringRef Path, const ArgList &Args, 1449 DetectedMultilibs &Result) { 1450 // Find multilibs with subdirectories like armv7-a, thumb, armv7-a/thumb. 1451 FilterNonExistent NonExistent(Path, "/crtbegin.o", D.getVFS()); 1452 Multilib ArmV7Multilib = makeMultilib("/armv7-a") 1453 .flag("+march=armv7-a") 1454 .flag("-mthumb"); 1455 Multilib ThumbMultilib = makeMultilib("/thumb") 1456 .flag("-march=armv7-a") 1457 .flag("+mthumb"); 1458 Multilib ArmV7ThumbMultilib = makeMultilib("/armv7-a/thumb") 1459 .flag("+march=armv7-a") 1460 .flag("+mthumb"); 1461 Multilib DefaultMultilib = makeMultilib("") 1462 .flag("-march=armv7-a") 1463 .flag("-mthumb"); 1464 MultilibSet AndroidArmMultilibs = 1465 MultilibSet() 1466 .Either(ThumbMultilib, ArmV7Multilib, 1467 ArmV7ThumbMultilib, DefaultMultilib) 1468 .FilterOut(NonExistent); 1469 1470 Multilib::flags_list Flags; 1471 llvm::StringRef Arch = Args.getLastArgValue(options::OPT_march_EQ); 1472 bool IsArmArch = TargetTriple.getArch() == llvm::Triple::arm; 1473 bool IsThumbArch = TargetTriple.getArch() == llvm::Triple::thumb; 1474 bool IsV7SubArch = TargetTriple.getSubArch() == llvm::Triple::ARMSubArch_v7; 1475 bool IsThumbMode = IsThumbArch || 1476 Args.hasFlag(options::OPT_mthumb, options::OPT_mno_thumb, false) || 1477 (IsArmArch && llvm::ARM::parseArchISA(Arch) == llvm::ARM::ISAKind::THUMB); 1478 bool IsArmV7Mode = (IsArmArch || IsThumbArch) && 1479 (llvm::ARM::parseArchVersion(Arch) == 7 || 1480 (IsArmArch && Arch == "" && IsV7SubArch)); 1481 addMultilibFlag(IsArmV7Mode, "march=armv7-a", Flags); 1482 addMultilibFlag(IsThumbMode, "mthumb", Flags); 1483 1484 if (AndroidArmMultilibs.select(Flags, Result.SelectedMultilib)) 1485 Result.Multilibs = AndroidArmMultilibs; 1486 } 1487 1488 static bool findMSP430Multilibs(const Driver &D, 1489 const llvm::Triple &TargetTriple, 1490 StringRef Path, const ArgList &Args, 1491 DetectedMultilibs &Result) { 1492 FilterNonExistent NonExistent(Path, "/crtbegin.o", D.getVFS()); 1493 Multilib MSP430Multilib = makeMultilib("/430"); 1494 // FIXME: when clang starts to support msp430x ISA additional logic 1495 // to select between multilib must be implemented 1496 // Multilib MSP430xMultilib = makeMultilib("/large"); 1497 1498 Result.Multilibs.push_back(MSP430Multilib); 1499 Result.Multilibs.FilterOut(NonExistent); 1500 1501 Multilib::flags_list Flags; 1502 if (Result.Multilibs.select(Flags, Result.SelectedMultilib)) 1503 return true; 1504 1505 return false; 1506 } 1507 1508 static void findRISCVMultilibs(const Driver &D, 1509 const llvm::Triple &TargetTriple, StringRef Path, 1510 const ArgList &Args, DetectedMultilibs &Result) { 1511 1512 FilterNonExistent NonExistent(Path, "/crtbegin.o", D.getVFS()); 1513 Multilib Ilp32 = makeMultilib("lib32/ilp32").flag("+m32").flag("+mabi=ilp32"); 1514 Multilib Ilp32f = 1515 makeMultilib("lib32/ilp32f").flag("+m32").flag("+mabi=ilp32f"); 1516 Multilib Ilp32d = 1517 makeMultilib("lib32/ilp32d").flag("+m32").flag("+mabi=ilp32d"); 1518 Multilib Lp64 = makeMultilib("lib64/lp64").flag("+m64").flag("+mabi=lp64"); 1519 Multilib Lp64f = makeMultilib("lib64/lp64f").flag("+m64").flag("+mabi=lp64f"); 1520 Multilib Lp64d = makeMultilib("lib64/lp64d").flag("+m64").flag("+mabi=lp64d"); 1521 MultilibSet RISCVMultilibs = 1522 MultilibSet() 1523 .Either({Ilp32, Ilp32f, Ilp32d, Lp64, Lp64f, Lp64d}) 1524 .FilterOut(NonExistent); 1525 1526 Multilib::flags_list Flags; 1527 bool IsRV64 = TargetTriple.getArch() == llvm::Triple::riscv64; 1528 StringRef ABIName = tools::riscv::getRISCVABI(Args, TargetTriple); 1529 1530 addMultilibFlag(!IsRV64, "m32", Flags); 1531 addMultilibFlag(IsRV64, "m64", Flags); 1532 addMultilibFlag(ABIName == "ilp32", "mabi=ilp32", Flags); 1533 addMultilibFlag(ABIName == "ilp32f", "mabi=ilp32f", Flags); 1534 addMultilibFlag(ABIName == "ilp32d", "mabi=ilp32d", Flags); 1535 addMultilibFlag(ABIName == "lp64", "mabi=lp64", Flags); 1536 addMultilibFlag(ABIName == "lp64f", "mabi=lp64f", Flags); 1537 addMultilibFlag(ABIName == "lp64d", "mabi=lp64d", Flags); 1538 1539 if (RISCVMultilibs.select(Flags, Result.SelectedMultilib)) 1540 Result.Multilibs = RISCVMultilibs; 1541 } 1542 1543 static bool findBiarchMultilibs(const Driver &D, 1544 const llvm::Triple &TargetTriple, 1545 StringRef Path, const ArgList &Args, 1546 bool NeedsBiarchSuffix, 1547 DetectedMultilibs &Result) { 1548 Multilib Default; 1549 1550 // Some versions of SUSE and Fedora on ppc64 put 32-bit libs 1551 // in what would normally be GCCInstallPath and put the 64-bit 1552 // libs in a subdirectory named 64. The simple logic we follow is that 1553 // *if* there is a subdirectory of the right name with crtbegin.o in it, 1554 // we use that. If not, and if not a biarch triple alias, we look for 1555 // crtbegin.o without the subdirectory. 1556 1557 StringRef Suff64 = "/64"; 1558 // Solaris uses platform-specific suffixes instead of /64. 1559 if (TargetTriple.getOS() == llvm::Triple::Solaris) { 1560 switch (TargetTriple.getArch()) { 1561 case llvm::Triple::x86: 1562 case llvm::Triple::x86_64: 1563 Suff64 = "/amd64"; 1564 break; 1565 case llvm::Triple::sparc: 1566 case llvm::Triple::sparcv9: 1567 Suff64 = "/sparcv9"; 1568 break; 1569 default: 1570 break; 1571 } 1572 } 1573 1574 Multilib Alt64 = Multilib() 1575 .gccSuffix(Suff64) 1576 .includeSuffix(Suff64) 1577 .flag("-m32") 1578 .flag("+m64") 1579 .flag("-mx32"); 1580 Multilib Alt32 = Multilib() 1581 .gccSuffix("/32") 1582 .includeSuffix("/32") 1583 .flag("+m32") 1584 .flag("-m64") 1585 .flag("-mx32"); 1586 Multilib Altx32 = Multilib() 1587 .gccSuffix("/x32") 1588 .includeSuffix("/x32") 1589 .flag("-m32") 1590 .flag("-m64") 1591 .flag("+mx32"); 1592 1593 // GCC toolchain for IAMCU doesn't have crtbegin.o, so look for libgcc.a. 1594 FilterNonExistent NonExistent( 1595 Path, TargetTriple.isOSIAMCU() ? "/libgcc.a" : "/crtbegin.o", D.getVFS()); 1596 1597 // Determine default multilib from: 32, 64, x32 1598 // Also handle cases such as 64 on 32, 32 on 64, etc. 1599 enum { UNKNOWN, WANT32, WANT64, WANTX32 } Want = UNKNOWN; 1600 const bool IsX32 = TargetTriple.getEnvironment() == llvm::Triple::GNUX32; 1601 if (TargetTriple.isArch32Bit() && !NonExistent(Alt32)) 1602 Want = WANT64; 1603 else if (TargetTriple.isArch64Bit() && IsX32 && !NonExistent(Altx32)) 1604 Want = WANT64; 1605 else if (TargetTriple.isArch64Bit() && !IsX32 && !NonExistent(Alt64)) 1606 Want = WANT32; 1607 else { 1608 if (TargetTriple.isArch32Bit()) 1609 Want = NeedsBiarchSuffix ? WANT64 : WANT32; 1610 else if (IsX32) 1611 Want = NeedsBiarchSuffix ? WANT64 : WANTX32; 1612 else 1613 Want = NeedsBiarchSuffix ? WANT32 : WANT64; 1614 } 1615 1616 if (Want == WANT32) 1617 Default.flag("+m32").flag("-m64").flag("-mx32"); 1618 else if (Want == WANT64) 1619 Default.flag("-m32").flag("+m64").flag("-mx32"); 1620 else if (Want == WANTX32) 1621 Default.flag("-m32").flag("-m64").flag("+mx32"); 1622 else 1623 return false; 1624 1625 Result.Multilibs.push_back(Default); 1626 Result.Multilibs.push_back(Alt64); 1627 Result.Multilibs.push_back(Alt32); 1628 Result.Multilibs.push_back(Altx32); 1629 1630 Result.Multilibs.FilterOut(NonExistent); 1631 1632 Multilib::flags_list Flags; 1633 addMultilibFlag(TargetTriple.isArch64Bit() && !IsX32, "m64", Flags); 1634 addMultilibFlag(TargetTriple.isArch32Bit(), "m32", Flags); 1635 addMultilibFlag(TargetTriple.isArch64Bit() && IsX32, "mx32", Flags); 1636 1637 if (!Result.Multilibs.select(Flags, Result.SelectedMultilib)) 1638 return false; 1639 1640 if (Result.SelectedMultilib == Alt64 || Result.SelectedMultilib == Alt32 || 1641 Result.SelectedMultilib == Altx32) 1642 Result.BiarchSibling = Default; 1643 1644 return true; 1645 } 1646 1647 /// Generic_GCC - A tool chain using the 'gcc' command to perform 1648 /// all subcommands; this relies on gcc translating the majority of 1649 /// command line options. 1650 1651 /// Less-than for GCCVersion, implementing a Strict Weak Ordering. 1652 bool Generic_GCC::GCCVersion::isOlderThan(int RHSMajor, int RHSMinor, 1653 int RHSPatch, 1654 StringRef RHSPatchSuffix) const { 1655 if (Major != RHSMajor) 1656 return Major < RHSMajor; 1657 if (Minor != RHSMinor) 1658 return Minor < RHSMinor; 1659 if (Patch != RHSPatch) { 1660 // Note that versions without a specified patch sort higher than those with 1661 // a patch. 1662 if (RHSPatch == -1) 1663 return true; 1664 if (Patch == -1) 1665 return false; 1666 1667 // Otherwise just sort on the patch itself. 1668 return Patch < RHSPatch; 1669 } 1670 if (PatchSuffix != RHSPatchSuffix) { 1671 // Sort empty suffixes higher. 1672 if (RHSPatchSuffix.empty()) 1673 return true; 1674 if (PatchSuffix.empty()) 1675 return false; 1676 1677 // Provide a lexicographic sort to make this a total ordering. 1678 return PatchSuffix < RHSPatchSuffix; 1679 } 1680 1681 // The versions are equal. 1682 return false; 1683 } 1684 1685 /// Parse a GCCVersion object out of a string of text. 1686 /// 1687 /// This is the primary means of forming GCCVersion objects. 1688 /*static*/ 1689 Generic_GCC::GCCVersion Generic_GCC::GCCVersion::Parse(StringRef VersionText) { 1690 const GCCVersion BadVersion = {VersionText.str(), -1, -1, -1, "", "", ""}; 1691 std::pair<StringRef, StringRef> First = VersionText.split('.'); 1692 std::pair<StringRef, StringRef> Second = First.second.split('.'); 1693 1694 GCCVersion GoodVersion = {VersionText.str(), -1, -1, -1, "", "", ""}; 1695 if (First.first.getAsInteger(10, GoodVersion.Major) || GoodVersion.Major < 0) 1696 return BadVersion; 1697 GoodVersion.MajorStr = First.first.str(); 1698 if (First.second.empty()) 1699 return GoodVersion; 1700 StringRef MinorStr = Second.first; 1701 if (Second.second.empty()) { 1702 if (size_t EndNumber = MinorStr.find_first_not_of("0123456789")) { 1703 GoodVersion.PatchSuffix = MinorStr.substr(EndNumber); 1704 MinorStr = MinorStr.slice(0, EndNumber); 1705 } 1706 } 1707 if (MinorStr.getAsInteger(10, GoodVersion.Minor) || GoodVersion.Minor < 0) 1708 return BadVersion; 1709 GoodVersion.MinorStr = MinorStr.str(); 1710 1711 // First look for a number prefix and parse that if present. Otherwise just 1712 // stash the entire patch string in the suffix, and leave the number 1713 // unspecified. This covers versions strings such as: 1714 // 5 (handled above) 1715 // 4.4 1716 // 4.4-patched 1717 // 4.4.0 1718 // 4.4.x 1719 // 4.4.2-rc4 1720 // 4.4.x-patched 1721 // And retains any patch number it finds. 1722 StringRef PatchText = Second.second; 1723 if (!PatchText.empty()) { 1724 if (size_t EndNumber = PatchText.find_first_not_of("0123456789")) { 1725 // Try to parse the number and any suffix. 1726 if (PatchText.slice(0, EndNumber).getAsInteger(10, GoodVersion.Patch) || 1727 GoodVersion.Patch < 0) 1728 return BadVersion; 1729 GoodVersion.PatchSuffix = PatchText.substr(EndNumber); 1730 } 1731 } 1732 1733 return GoodVersion; 1734 } 1735 1736 static llvm::StringRef getGCCToolchainDir(const ArgList &Args, 1737 llvm::StringRef SysRoot) { 1738 const Arg *A = Args.getLastArg(clang::driver::options::OPT_gcc_toolchain); 1739 if (A) 1740 return A->getValue(); 1741 1742 // If we have a SysRoot, ignore GCC_INSTALL_PREFIX. 1743 // GCC_INSTALL_PREFIX specifies the gcc installation for the default 1744 // sysroot and is likely not valid with a different sysroot. 1745 if (!SysRoot.empty()) 1746 return ""; 1747 1748 return GCC_INSTALL_PREFIX; 1749 } 1750 1751 /// Initialize a GCCInstallationDetector from the driver. 1752 /// 1753 /// This performs all of the autodetection and sets up the various paths. 1754 /// Once constructed, a GCCInstallationDetector is essentially immutable. 1755 /// 1756 /// FIXME: We shouldn't need an explicit TargetTriple parameter here, and 1757 /// should instead pull the target out of the driver. This is currently 1758 /// necessary because the driver doesn't store the final version of the target 1759 /// triple. 1760 void Generic_GCC::GCCInstallationDetector::init( 1761 const llvm::Triple &TargetTriple, const ArgList &Args, 1762 ArrayRef<std::string> ExtraTripleAliases) { 1763 llvm::Triple BiarchVariantTriple = TargetTriple.isArch32Bit() 1764 ? TargetTriple.get64BitArchVariant() 1765 : TargetTriple.get32BitArchVariant(); 1766 // The library directories which may contain GCC installations. 1767 SmallVector<StringRef, 4> CandidateLibDirs, CandidateBiarchLibDirs; 1768 // The compatible GCC triples for this particular architecture. 1769 SmallVector<StringRef, 16> CandidateTripleAliases; 1770 SmallVector<StringRef, 16> CandidateBiarchTripleAliases; 1771 CollectLibDirsAndTriples(TargetTriple, BiarchVariantTriple, CandidateLibDirs, 1772 CandidateTripleAliases, CandidateBiarchLibDirs, 1773 CandidateBiarchTripleAliases); 1774 1775 // Compute the set of prefixes for our search. 1776 SmallVector<std::string, 8> Prefixes(D.PrefixDirs.begin(), 1777 D.PrefixDirs.end()); 1778 1779 StringRef GCCToolchainDir = getGCCToolchainDir(Args, D.SysRoot); 1780 if (GCCToolchainDir != "") { 1781 if (GCCToolchainDir.back() == '/') 1782 GCCToolchainDir = GCCToolchainDir.drop_back(); // remove the / 1783 1784 Prefixes.push_back(GCCToolchainDir); 1785 } else { 1786 // If we have a SysRoot, try that first. 1787 if (!D.SysRoot.empty()) { 1788 Prefixes.push_back(D.SysRoot); 1789 AddDefaultGCCPrefixes(TargetTriple, Prefixes, D.SysRoot); 1790 } 1791 1792 // Then look for gcc installed alongside clang. 1793 Prefixes.push_back(D.InstalledDir + "/.."); 1794 1795 // Next, look for prefix(es) that correspond to distribution-supplied gcc 1796 // installations. 1797 if (D.SysRoot.empty()) { 1798 // Typically /usr. 1799 AddDefaultGCCPrefixes(TargetTriple, Prefixes, D.SysRoot); 1800 } 1801 } 1802 1803 // Try to respect gcc-config on Gentoo. However, do that only 1804 // if --gcc-toolchain is not provided or equal to the Gentoo install 1805 // in /usr. This avoids accidentally enforcing the system GCC version 1806 // when using a custom toolchain. 1807 if (GCCToolchainDir == "" || GCCToolchainDir == D.SysRoot + "/usr") { 1808 SmallVector<StringRef, 16> GentooTestTriples; 1809 // Try to match an exact triple as target triple first. 1810 // e.g. crossdev -S x86_64-gentoo-linux-gnu will install gcc libs for 1811 // x86_64-gentoo-linux-gnu. But "clang -target x86_64-gentoo-linux-gnu" 1812 // may pick the libraries for x86_64-pc-linux-gnu even when exact matching 1813 // triple x86_64-gentoo-linux-gnu is present. 1814 GentooTestTriples.push_back(TargetTriple.str()); 1815 // Check rest of triples. 1816 GentooTestTriples.append(ExtraTripleAliases.begin(), 1817 ExtraTripleAliases.end()); 1818 GentooTestTriples.append(CandidateTripleAliases.begin(), 1819 CandidateTripleAliases.end()); 1820 if (ScanGentooConfigs(TargetTriple, Args, GentooTestTriples, 1821 CandidateBiarchTripleAliases)) 1822 return; 1823 } 1824 1825 // Loop over the various components which exist and select the best GCC 1826 // installation available. GCC installs are ranked by version number. 1827 Version = GCCVersion::Parse("0.0.0"); 1828 for (const std::string &Prefix : Prefixes) { 1829 if (!D.getVFS().exists(Prefix)) 1830 continue; 1831 for (StringRef Suffix : CandidateLibDirs) { 1832 const std::string LibDir = Prefix + Suffix.str(); 1833 if (!D.getVFS().exists(LibDir)) 1834 continue; 1835 // Try to match the exact target triple first. 1836 ScanLibDirForGCCTriple(TargetTriple, Args, LibDir, TargetTriple.str()); 1837 // Try rest of possible triples. 1838 for (StringRef Candidate : ExtraTripleAliases) // Try these first. 1839 ScanLibDirForGCCTriple(TargetTriple, Args, LibDir, Candidate); 1840 for (StringRef Candidate : CandidateTripleAliases) 1841 ScanLibDirForGCCTriple(TargetTriple, Args, LibDir, Candidate); 1842 } 1843 for (StringRef Suffix : CandidateBiarchLibDirs) { 1844 const std::string LibDir = Prefix + Suffix.str(); 1845 if (!D.getVFS().exists(LibDir)) 1846 continue; 1847 for (StringRef Candidate : CandidateBiarchTripleAliases) 1848 ScanLibDirForGCCTriple(TargetTriple, Args, LibDir, Candidate, 1849 /*NeedsBiarchSuffix=*/ true); 1850 } 1851 } 1852 } 1853 1854 void Generic_GCC::GCCInstallationDetector::print(raw_ostream &OS) const { 1855 for (const auto &InstallPath : CandidateGCCInstallPaths) 1856 OS << "Found candidate GCC installation: " << InstallPath << "\n"; 1857 1858 if (!GCCInstallPath.empty()) 1859 OS << "Selected GCC installation: " << GCCInstallPath << "\n"; 1860 1861 for (const auto &Multilib : Multilibs) 1862 OS << "Candidate multilib: " << Multilib << "\n"; 1863 1864 if (Multilibs.size() != 0 || !SelectedMultilib.isDefault()) 1865 OS << "Selected multilib: " << SelectedMultilib << "\n"; 1866 } 1867 1868 bool Generic_GCC::GCCInstallationDetector::getBiarchSibling(Multilib &M) const { 1869 if (BiarchSibling.hasValue()) { 1870 M = BiarchSibling.getValue(); 1871 return true; 1872 } 1873 return false; 1874 } 1875 1876 void Generic_GCC::GCCInstallationDetector::AddDefaultGCCPrefixes( 1877 const llvm::Triple &TargetTriple, SmallVectorImpl<std::string> &Prefixes, 1878 StringRef SysRoot) { 1879 if (TargetTriple.getOS() == llvm::Triple::Solaris) { 1880 // Solaris is a special case. 1881 // The GCC installation is under 1882 // /usr/gcc/<major>.<minor>/lib/gcc/<triple>/<major>.<minor>.<patch>/ 1883 // so we need to find those /usr/gcc/*/lib/gcc libdirs and go with 1884 // /usr/gcc/<version> as a prefix. 1885 1886 std::string PrefixDir = SysRoot.str() + "/usr/gcc"; 1887 std::error_code EC; 1888 for (llvm::vfs::directory_iterator LI = D.getVFS().dir_begin(PrefixDir, EC), 1889 LE; 1890 !EC && LI != LE; LI = LI.increment(EC)) { 1891 StringRef VersionText = llvm::sys::path::filename(LI->path()); 1892 GCCVersion CandidateVersion = GCCVersion::Parse(VersionText); 1893 1894 // Filter out obviously bad entries. 1895 if (CandidateVersion.Major == -1 || CandidateVersion.isOlderThan(4, 1, 1)) 1896 continue; 1897 1898 std::string CandidatePrefix = PrefixDir + "/" + VersionText.str(); 1899 std::string CandidateLibPath = CandidatePrefix + "/lib/gcc"; 1900 if (!D.getVFS().exists(CandidateLibPath)) 1901 continue; 1902 1903 Prefixes.push_back(CandidatePrefix); 1904 } 1905 return; 1906 } 1907 1908 // Non-Solaris is much simpler - most systems just go with "/usr". 1909 if (SysRoot.empty() && TargetTriple.getOS() == llvm::Triple::Linux) { 1910 // Yet, still look for RHEL devtoolsets. 1911 Prefixes.push_back("/opt/rh/devtoolset-8/root/usr"); 1912 Prefixes.push_back("/opt/rh/devtoolset-7/root/usr"); 1913 Prefixes.push_back("/opt/rh/devtoolset-6/root/usr"); 1914 Prefixes.push_back("/opt/rh/devtoolset-4/root/usr"); 1915 Prefixes.push_back("/opt/rh/devtoolset-3/root/usr"); 1916 Prefixes.push_back("/opt/rh/devtoolset-2/root/usr"); 1917 } 1918 Prefixes.push_back(SysRoot.str() + "/usr"); 1919 } 1920 1921 /*static*/ void Generic_GCC::GCCInstallationDetector::CollectLibDirsAndTriples( 1922 const llvm::Triple &TargetTriple, const llvm::Triple &BiarchTriple, 1923 SmallVectorImpl<StringRef> &LibDirs, 1924 SmallVectorImpl<StringRef> &TripleAliases, 1925 SmallVectorImpl<StringRef> &BiarchLibDirs, 1926 SmallVectorImpl<StringRef> &BiarchTripleAliases) { 1927 // Declare a bunch of static data sets that we'll select between below. These 1928 // are specifically designed to always refer to string literals to avoid any 1929 // lifetime or initialization issues. 1930 static const char *const AArch64LibDirs[] = {"/lib64", "/lib"}; 1931 static const char *const AArch64Triples[] = { 1932 "aarch64-none-linux-gnu", "aarch64-linux-gnu", "aarch64-redhat-linux", 1933 "aarch64-suse-linux", "aarch64-linux-android"}; 1934 static const char *const AArch64beLibDirs[] = {"/lib"}; 1935 static const char *const AArch64beTriples[] = {"aarch64_be-none-linux-gnu", 1936 "aarch64_be-linux-gnu"}; 1937 1938 static const char *const ARMLibDirs[] = {"/lib"}; 1939 static const char *const ARMTriples[] = {"arm-linux-gnueabi", 1940 "arm-linux-androideabi"}; 1941 static const char *const ARMHFTriples[] = {"arm-linux-gnueabihf", 1942 "armv7hl-redhat-linux-gnueabi", 1943 "armv6hl-suse-linux-gnueabi", 1944 "armv7hl-suse-linux-gnueabi"}; 1945 static const char *const ARMebLibDirs[] = {"/lib"}; 1946 static const char *const ARMebTriples[] = {"armeb-linux-gnueabi", 1947 "armeb-linux-androideabi"}; 1948 static const char *const ARMebHFTriples[] = { 1949 "armeb-linux-gnueabihf", "armebv7hl-redhat-linux-gnueabi"}; 1950 1951 static const char *const AVRLibDirs[] = {"/lib"}; 1952 static const char *const AVRTriples[] = {"avr"}; 1953 1954 static const char *const X86_64LibDirs[] = {"/lib64", "/lib"}; 1955 static const char *const X86_64Triples[] = { 1956 "x86_64-linux-gnu", "x86_64-unknown-linux-gnu", 1957 "x86_64-pc-linux-gnu", "x86_64-redhat-linux6E", 1958 "x86_64-redhat-linux", "x86_64-suse-linux", 1959 "x86_64-manbo-linux-gnu", "x86_64-linux-gnu", 1960 "x86_64-slackware-linux", "x86_64-unknown-linux", 1961 "x86_64-amazon-linux", "x86_64-linux-android"}; 1962 static const char *const X32LibDirs[] = {"/libx32"}; 1963 static const char *const X86LibDirs[] = {"/lib32", "/lib"}; 1964 static const char *const X86Triples[] = { 1965 "i686-linux-gnu", "i686-pc-linux-gnu", "i486-linux-gnu", 1966 "i386-linux-gnu", "i386-redhat-linux6E", "i686-redhat-linux", 1967 "i586-redhat-linux", "i386-redhat-linux", "i586-suse-linux", 1968 "i486-slackware-linux", "i686-montavista-linux", "i586-linux-gnu", 1969 "i686-linux-android", "i386-gnu", "i486-gnu", 1970 "i586-gnu", "i686-gnu"}; 1971 1972 static const char *const MIPSLibDirs[] = {"/lib"}; 1973 static const char *const MIPSTriples[] = { 1974 "mips-linux-gnu", "mips-mti-linux", "mips-mti-linux-gnu", 1975 "mips-img-linux-gnu", "mipsisa32r6-linux-gnu"}; 1976 static const char *const MIPSELLibDirs[] = {"/lib"}; 1977 static const char *const MIPSELTriples[] = { 1978 "mipsel-linux-gnu", "mips-img-linux-gnu", "mipsisa32r6el-linux-gnu", 1979 "mipsel-linux-android"}; 1980 1981 static const char *const MIPS64LibDirs[] = {"/lib64", "/lib"}; 1982 static const char *const MIPS64Triples[] = { 1983 "mips64-linux-gnu", "mips-mti-linux-gnu", 1984 "mips-img-linux-gnu", "mips64-linux-gnuabi64", 1985 "mipsisa64r6-linux-gnu", "mipsisa64r6-linux-gnuabi64"}; 1986 static const char *const MIPS64ELLibDirs[] = {"/lib64", "/lib"}; 1987 static const char *const MIPS64ELTriples[] = { 1988 "mips64el-linux-gnu", "mips-mti-linux-gnu", 1989 "mips-img-linux-gnu", "mips64el-linux-gnuabi64", 1990 "mipsisa64r6el-linux-gnu", "mipsisa64r6el-linux-gnuabi64", 1991 "mips64el-linux-android"}; 1992 1993 static const char *const MIPSN32LibDirs[] = {"/lib32"}; 1994 static const char *const MIPSN32Triples[] = {"mips64-linux-gnuabin32", 1995 "mipsisa64r6-linux-gnuabin32"}; 1996 static const char *const MIPSN32ELLibDirs[] = {"/lib32"}; 1997 static const char *const MIPSN32ELTriples[] = { 1998 "mips64el-linux-gnuabin32", "mipsisa64r6el-linux-gnuabin32"}; 1999 2000 static const char *const MSP430LibDirs[] = {"/lib"}; 2001 static const char *const MSP430Triples[] = {"msp430-elf"}; 2002 2003 static const char *const PPCLibDirs[] = {"/lib32", "/lib"}; 2004 static const char *const PPCTriples[] = { 2005 "powerpc-linux-gnu", "powerpc-unknown-linux-gnu", "powerpc-linux-gnuspe", 2006 "powerpc-suse-linux", "powerpc-montavista-linuxspe"}; 2007 static const char *const PPC64LibDirs[] = {"/lib64", "/lib"}; 2008 static const char *const PPC64Triples[] = { 2009 "powerpc64-linux-gnu", "powerpc64-unknown-linux-gnu", 2010 "powerpc64-suse-linux", "ppc64-redhat-linux"}; 2011 static const char *const PPC64LELibDirs[] = {"/lib64", "/lib"}; 2012 static const char *const PPC64LETriples[] = { 2013 "powerpc64le-linux-gnu", "powerpc64le-unknown-linux-gnu", 2014 "powerpc64le-suse-linux", "ppc64le-redhat-linux"}; 2015 2016 static const char *const RISCV32LibDirs[] = {"/lib32", "/lib"}; 2017 static const char *const RISCV32Triples[] = {"riscv32-unknown-linux-gnu", 2018 "riscv32-linux-gnu", 2019 "riscv32-unknown-elf"}; 2020 static const char *const RISCV64LibDirs[] = {"/lib64", "/lib"}; 2021 static const char *const RISCV64Triples[] = {"riscv64-unknown-linux-gnu", 2022 "riscv64-linux-gnu", 2023 "riscv64-unknown-elf", 2024 "riscv64-suse-linux"}; 2025 2026 static const char *const SPARCv8LibDirs[] = {"/lib32", "/lib"}; 2027 static const char *const SPARCv8Triples[] = {"sparc-linux-gnu", 2028 "sparcv8-linux-gnu"}; 2029 static const char *const SPARCv9LibDirs[] = {"/lib64", "/lib"}; 2030 static const char *const SPARCv9Triples[] = {"sparc64-linux-gnu", 2031 "sparcv9-linux-gnu"}; 2032 2033 static const char *const SystemZLibDirs[] = {"/lib64", "/lib"}; 2034 static const char *const SystemZTriples[] = { 2035 "s390x-linux-gnu", "s390x-unknown-linux-gnu", "s390x-ibm-linux-gnu", 2036 "s390x-suse-linux", "s390x-redhat-linux"}; 2037 2038 2039 using std::begin; 2040 using std::end; 2041 2042 if (TargetTriple.getOS() == llvm::Triple::Solaris) { 2043 static const char *const SolarisLibDirs[] = {"/lib"}; 2044 static const char *const SolarisSparcV8Triples[] = { 2045 "sparc-sun-solaris2.11", "sparc-sun-solaris2.12"}; 2046 static const char *const SolarisSparcV9Triples[] = { 2047 "sparcv9-sun-solaris2.11", "sparcv9-sun-solaris2.12"}; 2048 static const char *const SolarisX86Triples[] = {"i386-pc-solaris2.11", 2049 "i386-pc-solaris2.12"}; 2050 static const char *const SolarisX86_64Triples[] = {"x86_64-pc-solaris2.11", 2051 "x86_64-pc-solaris2.12"}; 2052 LibDirs.append(begin(SolarisLibDirs), end(SolarisLibDirs)); 2053 BiarchLibDirs.append(begin(SolarisLibDirs), end(SolarisLibDirs)); 2054 switch (TargetTriple.getArch()) { 2055 case llvm::Triple::x86: 2056 TripleAliases.append(begin(SolarisX86Triples), end(SolarisX86Triples)); 2057 BiarchTripleAliases.append(begin(SolarisX86_64Triples), 2058 end(SolarisX86_64Triples)); 2059 break; 2060 case llvm::Triple::x86_64: 2061 TripleAliases.append(begin(SolarisX86_64Triples), 2062 end(SolarisX86_64Triples)); 2063 BiarchTripleAliases.append(begin(SolarisX86Triples), 2064 end(SolarisX86Triples)); 2065 break; 2066 case llvm::Triple::sparc: 2067 TripleAliases.append(begin(SolarisSparcV8Triples), 2068 end(SolarisSparcV8Triples)); 2069 BiarchTripleAliases.append(begin(SolarisSparcV9Triples), 2070 end(SolarisSparcV9Triples)); 2071 break; 2072 case llvm::Triple::sparcv9: 2073 TripleAliases.append(begin(SolarisSparcV9Triples), 2074 end(SolarisSparcV9Triples)); 2075 BiarchTripleAliases.append(begin(SolarisSparcV8Triples), 2076 end(SolarisSparcV8Triples)); 2077 break; 2078 default: 2079 break; 2080 } 2081 return; 2082 } 2083 2084 // Android targets should not use GNU/Linux tools or libraries. 2085 if (TargetTriple.isAndroid()) { 2086 static const char *const AArch64AndroidTriples[] = { 2087 "aarch64-linux-android"}; 2088 static const char *const ARMAndroidTriples[] = {"arm-linux-androideabi"}; 2089 static const char *const MIPSELAndroidTriples[] = {"mipsel-linux-android"}; 2090 static const char *const MIPS64ELAndroidTriples[] = { 2091 "mips64el-linux-android"}; 2092 static const char *const X86AndroidTriples[] = {"i686-linux-android"}; 2093 static const char *const X86_64AndroidTriples[] = {"x86_64-linux-android"}; 2094 2095 switch (TargetTriple.getArch()) { 2096 case llvm::Triple::aarch64: 2097 LibDirs.append(begin(AArch64LibDirs), end(AArch64LibDirs)); 2098 TripleAliases.append(begin(AArch64AndroidTriples), 2099 end(AArch64AndroidTriples)); 2100 break; 2101 case llvm::Triple::arm: 2102 case llvm::Triple::thumb: 2103 LibDirs.append(begin(ARMLibDirs), end(ARMLibDirs)); 2104 TripleAliases.append(begin(ARMAndroidTriples), end(ARMAndroidTriples)); 2105 break; 2106 case llvm::Triple::mipsel: 2107 LibDirs.append(begin(MIPSELLibDirs), end(MIPSELLibDirs)); 2108 TripleAliases.append(begin(MIPSELAndroidTriples), 2109 end(MIPSELAndroidTriples)); 2110 BiarchLibDirs.append(begin(MIPS64ELLibDirs), end(MIPS64ELLibDirs)); 2111 BiarchTripleAliases.append(begin(MIPS64ELAndroidTriples), 2112 end(MIPS64ELAndroidTriples)); 2113 break; 2114 case llvm::Triple::mips64el: 2115 LibDirs.append(begin(MIPS64ELLibDirs), end(MIPS64ELLibDirs)); 2116 TripleAliases.append(begin(MIPS64ELAndroidTriples), 2117 end(MIPS64ELAndroidTriples)); 2118 BiarchLibDirs.append(begin(MIPSELLibDirs), end(MIPSELLibDirs)); 2119 BiarchTripleAliases.append(begin(MIPSELAndroidTriples), 2120 end(MIPSELAndroidTriples)); 2121 break; 2122 case llvm::Triple::x86_64: 2123 LibDirs.append(begin(X86_64LibDirs), end(X86_64LibDirs)); 2124 TripleAliases.append(begin(X86_64AndroidTriples), 2125 end(X86_64AndroidTriples)); 2126 BiarchLibDirs.append(begin(X86LibDirs), end(X86LibDirs)); 2127 BiarchTripleAliases.append(begin(X86AndroidTriples), 2128 end(X86AndroidTriples)); 2129 break; 2130 case llvm::Triple::x86: 2131 LibDirs.append(begin(X86LibDirs), end(X86LibDirs)); 2132 TripleAliases.append(begin(X86AndroidTriples), end(X86AndroidTriples)); 2133 BiarchLibDirs.append(begin(X86_64LibDirs), end(X86_64LibDirs)); 2134 BiarchTripleAliases.append(begin(X86_64AndroidTriples), 2135 end(X86_64AndroidTriples)); 2136 break; 2137 default: 2138 break; 2139 } 2140 2141 return; 2142 } 2143 2144 switch (TargetTriple.getArch()) { 2145 case llvm::Triple::aarch64: 2146 LibDirs.append(begin(AArch64LibDirs), end(AArch64LibDirs)); 2147 TripleAliases.append(begin(AArch64Triples), end(AArch64Triples)); 2148 BiarchLibDirs.append(begin(AArch64LibDirs), end(AArch64LibDirs)); 2149 BiarchTripleAliases.append(begin(AArch64Triples), end(AArch64Triples)); 2150 break; 2151 case llvm::Triple::aarch64_be: 2152 LibDirs.append(begin(AArch64beLibDirs), end(AArch64beLibDirs)); 2153 TripleAliases.append(begin(AArch64beTriples), end(AArch64beTriples)); 2154 BiarchLibDirs.append(begin(AArch64beLibDirs), end(AArch64beLibDirs)); 2155 BiarchTripleAliases.append(begin(AArch64beTriples), end(AArch64beTriples)); 2156 break; 2157 case llvm::Triple::arm: 2158 case llvm::Triple::thumb: 2159 LibDirs.append(begin(ARMLibDirs), end(ARMLibDirs)); 2160 if (TargetTriple.getEnvironment() == llvm::Triple::GNUEABIHF) { 2161 TripleAliases.append(begin(ARMHFTriples), end(ARMHFTriples)); 2162 } else { 2163 TripleAliases.append(begin(ARMTriples), end(ARMTriples)); 2164 } 2165 break; 2166 case llvm::Triple::armeb: 2167 case llvm::Triple::thumbeb: 2168 LibDirs.append(begin(ARMebLibDirs), end(ARMebLibDirs)); 2169 if (TargetTriple.getEnvironment() == llvm::Triple::GNUEABIHF) { 2170 TripleAliases.append(begin(ARMebHFTriples), end(ARMebHFTriples)); 2171 } else { 2172 TripleAliases.append(begin(ARMebTriples), end(ARMebTriples)); 2173 } 2174 break; 2175 case llvm::Triple::avr: 2176 LibDirs.append(begin(AVRLibDirs), end(AVRLibDirs)); 2177 TripleAliases.append(begin(AVRTriples), end(AVRTriples)); 2178 break; 2179 case llvm::Triple::x86_64: 2180 LibDirs.append(begin(X86_64LibDirs), end(X86_64LibDirs)); 2181 TripleAliases.append(begin(X86_64Triples), end(X86_64Triples)); 2182 // x32 is always available when x86_64 is available, so adding it as 2183 // secondary arch with x86_64 triples 2184 if (TargetTriple.getEnvironment() == llvm::Triple::GNUX32) { 2185 BiarchLibDirs.append(begin(X32LibDirs), end(X32LibDirs)); 2186 BiarchTripleAliases.append(begin(X86_64Triples), end(X86_64Triples)); 2187 } else { 2188 BiarchLibDirs.append(begin(X86LibDirs), end(X86LibDirs)); 2189 BiarchTripleAliases.append(begin(X86Triples), end(X86Triples)); 2190 } 2191 break; 2192 case llvm::Triple::x86: 2193 LibDirs.append(begin(X86LibDirs), end(X86LibDirs)); 2194 // MCU toolchain is 32 bit only and its triple alias is TargetTriple 2195 // itself, which will be appended below. 2196 if (!TargetTriple.isOSIAMCU()) { 2197 TripleAliases.append(begin(X86Triples), end(X86Triples)); 2198 BiarchLibDirs.append(begin(X86_64LibDirs), end(X86_64LibDirs)); 2199 BiarchTripleAliases.append(begin(X86_64Triples), end(X86_64Triples)); 2200 } 2201 break; 2202 case llvm::Triple::mips: 2203 LibDirs.append(begin(MIPSLibDirs), end(MIPSLibDirs)); 2204 TripleAliases.append(begin(MIPSTriples), end(MIPSTriples)); 2205 BiarchLibDirs.append(begin(MIPS64LibDirs), end(MIPS64LibDirs)); 2206 BiarchTripleAliases.append(begin(MIPS64Triples), end(MIPS64Triples)); 2207 BiarchLibDirs.append(begin(MIPSN32LibDirs), end(MIPSN32LibDirs)); 2208 BiarchTripleAliases.append(begin(MIPSN32Triples), end(MIPSN32Triples)); 2209 break; 2210 case llvm::Triple::mipsel: 2211 LibDirs.append(begin(MIPSELLibDirs), end(MIPSELLibDirs)); 2212 TripleAliases.append(begin(MIPSELTriples), end(MIPSELTriples)); 2213 TripleAliases.append(begin(MIPSTriples), end(MIPSTriples)); 2214 BiarchLibDirs.append(begin(MIPS64ELLibDirs), end(MIPS64ELLibDirs)); 2215 BiarchTripleAliases.append(begin(MIPS64ELTriples), end(MIPS64ELTriples)); 2216 BiarchLibDirs.append(begin(MIPSN32ELLibDirs), end(MIPSN32ELLibDirs)); 2217 BiarchTripleAliases.append(begin(MIPSN32ELTriples), end(MIPSN32ELTriples)); 2218 break; 2219 case llvm::Triple::mips64: 2220 LibDirs.append(begin(MIPS64LibDirs), end(MIPS64LibDirs)); 2221 TripleAliases.append(begin(MIPS64Triples), end(MIPS64Triples)); 2222 BiarchLibDirs.append(begin(MIPSLibDirs), end(MIPSLibDirs)); 2223 BiarchTripleAliases.append(begin(MIPSTriples), end(MIPSTriples)); 2224 BiarchLibDirs.append(begin(MIPSN32LibDirs), end(MIPSN32LibDirs)); 2225 BiarchTripleAliases.append(begin(MIPSN32Triples), end(MIPSN32Triples)); 2226 break; 2227 case llvm::Triple::mips64el: 2228 LibDirs.append(begin(MIPS64ELLibDirs), end(MIPS64ELLibDirs)); 2229 TripleAliases.append(begin(MIPS64ELTriples), end(MIPS64ELTriples)); 2230 BiarchLibDirs.append(begin(MIPSELLibDirs), end(MIPSELLibDirs)); 2231 BiarchTripleAliases.append(begin(MIPSELTriples), end(MIPSELTriples)); 2232 BiarchLibDirs.append(begin(MIPSN32ELLibDirs), end(MIPSN32ELLibDirs)); 2233 BiarchTripleAliases.append(begin(MIPSN32ELTriples), end(MIPSN32ELTriples)); 2234 BiarchTripleAliases.append(begin(MIPSTriples), end(MIPSTriples)); 2235 break; 2236 case llvm::Triple::msp430: 2237 LibDirs.append(begin(MSP430LibDirs), end(MSP430LibDirs)); 2238 TripleAliases.append(begin(MSP430Triples), end(MSP430Triples)); 2239 break; 2240 case llvm::Triple::ppc: 2241 LibDirs.append(begin(PPCLibDirs), end(PPCLibDirs)); 2242 TripleAliases.append(begin(PPCTriples), end(PPCTriples)); 2243 BiarchLibDirs.append(begin(PPC64LibDirs), end(PPC64LibDirs)); 2244 BiarchTripleAliases.append(begin(PPC64Triples), end(PPC64Triples)); 2245 break; 2246 case llvm::Triple::ppc64: 2247 LibDirs.append(begin(PPC64LibDirs), end(PPC64LibDirs)); 2248 TripleAliases.append(begin(PPC64Triples), end(PPC64Triples)); 2249 BiarchLibDirs.append(begin(PPCLibDirs), end(PPCLibDirs)); 2250 BiarchTripleAliases.append(begin(PPCTriples), end(PPCTriples)); 2251 break; 2252 case llvm::Triple::ppc64le: 2253 LibDirs.append(begin(PPC64LELibDirs), end(PPC64LELibDirs)); 2254 TripleAliases.append(begin(PPC64LETriples), end(PPC64LETriples)); 2255 break; 2256 case llvm::Triple::riscv32: 2257 LibDirs.append(begin(RISCV32LibDirs), end(RISCV32LibDirs)); 2258 TripleAliases.append(begin(RISCV32Triples), end(RISCV32Triples)); 2259 BiarchLibDirs.append(begin(RISCV64LibDirs), end(RISCV64LibDirs)); 2260 BiarchTripleAliases.append(begin(RISCV64Triples), end(RISCV64Triples)); 2261 break; 2262 case llvm::Triple::riscv64: 2263 LibDirs.append(begin(RISCV64LibDirs), end(RISCV64LibDirs)); 2264 TripleAliases.append(begin(RISCV64Triples), end(RISCV64Triples)); 2265 BiarchLibDirs.append(begin(RISCV32LibDirs), end(RISCV32LibDirs)); 2266 BiarchTripleAliases.append(begin(RISCV32Triples), end(RISCV32Triples)); 2267 break; 2268 case llvm::Triple::sparc: 2269 case llvm::Triple::sparcel: 2270 LibDirs.append(begin(SPARCv8LibDirs), end(SPARCv8LibDirs)); 2271 TripleAliases.append(begin(SPARCv8Triples), end(SPARCv8Triples)); 2272 BiarchLibDirs.append(begin(SPARCv9LibDirs), end(SPARCv9LibDirs)); 2273 BiarchTripleAliases.append(begin(SPARCv9Triples), end(SPARCv9Triples)); 2274 break; 2275 case llvm::Triple::sparcv9: 2276 LibDirs.append(begin(SPARCv9LibDirs), end(SPARCv9LibDirs)); 2277 TripleAliases.append(begin(SPARCv9Triples), end(SPARCv9Triples)); 2278 BiarchLibDirs.append(begin(SPARCv8LibDirs), end(SPARCv8LibDirs)); 2279 BiarchTripleAliases.append(begin(SPARCv8Triples), end(SPARCv8Triples)); 2280 break; 2281 case llvm::Triple::systemz: 2282 LibDirs.append(begin(SystemZLibDirs), end(SystemZLibDirs)); 2283 TripleAliases.append(begin(SystemZTriples), end(SystemZTriples)); 2284 break; 2285 default: 2286 // By default, just rely on the standard lib directories and the original 2287 // triple. 2288 break; 2289 } 2290 2291 // Always append the drivers target triple to the end, in case it doesn't 2292 // match any of our aliases. 2293 TripleAliases.push_back(TargetTriple.str()); 2294 2295 // Also include the multiarch variant if it's different. 2296 if (TargetTriple.str() != BiarchTriple.str()) 2297 BiarchTripleAliases.push_back(BiarchTriple.str()); 2298 } 2299 2300 bool Generic_GCC::GCCInstallationDetector::ScanGCCForMultilibs( 2301 const llvm::Triple &TargetTriple, const ArgList &Args, 2302 StringRef Path, bool NeedsBiarchSuffix) { 2303 llvm::Triple::ArchType TargetArch = TargetTriple.getArch(); 2304 DetectedMultilibs Detected; 2305 2306 // Android standalone toolchain could have multilibs for ARM and Thumb. 2307 // Debian mips multilibs behave more like the rest of the biarch ones, 2308 // so handle them there 2309 if (isArmOrThumbArch(TargetArch) && TargetTriple.isAndroid()) { 2310 // It should also work without multilibs in a simplified toolchain. 2311 findAndroidArmMultilibs(D, TargetTriple, Path, Args, Detected); 2312 } else if (TargetTriple.isMIPS()) { 2313 if (!findMIPSMultilibs(D, TargetTriple, Path, Args, Detected)) 2314 return false; 2315 } else if (TargetTriple.isRISCV()) { 2316 findRISCVMultilibs(D, TargetTriple, Path, Args, Detected); 2317 } else if (isMSP430(TargetArch)) { 2318 findMSP430Multilibs(D, TargetTriple, Path, Args, Detected); 2319 } else if (TargetArch == llvm::Triple::avr) { 2320 // AVR has no multilibs. 2321 } else if (!findBiarchMultilibs(D, TargetTriple, Path, Args, 2322 NeedsBiarchSuffix, Detected)) { 2323 return false; 2324 } 2325 2326 Multilibs = Detected.Multilibs; 2327 SelectedMultilib = Detected.SelectedMultilib; 2328 BiarchSibling = Detected.BiarchSibling; 2329 2330 return true; 2331 } 2332 2333 void Generic_GCC::GCCInstallationDetector::ScanLibDirForGCCTriple( 2334 const llvm::Triple &TargetTriple, const ArgList &Args, 2335 const std::string &LibDir, StringRef CandidateTriple, 2336 bool NeedsBiarchSuffix) { 2337 llvm::Triple::ArchType TargetArch = TargetTriple.getArch(); 2338 // Locations relative to the system lib directory where GCC's triple-specific 2339 // directories might reside. 2340 struct GCCLibSuffix { 2341 // Path from system lib directory to GCC triple-specific directory. 2342 std::string LibSuffix; 2343 // Path from GCC triple-specific directory back to system lib directory. 2344 // This is one '..' component per component in LibSuffix. 2345 StringRef ReversePath; 2346 // Whether this library suffix is relevant for the triple. 2347 bool Active; 2348 } Suffixes[] = { 2349 // This is the normal place. 2350 {"gcc/" + CandidateTriple.str(), "../..", true}, 2351 2352 // Debian puts cross-compilers in gcc-cross. 2353 {"gcc-cross/" + CandidateTriple.str(), "../..", 2354 TargetTriple.getOS() != llvm::Triple::Solaris}, 2355 2356 // The Freescale PPC SDK has the gcc libraries in 2357 // <sysroot>/usr/lib/<triple>/x.y.z so have a look there as well. Only do 2358 // this on Freescale triples, though, since some systems put a *lot* of 2359 // files in that location, not just GCC installation data. 2360 {CandidateTriple.str(), "..", 2361 TargetTriple.getVendor() == llvm::Triple::Freescale || 2362 TargetTriple.getVendor() == llvm::Triple::OpenEmbedded}, 2363 2364 // Natively multiarch systems sometimes put the GCC triple-specific 2365 // directory within their multiarch lib directory, resulting in the 2366 // triple appearing twice. 2367 {CandidateTriple.str() + "/gcc/" + CandidateTriple.str(), "../../..", 2368 TargetTriple.getOS() != llvm::Triple::Solaris}, 2369 2370 // Deal with cases (on Ubuntu) where the system architecture could be i386 2371 // but the GCC target architecture could be (say) i686. 2372 // FIXME: It may be worthwhile to generalize this and look for a second 2373 // triple. 2374 {"i386-linux-gnu/gcc/" + CandidateTriple.str(), "../../..", 2375 (TargetArch == llvm::Triple::x86 && 2376 TargetTriple.getOS() != llvm::Triple::Solaris)}, 2377 {"i386-gnu/gcc/" + CandidateTriple.str(), "../../..", 2378 (TargetArch == llvm::Triple::x86 && 2379 TargetTriple.getOS() != llvm::Triple::Solaris)}}; 2380 2381 for (auto &Suffix : Suffixes) { 2382 if (!Suffix.Active) 2383 continue; 2384 2385 StringRef LibSuffix = Suffix.LibSuffix; 2386 std::error_code EC; 2387 for (llvm::vfs::directory_iterator 2388 LI = D.getVFS().dir_begin(LibDir + "/" + LibSuffix, EC), 2389 LE; 2390 !EC && LI != LE; LI = LI.increment(EC)) { 2391 StringRef VersionText = llvm::sys::path::filename(LI->path()); 2392 GCCVersion CandidateVersion = GCCVersion::Parse(VersionText); 2393 if (CandidateVersion.Major != -1) // Filter obviously bad entries. 2394 if (!CandidateGCCInstallPaths.insert(LI->path()).second) 2395 continue; // Saw this path before; no need to look at it again. 2396 if (CandidateVersion.isOlderThan(4, 1, 1)) 2397 continue; 2398 if (CandidateVersion <= Version) 2399 continue; 2400 2401 if (!ScanGCCForMultilibs(TargetTriple, Args, LI->path(), 2402 NeedsBiarchSuffix)) 2403 continue; 2404 2405 Version = CandidateVersion; 2406 GCCTriple.setTriple(CandidateTriple); 2407 // FIXME: We hack together the directory name here instead of 2408 // using LI to ensure stable path separators across Windows and 2409 // Linux. 2410 GCCInstallPath = (LibDir + "/" + LibSuffix + "/" + VersionText).str(); 2411 GCCParentLibPath = (GCCInstallPath + "/../" + Suffix.ReversePath).str(); 2412 IsValid = true; 2413 } 2414 } 2415 } 2416 2417 bool Generic_GCC::GCCInstallationDetector::ScanGentooConfigs( 2418 const llvm::Triple &TargetTriple, const ArgList &Args, 2419 const SmallVectorImpl<StringRef> &CandidateTriples, 2420 const SmallVectorImpl<StringRef> &CandidateBiarchTriples) { 2421 for (StringRef CandidateTriple : CandidateTriples) { 2422 if (ScanGentooGccConfig(TargetTriple, Args, CandidateTriple)) 2423 return true; 2424 } 2425 2426 for (StringRef CandidateTriple : CandidateBiarchTriples) { 2427 if (ScanGentooGccConfig(TargetTriple, Args, CandidateTriple, true)) 2428 return true; 2429 } 2430 return false; 2431 } 2432 2433 bool Generic_GCC::GCCInstallationDetector::ScanGentooGccConfig( 2434 const llvm::Triple &TargetTriple, const ArgList &Args, 2435 StringRef CandidateTriple, bool NeedsBiarchSuffix) { 2436 llvm::ErrorOr<std::unique_ptr<llvm::MemoryBuffer>> File = 2437 D.getVFS().getBufferForFile(D.SysRoot + "/etc/env.d/gcc/config-" + 2438 CandidateTriple.str()); 2439 if (File) { 2440 SmallVector<StringRef, 2> Lines; 2441 File.get()->getBuffer().split(Lines, "\n"); 2442 for (StringRef Line : Lines) { 2443 Line = Line.trim(); 2444 // CURRENT=triple-version 2445 if (!Line.consume_front("CURRENT=")) 2446 continue; 2447 // Process the config file pointed to by CURRENT. 2448 llvm::ErrorOr<std::unique_ptr<llvm::MemoryBuffer>> ConfigFile = 2449 D.getVFS().getBufferForFile(D.SysRoot + "/etc/env.d/gcc/" + 2450 Line.str()); 2451 std::pair<StringRef, StringRef> ActiveVersion = Line.rsplit('-'); 2452 // List of paths to scan for libraries. 2453 SmallVector<StringRef, 4> GentooScanPaths; 2454 // Scan the Config file to find installed GCC libraries path. 2455 // Typical content of the GCC config file: 2456 // LDPATH="/usr/lib/gcc/x86_64-pc-linux-gnu/4.9.x:/usr/lib/gcc/ 2457 // (continued from previous line) x86_64-pc-linux-gnu/4.9.x/32" 2458 // MANPATH="/usr/share/gcc-data/x86_64-pc-linux-gnu/4.9.x/man" 2459 // INFOPATH="/usr/share/gcc-data/x86_64-pc-linux-gnu/4.9.x/info" 2460 // STDCXX_INCDIR="/usr/lib/gcc/x86_64-pc-linux-gnu/4.9.x/include/g++-v4" 2461 // We are looking for the paths listed in LDPATH=... . 2462 if (ConfigFile) { 2463 SmallVector<StringRef, 2> ConfigLines; 2464 ConfigFile.get()->getBuffer().split(ConfigLines, "\n"); 2465 for (StringRef ConfLine : ConfigLines) { 2466 ConfLine = ConfLine.trim(); 2467 if (ConfLine.consume_front("LDPATH=")) { 2468 // Drop '"' from front and back if present. 2469 ConfLine.consume_back("\""); 2470 ConfLine.consume_front("\""); 2471 // Get all paths sperated by ':' 2472 ConfLine.split(GentooScanPaths, ':', -1, /*AllowEmpty*/ false); 2473 } 2474 } 2475 } 2476 // Test the path based on the version in /etc/env.d/gcc/config-{tuple}. 2477 std::string basePath = "/usr/lib/gcc/" + ActiveVersion.first.str() + "/" 2478 + ActiveVersion.second.str(); 2479 GentooScanPaths.push_back(StringRef(basePath)); 2480 2481 // Scan all paths for GCC libraries. 2482 for (const auto &GentooScanPath : GentooScanPaths) { 2483 std::string GentooPath = D.SysRoot + std::string(GentooScanPath); 2484 if (D.getVFS().exists(GentooPath + "/crtbegin.o")) { 2485 if (!ScanGCCForMultilibs(TargetTriple, Args, GentooPath, 2486 NeedsBiarchSuffix)) 2487 continue; 2488 2489 Version = GCCVersion::Parse(ActiveVersion.second); 2490 GCCInstallPath = GentooPath; 2491 GCCParentLibPath = GentooPath + std::string("/../../.."); 2492 GCCTriple.setTriple(ActiveVersion.first); 2493 IsValid = true; 2494 return true; 2495 } 2496 } 2497 } 2498 } 2499 2500 return false; 2501 } 2502 2503 Generic_GCC::Generic_GCC(const Driver &D, const llvm::Triple &Triple, 2504 const ArgList &Args) 2505 : ToolChain(D, Triple, Args), GCCInstallation(D), 2506 CudaInstallation(D, Triple, Args) { 2507 getProgramPaths().push_back(getDriver().getInstalledDir()); 2508 if (getDriver().getInstalledDir() != getDriver().Dir) 2509 getProgramPaths().push_back(getDriver().Dir); 2510 } 2511 2512 Generic_GCC::~Generic_GCC() {} 2513 2514 Tool *Generic_GCC::getTool(Action::ActionClass AC) const { 2515 switch (AC) { 2516 case Action::PreprocessJobClass: 2517 if (!Preprocess) 2518 Preprocess.reset(new clang::driver::tools::gcc::Preprocessor(*this)); 2519 return Preprocess.get(); 2520 case Action::CompileJobClass: 2521 if (!Compile) 2522 Compile.reset(new tools::gcc::Compiler(*this)); 2523 return Compile.get(); 2524 default: 2525 return ToolChain::getTool(AC); 2526 } 2527 } 2528 2529 Tool *Generic_GCC::buildAssembler() const { 2530 return new tools::gnutools::Assembler(*this); 2531 } 2532 2533 Tool *Generic_GCC::buildLinker() const { return new tools::gcc::Linker(*this); } 2534 2535 void Generic_GCC::printVerboseInfo(raw_ostream &OS) const { 2536 // Print the information about how we detected the GCC installation. 2537 GCCInstallation.print(OS); 2538 CudaInstallation.print(OS); 2539 } 2540 2541 bool Generic_GCC::IsUnwindTablesDefault(const ArgList &Args) const { 2542 return getArch() == llvm::Triple::x86_64; 2543 } 2544 2545 bool Generic_GCC::isPICDefault() const { 2546 switch (getArch()) { 2547 case llvm::Triple::x86_64: 2548 return getTriple().isOSWindows(); 2549 case llvm::Triple::ppc64: 2550 // Big endian PPC is PIC by default 2551 return !getTriple().isOSBinFormatMachO() && !getTriple().isMacOSX(); 2552 case llvm::Triple::mips64: 2553 case llvm::Triple::mips64el: 2554 return true; 2555 default: 2556 return false; 2557 } 2558 } 2559 2560 bool Generic_GCC::isPIEDefault() const { return false; } 2561 2562 bool Generic_GCC::isPICDefaultForced() const { 2563 return getArch() == llvm::Triple::x86_64 && getTriple().isOSWindows(); 2564 } 2565 2566 bool Generic_GCC::IsIntegratedAssemblerDefault() const { 2567 switch (getTriple().getArch()) { 2568 case llvm::Triple::x86: 2569 case llvm::Triple::x86_64: 2570 case llvm::Triple::aarch64: 2571 case llvm::Triple::aarch64_be: 2572 case llvm::Triple::arm: 2573 case llvm::Triple::armeb: 2574 case llvm::Triple::avr: 2575 case llvm::Triple::bpfel: 2576 case llvm::Triple::bpfeb: 2577 case llvm::Triple::thumb: 2578 case llvm::Triple::thumbeb: 2579 case llvm::Triple::ppc: 2580 case llvm::Triple::ppc64: 2581 case llvm::Triple::ppc64le: 2582 case llvm::Triple::riscv32: 2583 case llvm::Triple::riscv64: 2584 case llvm::Triple::systemz: 2585 case llvm::Triple::mips: 2586 case llvm::Triple::mipsel: 2587 case llvm::Triple::mips64: 2588 case llvm::Triple::mips64el: 2589 case llvm::Triple::msp430: 2590 return true; 2591 case llvm::Triple::sparc: 2592 case llvm::Triple::sparcel: 2593 case llvm::Triple::sparcv9: 2594 if (getTriple().isOSFreeBSD() || getTriple().isOSOpenBSD() || 2595 getTriple().isOSSolaris()) 2596 return true; 2597 return false; 2598 default: 2599 return false; 2600 } 2601 } 2602 2603 void Generic_GCC::AddClangCXXStdlibIncludeArgs(const ArgList &DriverArgs, 2604 ArgStringList &CC1Args) const { 2605 if (DriverArgs.hasArg(options::OPT_nostdlibinc) || 2606 DriverArgs.hasArg(options::OPT_nostdincxx)) 2607 return; 2608 2609 switch (GetCXXStdlibType(DriverArgs)) { 2610 case ToolChain::CST_Libcxx: 2611 addLibCxxIncludePaths(DriverArgs, CC1Args); 2612 break; 2613 2614 case ToolChain::CST_Libstdcxx: 2615 addLibStdCxxIncludePaths(DriverArgs, CC1Args); 2616 break; 2617 } 2618 } 2619 2620 void 2621 Generic_GCC::addLibCxxIncludePaths(const llvm::opt::ArgList &DriverArgs, 2622 llvm::opt::ArgStringList &CC1Args) const { 2623 // FIXME: The Linux behavior would probaby be a better approach here. 2624 addSystemInclude(DriverArgs, CC1Args, 2625 getDriver().SysRoot + "/usr/include/c++/v1"); 2626 } 2627 2628 void 2629 Generic_GCC::addLibStdCxxIncludePaths(const llvm::opt::ArgList &DriverArgs, 2630 llvm::opt::ArgStringList &CC1Args) const { 2631 // By default, we don't assume we know where libstdc++ might be installed. 2632 // FIXME: If we have a valid GCCInstallation, use it. 2633 } 2634 2635 /// Helper to add the variant paths of a libstdc++ installation. 2636 bool Generic_GCC::addLibStdCXXIncludePaths( 2637 Twine Base, Twine Suffix, StringRef GCCTriple, StringRef GCCMultiarchTriple, 2638 StringRef TargetMultiarchTriple, Twine IncludeSuffix, 2639 const ArgList &DriverArgs, ArgStringList &CC1Args) const { 2640 if (!getVFS().exists(Base + Suffix)) 2641 return false; 2642 2643 addSystemInclude(DriverArgs, CC1Args, Base + Suffix); 2644 2645 // The vanilla GCC layout of libstdc++ headers uses a triple subdirectory. If 2646 // that path exists or we have neither a GCC nor target multiarch triple, use 2647 // this vanilla search path. 2648 if ((GCCMultiarchTriple.empty() && TargetMultiarchTriple.empty()) || 2649 getVFS().exists(Base + Suffix + "/" + GCCTriple + IncludeSuffix)) { 2650 addSystemInclude(DriverArgs, CC1Args, 2651 Base + Suffix + "/" + GCCTriple + IncludeSuffix); 2652 } else { 2653 // Otherwise try to use multiarch naming schemes which have normalized the 2654 // triples and put the triple before the suffix. 2655 // 2656 // GCC surprisingly uses *both* the GCC triple with a multilib suffix and 2657 // the target triple, so we support that here. 2658 addSystemInclude(DriverArgs, CC1Args, 2659 Base + "/" + GCCMultiarchTriple + Suffix + IncludeSuffix); 2660 addSystemInclude(DriverArgs, CC1Args, 2661 Base + "/" + TargetMultiarchTriple + Suffix); 2662 } 2663 2664 addSystemInclude(DriverArgs, CC1Args, Base + Suffix + "/backward"); 2665 return true; 2666 } 2667 2668 llvm::opt::DerivedArgList * 2669 Generic_GCC::TranslateArgs(const llvm::opt::DerivedArgList &Args, StringRef, 2670 Action::OffloadKind DeviceOffloadKind) const { 2671 2672 // If this tool chain is used for an OpenMP offloading device we have to make 2673 // sure we always generate a shared library regardless of the commands the 2674 // user passed to the host. This is required because the runtime library 2675 // is required to load the device image dynamically at run time. 2676 if (DeviceOffloadKind == Action::OFK_OpenMP) { 2677 DerivedArgList *DAL = new DerivedArgList(Args.getBaseArgs()); 2678 const OptTable &Opts = getDriver().getOpts(); 2679 2680 // Request the shared library. Given that these options are decided 2681 // implicitly, they do not refer to any base argument. 2682 DAL->AddFlagArg(/*BaseArg=*/nullptr, Opts.getOption(options::OPT_shared)); 2683 DAL->AddFlagArg(/*BaseArg=*/nullptr, Opts.getOption(options::OPT_fPIC)); 2684 2685 // Filter all the arguments we don't care passing to the offloading 2686 // toolchain as they can mess up with the creation of a shared library. 2687 for (auto *A : Args) { 2688 switch ((options::ID)A->getOption().getID()) { 2689 default: 2690 DAL->append(A); 2691 break; 2692 case options::OPT_shared: 2693 case options::OPT_dynamic: 2694 case options::OPT_static: 2695 case options::OPT_fPIC: 2696 case options::OPT_fno_PIC: 2697 case options::OPT_fpic: 2698 case options::OPT_fno_pic: 2699 case options::OPT_fPIE: 2700 case options::OPT_fno_PIE: 2701 case options::OPT_fpie: 2702 case options::OPT_fno_pie: 2703 break; 2704 } 2705 } 2706 return DAL; 2707 } 2708 return nullptr; 2709 } 2710 2711 void Generic_ELF::anchor() {} 2712 2713 void Generic_ELF::addClangTargetOptions(const ArgList &DriverArgs, 2714 ArgStringList &CC1Args, 2715 Action::OffloadKind) const { 2716 const Generic_GCC::GCCVersion &V = GCCInstallation.getVersion(); 2717 bool UseInitArrayDefault = 2718 getTriple().getArch() == llvm::Triple::aarch64 || 2719 getTriple().getArch() == llvm::Triple::aarch64_be || 2720 (getTriple().isOSFreeBSD() && 2721 getTriple().getOSMajorVersion() >= 12) || 2722 (getTriple().getOS() == llvm::Triple::Linux && 2723 ((!GCCInstallation.isValid() || !V.isOlderThan(4, 7, 0)) || 2724 getTriple().isAndroid())) || 2725 getTriple().getOS() == llvm::Triple::NaCl || 2726 (getTriple().getVendor() == llvm::Triple::MipsTechnologies && 2727 !getTriple().hasEnvironment()) || 2728 getTriple().getOS() == llvm::Triple::Solaris || 2729 getTriple().getArch() == llvm::Triple::riscv32 || 2730 getTriple().getArch() == llvm::Triple::riscv64; 2731 2732 if (DriverArgs.hasFlag(options::OPT_fuse_init_array, 2733 options::OPT_fno_use_init_array, UseInitArrayDefault)) 2734 CC1Args.push_back("-fuse-init-array"); 2735 } 2736