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