1 //===--- Driver.cpp - Clang GCC Compatible Driver -------------------------===// 2 // 3 // The LLVM Compiler Infrastructure 4 // 5 // This file is distributed under the University of Illinois Open Source 6 // License. See LICENSE.TXT for details. 7 // 8 //===----------------------------------------------------------------------===// 9 10 #include "clang/Driver/Driver.h" 11 #include "InputInfo.h" 12 #include "ToolChains.h" 13 #include "clang/Basic/Version.h" 14 #include "clang/Basic/VirtualFileSystem.h" 15 #include "clang/Config/config.h" 16 #include "clang/Driver/Action.h" 17 #include "clang/Driver/Compilation.h" 18 #include "clang/Driver/DriverDiagnostic.h" 19 #include "clang/Driver/Job.h" 20 #include "clang/Driver/Options.h" 21 #include "clang/Driver/SanitizerArgs.h" 22 #include "clang/Driver/Tool.h" 23 #include "clang/Driver/ToolChain.h" 24 #include "llvm/ADT/ArrayRef.h" 25 #include "llvm/ADT/STLExtras.h" 26 #include "llvm/ADT/StringExtras.h" 27 #include "llvm/ADT/StringSet.h" 28 #include "llvm/ADT/StringSwitch.h" 29 #include "llvm/Option/Arg.h" 30 #include "llvm/Option/ArgList.h" 31 #include "llvm/Option/OptSpecifier.h" 32 #include "llvm/Option/OptTable.h" 33 #include "llvm/Option/Option.h" 34 #include "llvm/Support/Debug.h" 35 #include "llvm/Support/ErrorHandling.h" 36 #include "llvm/Support/FileSystem.h" 37 #include "llvm/Support/Path.h" 38 #include "llvm/Support/PrettyStackTrace.h" 39 #include "llvm/Support/Process.h" 40 #include "llvm/Support/Program.h" 41 #include "llvm/Support/raw_ostream.h" 42 #include <map> 43 #include <memory> 44 45 using namespace clang::driver; 46 using namespace clang; 47 using namespace llvm::opt; 48 49 Driver::Driver(StringRef ClangExecutable, StringRef DefaultTargetTriple, 50 DiagnosticsEngine &Diags, 51 IntrusiveRefCntPtr<vfs::FileSystem> VFS) 52 : Opts(createDriverOptTable()), Diags(Diags), VFS(VFS), Mode(GCCMode), 53 SaveTemps(SaveTempsNone), BitcodeEmbed(EmbedNone), LTOMode(LTOK_None), 54 ClangExecutable(ClangExecutable), 55 SysRoot(DEFAULT_SYSROOT), UseStdLib(true), 56 DefaultTargetTriple(DefaultTargetTriple), 57 DriverTitle("clang LLVM compiler"), CCPrintOptionsFilename(nullptr), 58 CCPrintHeadersFilename(nullptr), CCLogDiagnosticsFilename(nullptr), 59 CCCPrintBindings(false), CCPrintHeaders(false), CCLogDiagnostics(false), 60 CCGenDiagnostics(false), CCCGenericGCCName(""), CheckInputsExist(true), 61 CCCUsePCH(true), SuppressMissingInputWarning(false) { 62 63 // Provide a sane fallback if no VFS is specified. 64 if (!this->VFS) 65 this->VFS = vfs::getRealFileSystem(); 66 67 Name = llvm::sys::path::filename(ClangExecutable); 68 Dir = llvm::sys::path::parent_path(ClangExecutable); 69 InstalledDir = Dir; // Provide a sensible default installed dir. 70 71 // Compute the path to the resource directory. 72 StringRef ClangResourceDir(CLANG_RESOURCE_DIR); 73 SmallString<128> P(Dir); 74 if (ClangResourceDir != "") { 75 llvm::sys::path::append(P, ClangResourceDir); 76 } else { 77 StringRef ClangLibdirSuffix(CLANG_LIBDIR_SUFFIX); 78 llvm::sys::path::append(P, "..", Twine("lib") + ClangLibdirSuffix, "clang", 79 CLANG_VERSION_STRING); 80 } 81 ResourceDir = P.str(); 82 } 83 84 Driver::~Driver() { 85 delete Opts; 86 87 llvm::DeleteContainerSeconds(ToolChains); 88 } 89 90 void Driver::ParseDriverMode(ArrayRef<const char *> Args) { 91 const std::string OptName = 92 getOpts().getOption(options::OPT_driver_mode).getPrefixedName(); 93 94 for (const char *ArgPtr : Args) { 95 // Ingore nullptrs, they are response file's EOL markers 96 if (ArgPtr == nullptr) 97 continue; 98 const StringRef Arg = ArgPtr; 99 if (!Arg.startswith(OptName)) 100 continue; 101 102 const StringRef Value = Arg.drop_front(OptName.size()); 103 const unsigned M = llvm::StringSwitch<unsigned>(Value) 104 .Case("gcc", GCCMode) 105 .Case("g++", GXXMode) 106 .Case("cpp", CPPMode) 107 .Case("cl", CLMode) 108 .Default(~0U); 109 110 if (M != ~0U) 111 Mode = static_cast<DriverMode>(M); 112 else 113 Diag(diag::err_drv_unsupported_option_argument) << OptName << Value; 114 } 115 } 116 117 InputArgList Driver::ParseArgStrings(ArrayRef<const char *> ArgStrings) { 118 llvm::PrettyStackTraceString CrashInfo("Command line argument parsing"); 119 120 unsigned IncludedFlagsBitmask; 121 unsigned ExcludedFlagsBitmask; 122 std::tie(IncludedFlagsBitmask, ExcludedFlagsBitmask) = 123 getIncludeExcludeOptionFlagMasks(); 124 125 unsigned MissingArgIndex, MissingArgCount; 126 InputArgList Args = 127 getOpts().ParseArgs(ArgStrings, MissingArgIndex, MissingArgCount, 128 IncludedFlagsBitmask, ExcludedFlagsBitmask); 129 130 // Check for missing argument error. 131 if (MissingArgCount) 132 Diag(clang::diag::err_drv_missing_argument) 133 << Args.getArgString(MissingArgIndex) << MissingArgCount; 134 135 // Check for unsupported options. 136 for (const Arg *A : Args) { 137 if (A->getOption().hasFlag(options::Unsupported)) { 138 Diag(clang::diag::err_drv_unsupported_opt) << A->getAsString(Args); 139 continue; 140 } 141 142 // Warn about -mcpu= without an argument. 143 if (A->getOption().matches(options::OPT_mcpu_EQ) && A->containsValue("")) { 144 Diag(clang::diag::warn_drv_empty_joined_argument) << A->getAsString(Args); 145 } 146 } 147 148 for (const Arg *A : Args.filtered(options::OPT_UNKNOWN)) 149 Diags.Report(IsCLMode() ? diag::warn_drv_unknown_argument_clang_cl : 150 diag::err_drv_unknown_argument) 151 << A->getAsString(Args); 152 153 return Args; 154 } 155 156 // Determine which compilation mode we are in. We look for options which 157 // affect the phase, starting with the earliest phases, and record which 158 // option we used to determine the final phase. 159 phases::ID Driver::getFinalPhase(const DerivedArgList &DAL, 160 Arg **FinalPhaseArg) const { 161 Arg *PhaseArg = nullptr; 162 phases::ID FinalPhase; 163 164 // -{E,EP,P,M,MM} only run the preprocessor. 165 if (CCCIsCPP() || (PhaseArg = DAL.getLastArg(options::OPT_E)) || 166 (PhaseArg = DAL.getLastArg(options::OPT__SLASH_EP)) || 167 (PhaseArg = DAL.getLastArg(options::OPT_M, options::OPT_MM)) || 168 (PhaseArg = DAL.getLastArg(options::OPT__SLASH_P))) { 169 FinalPhase = phases::Preprocess; 170 171 // -{fsyntax-only,-analyze,emit-ast} only run up to the compiler. 172 } else if ((PhaseArg = DAL.getLastArg(options::OPT_fsyntax_only)) || 173 (PhaseArg = DAL.getLastArg(options::OPT_module_file_info)) || 174 (PhaseArg = DAL.getLastArg(options::OPT_verify_pch)) || 175 (PhaseArg = DAL.getLastArg(options::OPT_rewrite_objc)) || 176 (PhaseArg = DAL.getLastArg(options::OPT_rewrite_legacy_objc)) || 177 (PhaseArg = DAL.getLastArg(options::OPT__migrate)) || 178 (PhaseArg = DAL.getLastArg(options::OPT__analyze, 179 options::OPT__analyze_auto)) || 180 (PhaseArg = DAL.getLastArg(options::OPT_emit_ast))) { 181 FinalPhase = phases::Compile; 182 183 // -S only runs up to the backend. 184 } else if ((PhaseArg = DAL.getLastArg(options::OPT_S))) { 185 FinalPhase = phases::Backend; 186 187 // -c compilation only runs up to the assembler. 188 } else if ((PhaseArg = DAL.getLastArg(options::OPT_c))) { 189 FinalPhase = phases::Assemble; 190 191 // Otherwise do everything. 192 } else 193 FinalPhase = phases::Link; 194 195 if (FinalPhaseArg) 196 *FinalPhaseArg = PhaseArg; 197 198 return FinalPhase; 199 } 200 201 static Arg *MakeInputArg(DerivedArgList &Args, OptTable *Opts, 202 StringRef Value) { 203 Arg *A = new Arg(Opts->getOption(options::OPT_INPUT), Value, 204 Args.getBaseArgs().MakeIndex(Value), Value.data()); 205 Args.AddSynthesizedArg(A); 206 A->claim(); 207 return A; 208 } 209 210 DerivedArgList *Driver::TranslateInputArgs(const InputArgList &Args) const { 211 DerivedArgList *DAL = new DerivedArgList(Args); 212 213 bool HasNostdlib = Args.hasArg(options::OPT_nostdlib); 214 bool HasNodefaultlib = Args.hasArg(options::OPT_nodefaultlibs); 215 for (Arg *A : Args) { 216 // Unfortunately, we have to parse some forwarding options (-Xassembler, 217 // -Xlinker, -Xpreprocessor) because we either integrate their functionality 218 // (assembler and preprocessor), or bypass a previous driver ('collect2'). 219 220 // Rewrite linker options, to replace --no-demangle with a custom internal 221 // option. 222 if ((A->getOption().matches(options::OPT_Wl_COMMA) || 223 A->getOption().matches(options::OPT_Xlinker)) && 224 A->containsValue("--no-demangle")) { 225 // Add the rewritten no-demangle argument. 226 DAL->AddFlagArg(A, Opts->getOption(options::OPT_Z_Xlinker__no_demangle)); 227 228 // Add the remaining values as Xlinker arguments. 229 for (StringRef Val : A->getValues()) 230 if (Val != "--no-demangle") 231 DAL->AddSeparateArg(A, Opts->getOption(options::OPT_Xlinker), Val); 232 233 continue; 234 } 235 236 // Rewrite preprocessor options, to replace -Wp,-MD,FOO which is used by 237 // some build systems. We don't try to be complete here because we don't 238 // care to encourage this usage model. 239 if (A->getOption().matches(options::OPT_Wp_COMMA) && 240 (A->getValue(0) == StringRef("-MD") || 241 A->getValue(0) == StringRef("-MMD"))) { 242 // Rewrite to -MD/-MMD along with -MF. 243 if (A->getValue(0) == StringRef("-MD")) 244 DAL->AddFlagArg(A, Opts->getOption(options::OPT_MD)); 245 else 246 DAL->AddFlagArg(A, Opts->getOption(options::OPT_MMD)); 247 if (A->getNumValues() == 2) 248 DAL->AddSeparateArg(A, Opts->getOption(options::OPT_MF), 249 A->getValue(1)); 250 continue; 251 } 252 253 // Rewrite reserved library names. 254 if (A->getOption().matches(options::OPT_l)) { 255 StringRef Value = A->getValue(); 256 257 // Rewrite unless -nostdlib is present. 258 if (!HasNostdlib && !HasNodefaultlib && Value == "stdc++") { 259 DAL->AddFlagArg(A, Opts->getOption(options::OPT_Z_reserved_lib_stdcxx)); 260 continue; 261 } 262 263 // Rewrite unconditionally. 264 if (Value == "cc_kext") { 265 DAL->AddFlagArg(A, Opts->getOption(options::OPT_Z_reserved_lib_cckext)); 266 continue; 267 } 268 } 269 270 // Pick up inputs via the -- option. 271 if (A->getOption().matches(options::OPT__DASH_DASH)) { 272 A->claim(); 273 for (StringRef Val : A->getValues()) 274 DAL->append(MakeInputArg(*DAL, Opts, Val)); 275 continue; 276 } 277 278 DAL->append(A); 279 } 280 281 // Enforce -static if -miamcu is present. 282 if (Args.hasArg(options::OPT_miamcu)) 283 DAL->AddFlagArg(0, Opts->getOption(options::OPT_static)); 284 285 // Add a default value of -mlinker-version=, if one was given and the user 286 // didn't specify one. 287 #if defined(HOST_LINK_VERSION) 288 if (!Args.hasArg(options::OPT_mlinker_version_EQ) && 289 strlen(HOST_LINK_VERSION) > 0) { 290 DAL->AddJoinedArg(0, Opts->getOption(options::OPT_mlinker_version_EQ), 291 HOST_LINK_VERSION); 292 DAL->getLastArg(options::OPT_mlinker_version_EQ)->claim(); 293 } 294 #endif 295 296 return DAL; 297 } 298 299 /// \brief Compute target triple from args. 300 /// 301 /// This routine provides the logic to compute a target triple from various 302 /// args passed to the driver and the default triple string. 303 static llvm::Triple computeTargetTriple(const Driver &D, 304 StringRef DefaultTargetTriple, 305 const ArgList &Args, 306 StringRef DarwinArchName = "") { 307 // FIXME: Already done in Compilation *Driver::BuildCompilation 308 if (const Arg *A = Args.getLastArg(options::OPT_target)) 309 DefaultTargetTriple = A->getValue(); 310 311 llvm::Triple Target(llvm::Triple::normalize(DefaultTargetTriple)); 312 313 // Handle Apple-specific options available here. 314 if (Target.isOSBinFormatMachO()) { 315 // If an explict Darwin arch name is given, that trumps all. 316 if (!DarwinArchName.empty()) { 317 tools::darwin::setTripleTypeForMachOArchName(Target, DarwinArchName); 318 return Target; 319 } 320 321 // Handle the Darwin '-arch' flag. 322 if (Arg *A = Args.getLastArg(options::OPT_arch)) { 323 StringRef ArchName = A->getValue(); 324 tools::darwin::setTripleTypeForMachOArchName(Target, ArchName); 325 } 326 } 327 328 // Handle pseudo-target flags '-mlittle-endian'/'-EL' and 329 // '-mbig-endian'/'-EB'. 330 if (Arg *A = Args.getLastArg(options::OPT_mlittle_endian, 331 options::OPT_mbig_endian)) { 332 if (A->getOption().matches(options::OPT_mlittle_endian)) { 333 llvm::Triple LE = Target.getLittleEndianArchVariant(); 334 if (LE.getArch() != llvm::Triple::UnknownArch) 335 Target = std::move(LE); 336 } else { 337 llvm::Triple BE = Target.getBigEndianArchVariant(); 338 if (BE.getArch() != llvm::Triple::UnknownArch) 339 Target = std::move(BE); 340 } 341 } 342 343 // Skip further flag support on OSes which don't support '-m32' or '-m64'. 344 if (Target.getArch() == llvm::Triple::tce || 345 Target.getOS() == llvm::Triple::Minix) 346 return Target; 347 348 // Handle pseudo-target flags '-m64', '-mx32', '-m32' and '-m16'. 349 Arg *A = Args.getLastArg(options::OPT_m64, options::OPT_mx32, 350 options::OPT_m32, options::OPT_m16); 351 if (A) { 352 llvm::Triple::ArchType AT = llvm::Triple::UnknownArch; 353 354 if (A->getOption().matches(options::OPT_m64)) { 355 AT = Target.get64BitArchVariant().getArch(); 356 if (Target.getEnvironment() == llvm::Triple::GNUX32) 357 Target.setEnvironment(llvm::Triple::GNU); 358 } else if (A->getOption().matches(options::OPT_mx32) && 359 Target.get64BitArchVariant().getArch() == llvm::Triple::x86_64) { 360 AT = llvm::Triple::x86_64; 361 Target.setEnvironment(llvm::Triple::GNUX32); 362 } else if (A->getOption().matches(options::OPT_m32)) { 363 AT = Target.get32BitArchVariant().getArch(); 364 if (Target.getEnvironment() == llvm::Triple::GNUX32) 365 Target.setEnvironment(llvm::Triple::GNU); 366 } else if (A->getOption().matches(options::OPT_m16) && 367 Target.get32BitArchVariant().getArch() == llvm::Triple::x86) { 368 AT = llvm::Triple::x86; 369 Target.setEnvironment(llvm::Triple::CODE16); 370 } 371 372 if (AT != llvm::Triple::UnknownArch && AT != Target.getArch()) 373 Target.setArch(AT); 374 } 375 376 // Handle -miamcu flag. 377 if (Args.hasArg(options::OPT_miamcu)) { 378 if (Target.get32BitArchVariant().getArch() != llvm::Triple::x86) 379 D.Diag(diag::err_drv_unsupported_opt_for_target) << "-miamcu" 380 << Target.str(); 381 382 if (A && !A->getOption().matches(options::OPT_m32)) 383 D.Diag(diag::err_drv_argument_not_allowed_with) 384 << "-miamcu" << A->getBaseArg().getAsString(Args); 385 386 Target.setArch(llvm::Triple::x86); 387 Target.setArchName("i586"); 388 Target.setEnvironment(llvm::Triple::UnknownEnvironment); 389 Target.setEnvironmentName(""); 390 Target.setOS(llvm::Triple::ELFIAMCU); 391 Target.setVendor(llvm::Triple::UnknownVendor); 392 Target.setVendorName("intel"); 393 } 394 395 return Target; 396 } 397 398 // \brief Parse the LTO options and record the type of LTO compilation 399 // based on which -f(no-)?lto(=.*)? option occurs last. 400 void Driver::setLTOMode(const llvm::opt::ArgList &Args) { 401 LTOMode = LTOK_None; 402 if (!Args.hasFlag(options::OPT_flto, options::OPT_flto_EQ, 403 options::OPT_fno_lto, false)) 404 return; 405 406 StringRef LTOName("full"); 407 408 const Arg *A = Args.getLastArg(options::OPT_flto_EQ); 409 if (A) 410 LTOName = A->getValue(); 411 412 LTOMode = llvm::StringSwitch<LTOKind>(LTOName) 413 .Case("full", LTOK_Full) 414 .Case("thin", LTOK_Thin) 415 .Default(LTOK_Unknown); 416 417 if (LTOMode == LTOK_Unknown) { 418 assert(A); 419 Diag(diag::err_drv_unsupported_option_argument) << A->getOption().getName() 420 << A->getValue(); 421 } 422 } 423 424 Compilation *Driver::BuildCompilation(ArrayRef<const char *> ArgList) { 425 llvm::PrettyStackTraceString CrashInfo("Compilation construction"); 426 427 // FIXME: Handle environment options which affect driver behavior, somewhere 428 // (client?). GCC_EXEC_PREFIX, LPATH, CC_PRINT_OPTIONS. 429 430 if (char *env = ::getenv("COMPILER_PATH")) { 431 StringRef CompilerPath = env; 432 while (!CompilerPath.empty()) { 433 std::pair<StringRef, StringRef> Split = 434 CompilerPath.split(llvm::sys::EnvPathSeparator); 435 PrefixDirs.push_back(Split.first); 436 CompilerPath = Split.second; 437 } 438 } 439 440 // We look for the driver mode option early, because the mode can affect 441 // how other options are parsed. 442 ParseDriverMode(ArgList.slice(1)); 443 444 // FIXME: What are we going to do with -V and -b? 445 446 // FIXME: This stuff needs to go into the Compilation, not the driver. 447 bool CCCPrintPhases; 448 449 InputArgList Args = ParseArgStrings(ArgList.slice(1)); 450 451 // Silence driver warnings if requested 452 Diags.setIgnoreAllWarnings(Args.hasArg(options::OPT_w)); 453 454 // -no-canonical-prefixes is used very early in main. 455 Args.ClaimAllArgs(options::OPT_no_canonical_prefixes); 456 457 // Ignore -pipe. 458 Args.ClaimAllArgs(options::OPT_pipe); 459 460 // Extract -ccc args. 461 // 462 // FIXME: We need to figure out where this behavior should live. Most of it 463 // should be outside in the client; the parts that aren't should have proper 464 // options, either by introducing new ones or by overloading gcc ones like -V 465 // or -b. 466 CCCPrintPhases = Args.hasArg(options::OPT_ccc_print_phases); 467 CCCPrintBindings = Args.hasArg(options::OPT_ccc_print_bindings); 468 if (const Arg *A = Args.getLastArg(options::OPT_ccc_gcc_name)) 469 CCCGenericGCCName = A->getValue(); 470 CCCUsePCH = 471 Args.hasFlag(options::OPT_ccc_pch_is_pch, options::OPT_ccc_pch_is_pth); 472 // FIXME: DefaultTargetTriple is used by the target-prefixed calls to as/ld 473 // and getToolChain is const. 474 if (IsCLMode()) { 475 // clang-cl targets MSVC-style Win32. 476 llvm::Triple T(DefaultTargetTriple); 477 T.setOS(llvm::Triple::Win32); 478 T.setVendor(llvm::Triple::PC); 479 T.setEnvironment(llvm::Triple::MSVC); 480 DefaultTargetTriple = T.str(); 481 } 482 if (const Arg *A = Args.getLastArg(options::OPT_target)) 483 DefaultTargetTriple = A->getValue(); 484 if (const Arg *A = Args.getLastArg(options::OPT_ccc_install_dir)) 485 Dir = InstalledDir = A->getValue(); 486 for (const Arg *A : Args.filtered(options::OPT_B)) { 487 A->claim(); 488 PrefixDirs.push_back(A->getValue(0)); 489 } 490 if (const Arg *A = Args.getLastArg(options::OPT__sysroot_EQ)) 491 SysRoot = A->getValue(); 492 if (const Arg *A = Args.getLastArg(options::OPT__dyld_prefix_EQ)) 493 DyldPrefix = A->getValue(); 494 if (Args.hasArg(options::OPT_nostdlib)) 495 UseStdLib = false; 496 497 if (const Arg *A = Args.getLastArg(options::OPT_resource_dir)) 498 ResourceDir = A->getValue(); 499 500 if (const Arg *A = Args.getLastArg(options::OPT_save_temps_EQ)) { 501 SaveTemps = llvm::StringSwitch<SaveTempsMode>(A->getValue()) 502 .Case("cwd", SaveTempsCwd) 503 .Case("obj", SaveTempsObj) 504 .Default(SaveTempsCwd); 505 } 506 507 // Ignore -fembed-bitcode options with LTO 508 // since the output will be bitcode anyway. 509 if (!Args.hasFlag(options::OPT_flto, options::OPT_fno_lto, false)) { 510 if (Args.hasArg(options::OPT_fembed_bitcode)) 511 BitcodeEmbed = EmbedBitcode; 512 else if (Args.hasArg(options::OPT_fembed_bitcode_marker)) 513 BitcodeEmbed = EmbedMarker; 514 } else { 515 // claim the bitcode option under LTO so no warning is issued. 516 Args.ClaimAllArgs(options::OPT_fembed_bitcode); 517 Args.ClaimAllArgs(options::OPT_fembed_bitcode_marker); 518 } 519 520 setLTOMode(Args); 521 522 std::unique_ptr<llvm::opt::InputArgList> UArgs = 523 llvm::make_unique<InputArgList>(std::move(Args)); 524 525 // Perform the default argument translations. 526 DerivedArgList *TranslatedArgs = TranslateInputArgs(*UArgs); 527 528 // Owned by the host. 529 const ToolChain &TC = getToolChain( 530 *UArgs, computeTargetTriple(*this, DefaultTargetTriple, *UArgs)); 531 532 // The compilation takes ownership of Args. 533 Compilation *C = new Compilation(*this, TC, UArgs.release(), TranslatedArgs); 534 535 if (!HandleImmediateArgs(*C)) 536 return C; 537 538 // Construct the list of inputs. 539 InputList Inputs; 540 BuildInputs(C->getDefaultToolChain(), *TranslatedArgs, Inputs); 541 542 // Initialize the CUDA device TC only if we have any CUDA Inputs. This is 543 // necessary so that we don't break compilations that pass flags that are 544 // incompatible with the NVPTX TC (e.g. -mthread-model single). 545 if (llvm::any_of(Inputs, [](const std::pair<types::ID, const Arg *> &I) { 546 return I.first == types::TY_CUDA || I.first == types::TY_PP_CUDA || 547 I.first == types::TY_CUDA_DEVICE; 548 })) { 549 C->setCudaDeviceToolChain( 550 &getToolChain(C->getArgs(), llvm::Triple(TC.getTriple().isArch64Bit() 551 ? "nvptx64-nvidia-cuda" 552 : "nvptx-nvidia-cuda"))); 553 } 554 555 // Construct the list of abstract actions to perform for this compilation. On 556 // MachO targets this uses the driver-driver and universal actions. 557 if (TC.getTriple().isOSBinFormatMachO()) 558 BuildUniversalActions(*C, C->getDefaultToolChain(), Inputs); 559 else 560 BuildActions(*C, C->getArgs(), Inputs, C->getActions()); 561 562 if (CCCPrintPhases) { 563 PrintActions(*C); 564 return C; 565 } 566 567 BuildJobs(*C); 568 569 return C; 570 } 571 572 static void printArgList(raw_ostream &OS, const llvm::opt::ArgList &Args) { 573 llvm::opt::ArgStringList ASL; 574 for (const auto *A : Args) 575 A->render(Args, ASL); 576 577 for (auto I = ASL.begin(), E = ASL.end(); I != E; ++I) { 578 if (I != ASL.begin()) 579 OS << ' '; 580 Command::printArg(OS, *I, true); 581 } 582 OS << '\n'; 583 } 584 585 // When clang crashes, produce diagnostic information including the fully 586 // preprocessed source file(s). Request that the developer attach the 587 // diagnostic information to a bug report. 588 void Driver::generateCompilationDiagnostics(Compilation &C, 589 const Command &FailingCommand) { 590 if (C.getArgs().hasArg(options::OPT_fno_crash_diagnostics)) 591 return; 592 593 // Don't try to generate diagnostics for link or dsymutil jobs. 594 if (FailingCommand.getCreator().isLinkJob() || 595 FailingCommand.getCreator().isDsymutilJob()) 596 return; 597 598 // Print the version of the compiler. 599 PrintVersion(C, llvm::errs()); 600 601 Diag(clang::diag::note_drv_command_failed_diag_msg) 602 << "PLEASE submit a bug report to " BUG_REPORT_URL " and include the " 603 "crash backtrace, preprocessed source, and associated run script."; 604 605 // Suppress driver output and emit preprocessor output to temp file. 606 Mode = CPPMode; 607 CCGenDiagnostics = true; 608 609 // Save the original job command(s). 610 Command Cmd = FailingCommand; 611 612 // Keep track of whether we produce any errors while trying to produce 613 // preprocessed sources. 614 DiagnosticErrorTrap Trap(Diags); 615 616 // Suppress tool output. 617 C.initCompilationForDiagnostics(); 618 619 // Construct the list of inputs. 620 InputList Inputs; 621 BuildInputs(C.getDefaultToolChain(), C.getArgs(), Inputs); 622 623 for (InputList::iterator it = Inputs.begin(), ie = Inputs.end(); it != ie;) { 624 bool IgnoreInput = false; 625 626 // Ignore input from stdin or any inputs that cannot be preprocessed. 627 // Check type first as not all linker inputs have a value. 628 if (types::getPreprocessedType(it->first) == types::TY_INVALID) { 629 IgnoreInput = true; 630 } else if (!strcmp(it->second->getValue(), "-")) { 631 Diag(clang::diag::note_drv_command_failed_diag_msg) 632 << "Error generating preprocessed source(s) - " 633 "ignoring input from stdin."; 634 IgnoreInput = true; 635 } 636 637 if (IgnoreInput) { 638 it = Inputs.erase(it); 639 ie = Inputs.end(); 640 } else { 641 ++it; 642 } 643 } 644 645 if (Inputs.empty()) { 646 Diag(clang::diag::note_drv_command_failed_diag_msg) 647 << "Error generating preprocessed source(s) - " 648 "no preprocessable inputs."; 649 return; 650 } 651 652 // Don't attempt to generate preprocessed files if multiple -arch options are 653 // used, unless they're all duplicates. 654 llvm::StringSet<> ArchNames; 655 for (const Arg *A : C.getArgs()) { 656 if (A->getOption().matches(options::OPT_arch)) { 657 StringRef ArchName = A->getValue(); 658 ArchNames.insert(ArchName); 659 } 660 } 661 if (ArchNames.size() > 1) { 662 Diag(clang::diag::note_drv_command_failed_diag_msg) 663 << "Error generating preprocessed source(s) - cannot generate " 664 "preprocessed source with multiple -arch options."; 665 return; 666 } 667 668 // Construct the list of abstract actions to perform for this compilation. On 669 // Darwin OSes this uses the driver-driver and builds universal actions. 670 const ToolChain &TC = C.getDefaultToolChain(); 671 if (TC.getTriple().isOSBinFormatMachO()) 672 BuildUniversalActions(C, TC, Inputs); 673 else 674 BuildActions(C, C.getArgs(), Inputs, C.getActions()); 675 676 BuildJobs(C); 677 678 // If there were errors building the compilation, quit now. 679 if (Trap.hasErrorOccurred()) { 680 Diag(clang::diag::note_drv_command_failed_diag_msg) 681 << "Error generating preprocessed source(s)."; 682 return; 683 } 684 685 // Generate preprocessed output. 686 SmallVector<std::pair<int, const Command *>, 4> FailingCommands; 687 C.ExecuteJobs(C.getJobs(), FailingCommands); 688 689 // If any of the preprocessing commands failed, clean up and exit. 690 if (!FailingCommands.empty()) { 691 if (!isSaveTempsEnabled()) 692 C.CleanupFileList(C.getTempFiles(), true); 693 694 Diag(clang::diag::note_drv_command_failed_diag_msg) 695 << "Error generating preprocessed source(s)."; 696 return; 697 } 698 699 const ArgStringList &TempFiles = C.getTempFiles(); 700 if (TempFiles.empty()) { 701 Diag(clang::diag::note_drv_command_failed_diag_msg) 702 << "Error generating preprocessed source(s)."; 703 return; 704 } 705 706 Diag(clang::diag::note_drv_command_failed_diag_msg) 707 << "\n********************\n\n" 708 "PLEASE ATTACH THE FOLLOWING FILES TO THE BUG REPORT:\n" 709 "Preprocessed source(s) and associated run script(s) are located at:"; 710 711 SmallString<128> VFS; 712 for (const char *TempFile : TempFiles) { 713 Diag(clang::diag::note_drv_command_failed_diag_msg) << TempFile; 714 if (StringRef(TempFile).endswith(".cache")) { 715 // In some cases (modules) we'll dump extra data to help with reproducing 716 // the crash into a directory next to the output. 717 VFS = llvm::sys::path::filename(TempFile); 718 llvm::sys::path::append(VFS, "vfs", "vfs.yaml"); 719 } 720 } 721 722 // Assume associated files are based off of the first temporary file. 723 CrashReportInfo CrashInfo(TempFiles[0], VFS); 724 725 std::string Script = CrashInfo.Filename.rsplit('.').first.str() + ".sh"; 726 std::error_code EC; 727 llvm::raw_fd_ostream ScriptOS(Script, EC, llvm::sys::fs::F_Excl); 728 if (EC) { 729 Diag(clang::diag::note_drv_command_failed_diag_msg) 730 << "Error generating run script: " + Script + " " + EC.message(); 731 } else { 732 ScriptOS << "# Crash reproducer for " << getClangFullVersion() << "\n" 733 << "# Driver args: "; 734 printArgList(ScriptOS, C.getInputArgs()); 735 ScriptOS << "# Original command: "; 736 Cmd.Print(ScriptOS, "\n", /*Quote=*/true); 737 Cmd.Print(ScriptOS, "\n", /*Quote=*/true, &CrashInfo); 738 Diag(clang::diag::note_drv_command_failed_diag_msg) << Script; 739 } 740 741 for (const auto &A : C.getArgs().filtered(options::OPT_frewrite_map_file, 742 options::OPT_frewrite_map_file_EQ)) 743 Diag(clang::diag::note_drv_command_failed_diag_msg) << A->getValue(); 744 745 Diag(clang::diag::note_drv_command_failed_diag_msg) 746 << "\n\n********************"; 747 } 748 749 void Driver::setUpResponseFiles(Compilation &C, Command &Cmd) { 750 // Since commandLineFitsWithinSystemLimits() may underestimate system's capacity 751 // if the tool does not support response files, there is a chance/ that things 752 // will just work without a response file, so we silently just skip it. 753 if (Cmd.getCreator().getResponseFilesSupport() == Tool::RF_None || 754 llvm::sys::commandLineFitsWithinSystemLimits(Cmd.getExecutable(), Cmd.getArguments())) 755 return; 756 757 std::string TmpName = GetTemporaryPath("response", "txt"); 758 Cmd.setResponseFile( 759 C.addTempFile(C.getArgs().MakeArgString(TmpName.c_str()))); 760 } 761 762 int Driver::ExecuteCompilation( 763 Compilation &C, 764 SmallVectorImpl<std::pair<int, const Command *>> &FailingCommands) { 765 // Just print if -### was present. 766 if (C.getArgs().hasArg(options::OPT__HASH_HASH_HASH)) { 767 C.getJobs().Print(llvm::errs(), "\n", true); 768 return 0; 769 } 770 771 // If there were errors building the compilation, quit now. 772 if (Diags.hasErrorOccurred()) 773 return 1; 774 775 // Set up response file names for each command, if necessary 776 for (auto &Job : C.getJobs()) 777 setUpResponseFiles(C, Job); 778 779 C.ExecuteJobs(C.getJobs(), FailingCommands); 780 781 // Remove temp files. 782 C.CleanupFileList(C.getTempFiles()); 783 784 // If the command succeeded, we are done. 785 if (FailingCommands.empty()) 786 return 0; 787 788 // Otherwise, remove result files and print extra information about abnormal 789 // failures. 790 for (const auto &CmdPair : FailingCommands) { 791 int Res = CmdPair.first; 792 const Command *FailingCommand = CmdPair.second; 793 794 // Remove result files if we're not saving temps. 795 if (!isSaveTempsEnabled()) { 796 const JobAction *JA = cast<JobAction>(&FailingCommand->getSource()); 797 C.CleanupFileMap(C.getResultFiles(), JA, true); 798 799 // Failure result files are valid unless we crashed. 800 if (Res < 0) 801 C.CleanupFileMap(C.getFailureResultFiles(), JA, true); 802 } 803 804 // Print extra information about abnormal failures, if possible. 805 // 806 // This is ad-hoc, but we don't want to be excessively noisy. If the result 807 // status was 1, assume the command failed normally. In particular, if it 808 // was the compiler then assume it gave a reasonable error code. Failures 809 // in other tools are less common, and they generally have worse 810 // diagnostics, so always print the diagnostic there. 811 const Tool &FailingTool = FailingCommand->getCreator(); 812 813 if (!FailingCommand->getCreator().hasGoodDiagnostics() || Res != 1) { 814 // FIXME: See FIXME above regarding result code interpretation. 815 if (Res < 0) 816 Diag(clang::diag::err_drv_command_signalled) 817 << FailingTool.getShortName(); 818 else 819 Diag(clang::diag::err_drv_command_failed) << FailingTool.getShortName() 820 << Res; 821 } 822 } 823 return 0; 824 } 825 826 void Driver::PrintHelp(bool ShowHidden) const { 827 unsigned IncludedFlagsBitmask; 828 unsigned ExcludedFlagsBitmask; 829 std::tie(IncludedFlagsBitmask, ExcludedFlagsBitmask) = 830 getIncludeExcludeOptionFlagMasks(); 831 832 ExcludedFlagsBitmask |= options::NoDriverOption; 833 if (!ShowHidden) 834 ExcludedFlagsBitmask |= HelpHidden; 835 836 getOpts().PrintHelp(llvm::outs(), Name.c_str(), DriverTitle.c_str(), 837 IncludedFlagsBitmask, ExcludedFlagsBitmask); 838 } 839 840 void Driver::PrintVersion(const Compilation &C, raw_ostream &OS) const { 841 // FIXME: The following handlers should use a callback mechanism, we don't 842 // know what the client would like to do. 843 OS << getClangFullVersion() << '\n'; 844 const ToolChain &TC = C.getDefaultToolChain(); 845 OS << "Target: " << TC.getTripleString() << '\n'; 846 847 // Print the threading model. 848 if (Arg *A = C.getArgs().getLastArg(options::OPT_mthread_model)) { 849 // Don't print if the ToolChain would have barfed on it already 850 if (TC.isThreadModelSupported(A->getValue())) 851 OS << "Thread model: " << A->getValue(); 852 } else 853 OS << "Thread model: " << TC.getThreadModel(); 854 OS << '\n'; 855 856 // Print out the install directory. 857 OS << "InstalledDir: " << InstalledDir << '\n'; 858 } 859 860 /// PrintDiagnosticCategories - Implement the --print-diagnostic-categories 861 /// option. 862 static void PrintDiagnosticCategories(raw_ostream &OS) { 863 // Skip the empty category. 864 for (unsigned i = 1, max = DiagnosticIDs::getNumberOfCategories(); i != max; 865 ++i) 866 OS << i << ',' << DiagnosticIDs::getCategoryNameFromID(i) << '\n'; 867 } 868 869 bool Driver::HandleImmediateArgs(const Compilation &C) { 870 // The order these options are handled in gcc is all over the place, but we 871 // don't expect inconsistencies w.r.t. that to matter in practice. 872 873 if (C.getArgs().hasArg(options::OPT_dumpmachine)) { 874 llvm::outs() << C.getDefaultToolChain().getTripleString() << '\n'; 875 return false; 876 } 877 878 if (C.getArgs().hasArg(options::OPT_dumpversion)) { 879 // Since -dumpversion is only implemented for pedantic GCC compatibility, we 880 // return an answer which matches our definition of __VERSION__. 881 // 882 // If we want to return a more correct answer some day, then we should 883 // introduce a non-pedantically GCC compatible mode to Clang in which we 884 // provide sensible definitions for -dumpversion, __VERSION__, etc. 885 llvm::outs() << "4.2.1\n"; 886 return false; 887 } 888 889 if (C.getArgs().hasArg(options::OPT__print_diagnostic_categories)) { 890 PrintDiagnosticCategories(llvm::outs()); 891 return false; 892 } 893 894 if (C.getArgs().hasArg(options::OPT_help) || 895 C.getArgs().hasArg(options::OPT__help_hidden)) { 896 PrintHelp(C.getArgs().hasArg(options::OPT__help_hidden)); 897 return false; 898 } 899 900 if (C.getArgs().hasArg(options::OPT__version)) { 901 // Follow gcc behavior and use stdout for --version and stderr for -v. 902 PrintVersion(C, llvm::outs()); 903 return false; 904 } 905 906 if (C.getArgs().hasArg(options::OPT_v) || 907 C.getArgs().hasArg(options::OPT__HASH_HASH_HASH)) { 908 PrintVersion(C, llvm::errs()); 909 SuppressMissingInputWarning = true; 910 } 911 912 const ToolChain &TC = C.getDefaultToolChain(); 913 914 if (C.getArgs().hasArg(options::OPT_v)) 915 TC.printVerboseInfo(llvm::errs()); 916 917 if (C.getArgs().hasArg(options::OPT_print_search_dirs)) { 918 llvm::outs() << "programs: ="; 919 bool separator = false; 920 for (const std::string &Path : TC.getProgramPaths()) { 921 if (separator) 922 llvm::outs() << ':'; 923 llvm::outs() << Path; 924 separator = true; 925 } 926 llvm::outs() << "\n"; 927 llvm::outs() << "libraries: =" << ResourceDir; 928 929 StringRef sysroot = C.getSysRoot(); 930 931 for (const std::string &Path : TC.getFilePaths()) { 932 // Always print a separator. ResourceDir was the first item shown. 933 llvm::outs() << ':'; 934 // Interpretation of leading '=' is needed only for NetBSD. 935 if (Path[0] == '=') 936 llvm::outs() << sysroot << Path.substr(1); 937 else 938 llvm::outs() << Path; 939 } 940 llvm::outs() << "\n"; 941 return false; 942 } 943 944 // FIXME: The following handlers should use a callback mechanism, we don't 945 // know what the client would like to do. 946 if (Arg *A = C.getArgs().getLastArg(options::OPT_print_file_name_EQ)) { 947 llvm::outs() << GetFilePath(A->getValue(), TC) << "\n"; 948 return false; 949 } 950 951 if (Arg *A = C.getArgs().getLastArg(options::OPT_print_prog_name_EQ)) { 952 llvm::outs() << GetProgramPath(A->getValue(), TC) << "\n"; 953 return false; 954 } 955 956 if (C.getArgs().hasArg(options::OPT_print_libgcc_file_name)) { 957 llvm::outs() << GetFilePath("libgcc.a", TC) << "\n"; 958 return false; 959 } 960 961 if (C.getArgs().hasArg(options::OPT_print_multi_lib)) { 962 for (const Multilib &Multilib : TC.getMultilibs()) 963 llvm::outs() << Multilib << "\n"; 964 return false; 965 } 966 967 if (C.getArgs().hasArg(options::OPT_print_multi_directory)) { 968 for (const Multilib &Multilib : TC.getMultilibs()) { 969 if (Multilib.gccSuffix().empty()) 970 llvm::outs() << ".\n"; 971 else { 972 StringRef Suffix(Multilib.gccSuffix()); 973 assert(Suffix.front() == '/'); 974 llvm::outs() << Suffix.substr(1) << "\n"; 975 } 976 } 977 return false; 978 } 979 return true; 980 } 981 982 // Display an action graph human-readably. Action A is the "sink" node 983 // and latest-occuring action. Traversal is in pre-order, visiting the 984 // inputs to each action before printing the action itself. 985 static unsigned PrintActions1(const Compilation &C, Action *A, 986 std::map<Action *, unsigned> &Ids) { 987 if (Ids.count(A)) // A was already visited. 988 return Ids[A]; 989 990 std::string str; 991 llvm::raw_string_ostream os(str); 992 993 os << Action::getClassName(A->getKind()) << ", "; 994 if (InputAction *IA = dyn_cast<InputAction>(A)) { 995 os << "\"" << IA->getInputArg().getValue() << "\""; 996 } else if (BindArchAction *BIA = dyn_cast<BindArchAction>(A)) { 997 os << '"' << BIA->getArchName() << '"' << ", {" 998 << PrintActions1(C, *BIA->input_begin(), Ids) << "}"; 999 } else if (CudaDeviceAction *CDA = dyn_cast<CudaDeviceAction>(A)) { 1000 os << '"' 1001 << (CDA->getGpuArchName() ? CDA->getGpuArchName() : "(multiple archs)") 1002 << '"' << ", {" << PrintActions1(C, *CDA->input_begin(), Ids) << "}"; 1003 } else { 1004 const ActionList *AL; 1005 if (CudaHostAction *CHA = dyn_cast<CudaHostAction>(A)) { 1006 os << "{" << PrintActions1(C, *CHA->input_begin(), Ids) << "}" 1007 << ", gpu binaries "; 1008 AL = &CHA->getDeviceActions(); 1009 } else 1010 AL = &A->getInputs(); 1011 1012 if (AL->size()) { 1013 const char *Prefix = "{"; 1014 for (Action *PreRequisite : *AL) { 1015 os << Prefix << PrintActions1(C, PreRequisite, Ids); 1016 Prefix = ", "; 1017 } 1018 os << "}"; 1019 } else 1020 os << "{}"; 1021 } 1022 1023 unsigned Id = Ids.size(); 1024 Ids[A] = Id; 1025 llvm::errs() << Id << ": " << os.str() << ", " 1026 << types::getTypeName(A->getType()) << "\n"; 1027 1028 return Id; 1029 } 1030 1031 // Print the action graphs in a compilation C. 1032 // For example "clang -c file1.c file2.c" is composed of two subgraphs. 1033 void Driver::PrintActions(const Compilation &C) const { 1034 std::map<Action *, unsigned> Ids; 1035 for (Action *A : C.getActions()) 1036 PrintActions1(C, A, Ids); 1037 } 1038 1039 /// \brief Check whether the given input tree contains any compilation or 1040 /// assembly actions. 1041 static bool ContainsCompileOrAssembleAction(const Action *A) { 1042 if (isa<CompileJobAction>(A) || isa<BackendJobAction>(A) || 1043 isa<AssembleJobAction>(A)) 1044 return true; 1045 1046 for (const Action *Input : A->inputs()) 1047 if (ContainsCompileOrAssembleAction(Input)) 1048 return true; 1049 1050 return false; 1051 } 1052 1053 void Driver::BuildUniversalActions(Compilation &C, const ToolChain &TC, 1054 const InputList &BAInputs) const { 1055 DerivedArgList &Args = C.getArgs(); 1056 ActionList &Actions = C.getActions(); 1057 llvm::PrettyStackTraceString CrashInfo("Building universal build actions"); 1058 // Collect the list of architectures. Duplicates are allowed, but should only 1059 // be handled once (in the order seen). 1060 llvm::StringSet<> ArchNames; 1061 SmallVector<const char *, 4> Archs; 1062 for (Arg *A : Args) { 1063 if (A->getOption().matches(options::OPT_arch)) { 1064 // Validate the option here; we don't save the type here because its 1065 // particular spelling may participate in other driver choices. 1066 llvm::Triple::ArchType Arch = 1067 tools::darwin::getArchTypeForMachOArchName(A->getValue()); 1068 if (Arch == llvm::Triple::UnknownArch) { 1069 Diag(clang::diag::err_drv_invalid_arch_name) << A->getAsString(Args); 1070 continue; 1071 } 1072 1073 A->claim(); 1074 if (ArchNames.insert(A->getValue()).second) 1075 Archs.push_back(A->getValue()); 1076 } 1077 } 1078 1079 // When there is no explicit arch for this platform, make sure we still bind 1080 // the architecture (to the default) so that -Xarch_ is handled correctly. 1081 if (!Archs.size()) 1082 Archs.push_back(Args.MakeArgString(TC.getDefaultUniversalArchName())); 1083 1084 ActionList SingleActions; 1085 BuildActions(C, Args, BAInputs, SingleActions); 1086 1087 // Add in arch bindings for every top level action, as well as lipo and 1088 // dsymutil steps if needed. 1089 for (Action* Act : SingleActions) { 1090 // Make sure we can lipo this kind of output. If not (and it is an actual 1091 // output) then we disallow, since we can't create an output file with the 1092 // right name without overwriting it. We could remove this oddity by just 1093 // changing the output names to include the arch, which would also fix 1094 // -save-temps. Compatibility wins for now. 1095 1096 if (Archs.size() > 1 && !types::canLipoType(Act->getType())) 1097 Diag(clang::diag::err_drv_invalid_output_with_multiple_archs) 1098 << types::getTypeName(Act->getType()); 1099 1100 ActionList Inputs; 1101 for (unsigned i = 0, e = Archs.size(); i != e; ++i) 1102 Inputs.push_back(C.MakeAction<BindArchAction>(Act, Archs[i])); 1103 1104 // Lipo if necessary, we do it this way because we need to set the arch flag 1105 // so that -Xarch_ gets overwritten. 1106 if (Inputs.size() == 1 || Act->getType() == types::TY_Nothing) 1107 Actions.append(Inputs.begin(), Inputs.end()); 1108 else 1109 Actions.push_back(C.MakeAction<LipoJobAction>(Inputs, Act->getType())); 1110 1111 // Handle debug info queries. 1112 Arg *A = Args.getLastArg(options::OPT_g_Group); 1113 if (A && !A->getOption().matches(options::OPT_g0) && 1114 !A->getOption().matches(options::OPT_gstabs) && 1115 ContainsCompileOrAssembleAction(Actions.back())) { 1116 1117 // Add a 'dsymutil' step if necessary, when debug info is enabled and we 1118 // have a compile input. We need to run 'dsymutil' ourselves in such cases 1119 // because the debug info will refer to a temporary object file which 1120 // will be removed at the end of the compilation process. 1121 if (Act->getType() == types::TY_Image) { 1122 ActionList Inputs; 1123 Inputs.push_back(Actions.back()); 1124 Actions.pop_back(); 1125 Actions.push_back( 1126 C.MakeAction<DsymutilJobAction>(Inputs, types::TY_dSYM)); 1127 } 1128 1129 // Verify the debug info output. 1130 if (Args.hasArg(options::OPT_verify_debug_info)) { 1131 Action* LastAction = Actions.back(); 1132 Actions.pop_back(); 1133 Actions.push_back(C.MakeAction<VerifyDebugInfoJobAction>( 1134 LastAction, types::TY_Nothing)); 1135 } 1136 } 1137 } 1138 } 1139 1140 /// \brief Check that the file referenced by Value exists. If it doesn't, 1141 /// issue a diagnostic and return false. 1142 static bool DiagnoseInputExistence(const Driver &D, const DerivedArgList &Args, 1143 StringRef Value, types::ID Ty) { 1144 if (!D.getCheckInputsExist()) 1145 return true; 1146 1147 // stdin always exists. 1148 if (Value == "-") 1149 return true; 1150 1151 SmallString<64> Path(Value); 1152 if (Arg *WorkDir = Args.getLastArg(options::OPT_working_directory)) { 1153 if (!llvm::sys::path::is_absolute(Path)) { 1154 SmallString<64> Directory(WorkDir->getValue()); 1155 llvm::sys::path::append(Directory, Value); 1156 Path.assign(Directory); 1157 } 1158 } 1159 1160 if (llvm::sys::fs::exists(Twine(Path))) 1161 return true; 1162 1163 if (D.IsCLMode()) { 1164 if (!llvm::sys::path::is_absolute(Twine(Path)) && 1165 llvm::sys::Process::FindInEnvPath("LIB", Value)) 1166 return true; 1167 1168 if (Args.hasArg(options::OPT__SLASH_link) && Ty == types::TY_Object) { 1169 // Arguments to the /link flag might cause the linker to search for object 1170 // and library files in paths we don't know about. Don't error in such 1171 // cases. 1172 return true; 1173 } 1174 } 1175 1176 D.Diag(clang::diag::err_drv_no_such_file) << Path; 1177 return false; 1178 } 1179 1180 // Construct a the list of inputs and their types. 1181 void Driver::BuildInputs(const ToolChain &TC, DerivedArgList &Args, 1182 InputList &Inputs) const { 1183 // Track the current user specified (-x) input. We also explicitly track the 1184 // argument used to set the type; we only want to claim the type when we 1185 // actually use it, so we warn about unused -x arguments. 1186 types::ID InputType = types::TY_Nothing; 1187 Arg *InputTypeArg = nullptr; 1188 1189 // The last /TC or /TP option sets the input type to C or C++ globally. 1190 if (Arg *TCTP = Args.getLastArgNoClaim(options::OPT__SLASH_TC, 1191 options::OPT__SLASH_TP)) { 1192 InputTypeArg = TCTP; 1193 InputType = TCTP->getOption().matches(options::OPT__SLASH_TC) 1194 ? types::TY_C 1195 : types::TY_CXX; 1196 1197 arg_iterator it = 1198 Args.filtered_begin(options::OPT__SLASH_TC, options::OPT__SLASH_TP); 1199 const arg_iterator ie = Args.filtered_end(); 1200 Arg *Previous = *it++; 1201 bool ShowNote = false; 1202 while (it != ie) { 1203 Diag(clang::diag::warn_drv_overriding_flag_option) 1204 << Previous->getSpelling() << (*it)->getSpelling(); 1205 Previous = *it++; 1206 ShowNote = true; 1207 } 1208 if (ShowNote) 1209 Diag(clang::diag::note_drv_t_option_is_global); 1210 1211 // No driver mode exposes -x and /TC or /TP; we don't support mixing them. 1212 assert(!Args.hasArg(options::OPT_x) && "-x and /TC or /TP is not allowed"); 1213 } 1214 1215 for (Arg *A : Args) { 1216 if (A->getOption().getKind() == Option::InputClass) { 1217 const char *Value = A->getValue(); 1218 types::ID Ty = types::TY_INVALID; 1219 1220 // Infer the input type if necessary. 1221 if (InputType == types::TY_Nothing) { 1222 // If there was an explicit arg for this, claim it. 1223 if (InputTypeArg) 1224 InputTypeArg->claim(); 1225 1226 // stdin must be handled specially. 1227 if (memcmp(Value, "-", 2) == 0) { 1228 // If running with -E, treat as a C input (this changes the builtin 1229 // macros, for example). This may be overridden by -ObjC below. 1230 // 1231 // Otherwise emit an error but still use a valid type to avoid 1232 // spurious errors (e.g., no inputs). 1233 if (!Args.hasArgNoClaim(options::OPT_E) && !CCCIsCPP()) 1234 Diag(IsCLMode() ? clang::diag::err_drv_unknown_stdin_type_clang_cl 1235 : clang::diag::err_drv_unknown_stdin_type); 1236 Ty = types::TY_C; 1237 } else { 1238 // Otherwise lookup by extension. 1239 // Fallback is C if invoked as C preprocessor or Object otherwise. 1240 // We use a host hook here because Darwin at least has its own 1241 // idea of what .s is. 1242 if (const char *Ext = strrchr(Value, '.')) 1243 Ty = TC.LookupTypeForExtension(Ext + 1); 1244 1245 if (Ty == types::TY_INVALID) { 1246 if (CCCIsCPP()) 1247 Ty = types::TY_C; 1248 else 1249 Ty = types::TY_Object; 1250 } 1251 1252 // If the driver is invoked as C++ compiler (like clang++ or c++) it 1253 // should autodetect some input files as C++ for g++ compatibility. 1254 if (CCCIsCXX()) { 1255 types::ID OldTy = Ty; 1256 Ty = types::lookupCXXTypeForCType(Ty); 1257 1258 if (Ty != OldTy) 1259 Diag(clang::diag::warn_drv_treating_input_as_cxx) 1260 << getTypeName(OldTy) << getTypeName(Ty); 1261 } 1262 } 1263 1264 // -ObjC and -ObjC++ override the default language, but only for "source 1265 // files". We just treat everything that isn't a linker input as a 1266 // source file. 1267 // 1268 // FIXME: Clean this up if we move the phase sequence into the type. 1269 if (Ty != types::TY_Object) { 1270 if (Args.hasArg(options::OPT_ObjC)) 1271 Ty = types::TY_ObjC; 1272 else if (Args.hasArg(options::OPT_ObjCXX)) 1273 Ty = types::TY_ObjCXX; 1274 } 1275 } else { 1276 assert(InputTypeArg && "InputType set w/o InputTypeArg"); 1277 if (!InputTypeArg->getOption().matches(options::OPT_x)) { 1278 // If emulating cl.exe, make sure that /TC and /TP don't affect input 1279 // object files. 1280 const char *Ext = strrchr(Value, '.'); 1281 if (Ext && TC.LookupTypeForExtension(Ext + 1) == types::TY_Object) 1282 Ty = types::TY_Object; 1283 } 1284 if (Ty == types::TY_INVALID) { 1285 Ty = InputType; 1286 InputTypeArg->claim(); 1287 } 1288 } 1289 1290 if (DiagnoseInputExistence(*this, Args, Value, Ty)) 1291 Inputs.push_back(std::make_pair(Ty, A)); 1292 1293 } else if (A->getOption().matches(options::OPT__SLASH_Tc)) { 1294 StringRef Value = A->getValue(); 1295 if (DiagnoseInputExistence(*this, Args, Value, types::TY_C)) { 1296 Arg *InputArg = MakeInputArg(Args, Opts, A->getValue()); 1297 Inputs.push_back(std::make_pair(types::TY_C, InputArg)); 1298 } 1299 A->claim(); 1300 } else if (A->getOption().matches(options::OPT__SLASH_Tp)) { 1301 StringRef Value = A->getValue(); 1302 if (DiagnoseInputExistence(*this, Args, Value, types::TY_CXX)) { 1303 Arg *InputArg = MakeInputArg(Args, Opts, A->getValue()); 1304 Inputs.push_back(std::make_pair(types::TY_CXX, InputArg)); 1305 } 1306 A->claim(); 1307 } else if (A->getOption().hasFlag(options::LinkerInput)) { 1308 // Just treat as object type, we could make a special type for this if 1309 // necessary. 1310 Inputs.push_back(std::make_pair(types::TY_Object, A)); 1311 1312 } else if (A->getOption().matches(options::OPT_x)) { 1313 InputTypeArg = A; 1314 InputType = types::lookupTypeForTypeSpecifier(A->getValue()); 1315 A->claim(); 1316 1317 // Follow gcc behavior and treat as linker input for invalid -x 1318 // options. Its not clear why we shouldn't just revert to unknown; but 1319 // this isn't very important, we might as well be bug compatible. 1320 if (!InputType) { 1321 Diag(clang::diag::err_drv_unknown_language) << A->getValue(); 1322 InputType = types::TY_Object; 1323 } 1324 } 1325 } 1326 if (CCCIsCPP() && Inputs.empty()) { 1327 // If called as standalone preprocessor, stdin is processed 1328 // if no other input is present. 1329 Arg *A = MakeInputArg(Args, Opts, "-"); 1330 Inputs.push_back(std::make_pair(types::TY_C, A)); 1331 } 1332 } 1333 1334 // For each unique --cuda-gpu-arch= argument creates a TY_CUDA_DEVICE 1335 // input action and then wraps each in CudaDeviceAction paired with 1336 // appropriate GPU arch name. In case of partial (i.e preprocessing 1337 // only) or device-only compilation, each device action is added to /p 1338 // Actions and /p Current is released. Otherwise the function creates 1339 // and returns a new CudaHostAction which wraps /p Current and device 1340 // side actions. 1341 static Action *buildCudaActions(Compilation &C, DerivedArgList &Args, 1342 const Arg *InputArg, Action *HostAction, 1343 ActionList &Actions) { 1344 Arg *PartialCompilationArg = Args.getLastArg( 1345 options::OPT_cuda_host_only, options::OPT_cuda_device_only, 1346 options::OPT_cuda_compile_host_device); 1347 bool CompileHostOnly = 1348 PartialCompilationArg && 1349 PartialCompilationArg->getOption().matches(options::OPT_cuda_host_only); 1350 bool CompileDeviceOnly = 1351 PartialCompilationArg && 1352 PartialCompilationArg->getOption().matches(options::OPT_cuda_device_only); 1353 1354 if (CompileHostOnly) 1355 return C.MakeAction<CudaHostAction>(HostAction, ActionList()); 1356 1357 // Collect all cuda_gpu_arch parameters, removing duplicates. 1358 SmallVector<const char *, 4> GpuArchList; 1359 llvm::StringSet<> GpuArchNames; 1360 for (Arg *A : Args) { 1361 if (!A->getOption().matches(options::OPT_cuda_gpu_arch_EQ)) 1362 continue; 1363 A->claim(); 1364 1365 const auto& Arch = A->getValue(); 1366 if (!CudaDeviceAction::IsValidGpuArchName(Arch)) 1367 C.getDriver().Diag(clang::diag::err_drv_cuda_bad_gpu_arch) << Arch; 1368 else if (GpuArchNames.insert(Arch).second) 1369 GpuArchList.push_back(Arch); 1370 } 1371 1372 // Default to sm_20 which is the lowest common denominator for supported GPUs. 1373 // sm_20 code should work correctly, if suboptimally, on all newer GPUs. 1374 if (GpuArchList.empty()) 1375 GpuArchList.push_back("sm_20"); 1376 1377 // Replicate inputs for each GPU architecture. 1378 Driver::InputList CudaDeviceInputs; 1379 for (unsigned I = 0, E = GpuArchList.size(); I != E; ++I) 1380 CudaDeviceInputs.push_back(std::make_pair(types::TY_CUDA_DEVICE, InputArg)); 1381 1382 // Build actions for all device inputs. 1383 assert(C.getCudaDeviceToolChain() && 1384 "Missing toolchain for device-side compilation."); 1385 ActionList CudaDeviceActions; 1386 C.getDriver().BuildActions(C, Args, CudaDeviceInputs, CudaDeviceActions); 1387 assert(GpuArchList.size() == CudaDeviceActions.size() && 1388 "Failed to create actions for all devices"); 1389 1390 // Check whether any of device actions stopped before they could generate PTX. 1391 bool PartialCompilation = 1392 llvm::any_of(CudaDeviceActions, [](const Action *a) { 1393 return a->getKind() != Action::AssembleJobClass; 1394 }); 1395 1396 // Figure out what to do with device actions -- pass them as inputs to the 1397 // host action or run each of them independently. 1398 if (PartialCompilation || CompileDeviceOnly) { 1399 // In case of partial or device-only compilation results of device actions 1400 // are not consumed by the host action device actions have to be added to 1401 // top-level actions list with AtTopLevel=true and run independently. 1402 1403 // -o is ambiguous if we have more than one top-level action. 1404 if (Args.hasArg(options::OPT_o) && 1405 (!CompileDeviceOnly || GpuArchList.size() > 1)) { 1406 C.getDriver().Diag( 1407 clang::diag::err_drv_output_argument_with_multiple_files); 1408 return nullptr; 1409 } 1410 1411 for (unsigned I = 0, E = GpuArchList.size(); I != E; ++I) 1412 Actions.push_back(C.MakeAction<CudaDeviceAction>(CudaDeviceActions[I], 1413 GpuArchList[I], 1414 /* AtTopLevel */ true)); 1415 // Kill host action in case of device-only compilation. 1416 if (CompileDeviceOnly) 1417 return nullptr; 1418 return HostAction; 1419 } 1420 1421 // If we're not a partial or device-only compilation, we compile each arch to 1422 // ptx and assemble to cubin, then feed the cubin *and* the ptx into a device 1423 // "link" action, which uses fatbinary to combine these cubins into one 1424 // fatbin. The fatbin is then an input to the host compilation. 1425 ActionList DeviceActions; 1426 for (unsigned I = 0, E = GpuArchList.size(); I != E; ++I) { 1427 Action* AssembleAction = CudaDeviceActions[I]; 1428 assert(AssembleAction->getType() == types::TY_Object); 1429 assert(AssembleAction->getInputs().size() == 1); 1430 1431 Action* BackendAction = AssembleAction->getInputs()[0]; 1432 assert(BackendAction->getType() == types::TY_PP_Asm); 1433 1434 for (const auto& A : {AssembleAction, BackendAction}) { 1435 DeviceActions.push_back(C.MakeAction<CudaDeviceAction>( 1436 A, GpuArchList[I], /* AtTopLevel */ false)); 1437 } 1438 } 1439 auto FatbinAction = C.MakeAction<CudaDeviceAction>( 1440 C.MakeAction<LinkJobAction>(DeviceActions, types::TY_CUDA_FATBIN), 1441 /* GpuArchName = */ nullptr, 1442 /* AtTopLevel = */ false); 1443 // Return a new host action that incorporates original host action and all 1444 // device actions. 1445 return C.MakeAction<CudaHostAction>(std::move(HostAction), 1446 ActionList({FatbinAction})); 1447 } 1448 1449 void Driver::BuildActions(Compilation &C, DerivedArgList &Args, 1450 const InputList &Inputs, ActionList &Actions) const { 1451 llvm::PrettyStackTraceString CrashInfo("Building compilation actions"); 1452 1453 if (!SuppressMissingInputWarning && Inputs.empty()) { 1454 Diag(clang::diag::err_drv_no_input_files); 1455 return; 1456 } 1457 1458 Arg *FinalPhaseArg; 1459 phases::ID FinalPhase = getFinalPhase(Args, &FinalPhaseArg); 1460 1461 if (FinalPhase == phases::Link && Args.hasArg(options::OPT_emit_llvm)) { 1462 Diag(clang::diag::err_drv_emit_llvm_link); 1463 } 1464 1465 // Reject -Z* at the top level, these options should never have been exposed 1466 // by gcc. 1467 if (Arg *A = Args.getLastArg(options::OPT_Z_Joined)) 1468 Diag(clang::diag::err_drv_use_of_Z_option) << A->getAsString(Args); 1469 1470 // Diagnose misuse of /Fo. 1471 if (Arg *A = Args.getLastArg(options::OPT__SLASH_Fo)) { 1472 StringRef V = A->getValue(); 1473 if (Inputs.size() > 1 && !V.empty() && 1474 !llvm::sys::path::is_separator(V.back())) { 1475 // Check whether /Fo tries to name an output file for multiple inputs. 1476 Diag(clang::diag::err_drv_out_file_argument_with_multiple_sources) 1477 << A->getSpelling() << V; 1478 Args.eraseArg(options::OPT__SLASH_Fo); 1479 } 1480 } 1481 1482 // Diagnose misuse of /Fa. 1483 if (Arg *A = Args.getLastArg(options::OPT__SLASH_Fa)) { 1484 StringRef V = A->getValue(); 1485 if (Inputs.size() > 1 && !V.empty() && 1486 !llvm::sys::path::is_separator(V.back())) { 1487 // Check whether /Fa tries to name an asm file for multiple inputs. 1488 Diag(clang::diag::err_drv_out_file_argument_with_multiple_sources) 1489 << A->getSpelling() << V; 1490 Args.eraseArg(options::OPT__SLASH_Fa); 1491 } 1492 } 1493 1494 // Diagnose misuse of /o. 1495 if (Arg *A = Args.getLastArg(options::OPT__SLASH_o)) { 1496 if (A->getValue()[0] == '\0') { 1497 // It has to have a value. 1498 Diag(clang::diag::err_drv_missing_argument) << A->getSpelling() << 1; 1499 Args.eraseArg(options::OPT__SLASH_o); 1500 } 1501 } 1502 1503 // Diagnose unsupported forms of /Yc /Yu. Ignore /Yc/Yu for now if: 1504 // * no filename after it 1505 // * both /Yc and /Yu passed but with different filenames 1506 // * corresponding file not also passed as /FI 1507 Arg *YcArg = Args.getLastArg(options::OPT__SLASH_Yc); 1508 Arg *YuArg = Args.getLastArg(options::OPT__SLASH_Yu); 1509 if (YcArg && YcArg->getValue()[0] == '\0') { 1510 Diag(clang::diag::warn_drv_ycyu_no_arg_clang_cl) << YcArg->getSpelling(); 1511 Args.eraseArg(options::OPT__SLASH_Yc); 1512 YcArg = nullptr; 1513 } 1514 if (YuArg && YuArg->getValue()[0] == '\0') { 1515 Diag(clang::diag::warn_drv_ycyu_no_arg_clang_cl) << YuArg->getSpelling(); 1516 Args.eraseArg(options::OPT__SLASH_Yu); 1517 YuArg = nullptr; 1518 } 1519 if (YcArg && YuArg && strcmp(YcArg->getValue(), YuArg->getValue()) != 0) { 1520 Diag(clang::diag::warn_drv_ycyu_different_arg_clang_cl); 1521 Args.eraseArg(options::OPT__SLASH_Yc); 1522 Args.eraseArg(options::OPT__SLASH_Yu); 1523 YcArg = YuArg = nullptr; 1524 } 1525 if (YcArg || YuArg) { 1526 StringRef Val = YcArg ? YcArg->getValue() : YuArg->getValue(); 1527 bool FoundMatchingInclude = false; 1528 for (const Arg *Inc : Args.filtered(options::OPT_include)) { 1529 // FIXME: Do case-insensitive matching and consider / and \ as equal. 1530 if (Inc->getValue() == Val) 1531 FoundMatchingInclude = true; 1532 } 1533 if (!FoundMatchingInclude) { 1534 Diag(clang::diag::warn_drv_ycyu_no_fi_arg_clang_cl) 1535 << (YcArg ? YcArg : YuArg)->getSpelling(); 1536 Args.eraseArg(options::OPT__SLASH_Yc); 1537 Args.eraseArg(options::OPT__SLASH_Yu); 1538 YcArg = YuArg = nullptr; 1539 } 1540 } 1541 if (YcArg && Inputs.size() > 1) { 1542 Diag(clang::diag::warn_drv_yc_multiple_inputs_clang_cl); 1543 Args.eraseArg(options::OPT__SLASH_Yc); 1544 YcArg = nullptr; 1545 } 1546 if (Args.hasArg(options::OPT__SLASH_Y_)) { 1547 // /Y- disables all pch handling. Rather than check for it everywhere, 1548 // just remove clang-cl pch-related flags here. 1549 Args.eraseArg(options::OPT__SLASH_Fp); 1550 Args.eraseArg(options::OPT__SLASH_Yc); 1551 Args.eraseArg(options::OPT__SLASH_Yu); 1552 YcArg = YuArg = nullptr; 1553 } 1554 1555 // Construct the actions to perform. 1556 ActionList LinkerInputs; 1557 1558 llvm::SmallVector<phases::ID, phases::MaxNumberOfPhases> PL; 1559 for (auto &I : Inputs) { 1560 types::ID InputType = I.first; 1561 const Arg *InputArg = I.second; 1562 1563 PL.clear(); 1564 types::getCompilationPhases(InputType, PL); 1565 1566 // If the first step comes after the final phase we are doing as part of 1567 // this compilation, warn the user about it. 1568 phases::ID InitialPhase = PL[0]; 1569 if (InitialPhase > FinalPhase) { 1570 // Claim here to avoid the more general unused warning. 1571 InputArg->claim(); 1572 1573 // Suppress all unused style warnings with -Qunused-arguments 1574 if (Args.hasArg(options::OPT_Qunused_arguments)) 1575 continue; 1576 1577 // Special case when final phase determined by binary name, rather than 1578 // by a command-line argument with a corresponding Arg. 1579 if (CCCIsCPP()) 1580 Diag(clang::diag::warn_drv_input_file_unused_by_cpp) 1581 << InputArg->getAsString(Args) << getPhaseName(InitialPhase); 1582 // Special case '-E' warning on a previously preprocessed file to make 1583 // more sense. 1584 else if (InitialPhase == phases::Compile && 1585 FinalPhase == phases::Preprocess && 1586 getPreprocessedType(InputType) == types::TY_INVALID) 1587 Diag(clang::diag::warn_drv_preprocessed_input_file_unused) 1588 << InputArg->getAsString(Args) << !!FinalPhaseArg 1589 << (FinalPhaseArg ? FinalPhaseArg->getOption().getName() : ""); 1590 else 1591 Diag(clang::diag::warn_drv_input_file_unused) 1592 << InputArg->getAsString(Args) << getPhaseName(InitialPhase) 1593 << !!FinalPhaseArg 1594 << (FinalPhaseArg ? FinalPhaseArg->getOption().getName() : ""); 1595 continue; 1596 } 1597 1598 if (YcArg) { 1599 // Add a separate precompile phase for the compile phase. 1600 if (FinalPhase >= phases::Compile) { 1601 llvm::SmallVector<phases::ID, phases::MaxNumberOfPhases> PCHPL; 1602 types::getCompilationPhases(types::TY_CXXHeader, PCHPL); 1603 Arg *PchInputArg = MakeInputArg(Args, Opts, YcArg->getValue()); 1604 1605 // Build the pipeline for the pch file. 1606 Action *ClangClPch = C.MakeAction<InputAction>(*PchInputArg, InputType); 1607 for (phases::ID Phase : PCHPL) 1608 ClangClPch = ConstructPhaseAction(C, Args, Phase, ClangClPch); 1609 assert(ClangClPch); 1610 Actions.push_back(ClangClPch); 1611 // The driver currently exits after the first failed command. This 1612 // relies on that behavior, to make sure if the pch generation fails, 1613 // the main compilation won't run. 1614 } 1615 } 1616 1617 phases::ID CudaInjectionPhase = 1618 (phases::Compile < FinalPhase && 1619 llvm::find(PL, phases::Compile) != PL.end()) 1620 ? phases::Compile 1621 : FinalPhase; 1622 1623 // Build the pipeline for this file. 1624 Action *Current = C.MakeAction<InputAction>(*InputArg, InputType); 1625 for (SmallVectorImpl<phases::ID>::iterator i = PL.begin(), e = PL.end(); 1626 i != e; ++i) { 1627 phases::ID Phase = *i; 1628 1629 // We are done if this step is past what the user requested. 1630 if (Phase > FinalPhase) 1631 break; 1632 1633 // Queue linker inputs. 1634 if (Phase == phases::Link) { 1635 assert((i + 1) == e && "linking must be final compilation step."); 1636 LinkerInputs.push_back(Current); 1637 Current = nullptr; 1638 break; 1639 } 1640 1641 // Some types skip the assembler phase (e.g., llvm-bc), but we can't 1642 // encode this in the steps because the intermediate type depends on 1643 // arguments. Just special case here. 1644 if (Phase == phases::Assemble && Current->getType() != types::TY_PP_Asm) 1645 continue; 1646 1647 // Otherwise construct the appropriate action. 1648 Current = ConstructPhaseAction(C, Args, Phase, Current); 1649 1650 if (InputType == types::TY_CUDA && Phase == CudaInjectionPhase) { 1651 Current = buildCudaActions(C, Args, InputArg, Current, Actions); 1652 if (!Current) 1653 break; 1654 } 1655 1656 if (Current->getType() == types::TY_Nothing) 1657 break; 1658 } 1659 1660 // If we ended with something, add to the output list. 1661 if (Current) 1662 Actions.push_back(Current); 1663 } 1664 1665 // Add a link action if necessary. 1666 if (!LinkerInputs.empty()) 1667 Actions.push_back( 1668 C.MakeAction<LinkJobAction>(LinkerInputs, types::TY_Image)); 1669 1670 // If we are linking, claim any options which are obviously only used for 1671 // compilation. 1672 if (FinalPhase == phases::Link && PL.size() == 1) { 1673 Args.ClaimAllArgs(options::OPT_CompileOnly_Group); 1674 Args.ClaimAllArgs(options::OPT_cl_compile_Group); 1675 } 1676 1677 // Claim ignored clang-cl options. 1678 Args.ClaimAllArgs(options::OPT_cl_ignored_Group); 1679 1680 // Claim --cuda-host-only and --cuda-compile-host-device, which may be passed 1681 // to non-CUDA compilations and should not trigger warnings there. 1682 Args.ClaimAllArgs(options::OPT_cuda_host_only); 1683 Args.ClaimAllArgs(options::OPT_cuda_compile_host_device); 1684 } 1685 1686 Action *Driver::ConstructPhaseAction(Compilation &C, const ArgList &Args, 1687 phases::ID Phase, Action *Input) const { 1688 llvm::PrettyStackTraceString CrashInfo("Constructing phase actions"); 1689 // Build the appropriate action. 1690 switch (Phase) { 1691 case phases::Link: 1692 llvm_unreachable("link action invalid here."); 1693 case phases::Preprocess: { 1694 types::ID OutputTy; 1695 // -{M, MM} alter the output type. 1696 if (Args.hasArg(options::OPT_M, options::OPT_MM)) { 1697 OutputTy = types::TY_Dependencies; 1698 } else { 1699 OutputTy = Input->getType(); 1700 if (!Args.hasFlag(options::OPT_frewrite_includes, 1701 options::OPT_fno_rewrite_includes, false) && 1702 !CCGenDiagnostics) 1703 OutputTy = types::getPreprocessedType(OutputTy); 1704 assert(OutputTy != types::TY_INVALID && 1705 "Cannot preprocess this input type!"); 1706 } 1707 return C.MakeAction<PreprocessJobAction>(Input, OutputTy); 1708 } 1709 case phases::Precompile: { 1710 types::ID OutputTy = types::TY_PCH; 1711 if (Args.hasArg(options::OPT_fsyntax_only)) { 1712 // Syntax checks should not emit a PCH file 1713 OutputTy = types::TY_Nothing; 1714 } 1715 return C.MakeAction<PrecompileJobAction>(Input, OutputTy); 1716 } 1717 case phases::Compile: { 1718 if (Args.hasArg(options::OPT_fsyntax_only)) 1719 return C.MakeAction<CompileJobAction>(Input, types::TY_Nothing); 1720 if (Args.hasArg(options::OPT_rewrite_objc)) 1721 return C.MakeAction<CompileJobAction>(Input, types::TY_RewrittenObjC); 1722 if (Args.hasArg(options::OPT_rewrite_legacy_objc)) 1723 return C.MakeAction<CompileJobAction>(Input, 1724 types::TY_RewrittenLegacyObjC); 1725 if (Args.hasArg(options::OPT__analyze, options::OPT__analyze_auto)) 1726 return C.MakeAction<AnalyzeJobAction>(Input, types::TY_Plist); 1727 if (Args.hasArg(options::OPT__migrate)) 1728 return C.MakeAction<MigrateJobAction>(Input, types::TY_Remap); 1729 if (Args.hasArg(options::OPT_emit_ast)) 1730 return C.MakeAction<CompileJobAction>(Input, types::TY_AST); 1731 if (Args.hasArg(options::OPT_module_file_info)) 1732 return C.MakeAction<CompileJobAction>(Input, types::TY_ModuleFile); 1733 if (Args.hasArg(options::OPT_verify_pch)) 1734 return C.MakeAction<VerifyPCHJobAction>(Input, types::TY_Nothing); 1735 return C.MakeAction<CompileJobAction>(Input, types::TY_LLVM_BC); 1736 } 1737 case phases::Backend: { 1738 if (isUsingLTO()) { 1739 types::ID Output = 1740 Args.hasArg(options::OPT_S) ? types::TY_LTO_IR : types::TY_LTO_BC; 1741 return C.MakeAction<BackendJobAction>(Input, Output); 1742 } 1743 if (Args.hasArg(options::OPT_emit_llvm)) { 1744 types::ID Output = 1745 Args.hasArg(options::OPT_S) ? types::TY_LLVM_IR : types::TY_LLVM_BC; 1746 return C.MakeAction<BackendJobAction>(Input, Output); 1747 } 1748 return C.MakeAction<BackendJobAction>(Input, types::TY_PP_Asm); 1749 } 1750 case phases::Assemble: 1751 return C.MakeAction<AssembleJobAction>(std::move(Input), types::TY_Object); 1752 } 1753 1754 llvm_unreachable("invalid phase in ConstructPhaseAction"); 1755 } 1756 1757 void Driver::BuildJobs(Compilation &C) const { 1758 llvm::PrettyStackTraceString CrashInfo("Building compilation jobs"); 1759 1760 Arg *FinalOutput = C.getArgs().getLastArg(options::OPT_o); 1761 1762 // It is an error to provide a -o option if we are making multiple output 1763 // files. 1764 if (FinalOutput) { 1765 unsigned NumOutputs = 0; 1766 for (const Action *A : C.getActions()) 1767 if (A->getType() != types::TY_Nothing) 1768 ++NumOutputs; 1769 1770 if (NumOutputs > 1) { 1771 Diag(clang::diag::err_drv_output_argument_with_multiple_files); 1772 FinalOutput = nullptr; 1773 } 1774 } 1775 1776 // Collect the list of architectures. 1777 llvm::StringSet<> ArchNames; 1778 if (C.getDefaultToolChain().getTriple().isOSBinFormatMachO()) 1779 for (const Arg *A : C.getArgs()) 1780 if (A->getOption().matches(options::OPT_arch)) 1781 ArchNames.insert(A->getValue()); 1782 1783 // Set of (Action, canonical ToolChain triple) pairs we've built jobs for. 1784 std::map<std::pair<const Action *, std::string>, InputInfo> CachedResults; 1785 for (Action *A : C.getActions()) { 1786 // If we are linking an image for multiple archs then the linker wants 1787 // -arch_multiple and -final_output <final image name>. Unfortunately, this 1788 // doesn't fit in cleanly because we have to pass this information down. 1789 // 1790 // FIXME: This is a hack; find a cleaner way to integrate this into the 1791 // process. 1792 const char *LinkingOutput = nullptr; 1793 if (isa<LipoJobAction>(A)) { 1794 if (FinalOutput) 1795 LinkingOutput = FinalOutput->getValue(); 1796 else 1797 LinkingOutput = getDefaultImageName(); 1798 } 1799 1800 BuildJobsForAction(C, A, &C.getDefaultToolChain(), 1801 /*BoundArch*/ nullptr, 1802 /*AtTopLevel*/ true, 1803 /*MultipleArchs*/ ArchNames.size() > 1, 1804 /*LinkingOutput*/ LinkingOutput, CachedResults); 1805 } 1806 1807 // If the user passed -Qunused-arguments or there were errors, don't warn 1808 // about any unused arguments. 1809 if (Diags.hasErrorOccurred() || 1810 C.getArgs().hasArg(options::OPT_Qunused_arguments)) 1811 return; 1812 1813 // Claim -### here. 1814 (void)C.getArgs().hasArg(options::OPT__HASH_HASH_HASH); 1815 1816 // Claim --driver-mode, --rsp-quoting, it was handled earlier. 1817 (void)C.getArgs().hasArg(options::OPT_driver_mode); 1818 (void)C.getArgs().hasArg(options::OPT_rsp_quoting); 1819 1820 for (Arg *A : C.getArgs()) { 1821 // FIXME: It would be nice to be able to send the argument to the 1822 // DiagnosticsEngine, so that extra values, position, and so on could be 1823 // printed. 1824 if (!A->isClaimed()) { 1825 if (A->getOption().hasFlag(options::NoArgumentUnused)) 1826 continue; 1827 1828 // Suppress the warning automatically if this is just a flag, and it is an 1829 // instance of an argument we already claimed. 1830 const Option &Opt = A->getOption(); 1831 if (Opt.getKind() == Option::FlagClass) { 1832 bool DuplicateClaimed = false; 1833 1834 for (const Arg *AA : C.getArgs().filtered(&Opt)) { 1835 if (AA->isClaimed()) { 1836 DuplicateClaimed = true; 1837 break; 1838 } 1839 } 1840 1841 if (DuplicateClaimed) 1842 continue; 1843 } 1844 1845 // In clang-cl, don't mention unknown arguments here since they have 1846 // already been warned about. 1847 if (!IsCLMode() || !A->getOption().matches(options::OPT_UNKNOWN)) 1848 Diag(clang::diag::warn_drv_unused_argument) 1849 << A->getAsString(C.getArgs()); 1850 } 1851 } 1852 } 1853 1854 // Returns a Tool for a given JobAction. In case the action and its 1855 // predecessors can be combined, updates Inputs with the inputs of the 1856 // first combined action. If one of the collapsed actions is a 1857 // CudaHostAction, updates CollapsedCHA with the pointer to it so the 1858 // caller can deal with extra handling such action requires. 1859 static const Tool *selectToolForJob(Compilation &C, bool SaveTemps, 1860 bool EmbedBitcode, const ToolChain *TC, 1861 const JobAction *JA, 1862 const ActionList *&Inputs, 1863 const CudaHostAction *&CollapsedCHA) { 1864 const Tool *ToolForJob = nullptr; 1865 CollapsedCHA = nullptr; 1866 1867 // See if we should look for a compiler with an integrated assembler. We match 1868 // bottom up, so what we are actually looking for is an assembler job with a 1869 // compiler input. 1870 1871 if (TC->useIntegratedAs() && !SaveTemps && 1872 !C.getArgs().hasArg(options::OPT_via_file_asm) && 1873 !C.getArgs().hasArg(options::OPT__SLASH_FA) && 1874 !C.getArgs().hasArg(options::OPT__SLASH_Fa) && 1875 isa<AssembleJobAction>(JA) && Inputs->size() == 1 && 1876 isa<BackendJobAction>(*Inputs->begin())) { 1877 // A BackendJob is always preceded by a CompileJob, and without -save-temps 1878 // or -fembed-bitcode, they will always get combined together, so instead of 1879 // checking the backend tool, check if the tool for the CompileJob has an 1880 // integrated assembler. For -fembed-bitcode, CompileJob is still used to 1881 // look up tools for BackendJob, but they need to match before we can split 1882 // them. 1883 const ActionList *BackendInputs = &(*Inputs)[0]->getInputs(); 1884 // Compile job may be wrapped in CudaHostAction, extract it if 1885 // that's the case and update CollapsedCHA if we combine phases. 1886 CudaHostAction *CHA = dyn_cast<CudaHostAction>(*BackendInputs->begin()); 1887 JobAction *CompileJA = cast<CompileJobAction>( 1888 CHA ? *CHA->input_begin() : *BackendInputs->begin()); 1889 assert(CompileJA && "Backend job is not preceeded by compile job."); 1890 const Tool *Compiler = TC->SelectTool(*CompileJA); 1891 if (!Compiler) 1892 return nullptr; 1893 // When using -fembed-bitcode, it is required to have the same tool (clang) 1894 // for both CompilerJA and BackendJA. Otherwise, combine two stages. 1895 if (EmbedBitcode) { 1896 JobAction *InputJA = cast<JobAction>(*Inputs->begin()); 1897 const Tool *BackendTool = TC->SelectTool(*InputJA); 1898 if (BackendTool == Compiler) 1899 CompileJA = InputJA; 1900 } 1901 if (Compiler->hasIntegratedAssembler()) { 1902 Inputs = &CompileJA->getInputs(); 1903 ToolForJob = Compiler; 1904 CollapsedCHA = CHA; 1905 } 1906 } 1907 1908 // A backend job should always be combined with the preceding compile job 1909 // unless OPT_save_temps or OPT_fembed_bitcode is enabled and the compiler is 1910 // capable of emitting LLVM IR as an intermediate output. 1911 if (isa<BackendJobAction>(JA)) { 1912 // Check if the compiler supports emitting LLVM IR. 1913 assert(Inputs->size() == 1); 1914 // Compile job may be wrapped in CudaHostAction, extract it if 1915 // that's the case and update CollapsedCHA if we combine phases. 1916 CudaHostAction *CHA = dyn_cast<CudaHostAction>(*Inputs->begin()); 1917 JobAction *CompileJA = 1918 cast<CompileJobAction>(CHA ? *CHA->input_begin() : *Inputs->begin()); 1919 assert(CompileJA && "Backend job is not preceeded by compile job."); 1920 const Tool *Compiler = TC->SelectTool(*CompileJA); 1921 if (!Compiler) 1922 return nullptr; 1923 if (!Compiler->canEmitIR() || 1924 (!SaveTemps && !EmbedBitcode)) { 1925 Inputs = &CompileJA->getInputs(); 1926 ToolForJob = Compiler; 1927 CollapsedCHA = CHA; 1928 } 1929 } 1930 1931 // Otherwise use the tool for the current job. 1932 if (!ToolForJob) 1933 ToolForJob = TC->SelectTool(*JA); 1934 1935 // See if we should use an integrated preprocessor. We do so when we have 1936 // exactly one input, since this is the only use case we care about 1937 // (irrelevant since we don't support combine yet). 1938 if (Inputs->size() == 1 && isa<PreprocessJobAction>(*Inputs->begin()) && 1939 !C.getArgs().hasArg(options::OPT_no_integrated_cpp) && 1940 !C.getArgs().hasArg(options::OPT_traditional_cpp) && !SaveTemps && 1941 !C.getArgs().hasArg(options::OPT_rewrite_objc) && 1942 ToolForJob->hasIntegratedCPP()) 1943 Inputs = &(*Inputs)[0]->getInputs(); 1944 1945 return ToolForJob; 1946 } 1947 1948 InputInfo Driver::BuildJobsForAction( 1949 Compilation &C, const Action *A, const ToolChain *TC, const char *BoundArch, 1950 bool AtTopLevel, bool MultipleArchs, const char *LinkingOutput, 1951 std::map<std::pair<const Action *, std::string>, InputInfo> &CachedResults) 1952 const { 1953 // The bound arch is not necessarily represented in the toolchain's triple -- 1954 // for example, armv7 and armv7s both map to the same triple -- so we need 1955 // both in our map. 1956 std::string TriplePlusArch = TC->getTriple().normalize(); 1957 if (BoundArch) { 1958 TriplePlusArch += "-"; 1959 TriplePlusArch += BoundArch; 1960 } 1961 std::pair<const Action *, std::string> ActionTC = {A, TriplePlusArch}; 1962 auto CachedResult = CachedResults.find(ActionTC); 1963 if (CachedResult != CachedResults.end()) { 1964 return CachedResult->second; 1965 } 1966 InputInfo Result = 1967 BuildJobsForActionNoCache(C, A, TC, BoundArch, AtTopLevel, MultipleArchs, 1968 LinkingOutput, CachedResults); 1969 CachedResults[ActionTC] = Result; 1970 return Result; 1971 } 1972 1973 InputInfo Driver::BuildJobsForActionNoCache( 1974 Compilation &C, const Action *A, const ToolChain *TC, const char *BoundArch, 1975 bool AtTopLevel, bool MultipleArchs, const char *LinkingOutput, 1976 std::map<std::pair<const Action *, std::string>, InputInfo> &CachedResults) 1977 const { 1978 llvm::PrettyStackTraceString CrashInfo("Building compilation jobs"); 1979 1980 InputInfoList CudaDeviceInputInfos; 1981 if (const CudaHostAction *CHA = dyn_cast<CudaHostAction>(A)) { 1982 // Append outputs of device jobs to the input list. 1983 for (const Action *DA : CHA->getDeviceActions()) { 1984 CudaDeviceInputInfos.push_back(BuildJobsForAction( 1985 C, DA, TC, nullptr, AtTopLevel, 1986 /*MultipleArchs*/ false, LinkingOutput, CachedResults)); 1987 } 1988 // Override current action with a real host compile action and continue 1989 // processing it. 1990 A = *CHA->input_begin(); 1991 } 1992 1993 if (const InputAction *IA = dyn_cast<InputAction>(A)) { 1994 // FIXME: It would be nice to not claim this here; maybe the old scheme of 1995 // just using Args was better? 1996 const Arg &Input = IA->getInputArg(); 1997 Input.claim(); 1998 if (Input.getOption().matches(options::OPT_INPUT)) { 1999 const char *Name = Input.getValue(); 2000 return InputInfo(A, Name, /* BaseInput = */ Name); 2001 } 2002 return InputInfo(A, &Input, /* BaseInput = */ ""); 2003 } 2004 2005 if (const BindArchAction *BAA = dyn_cast<BindArchAction>(A)) { 2006 const ToolChain *TC; 2007 const char *ArchName = BAA->getArchName(); 2008 2009 if (ArchName) 2010 TC = &getToolChain(C.getArgs(), 2011 computeTargetTriple(*this, DefaultTargetTriple, 2012 C.getArgs(), ArchName)); 2013 else 2014 TC = &C.getDefaultToolChain(); 2015 2016 return BuildJobsForAction(C, *BAA->input_begin(), TC, ArchName, AtTopLevel, 2017 MultipleArchs, LinkingOutput, CachedResults); 2018 } 2019 2020 if (const CudaDeviceAction *CDA = dyn_cast<CudaDeviceAction>(A)) { 2021 // Initial processing of CudaDeviceAction carries host params. 2022 // Call BuildJobsForAction() again, now with correct device parameters. 2023 InputInfo II = BuildJobsForAction( 2024 C, *CDA->input_begin(), C.getCudaDeviceToolChain(), 2025 CDA->getGpuArchName(), CDA->isAtTopLevel(), /*MultipleArchs=*/true, 2026 LinkingOutput, CachedResults); 2027 // Currently II's Action is *CDA->input_begin(). Set it to CDA instead, so 2028 // that one can retrieve II's GPU arch. 2029 II.setAction(A); 2030 return II; 2031 } 2032 2033 const ActionList *Inputs = &A->getInputs(); 2034 2035 const JobAction *JA = cast<JobAction>(A); 2036 const CudaHostAction *CollapsedCHA = nullptr; 2037 const Tool *T = 2038 selectToolForJob(C, isSaveTempsEnabled(), embedBitcodeEnabled(), TC, JA, 2039 Inputs, CollapsedCHA); 2040 if (!T) 2041 return InputInfo(); 2042 2043 // If we've collapsed action list that contained CudaHostAction we 2044 // need to build jobs for device-side inputs it may have held. 2045 if (CollapsedCHA) { 2046 for (const Action *DA : CollapsedCHA->getDeviceActions()) { 2047 CudaDeviceInputInfos.push_back(BuildJobsForAction( 2048 C, DA, TC, "", AtTopLevel, 2049 /*MultipleArchs*/ false, LinkingOutput, CachedResults)); 2050 } 2051 } 2052 2053 // Only use pipes when there is exactly one input. 2054 InputInfoList InputInfos; 2055 for (const Action *Input : *Inputs) { 2056 // Treat dsymutil and verify sub-jobs as being at the top-level too, they 2057 // shouldn't get temporary output names. 2058 // FIXME: Clean this up. 2059 bool SubJobAtTopLevel = 2060 AtTopLevel && (isa<DsymutilJobAction>(A) || isa<VerifyJobAction>(A)); 2061 InputInfos.push_back(BuildJobsForAction(C, Input, TC, BoundArch, 2062 SubJobAtTopLevel, MultipleArchs, 2063 LinkingOutput, CachedResults)); 2064 } 2065 2066 // Always use the first input as the base input. 2067 const char *BaseInput = InputInfos[0].getBaseInput(); 2068 2069 // ... except dsymutil actions, which use their actual input as the base 2070 // input. 2071 if (JA->getType() == types::TY_dSYM) 2072 BaseInput = InputInfos[0].getFilename(); 2073 2074 // Append outputs of cuda device jobs to the input list 2075 if (CudaDeviceInputInfos.size()) 2076 InputInfos.append(CudaDeviceInputInfos.begin(), CudaDeviceInputInfos.end()); 2077 2078 // Determine the place to write output to, if any. 2079 InputInfo Result; 2080 if (JA->getType() == types::TY_Nothing) 2081 Result = InputInfo(A, BaseInput); 2082 else 2083 Result = InputInfo(A, GetNamedOutputPath(C, *JA, BaseInput, BoundArch, 2084 AtTopLevel, MultipleArchs), 2085 BaseInput); 2086 2087 if (CCCPrintBindings && !CCGenDiagnostics) { 2088 llvm::errs() << "# \"" << T->getToolChain().getTripleString() << '"' 2089 << " - \"" << T->getName() << "\", inputs: ["; 2090 for (unsigned i = 0, e = InputInfos.size(); i != e; ++i) { 2091 llvm::errs() << InputInfos[i].getAsString(); 2092 if (i + 1 != e) 2093 llvm::errs() << ", "; 2094 } 2095 llvm::errs() << "], output: " << Result.getAsString() << "\n"; 2096 } else { 2097 T->ConstructJob(C, *JA, Result, InputInfos, 2098 C.getArgsForToolChain(TC, BoundArch), LinkingOutput); 2099 } 2100 return Result; 2101 } 2102 2103 const char *Driver::getDefaultImageName() const { 2104 llvm::Triple Target(llvm::Triple::normalize(DefaultTargetTriple)); 2105 return Target.isOSWindows() ? "a.exe" : "a.out"; 2106 } 2107 2108 /// \brief Create output filename based on ArgValue, which could either be a 2109 /// full filename, filename without extension, or a directory. If ArgValue 2110 /// does not provide a filename, then use BaseName, and use the extension 2111 /// suitable for FileType. 2112 static const char *MakeCLOutputFilename(const ArgList &Args, StringRef ArgValue, 2113 StringRef BaseName, 2114 types::ID FileType) { 2115 SmallString<128> Filename = ArgValue; 2116 2117 if (ArgValue.empty()) { 2118 // If the argument is empty, output to BaseName in the current dir. 2119 Filename = BaseName; 2120 } else if (llvm::sys::path::is_separator(Filename.back())) { 2121 // If the argument is a directory, output to BaseName in that dir. 2122 llvm::sys::path::append(Filename, BaseName); 2123 } 2124 2125 if (!llvm::sys::path::has_extension(ArgValue)) { 2126 // If the argument didn't provide an extension, then set it. 2127 const char *Extension = types::getTypeTempSuffix(FileType, true); 2128 2129 if (FileType == types::TY_Image && 2130 Args.hasArg(options::OPT__SLASH_LD, options::OPT__SLASH_LDd)) { 2131 // The output file is a dll. 2132 Extension = "dll"; 2133 } 2134 2135 llvm::sys::path::replace_extension(Filename, Extension); 2136 } 2137 2138 return Args.MakeArgString(Filename.c_str()); 2139 } 2140 2141 const char *Driver::GetNamedOutputPath(Compilation &C, const JobAction &JA, 2142 const char *BaseInput, 2143 const char *BoundArch, bool AtTopLevel, 2144 bool MultipleArchs) const { 2145 llvm::PrettyStackTraceString CrashInfo("Computing output path"); 2146 // Output to a user requested destination? 2147 if (AtTopLevel && !isa<DsymutilJobAction>(JA) && !isa<VerifyJobAction>(JA)) { 2148 if (Arg *FinalOutput = C.getArgs().getLastArg(options::OPT_o)) 2149 return C.addResultFile(FinalOutput->getValue(), &JA); 2150 } 2151 2152 // For /P, preprocess to file named after BaseInput. 2153 if (C.getArgs().hasArg(options::OPT__SLASH_P)) { 2154 assert(AtTopLevel && isa<PreprocessJobAction>(JA)); 2155 StringRef BaseName = llvm::sys::path::filename(BaseInput); 2156 StringRef NameArg; 2157 if (Arg *A = C.getArgs().getLastArg(options::OPT__SLASH_Fi)) 2158 NameArg = A->getValue(); 2159 return C.addResultFile( 2160 MakeCLOutputFilename(C.getArgs(), NameArg, BaseName, types::TY_PP_C), 2161 &JA); 2162 } 2163 2164 // Default to writing to stdout? 2165 if (AtTopLevel && !CCGenDiagnostics && 2166 (isa<PreprocessJobAction>(JA) || JA.getType() == types::TY_ModuleFile)) 2167 return "-"; 2168 2169 // Is this the assembly listing for /FA? 2170 if (JA.getType() == types::TY_PP_Asm && 2171 (C.getArgs().hasArg(options::OPT__SLASH_FA) || 2172 C.getArgs().hasArg(options::OPT__SLASH_Fa))) { 2173 // Use /Fa and the input filename to determine the asm file name. 2174 StringRef BaseName = llvm::sys::path::filename(BaseInput); 2175 StringRef FaValue = C.getArgs().getLastArgValue(options::OPT__SLASH_Fa); 2176 return C.addResultFile( 2177 MakeCLOutputFilename(C.getArgs(), FaValue, BaseName, JA.getType()), 2178 &JA); 2179 } 2180 2181 // Output to a temporary file? 2182 if ((!AtTopLevel && !isSaveTempsEnabled() && 2183 !C.getArgs().hasArg(options::OPT__SLASH_Fo)) || 2184 CCGenDiagnostics) { 2185 StringRef Name = llvm::sys::path::filename(BaseInput); 2186 std::pair<StringRef, StringRef> Split = Name.split('.'); 2187 std::string TmpName = GetTemporaryPath( 2188 Split.first, types::getTypeTempSuffix(JA.getType(), IsCLMode())); 2189 return C.addTempFile(C.getArgs().MakeArgString(TmpName.c_str())); 2190 } 2191 2192 SmallString<128> BasePath(BaseInput); 2193 StringRef BaseName; 2194 2195 // Dsymutil actions should use the full path. 2196 if (isa<DsymutilJobAction>(JA) || isa<VerifyJobAction>(JA)) 2197 BaseName = BasePath; 2198 else 2199 BaseName = llvm::sys::path::filename(BasePath); 2200 2201 // Determine what the derived output name should be. 2202 const char *NamedOutput; 2203 2204 if (JA.getType() == types::TY_Object && 2205 C.getArgs().hasArg(options::OPT__SLASH_Fo, options::OPT__SLASH_o)) { 2206 // The /Fo or /o flag decides the object filename. 2207 StringRef Val = 2208 C.getArgs() 2209 .getLastArg(options::OPT__SLASH_Fo, options::OPT__SLASH_o) 2210 ->getValue(); 2211 NamedOutput = 2212 MakeCLOutputFilename(C.getArgs(), Val, BaseName, types::TY_Object); 2213 } else if (JA.getType() == types::TY_Image && 2214 C.getArgs().hasArg(options::OPT__SLASH_Fe, 2215 options::OPT__SLASH_o)) { 2216 // The /Fe or /o flag names the linked file. 2217 StringRef Val = 2218 C.getArgs() 2219 .getLastArg(options::OPT__SLASH_Fe, options::OPT__SLASH_o) 2220 ->getValue(); 2221 NamedOutput = 2222 MakeCLOutputFilename(C.getArgs(), Val, BaseName, types::TY_Image); 2223 } else if (JA.getType() == types::TY_Image) { 2224 if (IsCLMode()) { 2225 // clang-cl uses BaseName for the executable name. 2226 NamedOutput = 2227 MakeCLOutputFilename(C.getArgs(), "", BaseName, types::TY_Image); 2228 } else if (MultipleArchs && BoundArch) { 2229 SmallString<128> Output(getDefaultImageName()); 2230 Output += "-"; 2231 Output.append(BoundArch); 2232 NamedOutput = C.getArgs().MakeArgString(Output.c_str()); 2233 } else { 2234 NamedOutput = getDefaultImageName(); 2235 } 2236 } else if (JA.getType() == types::TY_PCH && IsCLMode()) { 2237 NamedOutput = C.getArgs().MakeArgString(GetClPchPath(C, BaseName).c_str()); 2238 } else { 2239 const char *Suffix = types::getTypeTempSuffix(JA.getType(), IsCLMode()); 2240 assert(Suffix && "All types used for output should have a suffix."); 2241 2242 std::string::size_type End = std::string::npos; 2243 if (!types::appendSuffixForType(JA.getType())) 2244 End = BaseName.rfind('.'); 2245 SmallString<128> Suffixed(BaseName.substr(0, End)); 2246 if (MultipleArchs && BoundArch) { 2247 Suffixed += "-"; 2248 Suffixed.append(BoundArch); 2249 } 2250 // When using both -save-temps and -emit-llvm, use a ".tmp.bc" suffix for 2251 // the unoptimized bitcode so that it does not get overwritten by the ".bc" 2252 // optimized bitcode output. 2253 if (!AtTopLevel && C.getArgs().hasArg(options::OPT_emit_llvm) && 2254 JA.getType() == types::TY_LLVM_BC) 2255 Suffixed += ".tmp"; 2256 Suffixed += '.'; 2257 Suffixed += Suffix; 2258 NamedOutput = C.getArgs().MakeArgString(Suffixed.c_str()); 2259 } 2260 2261 // Prepend object file path if -save-temps=obj 2262 if (!AtTopLevel && isSaveTempsObj() && C.getArgs().hasArg(options::OPT_o) && 2263 JA.getType() != types::TY_PCH) { 2264 Arg *FinalOutput = C.getArgs().getLastArg(options::OPT_o); 2265 SmallString<128> TempPath(FinalOutput->getValue()); 2266 llvm::sys::path::remove_filename(TempPath); 2267 StringRef OutputFileName = llvm::sys::path::filename(NamedOutput); 2268 llvm::sys::path::append(TempPath, OutputFileName); 2269 NamedOutput = C.getArgs().MakeArgString(TempPath.c_str()); 2270 } 2271 2272 // If we're saving temps and the temp file conflicts with the input file, 2273 // then avoid overwriting input file. 2274 if (!AtTopLevel && isSaveTempsEnabled() && NamedOutput == BaseName) { 2275 bool SameFile = false; 2276 SmallString<256> Result; 2277 llvm::sys::fs::current_path(Result); 2278 llvm::sys::path::append(Result, BaseName); 2279 llvm::sys::fs::equivalent(BaseInput, Result.c_str(), SameFile); 2280 // Must share the same path to conflict. 2281 if (SameFile) { 2282 StringRef Name = llvm::sys::path::filename(BaseInput); 2283 std::pair<StringRef, StringRef> Split = Name.split('.'); 2284 std::string TmpName = GetTemporaryPath( 2285 Split.first, types::getTypeTempSuffix(JA.getType(), IsCLMode())); 2286 return C.addTempFile(C.getArgs().MakeArgString(TmpName.c_str())); 2287 } 2288 } 2289 2290 // As an annoying special case, PCH generation doesn't strip the pathname. 2291 if (JA.getType() == types::TY_PCH && !IsCLMode()) { 2292 llvm::sys::path::remove_filename(BasePath); 2293 if (BasePath.empty()) 2294 BasePath = NamedOutput; 2295 else 2296 llvm::sys::path::append(BasePath, NamedOutput); 2297 return C.addResultFile(C.getArgs().MakeArgString(BasePath.c_str()), &JA); 2298 } else { 2299 return C.addResultFile(NamedOutput, &JA); 2300 } 2301 } 2302 2303 std::string Driver::GetFilePath(const char *Name, const ToolChain &TC) const { 2304 // Respect a limited subset of the '-Bprefix' functionality in GCC by 2305 // attempting to use this prefix when looking for file paths. 2306 for (const std::string &Dir : PrefixDirs) { 2307 if (Dir.empty()) 2308 continue; 2309 SmallString<128> P(Dir[0] == '=' ? SysRoot + Dir.substr(1) : Dir); 2310 llvm::sys::path::append(P, Name); 2311 if (llvm::sys::fs::exists(Twine(P))) 2312 return P.str(); 2313 } 2314 2315 SmallString<128> P(ResourceDir); 2316 llvm::sys::path::append(P, Name); 2317 if (llvm::sys::fs::exists(Twine(P))) 2318 return P.str(); 2319 2320 for (const std::string &Dir : TC.getFilePaths()) { 2321 if (Dir.empty()) 2322 continue; 2323 SmallString<128> P(Dir[0] == '=' ? SysRoot + Dir.substr(1) : Dir); 2324 llvm::sys::path::append(P, Name); 2325 if (llvm::sys::fs::exists(Twine(P))) 2326 return P.str(); 2327 } 2328 2329 return Name; 2330 } 2331 2332 void Driver::generatePrefixedToolNames( 2333 const char *Tool, const ToolChain &TC, 2334 SmallVectorImpl<std::string> &Names) const { 2335 // FIXME: Needs a better variable than DefaultTargetTriple 2336 Names.emplace_back(DefaultTargetTriple + "-" + Tool); 2337 Names.emplace_back(Tool); 2338 2339 // Allow the discovery of tools prefixed with LLVM's default target triple. 2340 std::string LLVMDefaultTargetTriple = llvm::sys::getDefaultTargetTriple(); 2341 if (LLVMDefaultTargetTriple != DefaultTargetTriple) 2342 Names.emplace_back(LLVMDefaultTargetTriple + "-" + Tool); 2343 } 2344 2345 static bool ScanDirForExecutable(SmallString<128> &Dir, 2346 ArrayRef<std::string> Names) { 2347 for (const auto &Name : Names) { 2348 llvm::sys::path::append(Dir, Name); 2349 if (llvm::sys::fs::can_execute(Twine(Dir))) 2350 return true; 2351 llvm::sys::path::remove_filename(Dir); 2352 } 2353 return false; 2354 } 2355 2356 std::string Driver::GetProgramPath(const char *Name, 2357 const ToolChain &TC) const { 2358 SmallVector<std::string, 2> TargetSpecificExecutables; 2359 generatePrefixedToolNames(Name, TC, TargetSpecificExecutables); 2360 2361 // Respect a limited subset of the '-Bprefix' functionality in GCC by 2362 // attempting to use this prefix when looking for program paths. 2363 for (const auto &PrefixDir : PrefixDirs) { 2364 if (llvm::sys::fs::is_directory(PrefixDir)) { 2365 SmallString<128> P(PrefixDir); 2366 if (ScanDirForExecutable(P, TargetSpecificExecutables)) 2367 return P.str(); 2368 } else { 2369 SmallString<128> P(PrefixDir + Name); 2370 if (llvm::sys::fs::can_execute(Twine(P))) 2371 return P.str(); 2372 } 2373 } 2374 2375 const ToolChain::path_list &List = TC.getProgramPaths(); 2376 for (const auto &Path : List) { 2377 SmallString<128> P(Path); 2378 if (ScanDirForExecutable(P, TargetSpecificExecutables)) 2379 return P.str(); 2380 } 2381 2382 // If all else failed, search the path. 2383 for (const auto &TargetSpecificExecutable : TargetSpecificExecutables) 2384 if (llvm::ErrorOr<std::string> P = 2385 llvm::sys::findProgramByName(TargetSpecificExecutable)) 2386 return *P; 2387 2388 return Name; 2389 } 2390 2391 std::string Driver::GetTemporaryPath(StringRef Prefix, 2392 const char *Suffix) const { 2393 SmallString<128> Path; 2394 std::error_code EC = llvm::sys::fs::createTemporaryFile(Prefix, Suffix, Path); 2395 if (EC) { 2396 Diag(clang::diag::err_unable_to_make_temp) << EC.message(); 2397 return ""; 2398 } 2399 2400 return Path.str(); 2401 } 2402 2403 std::string Driver::GetClPchPath(Compilation &C, StringRef BaseName) const { 2404 SmallString<128> Output; 2405 if (Arg *FpArg = C.getArgs().getLastArg(options::OPT__SLASH_Fp)) { 2406 // FIXME: If anybody needs it, implement this obscure rule: 2407 // "If you specify a directory without a file name, the default file name 2408 // is VCx0.pch., where x is the major version of Visual C++ in use." 2409 Output = FpArg->getValue(); 2410 2411 // "If you do not specify an extension as part of the path name, an 2412 // extension of .pch is assumed. " 2413 if (!llvm::sys::path::has_extension(Output)) 2414 Output += ".pch"; 2415 } else { 2416 Output = BaseName; 2417 llvm::sys::path::replace_extension(Output, ".pch"); 2418 } 2419 return Output.str(); 2420 } 2421 2422 const ToolChain &Driver::getToolChain(const ArgList &Args, 2423 const llvm::Triple &Target) const { 2424 2425 ToolChain *&TC = ToolChains[Target.str()]; 2426 if (!TC) { 2427 switch (Target.getOS()) { 2428 case llvm::Triple::CloudABI: 2429 TC = new toolchains::CloudABI(*this, Target, Args); 2430 break; 2431 case llvm::Triple::Darwin: 2432 case llvm::Triple::MacOSX: 2433 case llvm::Triple::IOS: 2434 case llvm::Triple::TvOS: 2435 case llvm::Triple::WatchOS: 2436 TC = new toolchains::DarwinClang(*this, Target, Args); 2437 break; 2438 case llvm::Triple::DragonFly: 2439 TC = new toolchains::DragonFly(*this, Target, Args); 2440 break; 2441 case llvm::Triple::OpenBSD: 2442 TC = new toolchains::OpenBSD(*this, Target, Args); 2443 break; 2444 case llvm::Triple::Bitrig: 2445 TC = new toolchains::Bitrig(*this, Target, Args); 2446 break; 2447 case llvm::Triple::NetBSD: 2448 TC = new toolchains::NetBSD(*this, Target, Args); 2449 break; 2450 case llvm::Triple::FreeBSD: 2451 TC = new toolchains::FreeBSD(*this, Target, Args); 2452 break; 2453 case llvm::Triple::Minix: 2454 TC = new toolchains::Minix(*this, Target, Args); 2455 break; 2456 case llvm::Triple::Linux: 2457 if (Target.getArch() == llvm::Triple::hexagon) 2458 TC = new toolchains::HexagonToolChain(*this, Target, Args); 2459 else if ((Target.getVendor() == llvm::Triple::MipsTechnologies) && 2460 !Target.hasEnvironment()) 2461 TC = new toolchains::MipsLLVMToolChain(*this, Target, Args); 2462 else 2463 TC = new toolchains::Linux(*this, Target, Args); 2464 break; 2465 case llvm::Triple::NaCl: 2466 TC = new toolchains::NaClToolChain(*this, Target, Args); 2467 break; 2468 case llvm::Triple::Solaris: 2469 TC = new toolchains::Solaris(*this, Target, Args); 2470 break; 2471 case llvm::Triple::AMDHSA: 2472 TC = new toolchains::AMDGPUToolChain(*this, Target, Args); 2473 break; 2474 case llvm::Triple::Win32: 2475 switch (Target.getEnvironment()) { 2476 default: 2477 if (Target.isOSBinFormatELF()) 2478 TC = new toolchains::Generic_ELF(*this, Target, Args); 2479 else if (Target.isOSBinFormatMachO()) 2480 TC = new toolchains::MachO(*this, Target, Args); 2481 else 2482 TC = new toolchains::Generic_GCC(*this, Target, Args); 2483 break; 2484 case llvm::Triple::GNU: 2485 TC = new toolchains::MinGW(*this, Target, Args); 2486 break; 2487 case llvm::Triple::Itanium: 2488 TC = new toolchains::CrossWindowsToolChain(*this, Target, Args); 2489 break; 2490 case llvm::Triple::MSVC: 2491 case llvm::Triple::UnknownEnvironment: 2492 TC = new toolchains::MSVCToolChain(*this, Target, Args); 2493 break; 2494 } 2495 break; 2496 case llvm::Triple::CUDA: 2497 TC = new toolchains::CudaToolChain(*this, Target, Args); 2498 break; 2499 case llvm::Triple::PS4: 2500 TC = new toolchains::PS4CPU(*this, Target, Args); 2501 break; 2502 default: 2503 // Of these targets, Hexagon is the only one that might have 2504 // an OS of Linux, in which case it got handled above already. 2505 switch (Target.getArch()) { 2506 case llvm::Triple::tce: 2507 TC = new toolchains::TCEToolChain(*this, Target, Args); 2508 break; 2509 case llvm::Triple::hexagon: 2510 TC = new toolchains::HexagonToolChain(*this, Target, Args); 2511 break; 2512 case llvm::Triple::lanai: 2513 TC = new toolchains::LanaiToolChain(*this, Target, Args); 2514 break; 2515 case llvm::Triple::xcore: 2516 TC = new toolchains::XCoreToolChain(*this, Target, Args); 2517 break; 2518 case llvm::Triple::wasm32: 2519 case llvm::Triple::wasm64: 2520 TC = new toolchains::WebAssembly(*this, Target, Args); 2521 break; 2522 default: 2523 if (Target.getVendor() == llvm::Triple::Myriad) 2524 TC = new toolchains::MyriadToolChain(*this, Target, Args); 2525 else if (Target.isOSBinFormatELF()) 2526 TC = new toolchains::Generic_ELF(*this, Target, Args); 2527 else if (Target.isOSBinFormatMachO()) 2528 TC = new toolchains::MachO(*this, Target, Args); 2529 else 2530 TC = new toolchains::Generic_GCC(*this, Target, Args); 2531 } 2532 } 2533 } 2534 return *TC; 2535 } 2536 2537 bool Driver::ShouldUseClangCompiler(const JobAction &JA) const { 2538 // Say "no" if there is not exactly one input of a type clang understands. 2539 if (JA.size() != 1 || 2540 !types::isAcceptedByClang((*JA.input_begin())->getType())) 2541 return false; 2542 2543 // And say "no" if this is not a kind of action clang understands. 2544 if (!isa<PreprocessJobAction>(JA) && !isa<PrecompileJobAction>(JA) && 2545 !isa<CompileJobAction>(JA) && !isa<BackendJobAction>(JA)) 2546 return false; 2547 2548 return true; 2549 } 2550 2551 /// GetReleaseVersion - Parse (([0-9]+)(.([0-9]+)(.([0-9]+)?))?)? and return the 2552 /// grouped values as integers. Numbers which are not provided are set to 0. 2553 /// 2554 /// \return True if the entire string was parsed (9.2), or all groups were 2555 /// parsed (10.3.5extrastuff). 2556 bool Driver::GetReleaseVersion(const char *Str, unsigned &Major, 2557 unsigned &Minor, unsigned &Micro, 2558 bool &HadExtra) { 2559 HadExtra = false; 2560 2561 Major = Minor = Micro = 0; 2562 if (*Str == '\0') 2563 return false; 2564 2565 char *End; 2566 Major = (unsigned)strtol(Str, &End, 10); 2567 if (*Str != '\0' && *End == '\0') 2568 return true; 2569 if (*End != '.') 2570 return false; 2571 2572 Str = End + 1; 2573 Minor = (unsigned)strtol(Str, &End, 10); 2574 if (*Str != '\0' && *End == '\0') 2575 return true; 2576 if (*End != '.') 2577 return false; 2578 2579 Str = End + 1; 2580 Micro = (unsigned)strtol(Str, &End, 10); 2581 if (*Str != '\0' && *End == '\0') 2582 return true; 2583 if (Str == End) 2584 return false; 2585 HadExtra = true; 2586 return true; 2587 } 2588 2589 /// Parse digits from a string \p Str and fulfill \p Digits with 2590 /// the parsed numbers. This method assumes that the max number of 2591 /// digits to look for is equal to Digits.size(). 2592 /// 2593 /// \return True if the entire string was parsed and there are 2594 /// no extra characters remaining at the end. 2595 bool Driver::GetReleaseVersion(const char *Str, 2596 MutableArrayRef<unsigned> Digits) { 2597 if (*Str == '\0') 2598 return false; 2599 2600 char *End; 2601 unsigned CurDigit = 0; 2602 while (CurDigit < Digits.size()) { 2603 unsigned Digit = (unsigned)strtol(Str, &End, 10); 2604 Digits[CurDigit] = Digit; 2605 if (*Str != '\0' && *End == '\0') 2606 return true; 2607 if (*End != '.' || Str == End) 2608 return false; 2609 Str = End + 1; 2610 CurDigit++; 2611 } 2612 2613 // More digits than requested, bail out... 2614 return false; 2615 } 2616 2617 std::pair<unsigned, unsigned> Driver::getIncludeExcludeOptionFlagMasks() const { 2618 unsigned IncludedFlagsBitmask = 0; 2619 unsigned ExcludedFlagsBitmask = options::NoDriverOption; 2620 2621 if (Mode == CLMode) { 2622 // Include CL and Core options. 2623 IncludedFlagsBitmask |= options::CLOption; 2624 IncludedFlagsBitmask |= options::CoreOption; 2625 } else { 2626 ExcludedFlagsBitmask |= options::CLOption; 2627 } 2628 2629 return std::make_pair(IncludedFlagsBitmask, ExcludedFlagsBitmask); 2630 } 2631 2632 bool clang::driver::isOptimizationLevelFast(const ArgList &Args) { 2633 return Args.hasFlag(options::OPT_Ofast, options::OPT_O_Group, false); 2634 } 2635