blob: 7c363e0d9ef886ee718ab72070937a2c00f658ac [file] [log] [blame]
Eugene Zelenkod4304d22015-11-04 21:37:17 +00001//===--- Tools.cpp - Tools Implementations ----------------------*- C++ -*-===//
Daniel Dunbar1a093d22009-03-18 06:00:36 +00002//
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 "Tools.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000011#include "InputInfo.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000012#include "ToolChains.h"
Ben Langmuire056ec32015-02-04 18:34:23 +000013#include "clang/Basic/CharInfo.h"
Josh Mageee0fc1a82014-02-11 01:35:14 +000014#include "clang/Basic/LangOptions.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000015#include "clang/Basic/ObjCRuntime.h"
Kevin Enderbyae2ec472013-01-17 21:38:06 +000016#include "clang/Basic/Version.h"
Rafael Espindola3e34e652015-02-03 16:33:53 +000017#include "clang/Config/config.h"
Daniel Dunbara2aedc62009-03-18 10:01:51 +000018#include "clang/Driver/Action.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000019#include "clang/Driver/Compilation.h"
Daniel Dunbar1a8a2e82009-10-29 02:39:57 +000020#include "clang/Driver/Driver.h"
21#include "clang/Driver/DriverDiagnostic.h"
Daniel Dunbar04c4c2c2009-03-18 07:06:02 +000022#include "clang/Driver/Job.h"
Daniel Dunbarda13faf2009-11-19 04:25:22 +000023#include "clang/Driver/Options.h"
Alexey Samsonov609213f92013-08-19 09:14:21 +000024#include "clang/Driver/SanitizerArgs.h"
Daniel Dunbara3246a02009-03-18 08:07:30 +000025#include "clang/Driver/ToolChain.h"
Daniel Dunbar04c4c2c2009-03-18 07:06:02 +000026#include "clang/Driver/Util.h"
Benjamin Kramer33335df2015-03-01 21:36:40 +000027#include "llvm/ADT/STLExtras.h"
Daniel Dunbar1c28f1e2009-09-09 22:32:48 +000028#include "llvm/ADT/SmallString.h"
Hans Wennborg188382e2013-09-20 18:16:35 +000029#include "llvm/ADT/StringExtras.h"
Douglas Gregorf7b87cb2009-10-29 00:41:01 +000030#include "llvm/ADT/StringSwitch.h"
Daniel Dunbarb4a3e432009-09-09 22:32:34 +000031#include "llvm/ADT/Twine.h"
Reid Kleckner898229a2013-06-14 17:17:23 +000032#include "llvm/Option/Arg.h"
33#include "llvm/Option/ArgList.h"
34#include "llvm/Option/Option.h"
James Y Knight5bdf7ab2015-08-19 15:12:02 +000035#include "llvm/Support/CodeGen.h"
David Blaikie24bbfed22014-03-31 23:29:38 +000036#include "llvm/Support/Compression.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000037#include "llvm/Support/ErrorHandling.h"
Michael J. Spencerf6efe582011-01-10 02:34:13 +000038#include "llvm/Support/FileSystem.h"
Michael J. Spencer8aaf4992010-11-29 18:12:39 +000039#include "llvm/Support/Host.h"
Hans Wennborg188382e2013-09-20 18:16:35 +000040#include "llvm/Support/Path.h"
Michael J. Spencer8aaf4992010-11-29 18:12:39 +000041#include "llvm/Support/Process.h"
Chandler Carruth5553d0d2014-01-07 11:51:46 +000042#include "llvm/Support/Program.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000043#include "llvm/Support/raw_ostream.h"
James Y Knight5bdf7ab2015-08-19 15:12:02 +000044#include "llvm/Support/TargetParser.h"
Daniel Dunbar04c4c2c2009-03-18 07:06:02 +000045
Ben Langmuir3b7b5402015-02-03 19:28:37 +000046#ifdef LLVM_ON_UNIX
47#include <unistd.h> // For getuid().
48#endif
49
Daniel Dunbar1a093d22009-03-18 06:00:36 +000050using namespace clang::driver;
51using namespace clang::driver::tools;
Chris Lattner0e62c1c2011-07-23 10:55:15 +000052using namespace clang;
Reid Kleckner898229a2013-06-14 17:17:23 +000053using namespace llvm::opt;
Daniel Dunbar1a093d22009-03-18 06:00:36 +000054
Eric Christopher49062a52015-12-22 03:12:34 +000055static void handleTargetFeaturesGroup(const ArgList &Args,
56 std::vector<const char *> &Features,
57 OptSpecifier Group) {
58 for (const Arg *A : Args.filtered(Group)) {
59 StringRef Name = A->getOption().getName();
60 A->claim();
61
62 // Skip over "-m".
63 assert(Name.startswith("m") && "Invalid feature name.");
64 Name = Name.substr(1);
65
66 bool IsNegative = Name.startswith("no-");
67 if (IsNegative)
68 Name = Name.substr(3);
69 Features.push_back(Args.MakeArgString((IsNegative ? "-" : "+") + Name));
70 }
71}
72
Joerg Sonnenbergerec353d32015-11-09 23:39:45 +000073static const char *getSparcAsmModeForCPU(StringRef Name,
74 const llvm::Triple &Triple) {
75 if (Triple.getArch() == llvm::Triple::sparcv9) {
76 return llvm::StringSwitch<const char *>(Name)
77 .Case("niagara", "-Av9b")
78 .Case("niagara2", "-Av9b")
79 .Case("niagara3", "-Av9d")
80 .Case("niagara4", "-Av9d")
81 .Default("-Av9");
82 } else {
83 return llvm::StringSwitch<const char *>(Name)
84 .Case("v8", "-Av8")
85 .Case("supersparc", "-Av8")
86 .Case("sparclite", "-Asparclite")
87 .Case("f934", "-Asparclite")
88 .Case("hypersparc", "-Av8")
89 .Case("sparclite86x", "-Asparclite")
90 .Case("sparclet", "-Asparclet")
91 .Case("tsc701", "-Asparclet")
92 .Case("v9", "-Av8plus")
93 .Case("ultrasparc", "-Av8plus")
94 .Case("ultrasparc3", "-Av8plus")
95 .Case("niagara", "-Av8plusb")
96 .Case("niagara2", "-Av8plusb")
97 .Case("niagara3", "-Av8plusd")
98 .Case("niagara4", "-Av8plusd")
99 .Default("-Av8");
100 }
101}
102
Daniel Dunbar64198ef2009-09-10 01:21:05 +0000103/// CheckPreprocessingOptions - Perform some validation of preprocessing
104/// arguments that is shared with gcc.
105static void CheckPreprocessingOptions(const Driver &D, const ArgList &Args) {
Hans Wennborg8f008372014-06-11 19:44:53 +0000106 if (Arg *A = Args.getLastArg(options::OPT_C, options::OPT_CC)) {
107 if (!Args.hasArg(options::OPT_E) && !Args.hasArg(options::OPT__SLASH_P) &&
108 !Args.hasArg(options::OPT__SLASH_EP) && !D.CCCIsCPP()) {
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000109 D.Diag(diag::err_drv_argument_only_allowed_with)
Hans Wennborg8f008372014-06-11 19:44:53 +0000110 << A->getBaseArg().getAsString(Args)
111 << (D.IsCLMode() ? "/E, /P or /EP" : "-E");
112 }
113 }
Daniel Dunbar64198ef2009-09-10 01:21:05 +0000114}
115
Daniel Dunbar4eadb602009-09-10 01:21:12 +0000116/// CheckCodeGenerationOptions - Perform some validation of code generation
117/// arguments that is shared with gcc.
118static void CheckCodeGenerationOptions(const Driver &D, const ArgList &Args) {
119 // In gcc, only ARM checks this, but it seems reasonable to check universally.
120 if (Args.hasArg(options::OPT_static))
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000121 if (const Arg *A =
122 Args.getLastArg(options::OPT_dynamic, options::OPT_mdynamic_no_pic))
123 D.Diag(diag::err_drv_argument_not_allowed_with) << A->getAsString(Args)
124 << "-static";
Daniel Dunbar4eadb602009-09-10 01:21:12 +0000125}
126
Bob Wilsond5aad2a2014-11-04 22:28:48 +0000127// Add backslashes to escape spaces and other backslashes.
128// This is used for the space-separated argument list specified with
129// the -dwarf-debug-flags option.
130static void EscapeSpacesAndBackslashes(const char *Arg,
131 SmallVectorImpl<char> &Res) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000132 for (; *Arg; ++Arg) {
Bob Wilsond5aad2a2014-11-04 22:28:48 +0000133 switch (*Arg) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000134 default:
135 break;
Bob Wilsond5aad2a2014-11-04 22:28:48 +0000136 case ' ':
137 case '\\':
138 Res.push_back('\\');
139 break;
140 }
141 Res.push_back(*Arg);
142 }
143}
144
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000145// Quote target names for inclusion in GNU Make dependency files.
146// Only the characters '$', '#', ' ', '\t' are quoted.
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000147static void QuoteTarget(StringRef Target, SmallVectorImpl<char> &Res) {
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000148 for (unsigned i = 0, e = Target.size(); i != e; ++i) {
149 switch (Target[i]) {
150 case ' ':
151 case '\t':
152 // Escape the preceding backslashes
153 for (int j = i - 1; j >= 0 && Target[j] == '\\'; --j)
154 Res.push_back('\\');
155
156 // Escape the space/tab
157 Res.push_back('\\');
158 break;
159 case '$':
160 Res.push_back('$');
161 break;
162 case '#':
163 Res.push_back('\\');
164 break;
165 default:
166 break;
167 }
168
169 Res.push_back(Target[i]);
170 }
171}
172
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000173static void addDirectoryList(const ArgList &Args, ArgStringList &CmdArgs,
174 const char *ArgName, const char *EnvVar) {
Bill Wendlingc0938f32012-03-12 22:10:06 +0000175 const char *DirList = ::getenv(EnvVar);
Chad Rosier616e8a52012-10-30 21:42:09 +0000176 bool CombinedArg = false;
177
Bill Wendling281ca292012-03-12 21:22:35 +0000178 if (!DirList)
179 return; // Nothing to do.
180
Chad Rosier616e8a52012-10-30 21:42:09 +0000181 StringRef Name(ArgName);
182 if (Name.equals("-I") || Name.equals("-L"))
183 CombinedArg = true;
184
Bill Wendling281ca292012-03-12 21:22:35 +0000185 StringRef Dirs(DirList);
186 if (Dirs.empty()) // Empty string should not add '.'.
187 return;
188
189 StringRef::size_type Delim;
Rafael Espindola04b3fc42013-06-25 14:29:51 +0000190 while ((Delim = Dirs.find(llvm::sys::EnvPathSeparator)) != StringRef::npos) {
Bill Wendling281ca292012-03-12 21:22:35 +0000191 if (Delim == 0) { // Leading colon.
Chad Rosier616e8a52012-10-30 21:42:09 +0000192 if (CombinedArg) {
193 CmdArgs.push_back(Args.MakeArgString(std::string(ArgName) + "."));
194 } else {
195 CmdArgs.push_back(ArgName);
196 CmdArgs.push_back(".");
197 }
Bill Wendling281ca292012-03-12 21:22:35 +0000198 } else {
Chad Rosier616e8a52012-10-30 21:42:09 +0000199 if (CombinedArg) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000200 CmdArgs.push_back(
201 Args.MakeArgString(std::string(ArgName) + Dirs.substr(0, Delim)));
Chad Rosier616e8a52012-10-30 21:42:09 +0000202 } else {
203 CmdArgs.push_back(ArgName);
204 CmdArgs.push_back(Args.MakeArgString(Dirs.substr(0, Delim)));
205 }
Bill Wendling281ca292012-03-12 21:22:35 +0000206 }
Nico Weber89355782012-03-19 15:00:03 +0000207 Dirs = Dirs.substr(Delim + 1);
Bill Wendling281ca292012-03-12 21:22:35 +0000208 }
209
210 if (Dirs.empty()) { // Trailing colon.
Chad Rosier616e8a52012-10-30 21:42:09 +0000211 if (CombinedArg) {
212 CmdArgs.push_back(Args.MakeArgString(std::string(ArgName) + "."));
213 } else {
214 CmdArgs.push_back(ArgName);
215 CmdArgs.push_back(".");
216 }
Bill Wendling281ca292012-03-12 21:22:35 +0000217 } else { // Add the last path.
Chad Rosier616e8a52012-10-30 21:42:09 +0000218 if (CombinedArg) {
219 CmdArgs.push_back(Args.MakeArgString(std::string(ArgName) + Dirs));
220 } else {
221 CmdArgs.push_back(ArgName);
222 CmdArgs.push_back(Args.MakeArgString(Dirs));
223 }
Bill Wendling281ca292012-03-12 21:22:35 +0000224 }
225}
226
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000227static void AddLinkerInputs(const ToolChain &TC, const InputInfoList &Inputs,
228 const ArgList &Args, ArgStringList &CmdArgs) {
Daniel Dunbar54423b22010-09-17 00:24:54 +0000229 const Driver &D = TC.getDriver();
230
Daniel Dunbar1094bb12011-02-19 05:33:51 +0000231 // Add extra linker input arguments which are not treated as inputs
232 // (constructed via -Xarch_).
233 Args.AddAllArgValues(CmdArgs, options::OPT_Zlinker_input);
234
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +0000235 for (const auto &II : Inputs) {
Eric Christopherc1984072015-12-08 02:10:19 +0000236 if (!TC.HasNativeLLVMSupport() && types::isLLVMIR(II.getType()))
Daniel Dunbar54423b22010-09-17 00:24:54 +0000237 // Don't try to pass LLVM inputs unless we have native support.
Eric Christopherc1984072015-12-08 02:10:19 +0000238 D.Diag(diag::err_drv_no_linker_llvm_support) << TC.getTripleString();
Daniel Dunbar54423b22010-09-17 00:24:54 +0000239
Daniel Dunbar2cc3f172010-09-17 00:45:02 +0000240 // Add filenames immediately.
241 if (II.isFilename()) {
Daniel Dunbar54423b22010-09-17 00:24:54 +0000242 CmdArgs.push_back(II.getFilename());
Daniel Dunbar2cc3f172010-09-17 00:45:02 +0000243 continue;
244 }
245
246 // Otherwise, this is a linker input argument.
247 const Arg &A = II.getInputArg();
248
249 // Handle reserved library options.
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +0000250 if (A.getOption().matches(options::OPT_Z_reserved_lib_stdcxx))
Daniel Dunbar3f7796f2010-09-17 01:20:05 +0000251 TC.AddCXXStdlibLibArgs(Args, CmdArgs);
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +0000252 else if (A.getOption().matches(options::OPT_Z_reserved_lib_cckext))
Shantonu Senafeb03b2010-09-17 18:39:08 +0000253 TC.AddCCKextLibArgs(Args, CmdArgs);
Arthur Marble31fb6f42014-07-16 21:16:16 +0000254 else if (A.getOption().matches(options::OPT_z)) {
255 // Pass -z prefix for gcc linker compatibility.
256 A.claim();
257 A.render(Args, CmdArgs);
258 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000259 A.renderAsInput(Args, CmdArgs);
Arthur Marble31fb6f42014-07-16 21:16:16 +0000260 }
Daniel Dunbar54423b22010-09-17 00:24:54 +0000261 }
Bill Wendling281ca292012-03-12 21:22:35 +0000262
263 // LIBRARY_PATH - included following the user specified library paths.
Richard Barton5828d7b2013-12-17 11:11:25 +0000264 // and only supported on native toolchains.
265 if (!TC.isCrossCompiling())
266 addDirectoryList(Args, CmdArgs, "-L", "LIBRARY_PATH");
Daniel Dunbar54423b22010-09-17 00:24:54 +0000267}
268
John McCall31168b02011-06-15 23:02:42 +0000269/// \brief Determine whether Objective-C automated reference counting is
270/// enabled.
271static bool isObjCAutoRefCount(const ArgList &Args) {
272 return Args.hasFlag(options::OPT_fobjc_arc, options::OPT_fno_objc_arc, false);
273}
274
Ted Kremeneke65b0862012-03-06 20:05:56 +0000275/// \brief Determine whether we are linking the ObjC runtime.
276static bool isObjCRuntimeLinked(const ArgList &Args) {
Bob Wilson29536fc2012-08-07 19:58:00 +0000277 if (isObjCAutoRefCount(Args)) {
278 Args.ClaimAllArgs(options::OPT_fobjc_link_runtime);
Ted Kremeneke65b0862012-03-06 20:05:56 +0000279 return true;
Bob Wilson29536fc2012-08-07 19:58:00 +0000280 }
Ted Kremeneke65b0862012-03-06 20:05:56 +0000281 return Args.hasArg(options::OPT_fobjc_link_runtime);
282}
283
Michael J. Spencer66e2b202012-10-19 22:37:06 +0000284static bool forwardToGCC(const Option &O) {
Reid Kleckner3793d5e2013-06-19 15:09:06 +0000285 // Don't forward inputs from the original command line. They are added from
286 // InputInfoList.
Richard Smith8e5e9762013-06-20 01:33:59 +0000287 return O.getKind() != Option::InputClass &&
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000288 !O.hasFlag(options::DriverOption) && !O.hasFlag(options::LinkerInput);
Michael J. Spencer66e2b202012-10-19 22:37:06 +0000289}
290
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000291void Clang::AddPreprocessingOptions(Compilation &C, const JobAction &JA,
292 const Driver &D, const ArgList &Args,
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000293 ArgStringList &CmdArgs,
294 const InputInfo &Output,
Artem Belevichfa11ab52015-11-17 22:28:46 +0000295 const InputInfoList &Inputs,
296 const ToolChain *AuxToolChain) const {
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000297 Arg *A;
Daniel Dunbar367dbb92009-06-08 21:48:20 +0000298
Daniel Dunbar64198ef2009-09-10 01:21:05 +0000299 CheckPreprocessingOptions(D, Args);
300
301 Args.AddLastArg(CmdArgs, options::OPT_C);
302 Args.AddLastArg(CmdArgs, options::OPT_CC);
Daniel Dunbar367dbb92009-06-08 21:48:20 +0000303
304 // Handle dependency file generation.
Daniel Dunbar86aed7d2010-12-08 21:33:40 +0000305 if ((A = Args.getLastArg(options::OPT_M, options::OPT_MM)) ||
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000306 (A = Args.getLastArg(options::OPT_MD)) ||
307 (A = Args.getLastArg(options::OPT_MMD))) {
308 // Determine the output location.
309 const char *DepFile;
Benjamin Kramer2715fce2012-09-26 19:01:49 +0000310 if (Arg *MF = Args.getLastArg(options::OPT_MF)) {
Richard Smithbd55daf2012-11-01 04:30:05 +0000311 DepFile = MF->getValue();
Chad Rosier633dcdc2013-01-24 19:14:47 +0000312 C.addFailureResultFile(DepFile, &JA);
Benjamin Kramer2715fce2012-09-26 19:01:49 +0000313 } else if (Output.getType() == types::TY_Dependencies) {
314 DepFile = Output.getFilename();
Daniel Dunbar0bfb21e2009-11-19 03:26:40 +0000315 } else if (A->getOption().matches(options::OPT_M) ||
316 A->getOption().matches(options::OPT_MM)) {
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000317 DepFile = "-";
318 } else {
Bob Wilsondecc03e2012-11-23 06:14:39 +0000319 DepFile = getDependencyFileName(Args, Inputs);
Chad Rosier633dcdc2013-01-24 19:14:47 +0000320 C.addFailureResultFile(DepFile, &JA);
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000321 }
322 CmdArgs.push_back("-dependency-file");
323 CmdArgs.push_back(DepFile);
324
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000325 // Add a default target if one wasn't specified.
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000326 if (!Args.hasArg(options::OPT_MT) && !Args.hasArg(options::OPT_MQ)) {
327 const char *DepTarget;
328
329 // If user provided -o, that is the dependency target, except
330 // when we are only generating a dependency file.
331 Arg *OutputOpt = Args.getLastArg(options::OPT_o);
332 if (OutputOpt && Output.getType() != types::TY_Dependencies) {
Richard Smithbd55daf2012-11-01 04:30:05 +0000333 DepTarget = OutputOpt->getValue();
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000334 } else {
335 // Otherwise derive from the base input.
336 //
337 // FIXME: This should use the computed output file location.
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +0000338 SmallString<128> P(Inputs[0].getBaseInput());
Michael J. Spencere1696752010-12-18 00:19:12 +0000339 llvm::sys::path::replace_extension(P, "o");
340 DepTarget = Args.MakeArgString(llvm::sys::path::filename(P));
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000341 }
342
343 CmdArgs.push_back("-MT");
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +0000344 SmallString<128> Quoted;
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000345 QuoteTarget(DepTarget, Quoted);
346 CmdArgs.push_back(Args.MakeArgString(Quoted));
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000347 }
348
Daniel Dunbar0bfb21e2009-11-19 03:26:40 +0000349 if (A->getOption().matches(options::OPT_M) ||
350 A->getOption().matches(options::OPT_MD))
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000351 CmdArgs.push_back("-sys-header-deps");
Manuel Klimekc68aa162015-03-19 12:00:22 +0000352 if ((isa<PrecompileJobAction>(JA) &&
353 !Args.hasArg(options::OPT_fno_module_file_deps)) ||
354 Args.hasArg(options::OPT_fmodule_file_deps))
Argyrios Kyrtzidis6d0753d2014-03-14 03:07:38 +0000355 CmdArgs.push_back("-module-file-deps");
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000356 }
357
Peter Collingbourne77b0e7f22011-07-12 19:35:15 +0000358 if (Args.hasArg(options::OPT_MG)) {
359 if (!A || A->getOption().matches(options::OPT_MD) ||
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000360 A->getOption().matches(options::OPT_MMD))
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000361 D.Diag(diag::err_drv_mg_requires_m_or_mm);
Peter Collingbourne77b0e7f22011-07-12 19:35:15 +0000362 CmdArgs.push_back("-MG");
363 }
364
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000365 Args.AddLastArg(CmdArgs, options::OPT_MP);
Paul Robinsond7214a72015-04-27 18:14:32 +0000366 Args.AddLastArg(CmdArgs, options::OPT_MV);
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000367
368 // Convert all -MQ <target> args to -MT <quoted target>
Sean Silva14facf32015-06-09 01:57:17 +0000369 for (const Arg *A : Args.filtered(options::OPT_MT, options::OPT_MQ)) {
Daniel Dunbara442fd52010-06-11 22:00:13 +0000370 A->claim();
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000371
Daniel Dunbara442fd52010-06-11 22:00:13 +0000372 if (A->getOption().matches(options::OPT_MQ)) {
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000373 CmdArgs.push_back("-MT");
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +0000374 SmallString<128> Quoted;
Richard Smithbd55daf2012-11-01 04:30:05 +0000375 QuoteTarget(A->getValue(), Quoted);
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000376 CmdArgs.push_back(Args.MakeArgString(Quoted));
377
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000378 // -MT flag - no change
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000379 } else {
Daniel Dunbara442fd52010-06-11 22:00:13 +0000380 A->render(Args, CmdArgs);
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000381 }
382 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000383
Douglas Gregor111af7d2009-04-18 00:34:01 +0000384 // Add -i* options, and automatically translate to
385 // -include-pch/-include-pth for transparent PCH support. It's
386 // wonky, but we include looking for .gch so we can support seamless
387 // replacement into a build system already set up to be generating
388 // .gch files.
Nico Weber2ca4be92016-03-01 23:16:44 +0000389 int YcIndex = -1, YuIndex = -1;
390 {
391 int AI = -1;
392 const Arg *YcArg = Args.getLastArg(options::OPT__SLASH_Yc);
393 const Arg *YuArg = Args.getLastArg(options::OPT__SLASH_Yu);
394 for (const Arg *A : Args.filtered(options::OPT_clang_i_Group)) {
395 // Walk the whole i_Group and skip non "-include" flags so that the index
396 // here matches the index in the next loop below.
397 ++AI;
398 if (!A->getOption().matches(options::OPT_include))
399 continue;
400 if (YcArg && strcmp(A->getValue(), YcArg->getValue()) == 0)
401 YcIndex = AI;
402 if (YuArg && strcmp(A->getValue(), YuArg->getValue()) == 0)
403 YuIndex = AI;
404 }
405 }
406 if (isa<PrecompileJobAction>(JA) && YcIndex != -1) {
407 Driver::InputList Inputs;
408 D.BuildInputs(getToolChain(), C.getArgs(), Inputs);
409 assert(Inputs.size() == 1 && "Need one input when building pch");
410 CmdArgs.push_back(Args.MakeArgString(Twine("-find-pch-source=") +
411 Inputs[0].second->getValue()));
412 }
413
Argyrios Kyrtzidis2f23b412010-09-30 16:53:47 +0000414 bool RenderedImplicitInclude = false;
Nico Weber2ca4be92016-03-01 23:16:44 +0000415 int AI = -1;
Sean Silva14facf32015-06-09 01:57:17 +0000416 for (const Arg *A : Args.filtered(options::OPT_clang_i_Group)) {
Nico Weber2ca4be92016-03-01 23:16:44 +0000417 ++AI;
418
Nico Weberd8ff0ee2016-04-02 19:10:07 +0000419 if (getToolChain().getDriver().IsCLMode() &&
420 A->getOption().matches(options::OPT_include)) {
Junmo Parke19d6792016-03-17 06:41:27 +0000421 // In clang-cl mode, /Ycfoo.h means that all code up to a foo.h
Nico Weber2ca4be92016-03-01 23:16:44 +0000422 // include is compiled into foo.h, and everything after goes into
423 // the .obj file. /Yufoo.h means that all includes prior to and including
424 // foo.h are completely skipped and replaced with a use of the pch file
425 // for foo.h. (Each flag can have at most one value, multiple /Yc flags
426 // just mean that the last one wins.) If /Yc and /Yu are both present
427 // and refer to the same file, /Yc wins.
428 // Note that OPT__SLASH_FI gets mapped to OPT_include.
429 // FIXME: The code here assumes that /Yc and /Yu refer to the same file.
430 // cl.exe seems to support both flags with different values, but that
431 // seems strange (which flag does /Fp now refer to?), so don't implement
Nico Weberd1728f02016-03-23 18:17:02 +0000432 // that until someone needs it.
Nico Weber2ca4be92016-03-01 23:16:44 +0000433 int PchIndex = YcIndex != -1 ? YcIndex : YuIndex;
434 if (PchIndex != -1) {
435 if (isa<PrecompileJobAction>(JA)) {
436 // When building the pch, skip all includes after the pch.
437 assert(YcIndex != -1 && PchIndex == YcIndex);
438 if (AI >= YcIndex)
439 continue;
440 } else {
441 // When using the pch, skip all includes prior to the pch.
Nico Weberd1728f02016-03-23 18:17:02 +0000442 if (AI < PchIndex) {
443 A->claim();
Nico Weber2ca4be92016-03-01 23:16:44 +0000444 continue;
Nico Weberd1728f02016-03-23 18:17:02 +0000445 }
Nico Weber2ca4be92016-03-01 23:16:44 +0000446 if (AI == PchIndex) {
447 A->claim();
448 CmdArgs.push_back("-include-pch");
449 CmdArgs.push_back(
450 Args.MakeArgString(D.GetClPchPath(C, A->getValue())));
451 continue;
452 }
453 }
454 }
455 } else if (A->getOption().matches(options::OPT_include)) {
456 // Handling of gcc-style gch precompiled headers.
Argyrios Kyrtzidis2f23b412010-09-30 16:53:47 +0000457 bool IsFirstImplicitInclude = !RenderedImplicitInclude;
458 RenderedImplicitInclude = true;
459
Argyrios Kyrtzidis90bdfbb2010-08-11 23:27:58 +0000460 // Use PCH if the user requested it.
Daniel Dunbarcbc34b72009-10-15 20:02:44 +0000461 bool UsePCH = D.CCCUsePCH;
Daniel Dunbarcbc34b72009-10-15 20:02:44 +0000462
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000463 bool FoundPTH = false;
Douglas Gregor111af7d2009-04-18 00:34:01 +0000464 bool FoundPCH = false;
Rafael Espindola00eaafd2013-06-25 15:03:59 +0000465 SmallString<128> P(A->getValue());
466 // We want the files to have a name like foo.h.pch. Add a dummy extension
467 // so that replace_extension does the right thing.
468 P += ".dummy";
Daniel Dunbarcbc34b72009-10-15 20:02:44 +0000469 if (UsePCH) {
Rafael Espindola00eaafd2013-06-25 15:03:59 +0000470 llvm::sys::path::replace_extension(P, "pch");
Yaron Keren92e1b622015-03-18 10:17:07 +0000471 if (llvm::sys::fs::exists(P))
Douglas Gregor111af7d2009-04-18 00:34:01 +0000472 FoundPCH = true;
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000473 }
474
Douglas Gregor111af7d2009-04-18 00:34:01 +0000475 if (!FoundPCH) {
Rafael Espindola00eaafd2013-06-25 15:03:59 +0000476 llvm::sys::path::replace_extension(P, "pth");
Yaron Keren92e1b622015-03-18 10:17:07 +0000477 if (llvm::sys::fs::exists(P))
Douglas Gregor111af7d2009-04-18 00:34:01 +0000478 FoundPTH = true;
Mike Stump11289f42009-09-09 15:08:12 +0000479 }
480
Douglas Gregor111af7d2009-04-18 00:34:01 +0000481 if (!FoundPCH && !FoundPTH) {
Rafael Espindola00eaafd2013-06-25 15:03:59 +0000482 llvm::sys::path::replace_extension(P, "gch");
Yaron Keren92e1b622015-03-18 10:17:07 +0000483 if (llvm::sys::fs::exists(P)) {
Daniel Dunbarcbc34b72009-10-15 20:02:44 +0000484 FoundPCH = UsePCH;
485 FoundPTH = !UsePCH;
Douglas Gregor111af7d2009-04-18 00:34:01 +0000486 }
Douglas Gregor111af7d2009-04-18 00:34:01 +0000487 }
488
489 if (FoundPCH || FoundPTH) {
Argyrios Kyrtzidis2f23b412010-09-30 16:53:47 +0000490 if (IsFirstImplicitInclude) {
491 A->claim();
492 if (UsePCH)
493 CmdArgs.push_back("-include-pch");
494 else
495 CmdArgs.push_back("-include-pth");
Yaron Keren92e1b622015-03-18 10:17:07 +0000496 CmdArgs.push_back(Args.MakeArgString(P));
Argyrios Kyrtzidis2f23b412010-09-30 16:53:47 +0000497 continue;
498 } else {
499 // Ignore the PCH if not first on command line and emit warning.
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000500 D.Diag(diag::warn_drv_pch_not_first_include) << P
501 << A->getAsString(Args);
Argyrios Kyrtzidis2f23b412010-09-30 16:53:47 +0000502 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000503 }
504 }
505
506 // Not translated, render as usual.
507 A->claim();
508 A->render(Args, CmdArgs);
509 }
510
Douglas Katzman57a9c7e2015-07-29 18:39:14 +0000511 Args.AddAllArgs(CmdArgs,
512 {options::OPT_D, options::OPT_U, options::OPT_I_Group,
513 options::OPT_F, options::OPT_index_header_map});
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000514
Douglas Katzman9dc81a42015-10-02 14:41:38 +0000515 // Add -Wp, and -Xpreprocessor if using the preprocessor.
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000516
517 // FIXME: There is a very unfortunate problem here, some troubled
518 // souls abuse -Wp, to pass preprocessor options in gcc syntax. To
519 // really support that we would have to parse and then translate
520 // those options. :(
521 Args.AddAllArgValues(CmdArgs, options::OPT_Wp_COMMA,
522 options::OPT_Xpreprocessor);
Daniel Dunbar38b62792009-10-29 01:53:44 +0000523
524 // -I- is a deprecated GCC feature, reject it.
525 if (Arg *A = Args.getLastArg(options::OPT_I_))
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000526 D.Diag(diag::err_drv_I_dash_not_supported) << A->getAsString(Args);
Chandler Carruth24e17e12010-10-20 07:00:47 +0000527
528 // If we have a --sysroot, and don't have an explicit -isysroot flag, add an
529 // -isysroot to the CC1 invocation.
Sebastian Pop980920a2012-04-16 04:16:43 +0000530 StringRef sysroot = C.getSysRoot();
531 if (sysroot != "") {
Chandler Carruth24e17e12010-10-20 07:00:47 +0000532 if (!Args.hasArg(options::OPT_isysroot)) {
533 CmdArgs.push_back("-isysroot");
Sebastian Pop980920a2012-04-16 04:16:43 +0000534 CmdArgs.push_back(C.getArgs().MakeArgString(sysroot));
Chandler Carruth24e17e12010-10-20 07:00:47 +0000535 }
536 }
Douglas Gregor5dc38992013-02-07 00:21:12 +0000537
Benjamin Kramer8404eb02011-09-22 21:41:16 +0000538 // Parse additional include paths from environment variables.
Chandler Carruth9802c142011-11-04 07:12:58 +0000539 // FIXME: We should probably sink the logic for handling these from the
540 // frontend into the driver. It will allow deleting 4 otherwise unused flags.
Benjamin Kramer8404eb02011-09-22 21:41:16 +0000541 // CPATH - included following the user specified includes (but prior to
542 // builtin and standard includes).
Bill Wendlingc0938f32012-03-12 22:10:06 +0000543 addDirectoryList(Args, CmdArgs, "-I", "CPATH");
Benjamin Kramer8404eb02011-09-22 21:41:16 +0000544 // C_INCLUDE_PATH - system includes enabled when compiling C.
Bill Wendlingc0938f32012-03-12 22:10:06 +0000545 addDirectoryList(Args, CmdArgs, "-c-isystem", "C_INCLUDE_PATH");
Benjamin Kramer8404eb02011-09-22 21:41:16 +0000546 // CPLUS_INCLUDE_PATH - system includes enabled when compiling C++.
Bill Wendlingc0938f32012-03-12 22:10:06 +0000547 addDirectoryList(Args, CmdArgs, "-cxx-isystem", "CPLUS_INCLUDE_PATH");
Benjamin Kramer8404eb02011-09-22 21:41:16 +0000548 // OBJC_INCLUDE_PATH - system includes enabled when compiling ObjC.
Bill Wendlingc0938f32012-03-12 22:10:06 +0000549 addDirectoryList(Args, CmdArgs, "-objc-isystem", "OBJC_INCLUDE_PATH");
Benjamin Kramer8404eb02011-09-22 21:41:16 +0000550 // OBJCPLUS_INCLUDE_PATH - system includes enabled when compiling ObjC++.
Bill Wendlingc0938f32012-03-12 22:10:06 +0000551 addDirectoryList(Args, CmdArgs, "-objcxx-isystem", "OBJCPLUS_INCLUDE_PATH");
Chandler Carruth6bfd84f2011-11-04 07:12:53 +0000552
Artem Belevichfa11ab52015-11-17 22:28:46 +0000553 // Optional AuxToolChain indicates that we need to include headers
554 // for more than one target. If that's the case, add include paths
555 // from AuxToolChain right after include paths of the same kind for
556 // the current target.
557
Chandler Carruth6bfd84f2011-11-04 07:12:53 +0000558 // Add C++ include arguments, if needed.
Artem Belevichfa11ab52015-11-17 22:28:46 +0000559 if (types::isCXX(Inputs[0].getType())) {
Chandler Carruth491db322011-11-04 07:34:47 +0000560 getToolChain().AddClangCXXStdlibIncludeArgs(Args, CmdArgs);
Artem Belevichfa11ab52015-11-17 22:28:46 +0000561 if (AuxToolChain)
562 AuxToolChain->AddClangCXXStdlibIncludeArgs(Args, CmdArgs);
563 }
Chandler Carrutha796f532011-11-05 20:17:13 +0000564
565 // Add system include arguments.
566 getToolChain().AddClangSystemIncludeArgs(Args, CmdArgs);
Artem Belevichfa11ab52015-11-17 22:28:46 +0000567 if (AuxToolChain)
568 AuxToolChain->AddClangCXXStdlibIncludeArgs(Args, CmdArgs);
569
570 // Add CUDA include arguments, if needed.
571 if (types::isCuda(Inputs[0].getType()))
572 getToolChain().AddCudaIncludeArgs(Args, CmdArgs);
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000573}
574
Daniel Dunbard609b7b2009-11-17 06:37:03 +0000575// FIXME: Move to target hook.
576static bool isSignedCharDefault(const llvm::Triple &Triple) {
577 switch (Triple.getArch()) {
578 default:
579 return true;
580
Tim Northover9bb857a2013-01-31 12:13:10 +0000581 case llvm::Triple::aarch64:
Christian Pirker9b019ae2014-02-25 13:51:00 +0000582 case llvm::Triple::aarch64_be:
Jim Grosbach7c2c6642011-05-24 15:40:46 +0000583 case llvm::Triple::arm:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +0000584 case llvm::Triple::armeb:
Oliver Stannardabed2ee2014-10-24 11:28:47 +0000585 case llvm::Triple::thumb:
586 case llvm::Triple::thumbeb:
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +0000587 if (Triple.isOSDarwin() || Triple.isOSWindows())
588 return true;
589 return false;
590
Daniel Dunbard609b7b2009-11-17 06:37:03 +0000591 case llvm::Triple::ppc:
592 case llvm::Triple::ppc64:
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +0000593 if (Triple.isOSDarwin())
Daniel Dunbard609b7b2009-11-17 06:37:03 +0000594 return true;
595 return false;
Ulrich Weigand47445072013-05-06 16:26:41 +0000596
David Majnemerdcecd932015-05-23 19:23:55 +0000597 case llvm::Triple::hexagon:
Bill Schmidt778d3872013-07-26 01:36:11 +0000598 case llvm::Triple::ppc64le:
Ulrich Weigand47445072013-05-06 16:26:41 +0000599 case llvm::Triple::systemz:
Robert Lytton0e076492013-08-13 09:43:10 +0000600 case llvm::Triple::xcore:
Ulrich Weigand47445072013-05-06 16:26:41 +0000601 return false;
Daniel Dunbard609b7b2009-11-17 06:37:03 +0000602 }
603}
604
Robert Lytton0e076492013-08-13 09:43:10 +0000605static bool isNoCommonDefault(const llvm::Triple &Triple) {
606 switch (Triple.getArch()) {
607 default:
608 return false;
609
610 case llvm::Triple::xcore:
Dan Gohmanc2853072015-09-03 22:51:53 +0000611 case llvm::Triple::wasm32:
612 case llvm::Triple::wasm64:
Robert Lytton0e076492013-08-13 09:43:10 +0000613 return true;
614 }
615}
616
Renato Goline17c5802015-07-27 23:44:42 +0000617// ARM tools start.
618
619// Get SubArch (vN).
620static int getARMSubArchVersionNumber(const llvm::Triple &Triple) {
621 llvm::StringRef Arch = Triple.getArchName();
Chandler Carruthaa0caeb2015-08-30 02:16:36 +0000622 return llvm::ARM::parseArchVersion(Arch);
Renato Goline17c5802015-07-27 23:44:42 +0000623}
624
625// True if M-profile.
626static bool isARMMProfile(const llvm::Triple &Triple) {
627 llvm::StringRef Arch = Triple.getArchName();
Chandler Carruthaa0caeb2015-08-30 02:16:36 +0000628 unsigned Profile = llvm::ARM::parseArchProfile(Arch);
Renato Goline17c5802015-07-27 23:44:42 +0000629 return Profile == llvm::ARM::PK_M;
630}
631
632// Get Arch/CPU from args.
Renato Golin7c542b42015-07-27 23:44:45 +0000633static void getARMArchCPUFromArgs(const ArgList &Args, llvm::StringRef &Arch,
634 llvm::StringRef &CPU, bool FromAs = false) {
Renato Goline17c5802015-07-27 23:44:42 +0000635 if (const Arg *A = Args.getLastArg(options::OPT_mcpu_EQ))
636 CPU = A->getValue();
637 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ))
638 Arch = A->getValue();
Renato Golin7c542b42015-07-27 23:44:45 +0000639 if (!FromAs)
640 return;
641
642 for (const Arg *A :
643 Args.filtered(options::OPT_Wa_COMMA, options::OPT_Xassembler)) {
644 StringRef Value = A->getValue();
645 if (Value.startswith("-mcpu="))
646 CPU = Value.substr(6);
647 if (Value.startswith("-march="))
648 Arch = Value.substr(7);
649 }
Renato Goline17c5802015-07-27 23:44:42 +0000650}
651
Silviu Barangaf9671dd2013-10-21 10:54:53 +0000652// Handle -mhwdiv=.
Renato Golin7c542b42015-07-27 23:44:45 +0000653// FIXME: Use ARMTargetParser.
Silviu Barangaf9671dd2013-10-21 10:54:53 +0000654static void getARMHWDivFeatures(const Driver &D, const Arg *A,
Renato Golin7c542b42015-07-27 23:44:45 +0000655 const ArgList &Args, StringRef HWDiv,
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000656 std::vector<const char *> &Features) {
Chandler Carruthaa0caeb2015-08-30 02:16:36 +0000657 unsigned HWDivID = llvm::ARM::parseHWDiv(HWDiv);
658 if (!llvm::ARM::getHWDivFeatures(HWDivID, Features))
Silviu Barangaf9671dd2013-10-21 10:54:53 +0000659 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
660}
Reid Kleckner0290c9c2014-09-15 17:45:39 +0000661
Amara Emerson4cdb87b2013-10-01 10:20:54 +0000662// Handle -mfpu=.
Amara Emerson4cdb87b2013-10-01 10:20:54 +0000663static void getARMFPUFeatures(const Driver &D, const Arg *A,
Renato Golin7c542b42015-07-27 23:44:45 +0000664 const ArgList &Args, StringRef FPU,
Amara Emerson4cdb87b2013-10-01 10:20:54 +0000665 std::vector<const char *> &Features) {
Chandler Carruthaa0caeb2015-08-30 02:16:36 +0000666 unsigned FPUID = llvm::ARM::parseFPU(FPU);
667 if (!llvm::ARM::getFPUFeatures(FPUID, Features))
Chad Rosiercfbfc582012-04-04 20:51:35 +0000668 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
669}
670
Bradley Smithbbf5a002015-11-18 16:33:48 +0000671// Decode ARM features from string like +[no]featureA+[no]featureB+...
672static bool DecodeARMFeatures(const Driver &D, StringRef text,
673 std::vector<const char *> &Features) {
674 SmallVector<StringRef, 8> Split;
675 text.split(Split, StringRef("+"), -1, false);
676
677 for (StringRef Feature : Split) {
678 const char *FeatureName = llvm::ARM::getArchExtFeature(Feature);
679 if (FeatureName)
680 Features.push_back(FeatureName);
681 else
682 return false;
683 }
684 return true;
685}
686
Renato Golin7c542b42015-07-27 23:44:45 +0000687// Check if -march is valid by checking if it can be canonicalised and parsed.
688// getARMArch is used here instead of just checking the -march value in order
689// to handle -march=native correctly.
690static void checkARMArchName(const Driver &D, const Arg *A, const ArgList &Args,
Renato Goline17c5802015-07-27 23:44:42 +0000691 llvm::StringRef ArchName,
Bradley Smithbbf5a002015-11-18 16:33:48 +0000692 std::vector<const char *> &Features,
Renato Goline17c5802015-07-27 23:44:42 +0000693 const llvm::Triple &Triple) {
Bradley Smithbbf5a002015-11-18 16:33:48 +0000694 std::pair<StringRef, StringRef> Split = ArchName.split("+");
695
Renato Goline17c5802015-07-27 23:44:42 +0000696 std::string MArch = arm::getARMArch(ArchName, Triple);
Bradley Smithbbf5a002015-11-18 16:33:48 +0000697 if (llvm::ARM::parseArch(MArch) == llvm::ARM::AK_INVALID ||
698 (Split.second.size() && !DecodeARMFeatures(D, Split.second, Features)))
Renato Goline17c5802015-07-27 23:44:42 +0000699 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
John Brawn94fd9632015-05-21 12:19:49 +0000700}
701
Renato Golin7c542b42015-07-27 23:44:45 +0000702// Check -mcpu=. Needs ArchName to handle -mcpu=generic.
703static void checkARMCPUName(const Driver &D, const Arg *A, const ArgList &Args,
704 llvm::StringRef CPUName, llvm::StringRef ArchName,
Bradley Smithbbf5a002015-11-18 16:33:48 +0000705 std::vector<const char *> &Features,
Renato Goline17c5802015-07-27 23:44:42 +0000706 const llvm::Triple &Triple) {
Bradley Smithbbf5a002015-11-18 16:33:48 +0000707 std::pair<StringRef, StringRef> Split = CPUName.split("+");
708
Renato Goline17c5802015-07-27 23:44:42 +0000709 std::string CPU = arm::getARMTargetCPU(CPUName, ArchName, Triple);
Bradley Smithbbf5a002015-11-18 16:33:48 +0000710 if (arm::getLLVMArchSuffixForARM(CPU, ArchName, Triple).empty() ||
711 (Split.second.size() && !DecodeARMFeatures(D, Split.second, Features)))
Renato Goline17c5802015-07-27 23:44:42 +0000712 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
John Brawn94fd9632015-05-21 12:19:49 +0000713}
714
Akira Hatanaka9d99bb52015-08-26 19:00:11 +0000715static bool useAAPCSForMachO(const llvm::Triple &T) {
716 // The backend is hardwired to assume AAPCS for M-class processors, ensure
717 // the frontend matches that.
718 return T.getEnvironment() == llvm::Triple::EABI ||
719 T.getOS() == llvm::Triple::UnknownOS || isARMMProfile(T);
720}
721
Asiri Rathnayake9e3c7cb2014-10-03 09:11:41 +0000722// Select the float ABI as determined by -msoft-float, -mhard-float, and
723// -mfloat-abi=.
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +0000724arm::FloatABI arm::getARMFloatABI(const ToolChain &TC, const ArgList &Args) {
725 const Driver &D = TC.getDriver();
726 const llvm::Triple Triple(TC.ComputeEffectiveClangTriple(Args));
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000727 auto SubArch = getARMSubArchVersionNumber(Triple);
728 arm::FloatABI ABI = FloatABI::Invalid;
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000729 if (Arg *A =
730 Args.getLastArg(options::OPT_msoft_float, options::OPT_mhard_float,
731 options::OPT_mfloat_abi_EQ)) {
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000732 if (A->getOption().matches(options::OPT_msoft_float)) {
733 ABI = FloatABI::Soft;
734 } else if (A->getOption().matches(options::OPT_mhard_float)) {
735 ABI = FloatABI::Hard;
736 } else {
737 ABI = llvm::StringSwitch<arm::FloatABI>(A->getValue())
738 .Case("soft", FloatABI::Soft)
739 .Case("softfp", FloatABI::SoftFP)
740 .Case("hard", FloatABI::Hard)
741 .Default(FloatABI::Invalid);
742 if (ABI == FloatABI::Invalid && !StringRef(A->getValue()).empty()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000743 D.Diag(diag::err_drv_invalid_mfloat_abi) << A->getAsString(Args);
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000744 ABI = FloatABI::Soft;
Daniel Dunbar78485922009-09-10 23:00:09 +0000745 }
746 }
Akira Hatanaka9d99bb52015-08-26 19:00:11 +0000747
748 // It is incorrect to select hard float ABI on MachO platforms if the ABI is
749 // "apcs-gnu".
750 if (Triple.isOSBinFormatMachO() && !useAAPCSForMachO(Triple) &&
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000751 ABI == FloatABI::Hard) {
Akira Hatanaka9d99bb52015-08-26 19:00:11 +0000752 D.Diag(diag::err_drv_unsupported_opt_for_target) << A->getAsString(Args)
753 << Triple.getArchName();
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000754 }
Daniel Dunbar78485922009-09-10 23:00:09 +0000755 }
756
757 // If unspecified, choose the default based on the platform.
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000758 if (ABI == FloatABI::Invalid) {
Rafael Espindola0e1fb4f2010-06-28 17:18:09 +0000759 switch (Triple.getOS()) {
Bob Wilson6524dd32011-10-14 05:03:44 +0000760 case llvm::Triple::Darwin:
761 case llvm::Triple::MacOSX:
Tim Northover756447a2015-10-30 16:30:36 +0000762 case llvm::Triple::IOS:
763 case llvm::Triple::TvOS: {
Daniel Dunbar78485922009-09-10 23:00:09 +0000764 // Darwin defaults to "softfp" for v6 and v7.
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000765 ABI = (SubArch == 6 || SubArch == 7) ? FloatABI::SoftFP : FloatABI::Soft;
Tim Northoverd88ecb32016-01-27 19:32:40 +0000766 ABI = Triple.isWatchABI() ? FloatABI::Hard : ABI;
Daniel Dunbar78485922009-09-10 23:00:09 +0000767 break;
768 }
Tim Northover756447a2015-10-30 16:30:36 +0000769 case llvm::Triple::WatchOS:
770 ABI = FloatABI::Hard;
771 break;
Daniel Dunbar78485922009-09-10 23:00:09 +0000772
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +0000773 // FIXME: this is invalid for WindowsCE
774 case llvm::Triple::Win32:
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000775 ABI = FloatABI::Hard;
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +0000776 break;
777
Rafael Espindola0f207ed2012-12-13 04:17:14 +0000778 case llvm::Triple::FreeBSD:
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000779 switch (Triple.getEnvironment()) {
Renato Golinf4421f72014-02-19 10:44:07 +0000780 case llvm::Triple::GNUEABIHF:
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000781 ABI = FloatABI::Hard;
Renato Golinf4421f72014-02-19 10:44:07 +0000782 break;
783 default:
784 // FreeBSD defaults to soft float
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000785 ABI = FloatABI::Soft;
Renato Golinf4421f72014-02-19 10:44:07 +0000786 break;
787 }
Rafael Espindola0f207ed2012-12-13 04:17:14 +0000788 break;
789
Daniel Dunbar78485922009-09-10 23:00:09 +0000790 default:
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000791 switch (Triple.getEnvironment()) {
Jiangning Liu61b06cb2012-07-31 08:06:29 +0000792 case llvm::Triple::GNUEABIHF:
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000793 case llvm::Triple::EABIHF:
794 ABI = FloatABI::Hard;
Jiangning Liu61b06cb2012-07-31 08:06:29 +0000795 break;
Bob Wilsond1447c42011-02-04 17:59:28 +0000796 case llvm::Triple::GNUEABI:
Bob Wilsond1447c42011-02-04 17:59:28 +0000797 case llvm::Triple::EABI:
798 // EABI is always AAPCS, and if it was not marked 'hard', it's softfp
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000799 ABI = FloatABI::SoftFP;
Bob Wilsond1447c42011-02-04 17:59:28 +0000800 break;
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000801 case llvm::Triple::Android:
802 ABI = (SubArch == 7) ? FloatABI::SoftFP : FloatABI::Soft;
Chandler Carruthc89aa9d2012-01-10 19:47:42 +0000803 break;
Bob Wilsond1447c42011-02-04 17:59:28 +0000804 default:
805 // Assume "soft", but warn the user we are guessing.
Tim Northover99694fe2016-04-13 17:08:51 +0000806 if (Triple.isOSBinFormatMachO() &&
807 Triple.getSubArch() == llvm::Triple::ARMSubArch_v7em)
808 ABI = FloatABI::Hard;
809 else
810 ABI = FloatABI::Soft;
811
Saleem Abdulrasool377066a2014-03-27 22:50:18 +0000812 if (Triple.getOS() != llvm::Triple::UnknownOS ||
813 !Triple.isOSBinFormatMachO())
814 D.Diag(diag::warn_drv_assuming_mfloat_abi_is) << "soft";
Bob Wilsond1447c42011-02-04 17:59:28 +0000815 break;
816 }
Daniel Dunbar78485922009-09-10 23:00:09 +0000817 }
818 }
819
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000820 assert(ABI != FloatABI::Invalid && "must select an ABI");
821 return ABI;
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000822}
823
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +0000824static void getARMTargetFeatures(const ToolChain &TC,
825 const llvm::Triple &Triple,
Rafael Espindola28e1f4b2013-08-21 16:39:20 +0000826 const ArgList &Args,
Rafael Espindola9c6fb0f2013-11-23 14:36:40 +0000827 std::vector<const char *> &Features,
828 bool ForAS) {
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +0000829 const Driver &D = TC.getDriver();
830
Akira Hatanaka3fb33a52015-07-07 06:42:05 +0000831 bool KernelOrKext =
832 Args.hasArg(options::OPT_mkernel, options::OPT_fapple_kext);
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +0000833 arm::FloatABI ABI = arm::getARMFloatABI(TC, Args);
Renato Golin7c542b42015-07-27 23:44:45 +0000834 const Arg *WaCPU = nullptr, *WaFPU = nullptr;
835 const Arg *WaHDiv = nullptr, *WaArch = nullptr;
836
Nico Weber6e0ebae2015-04-29 21:16:40 +0000837 if (!ForAS) {
838 // FIXME: Note, this is a hack, the LLVM backend doesn't actually use these
839 // yet (it uses the -mfloat-abi and -msoft-float options), and it is
840 // stripped out by the ARM target. We should probably pass this a new
841 // -target-option, which is handled by the -cc1/-cc1as invocation.
842 //
843 // FIXME2: For consistency, it would be ideal if we set up the target
844 // machine state the same when using the frontend or the assembler. We don't
845 // currently do that for the assembler, we pass the options directly to the
846 // backend and never even instantiate the frontend TargetInfo. If we did,
847 // and used its handleTargetFeatures hook, then we could ensure the
848 // assembler and the frontend behave the same.
849
850 // Use software floating point operations?
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000851 if (ABI == arm::FloatABI::Soft)
Nico Weber6e0ebae2015-04-29 21:16:40 +0000852 Features.push_back("+soft-float");
853
854 // Use software floating point argument passing?
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000855 if (ABI != arm::FloatABI::Hard)
Nico Weber6e0ebae2015-04-29 21:16:40 +0000856 Features.push_back("+soft-float-abi");
Renato Golin7c542b42015-07-27 23:44:45 +0000857 } else {
858 // Here, we make sure that -Wa,-mfpu/cpu/arch/hwdiv will be passed down
859 // to the assembler correctly.
860 for (const Arg *A :
861 Args.filtered(options::OPT_Wa_COMMA, options::OPT_Xassembler)) {
862 StringRef Value = A->getValue();
863 if (Value.startswith("-mfpu=")) {
864 WaFPU = A;
865 } else if (Value.startswith("-mcpu=")) {
866 WaCPU = A;
867 } else if (Value.startswith("-mhwdiv=")) {
868 WaHDiv = A;
869 } else if (Value.startswith("-march=")) {
870 WaArch = A;
871 }
872 }
Nico Weber6e0ebae2015-04-29 21:16:40 +0000873 }
874
Renato Golin7c542b42015-07-27 23:44:45 +0000875 // Check -march. ClangAs gives preference to -Wa,-march=.
876 const Arg *ArchArg = Args.getLastArg(options::OPT_march_EQ);
Renato Goline17c5802015-07-27 23:44:42 +0000877 StringRef ArchName;
Renato Golin7c542b42015-07-27 23:44:45 +0000878 if (WaArch) {
879 if (ArchArg)
880 D.Diag(clang::diag::warn_drv_unused_argument)
881 << ArchArg->getAsString(Args);
882 ArchName = StringRef(WaArch->getValue()).substr(7);
Bradley Smithbbf5a002015-11-18 16:33:48 +0000883 checkARMArchName(D, WaArch, Args, ArchName, Features, Triple);
Renato Golin7c542b42015-07-27 23:44:45 +0000884 // FIXME: Set Arch.
885 D.Diag(clang::diag::warn_drv_unused_argument) << WaArch->getAsString(Args);
886 } else if (ArchArg) {
887 ArchName = ArchArg->getValue();
Bradley Smithbbf5a002015-11-18 16:33:48 +0000888 checkARMArchName(D, ArchArg, Args, ArchName, Features, Triple);
John Brawn94fd9632015-05-21 12:19:49 +0000889 }
890
Renato Golin7c542b42015-07-27 23:44:45 +0000891 // Check -mcpu. ClangAs gives preference to -Wa,-mcpu=.
892 const Arg *CPUArg = Args.getLastArg(options::OPT_mcpu_EQ);
Renato Goline17c5802015-07-27 23:44:42 +0000893 StringRef CPUName;
Renato Golin7c542b42015-07-27 23:44:45 +0000894 if (WaCPU) {
895 if (CPUArg)
896 D.Diag(clang::diag::warn_drv_unused_argument)
897 << CPUArg->getAsString(Args);
898 CPUName = StringRef(WaCPU->getValue()).substr(6);
Bradley Smithbbf5a002015-11-18 16:33:48 +0000899 checkARMCPUName(D, WaCPU, Args, CPUName, ArchName, Features, Triple);
Renato Golin7c542b42015-07-27 23:44:45 +0000900 } else if (CPUArg) {
901 CPUName = CPUArg->getValue();
Bradley Smithbbf5a002015-11-18 16:33:48 +0000902 checkARMCPUName(D, CPUArg, Args, CPUName, ArchName, Features, Triple);
John Brawn94fd9632015-05-21 12:19:49 +0000903 }
John Brawna95c1a82015-05-08 12:52:18 +0000904
Renato Golin23459c62015-07-30 16:40:17 +0000905 // Add CPU features for generic CPUs
906 if (CPUName == "native") {
907 llvm::StringMap<bool> HostFeatures;
908 if (llvm::sys::getHostCPUFeatures(HostFeatures))
909 for (auto &F : HostFeatures)
910 Features.push_back(
911 Args.MakeArgString((F.second ? "+" : "-") + F.first()));
912 }
913
914 // Honor -mfpu=. ClangAs gives preference to -Wa,-mfpu=.
915 const Arg *FPUArg = Args.getLastArg(options::OPT_mfpu_EQ);
916 if (WaFPU) {
917 if (FPUArg)
918 D.Diag(clang::diag::warn_drv_unused_argument)
919 << FPUArg->getAsString(Args);
920 getARMFPUFeatures(D, WaFPU, Args, StringRef(WaFPU->getValue()).substr(6),
921 Features);
922 } else if (FPUArg) {
923 getARMFPUFeatures(D, FPUArg, Args, FPUArg->getValue(), Features);
924 }
925
926 // Honor -mhwdiv=. ClangAs gives preference to -Wa,-mhwdiv=.
927 const Arg *HDivArg = Args.getLastArg(options::OPT_mhwdiv_EQ);
928 if (WaHDiv) {
929 if (HDivArg)
930 D.Diag(clang::diag::warn_drv_unused_argument)
931 << HDivArg->getAsString(Args);
932 getARMHWDivFeatures(D, WaHDiv, Args,
933 StringRef(WaHDiv->getValue()).substr(8), Features);
934 } else if (HDivArg)
935 getARMHWDivFeatures(D, HDivArg, Args, HDivArg->getValue(), Features);
936
Rafael Espindola28e1f4b2013-08-21 16:39:20 +0000937 // Setting -msoft-float effectively disables NEON because of the GCC
938 // implementation, although the same isn't true of VFP or VFP3.
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000939 if (ABI == arm::FloatABI::Soft) {
Rafael Espindola28e1f4b2013-08-21 16:39:20 +0000940 Features.push_back("-neon");
Amara Emersonecbe18e2014-02-12 10:22:35 +0000941 // Also need to explicitly disable features which imply NEON.
942 Features.push_back("-crypto");
943 }
Bernard Ogden18b57012013-10-29 09:47:51 +0000944
Eric Christopher269c2a22015-04-04 03:34:43 +0000945 // En/disable crc code generation.
946 if (Arg *A = Args.getLastArg(options::OPT_mcrc, options::OPT_mnocrc)) {
Bernard Ogden18b57012013-10-29 09:47:51 +0000947 if (A->getOption().matches(options::OPT_mcrc))
948 Features.push_back("+crc");
949 else
950 Features.push_back("-crc");
951 }
Vladimir Sukharevc6dab752015-05-14 08:25:18 +0000952
Akira Hatanakac2694822015-07-07 08:28:42 +0000953 // Look for the last occurrence of -mlong-calls or -mno-long-calls. If
954 // neither options are specified, see if we are compiling for kernel/kext and
955 // decide whether to pass "+long-calls" based on the OS and its version.
Akira Hatanaka3fb33a52015-07-07 06:42:05 +0000956 if (Arg *A = Args.getLastArg(options::OPT_mlong_calls,
957 options::OPT_mno_long_calls)) {
958 if (A->getOption().matches(options::OPT_mlong_calls))
959 Features.push_back("+long-calls");
Tim Northover756447a2015-10-30 16:30:36 +0000960 } else if (KernelOrKext && (!Triple.isiOS() || Triple.isOSVersionLT(6)) &&
961 !Triple.isWatchOS()) {
Akira Hatanaka3fb33a52015-07-07 06:42:05 +0000962 Features.push_back("+long-calls");
963 }
Akira Hatanaka580efb22015-07-16 00:43:00 +0000964
Akira Hatanaka7651dd82015-07-28 22:26:45 +0000965 // Kernel code has more strict alignment requirements.
966 if (KernelOrKext)
967 Features.push_back("+strict-align");
968 else if (Arg *A = Args.getLastArg(options::OPT_mno_unaligned_access,
969 options::OPT_munaligned_access)) {
970 if (A->getOption().matches(options::OPT_munaligned_access)) {
971 // No v6M core supports unaligned memory access (v6M ARM ARM A3.2).
972 if (Triple.getSubArch() == llvm::Triple::SubArchType::ARMSubArch_v6m)
973 D.Diag(diag::err_target_unsupported_unaligned) << "v6m";
Bradley Smithf4affc12016-03-03 13:52:22 +0000974 // v8M Baseline follows on from v6M, so doesn't support unaligned memory
975 // access either.
976 else if (Triple.getSubArch() == llvm::Triple::SubArchType::ARMSubArch_v8m_baseline)
977 D.Diag(diag::err_target_unsupported_unaligned) << "v8m.base";
Akira Hatanaka7651dd82015-07-28 22:26:45 +0000978 } else
979 Features.push_back("+strict-align");
980 } else {
981 // Assume pre-ARMv6 doesn't support unaligned accesses.
982 //
983 // ARMv6 may or may not support unaligned accesses depending on the
984 // SCTLR.U bit, which is architecture-specific. We assume ARMv6
985 // Darwin and NetBSD targets support unaligned accesses, and others don't.
986 //
987 // ARMv7 always has SCTLR.U set to 1, but it has a new SCTLR.A bit
988 // which raises an alignment fault on unaligned accesses. Linux
989 // defaults this bit to 0 and handles it as a system-wide (not
990 // per-process) setting. It is therefore safe to assume that ARMv7+
991 // Linux targets support unaligned accesses. The same goes for NaCl.
992 //
993 // The above behavior is consistent with GCC.
994 int VersionNum = getARMSubArchVersionNumber(Triple);
995 if (Triple.isOSDarwin() || Triple.isOSNetBSD()) {
Alexandros Lamprineaseda554a2015-10-05 12:45:10 +0000996 if (VersionNum < 6 ||
997 Triple.getSubArch() == llvm::Triple::SubArchType::ARMSubArch_v6m)
Akira Hatanaka7651dd82015-07-28 22:26:45 +0000998 Features.push_back("+strict-align");
999 } else if (Triple.isOSLinux() || Triple.isOSNaCl()) {
1000 if (VersionNum < 7)
1001 Features.push_back("+strict-align");
1002 } else
1003 Features.push_back("+strict-align");
1004 }
1005
Akira Hatanaka0a23fac2015-07-21 01:41:08 +00001006 // llvm does not support reserving registers in general. There is support
1007 // for reserving r9 on ARM though (defined as a platform-specific register
1008 // in ARM EABI).
1009 if (Args.hasArg(options::OPT_ffixed_r9))
1010 Features.push_back("+reserve-r9");
1011
Dimitry Andric08107392016-01-06 07:42:18 +00001012 // The kext linker doesn't know how to deal with movw/movt.
1013 if (KernelOrKext || Args.hasArg(options::OPT_mno_movt))
Akira Hatanaka580efb22015-07-16 00:43:00 +00001014 Features.push_back("+no-movt");
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001015}
Anton Korobeynikova29e4622012-04-09 13:38:30 +00001016
Saleem Abdulrasoolce63ce92015-09-19 18:19:44 +00001017void Clang::AddARMTargetArgs(const llvm::Triple &Triple, const ArgList &Args,
1018 ArgStringList &CmdArgs, bool KernelOrKext) const {
Anton Korobeynikova29e4622012-04-09 13:38:30 +00001019 // Select the ABI to use.
Anton Korobeynikova29e4622012-04-09 13:38:30 +00001020 // FIXME: Support -meabi.
Eric Christopher52276532014-12-10 22:58:34 +00001021 // FIXME: Parts of this are duplicated in the backend, unify this somehow.
Craig Topper92fc2df2014-05-17 16:56:41 +00001022 const char *ABIName = nullptr;
Anton Korobeynikova29e4622012-04-09 13:38:30 +00001023 if (Arg *A = Args.getLastArg(options::OPT_mabi_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00001024 ABIName = A->getValue();
Tim Northovere5c6f4c2014-05-22 12:54:30 +00001025 } else if (Triple.isOSBinFormatMachO()) {
Akira Hatanaka9d99bb52015-08-26 19:00:11 +00001026 if (useAAPCSForMachO(Triple)) {
Daniel Dunbar5f18f6e2012-10-22 18:30:51 +00001027 ABIName = "aapcs";
Tim Northoverd88ecb32016-01-27 19:32:40 +00001028 } else if (Triple.isWatchABI()) {
Tim Northover756447a2015-10-30 16:30:36 +00001029 ABIName = "aapcs16";
Daniel Dunbar5f18f6e2012-10-22 18:30:51 +00001030 } else {
1031 ABIName = "apcs-gnu";
1032 }
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +00001033 } else if (Triple.isOSWindows()) {
1034 // FIXME: this is invalid for WindowsCE
1035 ABIName = "aapcs";
Anton Korobeynikova29e4622012-04-09 13:38:30 +00001036 } else {
1037 // Select the default based on the platform.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001038 switch (Triple.getEnvironment()) {
Logan Chienc6fd8202012-09-02 09:30:11 +00001039 case llvm::Triple::Android:
Anton Korobeynikova29e4622012-04-09 13:38:30 +00001040 case llvm::Triple::GNUEABI:
Jiangning Liu61b06cb2012-07-31 08:06:29 +00001041 case llvm::Triple::GNUEABIHF:
Anton Korobeynikova29e4622012-04-09 13:38:30 +00001042 ABIName = "aapcs-linux";
1043 break;
Joerg Sonnenbergerd75a1f82013-12-16 19:16:04 +00001044 case llvm::Triple::EABIHF:
Anton Korobeynikova29e4622012-04-09 13:38:30 +00001045 case llvm::Triple::EABI:
1046 ABIName = "aapcs";
1047 break;
Oliver Stannardec8b6b32014-09-04 10:38:53 +00001048 default:
Eric Christopher7a8b31d2014-12-18 02:08:51 +00001049 if (Triple.getOS() == llvm::Triple::NetBSD)
1050 ABIName = "apcs-gnu";
1051 else
1052 ABIName = "aapcs";
Oliver Stannardec8b6b32014-09-04 10:38:53 +00001053 break;
Anton Korobeynikova29e4622012-04-09 13:38:30 +00001054 }
1055 }
1056 CmdArgs.push_back("-target-abi");
1057 CmdArgs.push_back(ABIName);
1058
Anton Korobeynikova29e4622012-04-09 13:38:30 +00001059 // Determine floating point ABI from the options & target defaults.
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00001060 arm::FloatABI ABI = arm::getARMFloatABI(getToolChain(), Args);
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +00001061 if (ABI == arm::FloatABI::Soft) {
Daniel Dunbar78485922009-09-10 23:00:09 +00001062 // Floating point operations and argument passing are soft.
Daniel Dunbar78485922009-09-10 23:00:09 +00001063 // FIXME: This changes CPP defines, we need -target-soft-float.
Daniel Dunbara74f8ff2009-11-30 08:42:00 +00001064 CmdArgs.push_back("-msoft-float");
Daniel Dunbar6cc525b2009-12-08 19:49:51 +00001065 CmdArgs.push_back("-mfloat-abi");
1066 CmdArgs.push_back("soft");
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +00001067 } else if (ABI == arm::FloatABI::SoftFP) {
Daniel Dunbar78485922009-09-10 23:00:09 +00001068 // Floating point operations are hard, but argument passing is soft.
Daniel Dunbar6cc525b2009-12-08 19:49:51 +00001069 CmdArgs.push_back("-mfloat-abi");
1070 CmdArgs.push_back("soft");
Daniel Dunbar78485922009-09-10 23:00:09 +00001071 } else {
1072 // Floating point operations and argument passing are hard.
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +00001073 assert(ABI == arm::FloatABI::Hard && "Invalid float abi!");
Daniel Dunbar6cc525b2009-12-08 19:49:51 +00001074 CmdArgs.push_back("-mfloat-abi");
1075 CmdArgs.push_back("hard");
Daniel Dunbar78485922009-09-10 23:00:09 +00001076 }
Daniel Dunbar893d4752009-12-19 04:15:38 +00001077
Ahmed Bougacha256a8692015-04-11 00:10:44 +00001078 // Forward the -mglobal-merge option for explicit control over the pass.
Chad Rosierba3df1d2011-08-26 00:26:29 +00001079 if (Arg *A = Args.getLastArg(options::OPT_mglobal_merge,
1080 options::OPT_mno_global_merge)) {
Ahmed Bougacha256a8692015-04-11 00:10:44 +00001081 CmdArgs.push_back("-backend-option");
Chad Rosierba3df1d2011-08-26 00:26:29 +00001082 if (A->getOption().matches(options::OPT_mno_global_merge))
Ahmed Bougacha256a8692015-04-11 00:10:44 +00001083 CmdArgs.push_back("-arm-global-merge=false");
1084 else
1085 CmdArgs.push_back("-arm-global-merge=true");
Chad Rosierba3df1d2011-08-26 00:26:29 +00001086 }
Chad Rosierf1985d22012-05-16 20:40:09 +00001087
Bob Wilson9c8af452013-04-11 18:53:25 +00001088 if (!Args.hasFlag(options::OPT_mimplicit_float,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001089 options::OPT_mno_implicit_float, true))
Chad Rosierf1985d22012-05-16 20:40:09 +00001090 CmdArgs.push_back("-no-implicit-float");
Daniel Dunbar0f5c5422009-09-10 04:57:17 +00001091}
Renato Goline17c5802015-07-27 23:44:42 +00001092// ARM tools end.
Daniel Dunbar0f5c5422009-09-10 04:57:17 +00001093
Tim Northover573cbee2014-05-24 12:52:07 +00001094/// getAArch64TargetCPU - Get the (LLVM) name of the AArch64 cpu we are
1095/// targeting.
1096static std::string getAArch64TargetCPU(const ArgList &Args) {
Kevin Qin110db6f2014-07-18 07:03:22 +00001097 Arg *A;
1098 std::string CPU;
1099 // If we have -mtune or -mcpu, use that.
1100 if ((A = Args.getLastArg(options::OPT_mtune_EQ))) {
Gabor Ballabasa24a1a42015-07-20 11:28:20 +00001101 CPU = StringRef(A->getValue()).lower();
Kevin Qin110db6f2014-07-18 07:03:22 +00001102 } else if ((A = Args.getLastArg(options::OPT_mcpu_EQ))) {
Renato Golin4045f662015-05-08 15:44:36 +00001103 StringRef Mcpu = A->getValue();
Gabor Ballabas726ce7f2015-06-12 17:33:37 +00001104 CPU = Mcpu.split("+").first.lower();
Tim Northovera2ee4332014-03-29 15:09:45 +00001105 }
1106
Kevin Qin110db6f2014-07-18 07:03:22 +00001107 // Handle CPU name is 'native'.
1108 if (CPU == "native")
1109 return llvm::sys::getHostCPUName();
1110 else if (CPU.size())
1111 return CPU;
Tim Northovera2ee4332014-03-29 15:09:45 +00001112
James Molloy9b1586b2014-04-17 12:51:17 +00001113 // Make sure we pick "cyclone" if -arch is used.
1114 // FIXME: Should this be picked by checking the target triple instead?
1115 if (Args.getLastArg(options::OPT_arch))
1116 return "cyclone";
1117
1118 return "generic";
Tim Northovera2ee4332014-03-29 15:09:45 +00001119}
1120
Tim Northover573cbee2014-05-24 12:52:07 +00001121void Clang::AddAArch64TargetArgs(const ArgList &Args,
1122 ArgStringList &CmdArgs) const {
Tim Northovera2ee4332014-03-29 15:09:45 +00001123 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
1124 llvm::Triple Triple(TripleStr);
1125
1126 if (!Args.hasFlag(options::OPT_mred_zone, options::OPT_mno_red_zone, true) ||
1127 Args.hasArg(options::OPT_mkernel) ||
1128 Args.hasArg(options::OPT_fapple_kext))
1129 CmdArgs.push_back("-disable-red-zone");
1130
1131 if (!Args.hasFlag(options::OPT_mimplicit_float,
1132 options::OPT_mno_implicit_float, true))
1133 CmdArgs.push_back("-no-implicit-float");
1134
Craig Topper92fc2df2014-05-17 16:56:41 +00001135 const char *ABIName = nullptr;
Tim Northovera2ee4332014-03-29 15:09:45 +00001136 if (Arg *A = Args.getLastArg(options::OPT_mabi_EQ))
1137 ABIName = A->getValue();
1138 else if (Triple.isOSDarwin())
1139 ABIName = "darwinpcs";
1140 else
1141 ABIName = "aapcs";
1142
1143 CmdArgs.push_back("-target-abi");
1144 CmdArgs.push_back(ABIName);
1145
Bradley Smith9ff64332014-10-13 10:16:06 +00001146 if (Arg *A = Args.getLastArg(options::OPT_mfix_cortex_a53_835769,
1147 options::OPT_mno_fix_cortex_a53_835769)) {
1148 CmdArgs.push_back("-backend-option");
1149 if (A->getOption().matches(options::OPT_mfix_cortex_a53_835769))
1150 CmdArgs.push_back("-aarch64-fix-cortex-a53-835769=1");
1151 else
1152 CmdArgs.push_back("-aarch64-fix-cortex-a53-835769=0");
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00001153 } else if (Triple.isAndroid()) {
Bradley Smith04ee8aa2014-10-16 16:35:14 +00001154 // Enabled A53 errata (835769) workaround by default on android
1155 CmdArgs.push_back("-backend-option");
1156 CmdArgs.push_back("-aarch64-fix-cortex-a53-835769=1");
Bradley Smith9ff64332014-10-13 10:16:06 +00001157 }
1158
Ahmed Bougacha256a8692015-04-11 00:10:44 +00001159 // Forward the -mglobal-merge option for explicit control over the pass.
Bob Wilsonbdd2b3c2014-05-29 19:43:02 +00001160 if (Arg *A = Args.getLastArg(options::OPT_mglobal_merge,
1161 options::OPT_mno_global_merge)) {
Ahmed Bougacha256a8692015-04-11 00:10:44 +00001162 CmdArgs.push_back("-backend-option");
Bob Wilsonbdd2b3c2014-05-29 19:43:02 +00001163 if (A->getOption().matches(options::OPT_mno_global_merge))
Ahmed Bougacha256a8692015-04-11 00:10:44 +00001164 CmdArgs.push_back("-aarch64-global-merge=false");
1165 else
1166 CmdArgs.push_back("-aarch64-global-merge=true");
Bob Wilsonbdd2b3c2014-05-29 19:43:02 +00001167 }
Tim Northovera2ee4332014-03-29 15:09:45 +00001168}
1169
Simon Atanasyan3b7589a2012-04-07 22:09:23 +00001170// Get CPU and ABI names. They are not independent
1171// so we have to calculate them together.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001172void mips::getMipsCPUAndABI(const ArgList &Args, const llvm::Triple &Triple,
1173 StringRef &CPUName, StringRef &ABIName) {
Simon Atanasyan1a3665b62014-01-27 13:59:04 +00001174 const char *DefMips32CPU = "mips32r2";
1175 const char *DefMips64CPU = "mips64r2";
Akira Hatanaka37fd9e92011-09-26 21:07:52 +00001176
Daniel Sanders2bf13662014-07-10 14:40:57 +00001177 // MIPS32r6 is the default for mips(el)?-img-linux-gnu and MIPS64r6 is the
1178 // default for mips64(el)?-img-linux-gnu.
1179 if (Triple.getVendor() == llvm::Triple::ImaginationTechnologies &&
1180 Triple.getEnvironment() == llvm::Triple::GNU) {
1181 DefMips32CPU = "mips32r6";
1182 DefMips64CPU = "mips64r6";
1183 }
Renato Golin7c542b42015-07-27 23:44:45 +00001184
Petar Jovanovic9fe32cd2015-07-17 12:57:30 +00001185 // MIPS64r6 is the default for Android MIPS64 (mips64el-linux-android).
Petar Jovanovic009494f2016-05-17 10:46:10 +00001186 if (Triple.isAndroid()) {
1187 DefMips32CPU = "mips32";
Petar Jovanovic9fe32cd2015-07-17 12:57:30 +00001188 DefMips64CPU = "mips64r6";
Petar Jovanovic009494f2016-05-17 10:46:10 +00001189 }
Daniel Sanders2bf13662014-07-10 14:40:57 +00001190
Brad Smithba26f582015-01-06 02:53:17 +00001191 // MIPS3 is the default for mips64*-unknown-openbsd.
1192 if (Triple.getOS() == llvm::Triple::OpenBSD)
1193 DefMips64CPU = "mips3";
1194
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001195 if (Arg *A = Args.getLastArg(options::OPT_march_EQ, options::OPT_mcpu_EQ))
Simon Atanasyane0cc7c72013-10-09 12:12:24 +00001196 CPUName = A->getValue();
Simon Atanasyan464a7f72012-09-10 08:32:41 +00001197
Simon Atanasyan4938ddb2013-04-21 13:30:10 +00001198 if (Arg *A = Args.getLastArg(options::OPT_mabi_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00001199 ABIName = A->getValue();
Simon Atanasyan4938ddb2013-04-21 13:30:10 +00001200 // Convert a GNU style Mips ABI name to the name
1201 // accepted by LLVM Mips backend.
1202 ABIName = llvm::StringSwitch<llvm::StringRef>(ABIName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001203 .Case("32", "o32")
1204 .Case("64", "n64")
1205 .Default(ABIName);
Simon Atanasyan4938ddb2013-04-21 13:30:10 +00001206 }
Simon Atanasyan464a7f72012-09-10 08:32:41 +00001207
1208 // Setup default CPU and ABI names.
1209 if (CPUName.empty() && ABIName.empty()) {
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001210 switch (Triple.getArch()) {
Simon Atanasyan464a7f72012-09-10 08:32:41 +00001211 default:
1212 llvm_unreachable("Unexpected triple arch name");
1213 case llvm::Triple::mips:
1214 case llvm::Triple::mipsel:
1215 CPUName = DefMips32CPU;
1216 break;
1217 case llvm::Triple::mips64:
1218 case llvm::Triple::mips64el:
1219 CPUName = DefMips64CPU;
1220 break;
1221 }
1222 }
1223
Simon Atanasyana42a84e2014-07-02 13:20:36 +00001224 if (ABIName.empty()) {
1225 // Deduce ABI name from the target triple.
1226 if (Triple.getArch() == llvm::Triple::mips ||
1227 Triple.getArch() == llvm::Triple::mipsel)
1228 ABIName = "o32";
1229 else
1230 ABIName = "n64";
1231 }
1232
1233 if (CPUName.empty()) {
Simon Atanasyan464a7f72012-09-10 08:32:41 +00001234 // Deduce CPU name from ABI name.
1235 CPUName = llvm::StringSwitch<const char *>(ABIName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001236 .Cases("o32", "eabi", DefMips32CPU)
1237 .Cases("n32", "n64", DefMips64CPU)
1238 .Default("");
Simon Atanasyan464a7f72012-09-10 08:32:41 +00001239 }
Simon Atanasyanc92717f2014-07-23 09:27:10 +00001240
1241 // FIXME: Warn on inconsistent use of -march and -mabi.
Simon Atanasyan3b7589a2012-04-07 22:09:23 +00001242}
1243
Vasileios Kalintirisc744e122015-11-12 15:26:54 +00001244std::string mips::getMipsABILibSuffix(const ArgList &Args,
1245 const llvm::Triple &Triple) {
1246 StringRef CPUName, ABIName;
1247 tools::mips::getMipsCPUAndABI(Args, Triple, CPUName, ABIName);
1248 return llvm::StringSwitch<std::string>(ABIName)
1249 .Case("o32", "")
1250 .Case("n32", "32")
1251 .Case("n64", "64");
1252}
1253
Simon Atanasyan0da400c2013-02-27 14:55:49 +00001254// Convert ABI name to the GNU tools acceptable variant.
1255static StringRef getGnuCompatibleMipsABIName(StringRef ABI) {
1256 return llvm::StringSwitch<llvm::StringRef>(ABI)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001257 .Case("o32", "32")
1258 .Case("n64", "64")
1259 .Default(ABI);
Simon Atanasyan0da400c2013-02-27 14:55:49 +00001260}
1261
Simon Atanasyan590ad8f2012-06-02 15:06:29 +00001262// Select the MIPS float ABI as determined by -msoft-float, -mhard-float,
1263// and -mfloat-abi=.
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001264static mips::FloatABI getMipsFloatABI(const Driver &D, const ArgList &Args) {
1265 mips::FloatABI ABI = mips::FloatABI::Invalid;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001266 if (Arg *A =
1267 Args.getLastArg(options::OPT_msoft_float, options::OPT_mhard_float,
1268 options::OPT_mfloat_abi_EQ)) {
Eric Christopher0b26a612010-03-02 02:41:08 +00001269 if (A->getOption().matches(options::OPT_msoft_float))
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001270 ABI = mips::FloatABI::Soft;
Eric Christopher0b26a612010-03-02 02:41:08 +00001271 else if (A->getOption().matches(options::OPT_mhard_float))
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001272 ABI = mips::FloatABI::Hard;
Akira Hatanaka6976ec82012-03-23 23:07:09 +00001273 else {
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001274 ABI = llvm::StringSwitch<mips::FloatABI>(A->getValue())
1275 .Case("soft", mips::FloatABI::Soft)
1276 .Case("hard", mips::FloatABI::Hard)
1277 .Default(mips::FloatABI::Invalid);
1278 if (ABI == mips::FloatABI::Invalid && !StringRef(A->getValue()).empty()) {
Simon Atanasyan590ad8f2012-06-02 15:06:29 +00001279 D.Diag(diag::err_drv_invalid_mfloat_abi) << A->getAsString(Args);
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001280 ABI = mips::FloatABI::Hard;
Akira Hatanaka6976ec82012-03-23 23:07:09 +00001281 }
1282 }
Eric Christopher0b26a612010-03-02 02:41:08 +00001283 }
1284
1285 // If unspecified, choose the default based on the platform.
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001286 if (ABI == mips::FloatABI::Invalid) {
Akira Hatanaka6976ec82012-03-23 23:07:09 +00001287 // Assume "hard", because it's a default value used by gcc.
1288 // When we start to recognize specific target MIPS processors,
1289 // we will be able to select the default more correctly.
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001290 ABI = mips::FloatABI::Hard;
Eric Christopher0b26a612010-03-02 02:41:08 +00001291 }
1292
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001293 assert(ABI != mips::FloatABI::Invalid && "must select an ABI");
1294 return ABI;
Simon Atanasyan590ad8f2012-06-02 15:06:29 +00001295}
1296
Simon Atanasyan9b1932d2012-07-05 18:51:43 +00001297static void AddTargetFeature(const ArgList &Args,
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001298 std::vector<const char *> &Features,
1299 OptSpecifier OnOpt, OptSpecifier OffOpt,
Simon Atanasyan9b1932d2012-07-05 18:51:43 +00001300 StringRef FeatureName) {
1301 if (Arg *A = Args.getLastArg(OnOpt, OffOpt)) {
Simon Atanasyan9b1932d2012-07-05 18:51:43 +00001302 if (A->getOption().matches(OnOpt))
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001303 Features.push_back(Args.MakeArgString("+" + FeatureName));
Simon Atanasyan9b1932d2012-07-05 18:51:43 +00001304 else
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001305 Features.push_back(Args.MakeArgString("-" + FeatureName));
Simon Atanasyan9b1932d2012-07-05 18:51:43 +00001306 }
1307}
1308
Daniel Sanders379d44b2014-07-16 11:52:23 +00001309static void getMIPSTargetFeatures(const Driver &D, const llvm::Triple &Triple,
1310 const ArgList &Args,
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001311 std::vector<const char *> &Features) {
Daniel Sanders379d44b2014-07-16 11:52:23 +00001312 StringRef CPUName;
1313 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00001314 mips::getMipsCPUAndABI(Args, Triple, CPUName, ABIName);
Daniel Sanders379d44b2014-07-16 11:52:23 +00001315 ABIName = getGnuCompatibleMipsABIName(ABIName);
1316
Daniel Sandersfeb61302014-08-08 15:47:17 +00001317 AddTargetFeature(Args, Features, options::OPT_mno_abicalls,
1318 options::OPT_mabicalls, "noabicalls");
Daniel Sanderse805f442014-08-08 13:44:50 +00001319
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001320 mips::FloatABI FloatABI = getMipsFloatABI(D, Args);
1321 if (FloatABI == mips::FloatABI::Soft) {
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001322 // FIXME: Note, this is a hack. We need to pass the selected float
1323 // mode to the MipsTargetInfoBase to define appropriate macros there.
1324 // Now it is the only method.
1325 Features.push_back("+soft-float");
1326 }
1327
Simon Atanasyan22127ce2013-09-24 09:09:16 +00001328 if (Arg *A = Args.getLastArg(options::OPT_mnan_EQ)) {
Matheus Almeida602bff32014-05-07 16:16:07 +00001329 StringRef Val = StringRef(A->getValue());
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00001330 if (Val == "2008") {
1331 if (mips::getSupportedNanEncoding(CPUName) & mips::Nan2008)
1332 Features.push_back("+nan2008");
1333 else {
1334 Features.push_back("-nan2008");
1335 D.Diag(diag::warn_target_unsupported_nan2008) << CPUName;
1336 }
1337 } else if (Val == "legacy") {
1338 if (mips::getSupportedNanEncoding(CPUName) & mips::NanLegacy)
1339 Features.push_back("-nan2008");
1340 else {
1341 Features.push_back("+nan2008");
1342 D.Diag(diag::warn_target_unsupported_nanlegacy) << CPUName;
1343 }
1344 } else
Matheus Almeida602bff32014-05-07 16:16:07 +00001345 D.Diag(diag::err_drv_unsupported_option_argument)
1346 << A->getOption().getName() << Val;
Simon Atanasyan22127ce2013-09-24 09:09:16 +00001347 }
1348
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001349 AddTargetFeature(Args, Features, options::OPT_msingle_float,
1350 options::OPT_mdouble_float, "single-float");
1351 AddTargetFeature(Args, Features, options::OPT_mips16, options::OPT_mno_mips16,
1352 "mips16");
1353 AddTargetFeature(Args, Features, options::OPT_mmicromips,
1354 options::OPT_mno_micromips, "micromips");
1355 AddTargetFeature(Args, Features, options::OPT_mdsp, options::OPT_mno_dsp,
1356 "dsp");
1357 AddTargetFeature(Args, Features, options::OPT_mdspr2, options::OPT_mno_dspr2,
1358 "dspr2");
1359 AddTargetFeature(Args, Features, options::OPT_mmsa, options::OPT_mno_msa,
1360 "msa");
Daniel Sanders379d44b2014-07-16 11:52:23 +00001361
Petar Jovanovic3ca16222016-05-18 12:46:06 +00001362 // Add the last -mfp32/-mfpxx/-mfp64, if none are given and the ABI is O32
1363 // pass -mfpxx, or if none are given and fp64a is default, pass fp64 and
1364 // nooddspreg.
Daniel Sanders379d44b2014-07-16 11:52:23 +00001365 if (Arg *A = Args.getLastArg(options::OPT_mfp32, options::OPT_mfpxx,
1366 options::OPT_mfp64)) {
1367 if (A->getOption().matches(options::OPT_mfp32))
1368 Features.push_back(Args.MakeArgString("-fp64"));
1369 else if (A->getOption().matches(options::OPT_mfpxx)) {
1370 Features.push_back(Args.MakeArgString("+fpxx"));
1371 Features.push_back(Args.MakeArgString("+nooddspreg"));
1372 } else
1373 Features.push_back(Args.MakeArgString("+fp64"));
Toma Tabacu94ea6862015-06-16 13:54:13 +00001374 } else if (mips::shouldUseFPXX(Args, Triple, CPUName, ABIName, FloatABI)) {
Daniel Sanders2e9427a2014-07-16 09:57:54 +00001375 Features.push_back(Args.MakeArgString("+fpxx"));
1376 Features.push_back(Args.MakeArgString("+nooddspreg"));
Petar Jovanovic3ca16222016-05-18 12:46:06 +00001377 } else if (mips::isFP64ADefault(Triple, CPUName)) {
1378 Features.push_back(Args.MakeArgString("+fp64"));
1379 Features.push_back(Args.MakeArgString("+nooddspreg"));
Daniel Sanders2e9427a2014-07-16 09:57:54 +00001380 }
Daniel Sanders379d44b2014-07-16 11:52:23 +00001381
Daniel Sanders28e5d392014-07-10 10:39:51 +00001382 AddTargetFeature(Args, Features, options::OPT_mno_odd_spreg,
1383 options::OPT_modd_spreg, "nooddspreg");
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001384}
1385
Simon Atanasyan590ad8f2012-06-02 15:06:29 +00001386void Clang::AddMIPSTargetArgs(const ArgList &Args,
Simon Atanasyanf0087242013-04-14 14:07:41 +00001387 ArgStringList &CmdArgs) const {
Simon Atanasyan590ad8f2012-06-02 15:06:29 +00001388 const Driver &D = getToolChain().getDriver();
1389 StringRef CPUName;
1390 StringRef ABIName;
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001391 const llvm::Triple &Triple = getToolChain().getTriple();
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00001392 mips::getMipsCPUAndABI(Args, Triple, CPUName, ABIName);
Simon Atanasyan590ad8f2012-06-02 15:06:29 +00001393
1394 CmdArgs.push_back("-target-abi");
1395 CmdArgs.push_back(ABIName.data());
1396
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001397 mips::FloatABI ABI = getMipsFloatABI(D, Args);
1398 if (ABI == mips::FloatABI::Soft) {
Eric Christopher0b26a612010-03-02 02:41:08 +00001399 // Floating point operations and argument passing are soft.
Eric Christopher0b26a612010-03-02 02:41:08 +00001400 CmdArgs.push_back("-msoft-float");
Akira Hatanaka6976ec82012-03-23 23:07:09 +00001401 CmdArgs.push_back("-mfloat-abi");
1402 CmdArgs.push_back("soft");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001403 } else {
Akira Hatanaka6976ec82012-03-23 23:07:09 +00001404 // Floating point operations and argument passing are hard.
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001405 assert(ABI == mips::FloatABI::Hard && "Invalid float abi!");
Akira Hatanaka6976ec82012-03-23 23:07:09 +00001406 CmdArgs.push_back("-mfloat-abi");
1407 CmdArgs.push_back("hard");
Eric Christopher0b26a612010-03-02 02:41:08 +00001408 }
Simon Atanasyan6f23fa02012-07-05 14:19:39 +00001409
Simon Atanasyan2eaec512012-12-01 18:27:21 +00001410 if (Arg *A = Args.getLastArg(options::OPT_mxgot, options::OPT_mno_xgot)) {
1411 if (A->getOption().matches(options::OPT_mxgot)) {
1412 CmdArgs.push_back("-mllvm");
1413 CmdArgs.push_back("-mxgot");
1414 }
1415 }
1416
Simon Atanasyanc580b322013-05-11 06:33:44 +00001417 if (Arg *A = Args.getLastArg(options::OPT_mldc1_sdc1,
1418 options::OPT_mno_ldc1_sdc1)) {
1419 if (A->getOption().matches(options::OPT_mno_ldc1_sdc1)) {
1420 CmdArgs.push_back("-mllvm");
1421 CmdArgs.push_back("-mno-ldc1-sdc1");
1422 }
1423 }
1424
Akira Hatanaka0aa60ef2013-07-19 18:58:48 +00001425 if (Arg *A = Args.getLastArg(options::OPT_mcheck_zero_division,
1426 options::OPT_mno_check_zero_division)) {
1427 if (A->getOption().matches(options::OPT_mno_check_zero_division)) {
1428 CmdArgs.push_back("-mllvm");
1429 CmdArgs.push_back("-mno-check-zero-division");
1430 }
1431 }
1432
Simon Atanasyanec4b1c12012-08-27 20:55:56 +00001433 if (Arg *A = Args.getLastArg(options::OPT_G)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00001434 StringRef v = A->getValue();
Simon Atanasyanec4b1c12012-08-27 20:55:56 +00001435 CmdArgs.push_back("-mllvm");
1436 CmdArgs.push_back(Args.MakeArgString("-mips-ssection-threshold=" + v));
1437 A->claim();
1438 }
Eric Christopher0b26a612010-03-02 02:41:08 +00001439}
1440
Hal Finkel8eb59282012-06-11 22:35:19 +00001441/// getPPCTargetCPU - Get the (LLVM) name of the PowerPC cpu we are targeting.
1442static std::string getPPCTargetCPU(const ArgList &Args) {
1443 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00001444 StringRef CPUName = A->getValue();
Hal Finkel8eb59282012-06-11 22:35:19 +00001445
1446 if (CPUName == "native") {
1447 std::string CPU = llvm::sys::getHostCPUName();
1448 if (!CPU.empty() && CPU != "generic")
1449 return CPU;
1450 else
1451 return "";
1452 }
1453
1454 return llvm::StringSwitch<const char *>(CPUName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001455 .Case("common", "generic")
1456 .Case("440", "440")
1457 .Case("440fp", "440")
1458 .Case("450", "450")
1459 .Case("601", "601")
1460 .Case("602", "602")
1461 .Case("603", "603")
1462 .Case("603e", "603e")
1463 .Case("603ev", "603ev")
1464 .Case("604", "604")
1465 .Case("604e", "604e")
1466 .Case("620", "620")
1467 .Case("630", "pwr3")
1468 .Case("G3", "g3")
1469 .Case("7400", "7400")
1470 .Case("G4", "g4")
1471 .Case("7450", "7450")
1472 .Case("G4+", "g4+")
1473 .Case("750", "750")
1474 .Case("970", "970")
1475 .Case("G5", "g5")
1476 .Case("a2", "a2")
1477 .Case("a2q", "a2q")
1478 .Case("e500mc", "e500mc")
1479 .Case("e5500", "e5500")
1480 .Case("power3", "pwr3")
1481 .Case("power4", "pwr4")
1482 .Case("power5", "pwr5")
1483 .Case("power5x", "pwr5x")
1484 .Case("power6", "pwr6")
1485 .Case("power6x", "pwr6x")
1486 .Case("power7", "pwr7")
1487 .Case("power8", "pwr8")
Nemanja Ivanovicd99f21b2016-05-09 18:58:02 +00001488 .Case("power9", "pwr9")
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001489 .Case("pwr3", "pwr3")
1490 .Case("pwr4", "pwr4")
1491 .Case("pwr5", "pwr5")
1492 .Case("pwr5x", "pwr5x")
1493 .Case("pwr6", "pwr6")
1494 .Case("pwr6x", "pwr6x")
1495 .Case("pwr7", "pwr7")
1496 .Case("pwr8", "pwr8")
Nemanja Ivanovicd99f21b2016-05-09 18:58:02 +00001497 .Case("pwr9", "pwr9")
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001498 .Case("powerpc", "ppc")
1499 .Case("powerpc64", "ppc64")
1500 .Case("powerpc64le", "ppc64le")
1501 .Default("");
Hal Finkel8eb59282012-06-11 22:35:19 +00001502 }
1503
1504 return "";
1505}
1506
Petar Jovanovic88a328f2015-12-14 17:51:50 +00001507static void getPPCTargetFeatures(const Driver &D, const llvm::Triple &Triple,
1508 const ArgList &Args,
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001509 std::vector<const char *> &Features) {
Eric Christopher49062a52015-12-22 03:12:34 +00001510 handleTargetFeaturesGroup(Args, Features, options::OPT_m_ppc_Features_Group);
Eric Christopher643bb6a2013-10-16 20:40:08 +00001511
Petar Jovanovic88a328f2015-12-14 17:51:50 +00001512 ppc::FloatABI FloatABI = ppc::getPPCFloatABI(D, Args);
1513 if (FloatABI == ppc::FloatABI::Soft &&
1514 !(Triple.getArch() == llvm::Triple::ppc64 ||
1515 Triple.getArch() == llvm::Triple::ppc64le))
1516 Features.push_back("+soft-float");
1517 else if (FloatABI == ppc::FloatABI::Soft &&
1518 (Triple.getArch() == llvm::Triple::ppc64 ||
1519 Triple.getArch() == llvm::Triple::ppc64le))
Eric Christopherbce27882015-12-28 21:57:05 +00001520 D.Diag(diag::err_drv_invalid_mfloat_abi)
Petar Jovanovic88a328f2015-12-14 17:51:50 +00001521 << "soft float is not supported for ppc64";
1522
Eric Christopher643bb6a2013-10-16 20:40:08 +00001523 // Altivec is a bit weird, allow overriding of the Altivec feature here.
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001524 AddTargetFeature(Args, Features, options::OPT_faltivec,
1525 options::OPT_fno_altivec, "altivec");
Hal Finkel8eb59282012-06-11 22:35:19 +00001526}
1527
Petar Jovanovic88a328f2015-12-14 17:51:50 +00001528ppc::FloatABI ppc::getPPCFloatABI(const Driver &D, const ArgList &Args) {
1529 ppc::FloatABI ABI = ppc::FloatABI::Invalid;
1530 if (Arg *A =
1531 Args.getLastArg(options::OPT_msoft_float, options::OPT_mhard_float,
1532 options::OPT_mfloat_abi_EQ)) {
1533 if (A->getOption().matches(options::OPT_msoft_float))
1534 ABI = ppc::FloatABI::Soft;
1535 else if (A->getOption().matches(options::OPT_mhard_float))
1536 ABI = ppc::FloatABI::Hard;
1537 else {
1538 ABI = llvm::StringSwitch<ppc::FloatABI>(A->getValue())
1539 .Case("soft", ppc::FloatABI::Soft)
1540 .Case("hard", ppc::FloatABI::Hard)
1541 .Default(ppc::FloatABI::Invalid);
1542 if (ABI == ppc::FloatABI::Invalid && !StringRef(A->getValue()).empty()) {
1543 D.Diag(diag::err_drv_invalid_mfloat_abi) << A->getAsString(Args);
1544 ABI = ppc::FloatABI::Hard;
1545 }
1546 }
1547 }
1548
1549 // If unspecified, choose the default based on the platform.
1550 if (ABI == ppc::FloatABI::Invalid) {
1551 ABI = ppc::FloatABI::Hard;
1552 }
1553
1554 return ABI;
1555}
1556
Ulrich Weigand8afad612014-07-28 13:17:52 +00001557void Clang::AddPPCTargetArgs(const ArgList &Args,
1558 ArgStringList &CmdArgs) const {
1559 // Select the ABI to use.
1560 const char *ABIName = nullptr;
Eric Christopher71e5e3d2015-07-10 18:25:54 +00001561 if (getToolChain().getTriple().isOSLinux())
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001562 switch (getToolChain().getArch()) {
Hal Finkel0d0a1a52015-03-11 19:14:15 +00001563 case llvm::Triple::ppc64: {
1564 // When targeting a processor that supports QPX, or if QPX is
1565 // specifically enabled, default to using the ABI that supports QPX (so
1566 // long as it is not specifically disabled).
1567 bool HasQPX = false;
1568 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ))
1569 HasQPX = A->getValue() == StringRef("a2q");
1570 HasQPX = Args.hasFlag(options::OPT_mqpx, options::OPT_mno_qpx, HasQPX);
1571 if (HasQPX) {
1572 ABIName = "elfv1-qpx";
1573 break;
1574 }
1575
Ulrich Weigand8afad612014-07-28 13:17:52 +00001576 ABIName = "elfv1";
1577 break;
Hal Finkel0d0a1a52015-03-11 19:14:15 +00001578 }
Ulrich Weigand8afad612014-07-28 13:17:52 +00001579 case llvm::Triple::ppc64le:
1580 ABIName = "elfv2";
1581 break;
1582 default:
1583 break;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001584 }
Ulrich Weigand8afad612014-07-28 13:17:52 +00001585
Eric Christopher71e5e3d2015-07-10 18:25:54 +00001586 if (Arg *A = Args.getLastArg(options::OPT_mabi_EQ))
1587 // The ppc64 linux abis are all "altivec" abis by default. Accept and ignore
1588 // the option if given as we don't have backend support for any targets
1589 // that don't use the altivec abi.
1590 if (StringRef(A->getValue()) != "altivec")
1591 ABIName = A->getValue();
1592
Petar Jovanovic88a328f2015-12-14 17:51:50 +00001593 ppc::FloatABI FloatABI =
1594 ppc::getPPCFloatABI(getToolChain().getDriver(), Args);
1595
1596 if (FloatABI == ppc::FloatABI::Soft) {
1597 // Floating point operations and argument passing are soft.
1598 CmdArgs.push_back("-msoft-float");
1599 CmdArgs.push_back("-mfloat-abi");
1600 CmdArgs.push_back("soft");
1601 } else {
1602 // Floating point operations and argument passing are hard.
1603 assert(FloatABI == ppc::FloatABI::Hard && "Invalid float abi!");
1604 CmdArgs.push_back("-mfloat-abi");
1605 CmdArgs.push_back("hard");
1606 }
1607
Ulrich Weigand8afad612014-07-28 13:17:52 +00001608 if (ABIName) {
1609 CmdArgs.push_back("-target-abi");
1610 CmdArgs.push_back(ABIName);
1611 }
1612}
1613
1614bool ppc::hasPPCAbiArg(const ArgList &Args, const char *Value) {
1615 Arg *A = Args.getLastArg(options::OPT_mabi_EQ);
1616 return A && (A->getValue() == StringRef(Value));
1617}
1618
Tom Stellard6674c702013-04-01 20:56:53 +00001619/// Get the (LLVM) name of the R600 gpu we are targeting.
1620static std::string getR600TargetGPU(const ArgList &Args) {
1621 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ)) {
Benjamin Kramerb2ccade2013-10-21 12:33:55 +00001622 const char *GPUName = A->getValue();
Tom Stellard6674c702013-04-01 20:56:53 +00001623 return llvm::StringSwitch<const char *>(GPUName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001624 .Cases("rv630", "rv635", "r600")
1625 .Cases("rv610", "rv620", "rs780", "rs880")
1626 .Case("rv740", "rv770")
1627 .Case("palm", "cedar")
1628 .Cases("sumo", "sumo2", "sumo")
1629 .Case("hemlock", "cypress")
1630 .Case("aruba", "cayman")
1631 .Default(GPUName);
Tom Stellard6674c702013-04-01 20:56:53 +00001632 }
1633 return "";
1634}
1635
Jacques Pienaard964cc22016-03-28 21:02:54 +00001636static std::string getLanaiTargetCPU(const ArgList &Args) {
1637 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ)) {
1638 return A->getValue();
1639 }
1640 return "";
1641}
1642
Jacob Baungard Hansen13a49372016-05-24 08:30:08 +00001643sparc::FloatABI sparc::getSparcFloatABI(const Driver &D,
1644 const ArgList &Args) {
1645 sparc::FloatABI ABI = sparc::FloatABI::Invalid;
1646 if (Arg *A =
1647 Args.getLastArg(options::OPT_msoft_float, options::OPT_mhard_float,
1648 options::OPT_mfloat_abi_EQ)) {
1649 if (A->getOption().matches(options::OPT_msoft_float))
1650 ABI = sparc::FloatABI::Soft;
1651 else if (A->getOption().matches(options::OPT_mhard_float))
1652 ABI = sparc::FloatABI::Hard;
1653 else {
1654 ABI = llvm::StringSwitch<sparc::FloatABI>(A->getValue())
1655 .Case("soft", sparc::FloatABI::Soft)
1656 .Case("hard", sparc::FloatABI::Hard)
1657 .Default(sparc::FloatABI::Invalid);
1658 if (ABI == sparc::FloatABI::Invalid &&
1659 !StringRef(A->getValue()).empty()) {
1660 D.Diag(diag::err_drv_invalid_mfloat_abi) << A->getAsString(Args);
1661 ABI = sparc::FloatABI::Hard;
1662 }
1663 }
1664 }
1665
1666 // If unspecified, choose the default based on the platform.
1667 // Only the hard-float ABI on Sparc is standardized, and it is the
1668 // default. GCC also supports a nonstandard soft-float ABI mode, also
1669 // implemented in LLVM. However as this is not standard we set the default
1670 // to be hard-float.
1671 if (ABI == sparc::FloatABI::Invalid) {
1672 ABI = sparc::FloatABI::Hard;
1673 }
1674
1675 return ABI;
1676}
1677
1678static void getSparcTargetFeatures(const Driver &D, const ArgList &Args,
1679 std::vector<const char *> &Features) {
1680 sparc::FloatABI FloatABI = sparc::getSparcFloatABI(D, Args);
1681 if (FloatABI == sparc::FloatABI::Soft)
1682 Features.push_back("+soft-float");
1683}
1684
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001685void Clang::AddSparcTargetArgs(const ArgList &Args,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001686 ArgStringList &CmdArgs) const {
Jacob Baungard Hansen13a49372016-05-24 08:30:08 +00001687 //const Driver &D = getToolChain().getDriver();
James Y Knightb2406522015-06-15 20:51:24 +00001688 std::string Triple = getToolChain().ComputeEffectiveClangTriple(Args);
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001689
Jacob Baungard Hansen13a49372016-05-24 08:30:08 +00001690 sparc::FloatABI FloatABI =
1691 sparc::getSparcFloatABI(getToolChain().getDriver(), Args);
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001692
Jacob Baungard Hansen13a49372016-05-24 08:30:08 +00001693 if (FloatABI == sparc::FloatABI::Soft) {
1694 // Floating point operations and argument passing are soft.
1695 CmdArgs.push_back("-msoft-float");
1696 CmdArgs.push_back("-mfloat-abi");
1697 CmdArgs.push_back("soft");
1698 } else {
1699 // Floating point operations and argument passing are hard.
1700 assert(FloatABI == sparc::FloatABI::Hard && "Invalid float abi!");
1701 CmdArgs.push_back("-mfloat-abi");
1702 CmdArgs.push_back("hard");
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001703 }
1704}
1705
Marcin Koscielnickib31ee6d2016-05-04 23:37:40 +00001706void Clang::AddSystemZTargetArgs(const ArgList &Args,
1707 ArgStringList &CmdArgs) const {
1708 if (Args.hasFlag(options::OPT_mbackchain, options::OPT_mno_backchain, false))
1709 CmdArgs.push_back("-mbackchain");
1710}
1711
Richard Sandiford4652d892013-07-19 16:51:51 +00001712static const char *getSystemZTargetCPU(const ArgList &Args) {
1713 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ))
1714 return A->getValue();
1715 return "z10";
1716}
1717
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00001718static void getSystemZTargetFeatures(const ArgList &Args,
1719 std::vector<const char *> &Features) {
1720 // -m(no-)htm overrides use of the transactional-execution facility.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001721 if (Arg *A = Args.getLastArg(options::OPT_mhtm, options::OPT_mno_htm)) {
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00001722 if (A->getOption().matches(options::OPT_mhtm))
1723 Features.push_back("+transactional-execution");
1724 else
1725 Features.push_back("-transactional-execution");
1726 }
Ulrich Weigand66ff51b2015-05-05 19:35:52 +00001727 // -m(no-)vx overrides use of the vector facility.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001728 if (Arg *A = Args.getLastArg(options::OPT_mvx, options::OPT_mno_vx)) {
Ulrich Weigand66ff51b2015-05-05 19:35:52 +00001729 if (A->getOption().matches(options::OPT_mvx))
1730 Features.push_back("+vector");
1731 else
1732 Features.push_back("-vector");
1733 }
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00001734}
1735
Chandler Carruth953fb082013-01-13 11:46:33 +00001736static const char *getX86TargetCPU(const ArgList &Args,
1737 const llvm::Triple &Triple) {
1738 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ)) {
Jim Grosbach82eee262013-11-16 00:53:35 +00001739 if (StringRef(A->getValue()) != "native") {
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00001740 if (Triple.isOSDarwin() && Triple.getArchName() == "x86_64h")
Jim Grosbach82eee262013-11-16 00:53:35 +00001741 return "core-avx2";
1742
Chandler Carruth953fb082013-01-13 11:46:33 +00001743 return A->getValue();
Jim Grosbach82eee262013-11-16 00:53:35 +00001744 }
Chandler Carruth953fb082013-01-13 11:46:33 +00001745
1746 // FIXME: Reject attempts to use -march=native unless the target matches
1747 // the host.
1748 //
1749 // FIXME: We should also incorporate the detected target features for use
1750 // with -native.
1751 std::string CPU = llvm::sys::getHostCPUName();
1752 if (!CPU.empty() && CPU != "generic")
1753 return Args.MakeArgString(CPU);
1754 }
1755
Reid Kleckner3123eff2015-06-30 16:32:04 +00001756 if (const Arg *A = Args.getLastArg(options::OPT__SLASH_arch)) {
1757 // Mapping built by referring to X86TargetInfo::getDefaultFeatures().
1758 StringRef Arch = A->getValue();
1759 const char *CPU;
1760 if (Triple.getArch() == llvm::Triple::x86) {
1761 CPU = llvm::StringSwitch<const char *>(Arch)
1762 .Case("IA32", "i386")
1763 .Case("SSE", "pentium3")
1764 .Case("SSE2", "pentium4")
1765 .Case("AVX", "sandybridge")
1766 .Case("AVX2", "haswell")
1767 .Default(nullptr);
1768 } else {
1769 CPU = llvm::StringSwitch<const char *>(Arch)
1770 .Case("AVX", "sandybridge")
1771 .Case("AVX2", "haswell")
1772 .Default(nullptr);
1773 }
1774 if (CPU)
1775 return CPU;
1776 }
1777
Chandler Carruth953fb082013-01-13 11:46:33 +00001778 // Select the default CPU if none was given (or detection failed).
1779
1780 if (Triple.getArch() != llvm::Triple::x86_64 &&
1781 Triple.getArch() != llvm::Triple::x86)
Craig Topper92fc2df2014-05-17 16:56:41 +00001782 return nullptr; // This routine is only handling x86 targets.
Chandler Carruth953fb082013-01-13 11:46:33 +00001783
1784 bool Is64Bit = Triple.getArch() == llvm::Triple::x86_64;
1785
1786 // FIXME: Need target hooks.
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00001787 if (Triple.isOSDarwin()) {
Jim Grosbach82eee262013-11-16 00:53:35 +00001788 if (Triple.getArchName() == "x86_64h")
1789 return "core-avx2";
Chandler Carruth953fb082013-01-13 11:46:33 +00001790 return Is64Bit ? "core2" : "yonah";
Jim Grosbach82eee262013-11-16 00:53:35 +00001791 }
Chandler Carruth953fb082013-01-13 11:46:33 +00001792
Filipe Cabecinhas4b442572015-01-27 17:27:37 +00001793 // Set up default CPU name for PS4 compilers.
1794 if (Triple.isPS4CPU())
1795 return "btver2";
1796
Alexey Bataev286d1b92014-01-31 04:07:13 +00001797 // On Android use targets compatible with gcc
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00001798 if (Triple.isAndroid())
Alexey Bataev286d1b92014-01-31 04:07:13 +00001799 return Is64Bit ? "x86-64" : "i686";
Chandler Carruth953fb082013-01-13 11:46:33 +00001800
Benjamin Kramerb2ccade2013-10-21 12:33:55 +00001801 // Everything else goes to x86-64 in 64-bit mode.
1802 if (Is64Bit)
1803 return "x86-64";
1804
1805 switch (Triple.getOS()) {
1806 case llvm::Triple::FreeBSD:
1807 case llvm::Triple::NetBSD:
1808 case llvm::Triple::OpenBSD:
1809 return "i486";
1810 case llvm::Triple::Haiku:
1811 return "i586";
1812 case llvm::Triple::Bitrig:
1813 return "i686";
1814 default:
1815 // Fallback to p4.
1816 return "pentium4";
1817 }
Chandler Carruth953fb082013-01-13 11:46:33 +00001818}
1819
Dan Gohmanc2853072015-09-03 22:51:53 +00001820/// Get the (LLVM) name of the WebAssembly cpu we are targeting.
1821static StringRef getWebAssemblyTargetCPU(const ArgList &Args) {
1822 // If we have -mcpu=, use that.
1823 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ)) {
1824 StringRef CPU = A->getValue();
1825
1826#ifdef __wasm__
1827 // Handle "native" by examining the host. "native" isn't meaningful when
1828 // cross compiling, so only support this when the host is also WebAssembly.
1829 if (CPU == "native")
1830 return llvm::sys::getHostCPUName();
1831#endif
1832
1833 return CPU;
1834 }
1835
1836 return "generic";
1837}
1838
Renato Golin7c542b42015-07-27 23:44:45 +00001839static std::string getCPUName(const ArgList &Args, const llvm::Triple &T,
1840 bool FromAs = false) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001841 switch (T.getArch()) {
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001842 default:
1843 return "";
1844
Amara Emerson703da2e2013-10-31 09:32:33 +00001845 case llvm::Triple::aarch64:
Christian Pirker9b019ae2014-02-25 13:51:00 +00001846 case llvm::Triple::aarch64_be:
Tim Northover573cbee2014-05-24 12:52:07 +00001847 return getAArch64TargetCPU(Args);
Quentin Colombetd9f26202014-04-15 00:27:35 +00001848
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001849 case llvm::Triple::arm:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00001850 case llvm::Triple::armeb:
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001851 case llvm::Triple::thumb:
Renato Goline17c5802015-07-27 23:44:42 +00001852 case llvm::Triple::thumbeb: {
1853 StringRef MArch, MCPU;
Renato Golin7c542b42015-07-27 23:44:45 +00001854 getARMArchCPUFromArgs(Args, MArch, MCPU, FromAs);
Renato Goline17c5802015-07-27 23:44:42 +00001855 return arm::getARMTargetCPU(MCPU, MArch, T);
1856 }
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001857 case llvm::Triple::mips:
1858 case llvm::Triple::mipsel:
1859 case llvm::Triple::mips64:
1860 case llvm::Triple::mips64el: {
1861 StringRef CPUName;
1862 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00001863 mips::getMipsCPUAndABI(Args, T, CPUName, ABIName);
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001864 return CPUName;
1865 }
1866
Artem Belevich0ff05cd2015-07-13 23:27:56 +00001867 case llvm::Triple::nvptx:
1868 case llvm::Triple::nvptx64:
1869 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ))
1870 return A->getValue();
1871 return "";
1872
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001873 case llvm::Triple::ppc:
1874 case llvm::Triple::ppc64:
1875 case llvm::Triple::ppc64le: {
1876 std::string TargetCPUName = getPPCTargetCPU(Args);
1877 // LLVM may default to generating code for the native CPU,
1878 // but, like gcc, we default to a more generic option for
1879 // each architecture. (except on Darwin)
1880 if (TargetCPUName.empty() && !T.isOSDarwin()) {
1881 if (T.getArch() == llvm::Triple::ppc64)
1882 TargetCPUName = "ppc64";
1883 else if (T.getArch() == llvm::Triple::ppc64le)
1884 TargetCPUName = "ppc64le";
1885 else
1886 TargetCPUName = "ppc";
1887 }
1888 return TargetCPUName;
1889 }
1890
1891 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00001892 case llvm::Triple::sparcel:
Roman Divackyb1ae3d42014-02-25 18:35:30 +00001893 case llvm::Triple::sparcv9:
1894 if (const Arg *A = Args.getLastArg(options::OPT_mcpu_EQ))
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001895 return A->getValue();
1896 return "";
1897
1898 case llvm::Triple::x86:
1899 case llvm::Triple::x86_64:
1900 return getX86TargetCPU(Args, T);
1901
1902 case llvm::Triple::hexagon:
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00001903 return "hexagon" +
1904 toolchains::HexagonToolChain::GetTargetCPUVersion(Args).str();
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001905
Jacques Pienaard964cc22016-03-28 21:02:54 +00001906 case llvm::Triple::lanai:
1907 return getLanaiTargetCPU(Args);
1908
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001909 case llvm::Triple::systemz:
1910 return getSystemZTargetCPU(Args);
1911
1912 case llvm::Triple::r600:
Tom Stellardd8e38a32015-01-06 20:34:47 +00001913 case llvm::Triple::amdgcn:
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001914 return getR600TargetGPU(Args);
Dan Gohmanc2853072015-09-03 22:51:53 +00001915
1916 case llvm::Triple::wasm32:
1917 case llvm::Triple::wasm64:
1918 return getWebAssemblyTargetCPU(Args);
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001919 }
1920}
1921
Alp Tokerce365ca2013-12-02 12:43:03 +00001922static void AddGoldPlugin(const ToolChain &ToolChain, const ArgList &Args,
Teresa Johnson945bc502015-10-15 20:35:53 +00001923 ArgStringList &CmdArgs, bool IsThinLTO) {
Alp Tokerce365ca2013-12-02 12:43:03 +00001924 // Tell the linker to load the plugin. This has to come before AddLinkerInputs
1925 // as gold requires -plugin to come before any -plugin-opt that -Wl might
1926 // forward.
1927 CmdArgs.push_back("-plugin");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001928 std::string Plugin =
1929 ToolChain.getDriver().Dir + "/../lib" CLANG_LIBDIR_SUFFIX "/LLVMgold.so";
Alp Tokerce365ca2013-12-02 12:43:03 +00001930 CmdArgs.push_back(Args.MakeArgString(Plugin));
1931
1932 // Try to pass driver level flags relevant to LTO code generation down to
1933 // the plugin.
1934
1935 // Handle flags for selecting CPU variants.
1936 std::string CPU = getCPUName(Args, ToolChain.getTriple());
1937 if (!CPU.empty())
1938 CmdArgs.push_back(Args.MakeArgString(Twine("-plugin-opt=mcpu=") + CPU));
Teresa Johnson945bc502015-10-15 20:35:53 +00001939
James Molloyf97fdae2015-12-21 10:44:36 +00001940 if (Arg *A = Args.getLastArg(options::OPT_O_Group)) {
1941 StringRef OOpt;
1942 if (A->getOption().matches(options::OPT_O4) ||
1943 A->getOption().matches(options::OPT_Ofast))
1944 OOpt = "3";
1945 else if (A->getOption().matches(options::OPT_O))
1946 OOpt = A->getValue();
1947 else if (A->getOption().matches(options::OPT_O0))
1948 OOpt = "0";
1949 if (!OOpt.empty())
1950 CmdArgs.push_back(Args.MakeArgString(Twine("-plugin-opt=O") + OOpt));
1951 }
1952
Teresa Johnson6ef80dc2015-11-02 18:03:12 +00001953 if (IsThinLTO)
1954 CmdArgs.push_back("-plugin-opt=thinlto");
Paul Robinson4391d092016-01-25 19:46:40 +00001955
1956 // If an explicit debugger tuning argument appeared, pass it along.
1957 if (Arg *A = Args.getLastArg(options::OPT_gTune_Group,
1958 options::OPT_ggdbN_Group)) {
1959 if (A->getOption().matches(options::OPT_glldb))
1960 CmdArgs.push_back("-plugin-opt=-debugger-tune=lldb");
1961 else if (A->getOption().matches(options::OPT_gsce))
1962 CmdArgs.push_back("-plugin-opt=-debugger-tune=sce");
1963 else
1964 CmdArgs.push_back("-plugin-opt=-debugger-tune=gdb");
1965 }
Alp Tokerce365ca2013-12-02 12:43:03 +00001966}
1967
Sanjay Patel2987c292015-06-11 14:53:41 +00001968/// This is a helper function for validating the optional refinement step
1969/// parameter in reciprocal argument strings. Return false if there is an error
1970/// parsing the refinement step. Otherwise, return true and set the Position
1971/// of the refinement step in the input string.
Craig Topper3db9ba42015-09-21 00:20:04 +00001972static bool getRefinementStep(StringRef In, const Driver &D,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001973 const Arg &A, size_t &Position) {
Sanjay Patel2987c292015-06-11 14:53:41 +00001974 const char RefinementStepToken = ':';
1975 Position = In.find(RefinementStepToken);
1976 if (Position != StringRef::npos) {
1977 StringRef Option = A.getOption().getName();
1978 StringRef RefStep = In.substr(Position + 1);
1979 // Allow exactly one numeric character for the additional refinement
1980 // step parameter. This is reasonable for all currently-supported
1981 // operations and architectures because we would expect that a larger value
1982 // of refinement steps would cause the estimate "optimization" to
1983 // under-perform the native operation. Also, if the estimate does not
1984 // converge quickly, it probably will not ever converge, so further
1985 // refinement steps will not produce a better answer.
1986 if (RefStep.size() != 1) {
1987 D.Diag(diag::err_drv_invalid_value) << Option << RefStep;
1988 return false;
1989 }
1990 char RefStepChar = RefStep[0];
1991 if (RefStepChar < '0' || RefStepChar > '9') {
1992 D.Diag(diag::err_drv_invalid_value) << Option << RefStep;
1993 return false;
1994 }
1995 }
1996 return true;
1997}
1998
1999/// The -mrecip flag requires processing of many optional parameters.
2000static void ParseMRecip(const Driver &D, const ArgList &Args,
2001 ArgStringList &OutStrings) {
2002 StringRef DisabledPrefixIn = "!";
2003 StringRef DisabledPrefixOut = "!";
2004 StringRef EnabledPrefixOut = "";
2005 StringRef Out = "-mrecip=";
2006
2007 Arg *A = Args.getLastArg(options::OPT_mrecip, options::OPT_mrecip_EQ);
2008 if (!A)
2009 return;
2010
2011 unsigned NumOptions = A->getNumValues();
2012 if (NumOptions == 0) {
2013 // No option is the same as "all".
2014 OutStrings.push_back(Args.MakeArgString(Out + "all"));
2015 return;
2016 }
2017
2018 // Pass through "all", "none", or "default" with an optional refinement step.
2019 if (NumOptions == 1) {
2020 StringRef Val = A->getValue(0);
2021 size_t RefStepLoc;
2022 if (!getRefinementStep(Val, D, *A, RefStepLoc))
2023 return;
2024 StringRef ValBase = Val.slice(0, RefStepLoc);
2025 if (ValBase == "all" || ValBase == "none" || ValBase == "default") {
2026 OutStrings.push_back(Args.MakeArgString(Out + Val));
2027 return;
2028 }
2029 }
2030
2031 // Each reciprocal type may be enabled or disabled individually.
2032 // Check each input value for validity, concatenate them all back together,
2033 // and pass through.
2034
2035 llvm::StringMap<bool> OptionStrings;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002036 OptionStrings.insert(std::make_pair("divd", false));
2037 OptionStrings.insert(std::make_pair("divf", false));
2038 OptionStrings.insert(std::make_pair("vec-divd", false));
2039 OptionStrings.insert(std::make_pair("vec-divf", false));
2040 OptionStrings.insert(std::make_pair("sqrtd", false));
2041 OptionStrings.insert(std::make_pair("sqrtf", false));
2042 OptionStrings.insert(std::make_pair("vec-sqrtd", false));
2043 OptionStrings.insert(std::make_pair("vec-sqrtf", false));
Sanjay Patel2987c292015-06-11 14:53:41 +00002044
2045 for (unsigned i = 0; i != NumOptions; ++i) {
2046 StringRef Val = A->getValue(i);
2047
2048 bool IsDisabled = Val.startswith(DisabledPrefixIn);
2049 // Ignore the disablement token for string matching.
2050 if (IsDisabled)
2051 Val = Val.substr(1);
2052
2053 size_t RefStep;
2054 if (!getRefinementStep(Val, D, *A, RefStep))
2055 return;
2056
2057 StringRef ValBase = Val.slice(0, RefStep);
2058 llvm::StringMap<bool>::iterator OptionIter = OptionStrings.find(ValBase);
2059 if (OptionIter == OptionStrings.end()) {
2060 // Try again specifying float suffix.
2061 OptionIter = OptionStrings.find(ValBase.str() + 'f');
2062 if (OptionIter == OptionStrings.end()) {
2063 // The input name did not match any known option string.
2064 D.Diag(diag::err_drv_unknown_argument) << Val;
2065 return;
2066 }
2067 // The option was specified without a float or double suffix.
2068 // Make sure that the double entry was not already specified.
2069 // The float entry will be checked below.
2070 if (OptionStrings[ValBase.str() + 'd']) {
2071 D.Diag(diag::err_drv_invalid_value) << A->getOption().getName() << Val;
2072 return;
2073 }
2074 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002075
Sanjay Patel2987c292015-06-11 14:53:41 +00002076 if (OptionIter->second == true) {
2077 // Duplicate option specified.
2078 D.Diag(diag::err_drv_invalid_value) << A->getOption().getName() << Val;
2079 return;
2080 }
2081
2082 // Mark the matched option as found. Do not allow duplicate specifiers.
2083 OptionIter->second = true;
2084
2085 // If the precision was not specified, also mark the double entry as found.
2086 if (ValBase.back() != 'f' && ValBase.back() != 'd')
2087 OptionStrings[ValBase.str() + 'd'] = true;
2088
2089 // Build the output string.
2090 StringRef Prefix = IsDisabled ? DisabledPrefixOut : EnabledPrefixOut;
2091 Out = Args.MakeArgString(Out + Prefix + Val);
2092 if (i != NumOptions - 1)
2093 Out = Args.MakeArgString(Out + ",");
2094 }
2095
2096 OutStrings.push_back(Args.MakeArgString(Out));
2097}
2098
Eric Christopherc54920a2015-03-23 19:26:05 +00002099static void getX86TargetFeatures(const Driver &D, const llvm::Triple &Triple,
Jim Grosbach82eee262013-11-16 00:53:35 +00002100 const ArgList &Args,
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002101 std::vector<const char *> &Features) {
Craig Toppera8bd6002015-03-31 05:45:00 +00002102 // If -march=native, autodetect the feature list.
2103 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ)) {
2104 if (StringRef(A->getValue()) == "native") {
2105 llvm::StringMap<bool> HostFeatures;
2106 if (llvm::sys::getHostCPUFeatures(HostFeatures))
2107 for (auto &F : HostFeatures)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002108 Features.push_back(
2109 Args.MakeArgString((F.second ? "+" : "-") + F.first()));
Craig Toppera8bd6002015-03-31 05:45:00 +00002110 }
2111 }
2112
Jim Grosbach82eee262013-11-16 00:53:35 +00002113 if (Triple.getArchName() == "x86_64h") {
2114 // x86_64h implies quite a few of the more modern subtarget features
2115 // for Haswell class CPUs, but not all of them. Opt-out of a few.
2116 Features.push_back("-rdrnd");
2117 Features.push_back("-aes");
2118 Features.push_back("-pclmul");
2119 Features.push_back("-rtm");
2120 Features.push_back("-hle");
2121 Features.push_back("-fsgsbase");
2122 }
2123
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00002124 const llvm::Triple::ArchType ArchType = Triple.getArch();
Eric Christopherc54920a2015-03-23 19:26:05 +00002125 // Add features to be compatible with gcc for Android.
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00002126 if (Triple.isAndroid()) {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00002127 if (ArchType == llvm::Triple::x86_64) {
Alexey Volkov54ff0802014-06-25 12:15:36 +00002128 Features.push_back("+sse4.2");
2129 Features.push_back("+popcnt");
2130 } else
2131 Features.push_back("+ssse3");
Alexey Bataev286d1b92014-01-31 04:07:13 +00002132 }
2133
Eric Christopherc54920a2015-03-23 19:26:05 +00002134 // Set features according to the -arch flag on MSVC.
Ehsan Akhgarieeb7e652014-07-15 18:27:51 +00002135 if (Arg *A = Args.getLastArg(options::OPT__SLASH_arch)) {
2136 StringRef Arch = A->getValue();
2137 bool ArchUsed = false;
2138 // First, look for flags that are shared in x86 and x86-64.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00002139 if (ArchType == llvm::Triple::x86_64 || ArchType == llvm::Triple::x86) {
Ehsan Akhgarieeb7e652014-07-15 18:27:51 +00002140 if (Arch == "AVX" || Arch == "AVX2") {
2141 ArchUsed = true;
2142 Features.push_back(Args.MakeArgString("+" + Arch.lower()));
2143 }
2144 }
2145 // Then, look for x86-specific flags.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00002146 if (ArchType == llvm::Triple::x86) {
Ehsan Akhgarieeb7e652014-07-15 18:27:51 +00002147 if (Arch == "IA32") {
2148 ArchUsed = true;
2149 } else if (Arch == "SSE" || Arch == "SSE2") {
2150 ArchUsed = true;
2151 Features.push_back(Args.MakeArgString("+" + Arch.lower()));
2152 }
2153 }
2154 if (!ArchUsed)
2155 D.Diag(clang::diag::warn_drv_unused_argument) << A->getAsString(Args);
2156 }
2157
Jim Grosbach82eee262013-11-16 00:53:35 +00002158 // Now add any that the user explicitly requested on the command line,
2159 // which may override the defaults.
Eric Christopher49062a52015-12-22 03:12:34 +00002160 handleTargetFeaturesGroup(Args, Features, options::OPT_m_x86_Features_Group);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002161}
2162
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00002163void Clang::AddX86TargetArgs(const ArgList &Args,
2164 ArgStringList &CmdArgs) const {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002165 if (!Args.hasFlag(options::OPT_mred_zone, options::OPT_mno_red_zone, true) ||
Daniel Dunbare2cf8f72009-09-10 22:59:57 +00002166 Args.hasArg(options::OPT_mkernel) ||
2167 Args.hasArg(options::OPT_fapple_kext))
Daniel Dunbar8bed86c2009-11-20 22:21:36 +00002168 CmdArgs.push_back("-disable-red-zone");
Daniel Dunbare2cf8f72009-09-10 22:59:57 +00002169
Bob Wilson2616e2e2013-02-10 16:01:41 +00002170 // Default to avoid implicit floating-point for kernel/kext code, but allow
2171 // that to be overridden with -mno-soft-float.
2172 bool NoImplicitFloat = (Args.hasArg(options::OPT_mkernel) ||
2173 Args.hasArg(options::OPT_fapple_kext));
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002174 if (Arg *A = Args.getLastArg(
2175 options::OPT_msoft_float, options::OPT_mno_soft_float,
2176 options::OPT_mimplicit_float, options::OPT_mno_implicit_float)) {
Bob Wilson2616e2e2013-02-10 16:01:41 +00002177 const Option &O = A->getOption();
2178 NoImplicitFloat = (O.matches(options::OPT_mno_implicit_float) ||
2179 O.matches(options::OPT_msoft_float));
2180 }
2181 if (NoImplicitFloat)
Daniel Dunbar8bed86c2009-11-20 22:21:36 +00002182 CmdArgs.push_back("-no-implicit-float");
Nico Weberad8e36c2014-05-13 11:11:24 +00002183
2184 if (Arg *A = Args.getLastArg(options::OPT_masm_EQ)) {
2185 StringRef Value = A->getValue();
2186 if (Value == "intel" || Value == "att") {
2187 CmdArgs.push_back("-mllvm");
2188 CmdArgs.push_back(Args.MakeArgString("-x86-asm-syntax=" + Value));
2189 } else {
2190 getToolChain().getDriver().Diag(diag::err_drv_unsupported_option_argument)
2191 << A->getOption().getName() << Value;
2192 }
2193 }
Andrey Turetskiy6a8b91d2016-04-21 10:16:48 +00002194
2195 // Set flags to support MCU ABI.
2196 if (Args.hasArg(options::OPT_miamcu)) {
2197 CmdArgs.push_back("-mfloat-abi");
2198 CmdArgs.push_back("soft");
2199 CmdArgs.push_back("-mstack-alignment=4");
2200 }
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00002201}
2202
Tony Linthicum76329bf2011-12-12 21:14:55 +00002203void Clang::AddHexagonTargetArgs(const ArgList &Args,
2204 ArgStringList &CmdArgs) const {
Matthew Curtis6b222782012-12-07 13:52:44 +00002205 CmdArgs.push_back("-mqdsp6-compat");
2206 CmdArgs.push_back("-Wreturn-type");
Tony Linthicum76329bf2011-12-12 21:14:55 +00002207
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00002208 if (auto G = toolchains::HexagonToolChain::getSmallDataThreshold(Args)) {
2209 std::string N = llvm::utostr(G.getValue());
2210 std::string Opt = std::string("-hexagon-small-data-threshold=") + N;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002211 CmdArgs.push_back("-mllvm");
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00002212 CmdArgs.push_back(Args.MakeArgString(Opt));
Tony Linthicum76329bf2011-12-12 21:14:55 +00002213 }
2214
Sirish Pande11ebc4e2012-05-10 20:19:54 +00002215 if (!Args.hasArg(options::OPT_fno_short_enums))
2216 CmdArgs.push_back("-fshort-enums");
2217 if (Args.getLastArg(options::OPT_mieee_rnd_near)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002218 CmdArgs.push_back("-mllvm");
2219 CmdArgs.push_back("-enable-hexagon-ieee-rnd-near");
Sirish Pande11ebc4e2012-05-10 20:19:54 +00002220 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002221 CmdArgs.push_back("-mllvm");
2222 CmdArgs.push_back("-machine-sink-split=0");
Tony Linthicum76329bf2011-12-12 21:14:55 +00002223}
2224
Jacques Pienaard964cc22016-03-28 21:02:54 +00002225void Clang::AddLanaiTargetArgs(const ArgList &Args,
2226 ArgStringList &CmdArgs) const {
2227 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ)) {
2228 StringRef CPUName = A->getValue();
2229
2230 CmdArgs.push_back("-target-cpu");
2231 CmdArgs.push_back(Args.MakeArgString(CPUName));
2232 }
2233 if (Arg *A = Args.getLastArg(options::OPT_mregparm_EQ)) {
2234 StringRef Value = A->getValue();
2235 // Only support mregparm=4 to support old usage. Report error for all other
2236 // cases.
2237 int Mregparm;
2238 if (Value.getAsInteger(10, Mregparm)) {
2239 if (Mregparm != 4) {
2240 getToolChain().getDriver().Diag(
2241 diag::err_drv_unsupported_option_argument)
2242 << A->getOption().getName() << Value;
2243 }
2244 }
2245 }
2246}
2247
Dan Gohmane3d71e12016-01-07 01:00:21 +00002248void Clang::AddWebAssemblyTargetArgs(const ArgList &Args,
2249 ArgStringList &CmdArgs) const {
2250 // Default to "hidden" visibility.
2251 if (!Args.hasArg(options::OPT_fvisibility_EQ,
2252 options::OPT_fvisibility_ms_compat)) {
2253 CmdArgs.push_back("-fvisibility");
2254 CmdArgs.push_back("hidden");
2255 }
2256}
2257
Kevin Qin110db6f2014-07-18 07:03:22 +00002258// Decode AArch64 features from string like +[no]featureA+[no]featureB+...
Craig Topperbf3e3272014-08-30 16:55:52 +00002259static bool DecodeAArch64Features(const Driver &D, StringRef text,
Kevin Qin110db6f2014-07-18 07:03:22 +00002260 std::vector<const char *> &Features) {
2261 SmallVector<StringRef, 8> Split;
2262 text.split(Split, StringRef("+"), -1, false);
2263
Benjamin Kramer72e64312015-09-24 14:48:49 +00002264 for (StringRef Feature : Split) {
Renato Golin3b8709c2016-05-25 12:36:31 +00002265 const char *result = llvm::StringSwitch<const char *>(Feature)
2266 .Case("fp", "+fp-armv8")
2267 .Case("simd", "+neon")
2268 .Case("crc", "+crc")
2269 .Case("crypto", "+crypto")
2270 .Case("fp16", "+fullfp16")
2271 .Case("profile", "+spe")
2272 .Case("nofp", "-fp-armv8")
2273 .Case("nosimd", "-neon")
2274 .Case("nocrc", "-crc")
2275 .Case("nocrypto", "-crypto")
2276 .Case("nofp16", "-fullfp16")
2277 .Case("noprofile", "-spe")
2278 .Default(nullptr);
2279 if (result)
2280 Features.push_back(result);
Douglas Katzman2675d012015-06-29 19:12:56 +00002281 else if (Feature == "neon" || Feature == "noneon")
Kevin Qin110db6f2014-07-18 07:03:22 +00002282 D.Diag(diag::err_drv_no_neon_modifier);
2283 else
2284 return false;
2285 }
2286 return true;
2287}
2288
2289// Check if the CPU name and feature modifiers in -mcpu are legal. If yes,
2290// decode CPU and feature.
2291static bool DecodeAArch64Mcpu(const Driver &D, StringRef Mcpu, StringRef &CPU,
2292 std::vector<const char *> &Features) {
2293 std::pair<StringRef, StringRef> Split = Mcpu.split("+");
2294 CPU = Split.first;
Renato Golin3b8709c2016-05-25 12:36:31 +00002295 if (CPU == "cortex-a53" || CPU == "cortex-a57" ||
2296 CPU == "cortex-a72" || CPU == "cortex-a35" || CPU == "exynos-m1" ||
2297 CPU == "kryo") {
2298 Features.push_back("+neon");
2299 Features.push_back("+crc");
2300 Features.push_back("+crypto");
2301 } else if (CPU == "cyclone") {
2302 Features.push_back("+neon");
2303 Features.push_back("+crypto");
2304 } else if (CPU == "generic") {
Kevin Qin110db6f2014-07-18 07:03:22 +00002305 Features.push_back("+neon");
2306 } else {
Renato Golin3b8709c2016-05-25 12:36:31 +00002307 return false;
2308 }
Kevin Qin110db6f2014-07-18 07:03:22 +00002309
2310 if (Split.second.size() && !DecodeAArch64Features(D, Split.second, Features))
2311 return false;
2312
2313 return true;
2314}
2315
2316static bool
2317getAArch64ArchFeaturesFromMarch(const Driver &D, StringRef March,
2318 const ArgList &Args,
2319 std::vector<const char *> &Features) {
Gabor Ballabas36451492015-06-18 14:23:12 +00002320 std::string MarchLowerCase = March.lower();
2321 std::pair<StringRef, StringRef> Split = StringRef(MarchLowerCase).split("+");
Vladimir Sukhareve851e042015-04-16 15:53:09 +00002322
Renato Golin3b8709c2016-05-25 12:36:31 +00002323 if (Split.first == "armv8-a" || Split.first == "armv8a") {
2324 // ok, no additional features.
2325 } else if (Split.first == "armv8.1-a" || Split.first == "armv8.1a") {
2326 Features.push_back("+v8.1a");
2327 } else if (Split.first == "armv8.2-a" || Split.first == "armv8.2a" ) {
2328 Features.push_back("+v8.2a");
2329 } else {
2330 return false;
2331 }
2332
2333 if (Split.second.size() && !DecodeAArch64Features(D, Split.second, Features))
Kevin Qin110db6f2014-07-18 07:03:22 +00002334 return false;
2335
2336 return true;
2337}
2338
2339static bool
2340getAArch64ArchFeaturesFromMcpu(const Driver &D, StringRef Mcpu,
2341 const ArgList &Args,
2342 std::vector<const char *> &Features) {
2343 StringRef CPU;
Gabor Ballabas726ce7f2015-06-12 17:33:37 +00002344 std::string McpuLowerCase = Mcpu.lower();
2345 if (!DecodeAArch64Mcpu(D, McpuLowerCase, CPU, Features))
Kevin Qin110db6f2014-07-18 07:03:22 +00002346 return false;
2347
2348 return true;
2349}
2350
2351static bool
2352getAArch64MicroArchFeaturesFromMtune(const Driver &D, StringRef Mtune,
2353 const ArgList &Args,
2354 std::vector<const char *> &Features) {
Gabor Ballabasa24a1a42015-07-20 11:28:20 +00002355 std::string MtuneLowerCase = Mtune.lower();
Kevin Qin110db6f2014-07-18 07:03:22 +00002356 // Handle CPU name is 'native'.
Gabor Ballabasa24a1a42015-07-20 11:28:20 +00002357 if (MtuneLowerCase == "native")
2358 MtuneLowerCase = llvm::sys::getHostCPUName();
2359 if (MtuneLowerCase == "cyclone") {
Kevin Qin110db6f2014-07-18 07:03:22 +00002360 Features.push_back("+zcm");
2361 Features.push_back("+zcz");
2362 }
2363 return true;
2364}
2365
2366static bool
2367getAArch64MicroArchFeaturesFromMcpu(const Driver &D, StringRef Mcpu,
2368 const ArgList &Args,
2369 std::vector<const char *> &Features) {
2370 StringRef CPU;
2371 std::vector<const char *> DecodedFeature;
Gabor Ballabas726ce7f2015-06-12 17:33:37 +00002372 std::string McpuLowerCase = Mcpu.lower();
2373 if (!DecodeAArch64Mcpu(D, McpuLowerCase, CPU, DecodedFeature))
Kevin Qin110db6f2014-07-18 07:03:22 +00002374 return false;
2375
2376 return getAArch64MicroArchFeaturesFromMtune(D, CPU, Args, Features);
2377}
2378
Justin Bognerf9052562015-11-13 23:07:31 +00002379static void getAArch64TargetFeatures(const Driver &D, const ArgList &Args,
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002380 std::vector<const char *> &Features) {
Kevin Qin110db6f2014-07-18 07:03:22 +00002381 Arg *A;
2382 bool success = true;
2383 // Enable NEON by default.
2384 Features.push_back("+neon");
2385 if ((A = Args.getLastArg(options::OPT_march_EQ)))
2386 success = getAArch64ArchFeaturesFromMarch(D, A->getValue(), Args, Features);
2387 else if ((A = Args.getLastArg(options::OPT_mcpu_EQ)))
2388 success = getAArch64ArchFeaturesFromMcpu(D, A->getValue(), Args, Features);
Tim Northover642e7702014-11-10 21:17:23 +00002389 else if (Args.hasArg(options::OPT_arch))
2390 success = getAArch64ArchFeaturesFromMcpu(D, getAArch64TargetCPU(Args), Args,
2391 Features);
Kevin Qin110db6f2014-07-18 07:03:22 +00002392
2393 if (success && (A = Args.getLastArg(options::OPT_mtune_EQ)))
2394 success =
2395 getAArch64MicroArchFeaturesFromMtune(D, A->getValue(), Args, Features);
2396 else if (success && (A = Args.getLastArg(options::OPT_mcpu_EQ)))
2397 success =
2398 getAArch64MicroArchFeaturesFromMcpu(D, A->getValue(), Args, Features);
Tim Northover642e7702014-11-10 21:17:23 +00002399 else if (Args.hasArg(options::OPT_arch))
2400 success = getAArch64MicroArchFeaturesFromMcpu(D, getAArch64TargetCPU(Args),
2401 Args, Features);
Kevin Qin110db6f2014-07-18 07:03:22 +00002402
2403 if (!success)
2404 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
Amara Emerson04e2ecf2014-01-23 15:48:30 +00002405
2406 if (Args.getLastArg(options::OPT_mgeneral_regs_only)) {
2407 Features.push_back("-fp-armv8");
2408 Features.push_back("-crypto");
2409 Features.push_back("-neon");
2410 }
Bradley Smith418c5932014-05-02 15:17:51 +00002411
2412 // En/disable crc
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002413 if (Arg *A = Args.getLastArg(options::OPT_mcrc, options::OPT_mnocrc)) {
Bradley Smith418c5932014-05-02 15:17:51 +00002414 if (A->getOption().matches(options::OPT_mcrc))
2415 Features.push_back("+crc");
2416 else
2417 Features.push_back("-crc");
2418 }
Akira Hatanaka4e3c86f2015-07-25 00:18:00 +00002419
Akira Hatanaka085da7e2015-07-29 14:25:58 +00002420 if (Arg *A = Args.getLastArg(options::OPT_mno_unaligned_access,
2421 options::OPT_munaligned_access))
2422 if (A->getOption().matches(options::OPT_mno_unaligned_access))
2423 Features.push_back("+strict-align");
2424
Justin Bognerf9052562015-11-13 23:07:31 +00002425 if (Args.hasArg(options::OPT_ffixed_x18))
Akira Hatanaka4e3c86f2015-07-25 00:18:00 +00002426 Features.push_back("+reserve-x18");
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002427}
2428
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00002429static void getHexagonTargetFeatures(const ArgList &Args,
2430 std::vector<const char *> &Features) {
2431 bool HasHVX = false, HasHVXD = false;
2432
Eric Christopher49062a52015-12-22 03:12:34 +00002433 // FIXME: This should be able to use handleTargetFeaturesGroup except it is
2434 // doing dependent option handling here rather than in initFeatureMap or a
2435 // similar handler.
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00002436 for (auto &A : Args) {
2437 auto &Opt = A->getOption();
2438 if (Opt.matches(options::OPT_mhexagon_hvx))
2439 HasHVX = true;
2440 else if (Opt.matches(options::OPT_mno_hexagon_hvx))
2441 HasHVXD = HasHVX = false;
2442 else if (Opt.matches(options::OPT_mhexagon_hvx_double))
2443 HasHVXD = HasHVX = true;
2444 else if (Opt.matches(options::OPT_mno_hexagon_hvx_double))
2445 HasHVXD = false;
2446 else
2447 continue;
2448 A->claim();
2449 }
2450
2451 Features.push_back(HasHVX ? "+hvx" : "-hvx");
2452 Features.push_back(HasHVXD ? "+hvx-double" : "-hvx-double");
2453}
2454
Dan Gohmanc2853072015-09-03 22:51:53 +00002455static void getWebAssemblyTargetFeatures(const ArgList &Args,
2456 std::vector<const char *> &Features) {
Eric Christopher49062a52015-12-22 03:12:34 +00002457 handleTargetFeaturesGroup(Args, Features, options::OPT_m_wasm_Features_Group);
Dan Gohmanc2853072015-09-03 22:51:53 +00002458}
2459
Konstantin Zhuravlyov5124bf82016-04-12 21:42:15 +00002460static void getAMDGPUTargetFeatures(const Driver &D, const ArgList &Args,
2461 std::vector<const char *> &Features) {
2462 if (const Arg *dAbi = Args.getLastArg(options::OPT_mamdgpu_debugger_abi)) {
2463 StringRef value = dAbi->getValue();
2464 if (value == "1.0") {
2465 Features.push_back("+amdgpu-debugger-insert-nops");
2466 Features.push_back("+amdgpu-debugger-reserve-trap-regs");
2467 } else {
2468 D.Diag(diag::err_drv_clang_unsupported) << dAbi->getAsString(Args);
2469 }
2470 }
2471
2472 handleTargetFeaturesGroup(
2473 Args, Features, options::OPT_m_amdgpu_Features_Group);
2474}
2475
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00002476static void getTargetFeatures(const ToolChain &TC, const llvm::Triple &Triple,
Rafael Espindola9c6fb0f2013-11-23 14:36:40 +00002477 const ArgList &Args, ArgStringList &CmdArgs,
2478 bool ForAS) {
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00002479 const Driver &D = TC.getDriver();
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002480 std::vector<const char *> Features;
2481 switch (Triple.getArch()) {
2482 default:
2483 break;
2484 case llvm::Triple::mips:
2485 case llvm::Triple::mipsel:
2486 case llvm::Triple::mips64:
2487 case llvm::Triple::mips64el:
Daniel Sanders379d44b2014-07-16 11:52:23 +00002488 getMIPSTargetFeatures(D, Triple, Args, Features);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002489 break;
2490
2491 case llvm::Triple::arm:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00002492 case llvm::Triple::armeb:
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002493 case llvm::Triple::thumb:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00002494 case llvm::Triple::thumbeb:
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00002495 getARMTargetFeatures(TC, Triple, Args, Features, ForAS);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002496 break;
2497
2498 case llvm::Triple::ppc:
2499 case llvm::Triple::ppc64:
2500 case llvm::Triple::ppc64le:
Petar Jovanovic88a328f2015-12-14 17:51:50 +00002501 getPPCTargetFeatures(D, Triple, Args, Features);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002502 break;
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00002503 case llvm::Triple::systemz:
2504 getSystemZTargetFeatures(Args, Features);
2505 break;
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002506 case llvm::Triple::aarch64:
Christian Pirker9b019ae2014-02-25 13:51:00 +00002507 case llvm::Triple::aarch64_be:
Justin Bognerf9052562015-11-13 23:07:31 +00002508 getAArch64TargetFeatures(D, Args, Features);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002509 break;
2510 case llvm::Triple::x86:
2511 case llvm::Triple::x86_64:
Ehsan Akhgarieeb7e652014-07-15 18:27:51 +00002512 getX86TargetFeatures(D, Triple, Args, Features);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002513 break;
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00002514 case llvm::Triple::hexagon:
2515 getHexagonTargetFeatures(Args, Features);
2516 break;
Dan Gohmanc2853072015-09-03 22:51:53 +00002517 case llvm::Triple::wasm32:
2518 case llvm::Triple::wasm64:
2519 getWebAssemblyTargetFeatures(Args, Features);
Jacob Baungard Hansen13a49372016-05-24 08:30:08 +00002520 break;
2521 case llvm::Triple::sparc:
2522 case llvm::Triple::sparcel:
2523 case llvm::Triple::sparcv9:
2524 getSparcTargetFeatures(D, Args, Features);
Dan Gohmanc2853072015-09-03 22:51:53 +00002525 break;
Konstantin Zhuravlyov5124bf82016-04-12 21:42:15 +00002526 case llvm::Triple::r600:
2527 case llvm::Triple::amdgcn:
2528 getAMDGPUTargetFeatures(D, Args, Features);
2529 break;
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002530 }
Rafael Espindola43964802013-08-21 17:34:32 +00002531
2532 // Find the last of each feature.
2533 llvm::StringMap<unsigned> LastOpt;
2534 for (unsigned I = 0, N = Features.size(); I < N; ++I) {
2535 const char *Name = Features[I];
2536 assert(Name[0] == '-' || Name[0] == '+');
2537 LastOpt[Name + 1] = I;
2538 }
2539
2540 for (unsigned I = 0, N = Features.size(); I < N; ++I) {
2541 // If this feature was overridden, ignore it.
2542 const char *Name = Features[I];
2543 llvm::StringMap<unsigned>::iterator LastI = LastOpt.find(Name + 1);
2544 assert(LastI != LastOpt.end());
2545 unsigned Last = LastI->second;
2546 if (Last != I)
2547 continue;
2548
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002549 CmdArgs.push_back("-target-feature");
Rafael Espindola43964802013-08-21 17:34:32 +00002550 CmdArgs.push_back(Name);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002551 }
Tim Northover2fe823a2013-08-01 09:23:19 +00002552}
2553
David Majnemerae394812014-12-09 00:12:30 +00002554static bool
2555shouldUseExceptionTablesForObjCExceptions(const ObjCRuntime &runtime,
2556 const llvm::Triple &Triple) {
2557 // We use the zero-cost exception tables for Objective-C if the non-fragile
2558 // ABI is enabled or when compiling for x86_64 and ARM on Snow Leopard and
2559 // later.
2560 if (runtime.isNonFragile())
2561 return true;
2562
2563 if (!Triple.isMacOSX())
2564 return false;
2565
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002566 return (!Triple.isMacOSXVersionLT(10, 5) &&
David Majnemerae394812014-12-09 00:12:30 +00002567 (Triple.getArch() == llvm::Triple::x86_64 ||
2568 Triple.getArch() == llvm::Triple::arm));
2569}
2570
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002571/// Adds exception related arguments to the driver command arguments. There's a
2572/// master flag, -fexceptions and also language specific flags to enable/disable
2573/// C++ and Objective-C exceptions. This makes it possible to for example
2574/// disable C++ exceptions but enable Objective-C exceptions.
Anders Carlssone96ab552011-02-28 02:27:16 +00002575static void addExceptionArgs(const ArgList &Args, types::ID InputType,
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002576 const ToolChain &TC, bool KernelOrKext,
John McCall5fb5df92012-06-20 06:18:46 +00002577 const ObjCRuntime &objcRuntime,
Anders Carlssone96ab552011-02-28 02:27:16 +00002578 ArgStringList &CmdArgs) {
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002579 const Driver &D = TC.getDriver();
2580 const llvm::Triple &Triple = TC.getTriple();
2581
Chad Rosier4fab82c2012-03-26 22:04:46 +00002582 if (KernelOrKext) {
2583 // -mkernel and -fapple-kext imply no exceptions, so claim exception related
2584 // arguments now to avoid warnings about unused arguments.
2585 Args.ClaimAllArgs(options::OPT_fexceptions);
2586 Args.ClaimAllArgs(options::OPT_fno_exceptions);
2587 Args.ClaimAllArgs(options::OPT_fobjc_exceptions);
2588 Args.ClaimAllArgs(options::OPT_fno_objc_exceptions);
2589 Args.ClaimAllArgs(options::OPT_fcxx_exceptions);
2590 Args.ClaimAllArgs(options::OPT_fno_cxx_exceptions);
Anders Carlssone96ab552011-02-28 02:27:16 +00002591 return;
Chad Rosier4fab82c2012-03-26 22:04:46 +00002592 }
Anders Carlssone96ab552011-02-28 02:27:16 +00002593
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00002594 // See if the user explicitly enabled exceptions.
2595 bool EH = Args.hasFlag(options::OPT_fexceptions, options::OPT_fno_exceptions,
2596 false);
Daniel Dunbar30a12b82010-09-14 23:12:31 +00002597
David Majnemerae394812014-12-09 00:12:30 +00002598 // Obj-C exceptions are enabled by default, regardless of -fexceptions. This
2599 // is not necessarily sensible, but follows GCC.
2600 if (types::isObjC(InputType) &&
2601 Args.hasFlag(options::OPT_fobjc_exceptions,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002602 options::OPT_fno_objc_exceptions, true)) {
David Majnemerae394812014-12-09 00:12:30 +00002603 CmdArgs.push_back("-fobjc-exceptions");
Anders Carlssone96ab552011-02-28 02:27:16 +00002604
David Majnemerae394812014-12-09 00:12:30 +00002605 EH |= shouldUseExceptionTablesForObjCExceptions(objcRuntime, Triple);
Anders Carlssone96ab552011-02-28 02:27:16 +00002606 }
2607
2608 if (types::isCXX(InputType)) {
David Majnemer59729392016-02-18 08:15:05 +00002609 // Disable C++ EH by default on XCore and PS4.
2610 bool CXXExceptionsEnabled =
2611 Triple.getArch() != llvm::Triple::xcore && !Triple.isPS4CPU();
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002612 Arg *ExceptionArg = Args.getLastArg(
2613 options::OPT_fcxx_exceptions, options::OPT_fno_cxx_exceptions,
2614 options::OPT_fexceptions, options::OPT_fno_exceptions);
2615 if (ExceptionArg)
David Majnemer8de68642014-12-05 08:11:58 +00002616 CXXExceptionsEnabled =
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002617 ExceptionArg->getOption().matches(options::OPT_fcxx_exceptions) ||
2618 ExceptionArg->getOption().matches(options::OPT_fexceptions);
Anders Carlssone96ab552011-02-28 02:27:16 +00002619
2620 if (CXXExceptionsEnabled) {
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002621 if (Triple.isPS4CPU()) {
2622 ToolChain::RTTIMode RTTIMode = TC.getRTTIMode();
2623 assert(ExceptionArg &&
2624 "On the PS4 exceptions should only be enabled if passing "
2625 "an argument");
2626 if (RTTIMode == ToolChain::RM_DisabledExplicitly) {
2627 const Arg *RTTIArg = TC.getRTTIArg();
2628 assert(RTTIArg && "RTTI disabled explicitly but no RTTIArg!");
2629 D.Diag(diag::err_drv_argument_not_allowed_with)
2630 << RTTIArg->getAsString(Args) << ExceptionArg->getAsString(Args);
2631 } else if (RTTIMode == ToolChain::RM_EnabledImplicitly)
2632 D.Diag(diag::warn_drv_enabling_rtti_with_exceptions);
2633 } else
2634 assert(TC.getRTTIMode() != ToolChain::RM_DisabledImplicitly);
2635
Anders Carlssone96ab552011-02-28 02:27:16 +00002636 CmdArgs.push_back("-fcxx-exceptions");
2637
David Majnemer8de68642014-12-05 08:11:58 +00002638 EH = true;
Anders Carlssone96ab552011-02-28 02:27:16 +00002639 }
2640 }
2641
David Majnemer8de68642014-12-05 08:11:58 +00002642 if (EH)
Anders Carlssone96ab552011-02-28 02:27:16 +00002643 CmdArgs.push_back("-fexceptions");
Rafael Espindola00a66572009-10-01 13:33:33 +00002644}
2645
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002646static bool ShouldDisableAutolink(const ArgList &Args, const ToolChain &TC) {
Daniel Dunbare246fbe2013-04-16 18:21:19 +00002647 bool Default = true;
2648 if (TC.getTriple().isOSDarwin()) {
2649 // The native darwin assembler doesn't support the linker_option directives,
2650 // so we disable them if we think the .s file will be passed to it.
2651 Default = TC.useIntegratedAs();
2652 }
2653 return !Args.hasFlag(options::OPT_fautolink, options::OPT_fno_autolink,
2654 Default);
2655}
2656
Ted Kremenek62093662013-03-12 17:02:12 +00002657static bool ShouldDisableDwarfDirectory(const ArgList &Args,
2658 const ToolChain &TC) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002659 bool UseDwarfDirectory =
2660 Args.hasFlag(options::OPT_fdwarf_directory_asm,
2661 options::OPT_fno_dwarf_directory_asm, TC.useIntegratedAs());
Nick Lewycky1d617ac2011-10-17 23:05:52 +00002662 return !UseDwarfDirectory;
2663}
2664
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00002665/// \brief Check whether the given input tree contains any compilation actions.
2666static bool ContainsCompileAction(const Action *A) {
Bob Wilson23a55f12014-12-21 07:00:00 +00002667 if (isa<CompileJobAction>(A) || isa<BackendJobAction>(A))
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00002668 return true;
2669
Nico Weber5a459f82016-02-23 19:30:43 +00002670 for (const auto &AI : A->inputs())
2671 if (ContainsCompileAction(AI))
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00002672 return true;
2673
2674 return false;
2675}
2676
2677/// \brief Check if -relax-all should be passed to the internal assembler.
2678/// This is done by default when compiling non-assembler source with -O0.
2679static bool UseRelaxAll(Compilation &C, const ArgList &Args) {
2680 bool RelaxDefault = true;
2681
2682 if (Arg *A = Args.getLastArg(options::OPT_O_Group))
2683 RelaxDefault = A->getOption().matches(options::OPT_O0);
2684
2685 if (RelaxDefault) {
2686 RelaxDefault = false;
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00002687 for (const auto &Act : C.getActions()) {
2688 if (ContainsCompileAction(Act)) {
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00002689 RelaxDefault = true;
2690 break;
2691 }
2692 }
2693 }
2694
2695 return Args.hasFlag(options::OPT_mrelax_all, options::OPT_mno_relax_all,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002696 RelaxDefault);
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00002697}
2698
Paul Robinson0334a042015-12-19 19:41:48 +00002699// Convert an arg of the form "-gN" or "-ggdbN" or one of their aliases
2700// to the corresponding DebugInfoKind.
Benjamin Kramer8c305922016-02-02 11:06:51 +00002701static codegenoptions::DebugInfoKind DebugLevelToInfoKind(const Arg &A) {
Paul Robinson0334a042015-12-19 19:41:48 +00002702 assert(A.getOption().matches(options::OPT_gN_Group) &&
2703 "Not a -g option that specifies a debug-info level");
2704 if (A.getOption().matches(options::OPT_g0) ||
2705 A.getOption().matches(options::OPT_ggdb0))
Benjamin Kramer8c305922016-02-02 11:06:51 +00002706 return codegenoptions::NoDebugInfo;
Paul Robinson0334a042015-12-19 19:41:48 +00002707 if (A.getOption().matches(options::OPT_gline_tables_only) ||
2708 A.getOption().matches(options::OPT_ggdb1))
Benjamin Kramer8c305922016-02-02 11:06:51 +00002709 return codegenoptions::DebugLineTablesOnly;
2710 return codegenoptions::LimitedDebugInfo;
Paul Robinson0334a042015-12-19 19:41:48 +00002711}
2712
Douglas Katzman3459ce22015-10-08 04:24:12 +00002713// Extract the integer N from a string spelled "-dwarf-N", returning 0
2714// on mismatch. The StringRef input (rather than an Arg) allows
2715// for use by the "-Xassembler" option parser.
2716static unsigned DwarfVersionNum(StringRef ArgValue) {
2717 return llvm::StringSwitch<unsigned>(ArgValue)
2718 .Case("-gdwarf-2", 2)
2719 .Case("-gdwarf-3", 3)
2720 .Case("-gdwarf-4", 4)
Eric Christopher3cb592d2015-12-28 19:58:44 +00002721 .Case("-gdwarf-5", 5)
Douglas Katzman3459ce22015-10-08 04:24:12 +00002722 .Default(0);
2723}
2724
2725static void RenderDebugEnablingArgs(const ArgList &Args, ArgStringList &CmdArgs,
Benjamin Kramer8c305922016-02-02 11:06:51 +00002726 codegenoptions::DebugInfoKind DebugInfoKind,
Paul Robinson0334a042015-12-19 19:41:48 +00002727 unsigned DwarfVersion,
2728 llvm::DebuggerKind DebuggerTuning) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00002729 switch (DebugInfoKind) {
Benjamin Kramer8c305922016-02-02 11:06:51 +00002730 case codegenoptions::DebugLineTablesOnly:
Douglas Katzman3459ce22015-10-08 04:24:12 +00002731 CmdArgs.push_back("-debug-info-kind=line-tables-only");
2732 break;
Benjamin Kramer8c305922016-02-02 11:06:51 +00002733 case codegenoptions::LimitedDebugInfo:
Douglas Katzman3459ce22015-10-08 04:24:12 +00002734 CmdArgs.push_back("-debug-info-kind=limited");
2735 break;
Benjamin Kramer8c305922016-02-02 11:06:51 +00002736 case codegenoptions::FullDebugInfo:
Douglas Katzman3459ce22015-10-08 04:24:12 +00002737 CmdArgs.push_back("-debug-info-kind=standalone");
2738 break;
2739 default:
2740 break;
2741 }
2742 if (DwarfVersion > 0)
2743 CmdArgs.push_back(
Benjamin Kramer32bd3c82015-10-08 10:31:17 +00002744 Args.MakeArgString("-dwarf-version=" + Twine(DwarfVersion)));
Paul Robinson0334a042015-12-19 19:41:48 +00002745 switch (DebuggerTuning) {
2746 case llvm::DebuggerKind::GDB:
2747 CmdArgs.push_back("-debugger-tuning=gdb");
2748 break;
2749 case llvm::DebuggerKind::LLDB:
2750 CmdArgs.push_back("-debugger-tuning=lldb");
2751 break;
2752 case llvm::DebuggerKind::SCE:
2753 CmdArgs.push_back("-debugger-tuning=sce");
2754 break;
2755 default:
2756 break;
2757 }
Douglas Katzman3459ce22015-10-08 04:24:12 +00002758}
2759
David Blaikie9260ed62013-07-25 21:19:01 +00002760static void CollectArgsForIntegratedAssembler(Compilation &C,
2761 const ArgList &Args,
2762 ArgStringList &CmdArgs,
2763 const Driver &D) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002764 if (UseRelaxAll(C, Args))
2765 CmdArgs.push_back("-mrelax-all");
David Blaikie9260ed62013-07-25 21:19:01 +00002766
David Majnemer2b9349d2015-12-21 22:09:34 +00002767 // Only default to -mincremental-linker-compatible if we think we are
2768 // targeting the MSVC linker.
2769 bool DefaultIncrementalLinkerCompatible =
2770 C.getDefaultToolChain().getTriple().isWindowsMSVCEnvironment();
2771 if (Args.hasFlag(options::OPT_mincremental_linker_compatible,
2772 options::OPT_mno_incremental_linker_compatible,
2773 DefaultIncrementalLinkerCompatible))
2774 CmdArgs.push_back("-mincremental-linker-compatible");
2775
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002776 // When passing -I arguments to the assembler we sometimes need to
2777 // unconditionally take the next argument. For example, when parsing
2778 // '-Wa,-I -Wa,foo' we need to accept the -Wa,foo arg after seeing the
2779 // -Wa,-I arg and when parsing '-Wa,-I,foo' we need to accept the 'foo'
2780 // arg after parsing the '-I' arg.
2781 bool TakeNextArg = false;
David Peixottodfb66142013-11-14 22:52:58 +00002782
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002783 // When using an integrated assembler, translate -Wa, and -Xassembler
2784 // options.
2785 bool CompressDebugSections = false;
Scott Egertonb67d4692016-01-14 13:01:48 +00002786 const char *MipsTargetFeature = nullptr;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002787 for (const Arg *A :
2788 Args.filtered(options::OPT_Wa_COMMA, options::OPT_Xassembler)) {
2789 A->claim();
David Blaikie9260ed62013-07-25 21:19:01 +00002790
Benjamin Kramer72e64312015-09-24 14:48:49 +00002791 for (StringRef Value : A->getValues()) {
Renato Golin7c542b42015-07-27 23:44:45 +00002792 if (TakeNextArg) {
2793 CmdArgs.push_back(Value.data());
2794 TakeNextArg = false;
2795 continue;
2796 }
David Blaikie9260ed62013-07-25 21:19:01 +00002797
Daniel Sanders3d5e5682015-10-27 18:04:42 +00002798 switch (C.getDefaultToolChain().getArch()) {
2799 default:
2800 break;
2801 case llvm::Triple::mips:
2802 case llvm::Triple::mipsel:
2803 case llvm::Triple::mips64:
2804 case llvm::Triple::mips64el:
2805 if (Value == "--trap") {
2806 CmdArgs.push_back("-target-feature");
2807 CmdArgs.push_back("+use-tcc-in-div");
2808 continue;
2809 }
2810 if (Value == "--break") {
2811 CmdArgs.push_back("-target-feature");
2812 CmdArgs.push_back("-use-tcc-in-div");
2813 continue;
2814 }
2815 if (Value.startswith("-msoft-float")) {
2816 CmdArgs.push_back("-target-feature");
2817 CmdArgs.push_back("+soft-float");
2818 continue;
2819 }
2820 if (Value.startswith("-mhard-float")) {
2821 CmdArgs.push_back("-target-feature");
2822 CmdArgs.push_back("-soft-float");
2823 continue;
2824 }
Scott Egertonb67d4692016-01-14 13:01:48 +00002825
2826 MipsTargetFeature = llvm::StringSwitch<const char *>(Value)
2827 .Case("-mips1", "+mips1")
2828 .Case("-mips2", "+mips2")
2829 .Case("-mips3", "+mips3")
2830 .Case("-mips4", "+mips4")
2831 .Case("-mips5", "+mips5")
2832 .Case("-mips32", "+mips32")
2833 .Case("-mips32r2", "+mips32r2")
2834 .Case("-mips32r3", "+mips32r3")
2835 .Case("-mips32r5", "+mips32r5")
2836 .Case("-mips32r6", "+mips32r6")
2837 .Case("-mips64", "+mips64")
2838 .Case("-mips64r2", "+mips64r2")
2839 .Case("-mips64r3", "+mips64r3")
2840 .Case("-mips64r5", "+mips64r5")
2841 .Case("-mips64r6", "+mips64r6")
2842 .Default(nullptr);
2843 if (MipsTargetFeature)
2844 continue;
Daniel Sanders3d5e5682015-10-27 18:04:42 +00002845 }
2846
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002847 if (Value == "-force_cpusubtype_ALL") {
2848 // Do nothing, this is the default and we don't support anything else.
2849 } else if (Value == "-L") {
2850 CmdArgs.push_back("-msave-temp-labels");
2851 } else if (Value == "--fatal-warnings") {
2852 CmdArgs.push_back("-massembler-fatal-warnings");
2853 } else if (Value == "--noexecstack") {
2854 CmdArgs.push_back("-mnoexecstack");
2855 } else if (Value == "-compress-debug-sections" ||
2856 Value == "--compress-debug-sections") {
2857 CompressDebugSections = true;
2858 } else if (Value == "-nocompress-debug-sections" ||
2859 Value == "--nocompress-debug-sections") {
2860 CompressDebugSections = false;
2861 } else if (Value.startswith("-I")) {
2862 CmdArgs.push_back(Value.data());
2863 // We need to consume the next argument if the current arg is a plain
2864 // -I. The next arg will be the include directory.
2865 if (Value == "-I")
2866 TakeNextArg = true;
2867 } else if (Value.startswith("-gdwarf-")) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00002868 // "-gdwarf-N" options are not cc1as options.
2869 unsigned DwarfVersion = DwarfVersionNum(Value);
2870 if (DwarfVersion == 0) { // Send it onward, and let cc1as complain.
2871 CmdArgs.push_back(Value.data());
2872 } else {
Benjamin Kramer8c305922016-02-02 11:06:51 +00002873 RenderDebugEnablingArgs(Args, CmdArgs,
2874 codegenoptions::LimitedDebugInfo,
2875 DwarfVersion, llvm::DebuggerKind::Default);
Douglas Katzman3459ce22015-10-08 04:24:12 +00002876 }
Renato Golin7c542b42015-07-27 23:44:45 +00002877 } else if (Value.startswith("-mcpu") || Value.startswith("-mfpu") ||
2878 Value.startswith("-mhwdiv") || Value.startswith("-march")) {
2879 // Do nothing, we'll validate it later.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002880 } else {
2881 D.Diag(diag::err_drv_unsupported_option_argument)
David Blaikie9260ed62013-07-25 21:19:01 +00002882 << A->getOption().getName() << Value;
David Blaikie9260ed62013-07-25 21:19:01 +00002883 }
2884 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002885 }
2886 if (CompressDebugSections) {
2887 if (llvm::zlib::isAvailable())
2888 CmdArgs.push_back("-compress-debug-sections");
2889 else
2890 D.Diag(diag::warn_debug_compression_unavailable);
2891 }
Scott Egertonb67d4692016-01-14 13:01:48 +00002892 if (MipsTargetFeature != nullptr) {
2893 CmdArgs.push_back("-target-feature");
2894 CmdArgs.push_back(MipsTargetFeature);
2895 }
David Blaikie9260ed62013-07-25 21:19:01 +00002896}
2897
Alexey Samsonov99ee10d2014-05-22 21:13:30 +00002898// This adds the static libclang_rt.builtins-arch.a directly to the command line
Renato Golinc4b49242014-02-13 10:01:16 +00002899// FIXME: Make sure we can also emit shared objects if they're requested
2900// and available, check for possible errors, etc.
Saleem Abdulrasool8d7ade72014-12-30 02:10:36 +00002901static void addClangRT(const ToolChain &TC, const ArgList &Args,
2902 ArgStringList &CmdArgs) {
Xinliang David Li69306c02015-10-22 06:15:31 +00002903 CmdArgs.push_back(TC.getCompilerRTArgString(Args, "builtins"));
Alexey Samsonovbdfa6c22014-04-01 13:31:10 +00002904}
2905
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002906namespace {
2907enum OpenMPRuntimeKind {
2908 /// An unknown OpenMP runtime. We can't generate effective OpenMP code
2909 /// without knowing what runtime to target.
2910 OMPRT_Unknown,
2911
2912 /// The LLVM OpenMP runtime. When completed and integrated, this will become
2913 /// the default for Clang.
2914 OMPRT_OMP,
2915
2916 /// The GNU OpenMP runtime. Clang doesn't support generating OpenMP code for
2917 /// this runtime but can swallow the pragmas, and find and link against the
2918 /// runtime library itself.
2919 OMPRT_GOMP,
2920
Chandler Carruthc6625c62015-05-28 21:10:31 +00002921 /// The legacy name for the LLVM OpenMP runtime from when it was the Intel
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002922 /// OpenMP runtime. We support this mode for users with existing dependencies
2923 /// on this runtime library name.
2924 OMPRT_IOMP5
2925};
Alexander Kornienkoab9db512015-06-22 23:07:51 +00002926}
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002927
2928/// Compute the desired OpenMP runtime from the flag provided.
Chandler Carruthc6625c62015-05-28 21:10:31 +00002929static OpenMPRuntimeKind getOpenMPRuntime(const ToolChain &TC,
2930 const ArgList &Args) {
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002931 StringRef RuntimeName(CLANG_DEFAULT_OPENMP_RUNTIME);
2932
2933 const Arg *A = Args.getLastArg(options::OPT_fopenmp_EQ);
2934 if (A)
2935 RuntimeName = A->getValue();
2936
2937 auto RT = llvm::StringSwitch<OpenMPRuntimeKind>(RuntimeName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002938 .Case("libomp", OMPRT_OMP)
2939 .Case("libgomp", OMPRT_GOMP)
2940 .Case("libiomp5", OMPRT_IOMP5)
2941 .Default(OMPRT_Unknown);
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002942
2943 if (RT == OMPRT_Unknown) {
2944 if (A)
2945 TC.getDriver().Diag(diag::err_drv_unsupported_option_argument)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002946 << A->getOption().getName() << A->getValue();
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002947 else
2948 // FIXME: We could use a nicer diagnostic here.
2949 TC.getDriver().Diag(diag::err_drv_unsupported_opt) << "-fopenmp";
2950 }
2951
2952 return RT;
2953}
2954
Joerg Sonnenberger95a90132015-09-23 14:06:52 +00002955static void addOpenMPRuntime(ArgStringList &CmdArgs, const ToolChain &TC,
2956 const ArgList &Args) {
2957 if (!Args.hasFlag(options::OPT_fopenmp, options::OPT_fopenmp_EQ,
2958 options::OPT_fno_openmp, false))
2959 return;
2960
2961 switch (getOpenMPRuntime(TC, Args)) {
2962 case OMPRT_OMP:
2963 CmdArgs.push_back("-lomp");
2964 break;
2965 case OMPRT_GOMP:
2966 CmdArgs.push_back("-lgomp");
2967 break;
2968 case OMPRT_IOMP5:
2969 CmdArgs.push_back("-liomp5");
2970 break;
2971 case OMPRT_Unknown:
2972 // Already diagnosed.
2973 break;
2974 }
2975}
2976
Alexey Samsonov52550342014-09-15 19:58:40 +00002977static void addSanitizerRuntime(const ToolChain &TC, const ArgList &Args,
2978 ArgStringList &CmdArgs, StringRef Sanitizer,
Peter Collingbournedc134532016-01-16 00:31:22 +00002979 bool IsShared, bool IsWhole) {
2980 // Wrap any static runtimes that must be forced into executable in
Peter Collingbournef7ef3fd812013-10-20 21:29:13 +00002981 // whole-archive.
Peter Collingbournedc134532016-01-16 00:31:22 +00002982 if (IsWhole) CmdArgs.push_back("-whole-archive");
Xinliang David Li69306c02015-10-22 06:15:31 +00002983 CmdArgs.push_back(TC.getCompilerRTArgString(Args, Sanitizer, IsShared));
Peter Collingbournedc134532016-01-16 00:31:22 +00002984 if (IsWhole) CmdArgs.push_back("-no-whole-archive");
Alexey Samsonovbfb0cd32013-02-27 11:14:55 +00002985}
2986
Alexey Samsonov52550342014-09-15 19:58:40 +00002987// Tries to use a file with the list of dynamic symbols that need to be exported
2988// from the runtime library. Returns true if the file was found.
2989static bool addSanitizerDynamicList(const ToolChain &TC, const ArgList &Args,
2990 ArgStringList &CmdArgs,
2991 StringRef Sanitizer) {
Vasileios Kalintiris447e3572015-10-01 16:54:58 +00002992 SmallString<128> SanRT(TC.getCompilerRT(Args, Sanitizer));
Saleem Abdulrasool68150942014-12-30 22:52:08 +00002993 if (llvm::sys::fs::exists(SanRT + ".syms")) {
2994 CmdArgs.push_back(Args.MakeArgString("--dynamic-list=" + SanRT + ".syms"));
Alexey Samsonov52550342014-09-15 19:58:40 +00002995 return true;
2996 }
2997 return false;
2998}
2999
3000static void linkSanitizerRuntimeDeps(const ToolChain &TC,
3001 ArgStringList &CmdArgs) {
3002 // Force linking against the system libraries sanitizers depends on
3003 // (see PR15823 why this is necessary).
3004 CmdArgs.push_back("--no-as-needed");
3005 CmdArgs.push_back("-lpthread");
3006 CmdArgs.push_back("-lrt");
3007 CmdArgs.push_back("-lm");
3008 // There's no libdl on FreeBSD.
3009 if (TC.getTriple().getOS() != llvm::Triple::FreeBSD)
3010 CmdArgs.push_back("-ldl");
3011}
3012
3013static void
3014collectSanitizerRuntimes(const ToolChain &TC, const ArgList &Args,
3015 SmallVectorImpl<StringRef> &SharedRuntimes,
3016 SmallVectorImpl<StringRef> &StaticRuntimes,
Peter Collingbournedc134532016-01-16 00:31:22 +00003017 SmallVectorImpl<StringRef> &NonWholeStaticRuntimes,
3018 SmallVectorImpl<StringRef> &HelperStaticRuntimes,
3019 SmallVectorImpl<StringRef> &RequiredSymbols) {
Alexey Samsonov52550342014-09-15 19:58:40 +00003020 const SanitizerArgs &SanArgs = TC.getSanitizerArgs();
3021 // Collect shared runtimes.
3022 if (SanArgs.needsAsanRt() && SanArgs.needsSharedAsanRt()) {
3023 SharedRuntimes.push_back("asan");
Evgeniy Stepanov77866712012-04-25 08:59:22 +00003024 }
Peter Collingbournedc134532016-01-16 00:31:22 +00003025 // The stats_client library is also statically linked into DSOs.
3026 if (SanArgs.needsStatsRt())
3027 StaticRuntimes.push_back("stats_client");
Alexey Samsonovbdfa6c22014-04-01 13:31:10 +00003028
Alexey Samsonov52550342014-09-15 19:58:40 +00003029 // Collect static runtimes.
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00003030 if (Args.hasArg(options::OPT_shared) || TC.getTriple().isAndroid()) {
Alexey Samsonov52550342014-09-15 19:58:40 +00003031 // Don't link static runtimes into DSOs or if compiling for Android.
Alexey Samsonovbdfa6c22014-04-01 13:31:10 +00003032 return;
Alexey Samsonov52550342014-09-15 19:58:40 +00003033 }
3034 if (SanArgs.needsAsanRt()) {
3035 if (SanArgs.needsSharedAsanRt()) {
3036 HelperStaticRuntimes.push_back("asan-preinit");
3037 } else {
3038 StaticRuntimes.push_back("asan");
3039 if (SanArgs.linkCXXRuntimes())
3040 StaticRuntimes.push_back("asan_cxx");
3041 }
3042 }
3043 if (SanArgs.needsDfsanRt())
3044 StaticRuntimes.push_back("dfsan");
3045 if (SanArgs.needsLsanRt())
3046 StaticRuntimes.push_back("lsan");
Alexey Samsonov381845d2015-04-27 22:07:50 +00003047 if (SanArgs.needsMsanRt()) {
Alexey Samsonov52550342014-09-15 19:58:40 +00003048 StaticRuntimes.push_back("msan");
Alexey Samsonov381845d2015-04-27 22:07:50 +00003049 if (SanArgs.linkCXXRuntimes())
3050 StaticRuntimes.push_back("msan_cxx");
3051 }
3052 if (SanArgs.needsTsanRt()) {
Alexey Samsonov52550342014-09-15 19:58:40 +00003053 StaticRuntimes.push_back("tsan");
Alexey Samsonov381845d2015-04-27 22:07:50 +00003054 if (SanArgs.linkCXXRuntimes())
3055 StaticRuntimes.push_back("tsan_cxx");
3056 }
Alexey Samsonov52550342014-09-15 19:58:40 +00003057 if (SanArgs.needsUbsanRt()) {
Alexey Samsonov31095462015-04-01 22:42:25 +00003058 StaticRuntimes.push_back("ubsan_standalone");
3059 if (SanArgs.linkCXXRuntimes())
3060 StaticRuntimes.push_back("ubsan_standalone_cxx");
Alexey Samsonovb01f9362014-05-12 18:39:51 +00003061 }
Peter Collingbournec4122c12015-06-15 21:08:13 +00003062 if (SanArgs.needsSafeStackRt())
3063 StaticRuntimes.push_back("safestack");
Evgeniy Stepanovfd6f92d2015-12-15 23:00:20 +00003064 if (SanArgs.needsCfiRt())
3065 StaticRuntimes.push_back("cfi");
Evgeniy Stepanov3fd61df2016-01-25 23:34:52 +00003066 if (SanArgs.needsCfiDiagRt()) {
Evgeniy Stepanove3fb51c2015-12-16 00:38:42 +00003067 StaticRuntimes.push_back("cfi_diag");
Evgeniy Stepanov3fd61df2016-01-25 23:34:52 +00003068 if (SanArgs.linkCXXRuntimes())
3069 StaticRuntimes.push_back("ubsan_standalone_cxx");
3070 }
Peter Collingbournedc134532016-01-16 00:31:22 +00003071 if (SanArgs.needsStatsRt()) {
3072 NonWholeStaticRuntimes.push_back("stats");
3073 RequiredSymbols.push_back("__sanitizer_stats_register");
3074 }
Derek Bruening256c2e12016-04-21 21:32:04 +00003075 if (SanArgs.needsEsanRt())
3076 StaticRuntimes.push_back("esan");
Kostya Serebryany7bca6c22011-11-30 01:39:16 +00003077}
3078
Alexey Samsonov52550342014-09-15 19:58:40 +00003079// Should be called before we add system libraries (C++ ABI, libstdc++/libc++,
3080// C runtime, etc). Returns true if sanitizer system deps need to be linked in.
3081static bool addSanitizerRuntimes(const ToolChain &TC, const ArgList &Args,
Alexey Samsonovce8ab102014-02-25 12:43:43 +00003082 ArgStringList &CmdArgs) {
Alexey Samsonov52550342014-09-15 19:58:40 +00003083 SmallVector<StringRef, 4> SharedRuntimes, StaticRuntimes,
Peter Collingbournedc134532016-01-16 00:31:22 +00003084 NonWholeStaticRuntimes, HelperStaticRuntimes, RequiredSymbols;
Alexey Samsonov52550342014-09-15 19:58:40 +00003085 collectSanitizerRuntimes(TC, Args, SharedRuntimes, StaticRuntimes,
Peter Collingbournedc134532016-01-16 00:31:22 +00003086 NonWholeStaticRuntimes, HelperStaticRuntimes,
3087 RequiredSymbols);
Alexey Samsonov52550342014-09-15 19:58:40 +00003088 for (auto RT : SharedRuntimes)
Peter Collingbournedc134532016-01-16 00:31:22 +00003089 addSanitizerRuntime(TC, Args, CmdArgs, RT, true, false);
Alexey Samsonov52550342014-09-15 19:58:40 +00003090 for (auto RT : HelperStaticRuntimes)
Peter Collingbournedc134532016-01-16 00:31:22 +00003091 addSanitizerRuntime(TC, Args, CmdArgs, RT, false, true);
Alexey Samsonov52550342014-09-15 19:58:40 +00003092 bool AddExportDynamic = false;
3093 for (auto RT : StaticRuntimes) {
Peter Collingbournedc134532016-01-16 00:31:22 +00003094 addSanitizerRuntime(TC, Args, CmdArgs, RT, false, true);
Alexey Samsonov52550342014-09-15 19:58:40 +00003095 AddExportDynamic |= !addSanitizerDynamicList(TC, Args, CmdArgs, RT);
3096 }
Peter Collingbournedc134532016-01-16 00:31:22 +00003097 for (auto RT : NonWholeStaticRuntimes) {
3098 addSanitizerRuntime(TC, Args, CmdArgs, RT, false, false);
3099 AddExportDynamic |= !addSanitizerDynamicList(TC, Args, CmdArgs, RT);
3100 }
3101 for (auto S : RequiredSymbols) {
3102 CmdArgs.push_back("-u");
3103 CmdArgs.push_back(Args.MakeArgString(S));
3104 }
Alexey Samsonov52550342014-09-15 19:58:40 +00003105 // If there is a static runtime with no dynamic list, force all the symbols
3106 // to be dynamic to be sure we export sanitizer interface functions.
3107 if (AddExportDynamic)
3108 CmdArgs.push_back("-export-dynamic");
3109 return !StaticRuntimes.empty();
Peter Collingbournec3772752013-08-07 22:47:34 +00003110}
3111
Reid Kleckner86ea7702015-02-04 23:45:07 +00003112static bool areOptimizationsEnabled(const ArgList &Args) {
3113 // Find the last -O arg and see if it is non-zero.
3114 if (Arg *A = Args.getLastArg(options::OPT_O_Group))
3115 return !A->getOption().matches(options::OPT_O0);
3116 // Defaults to -O0.
3117 return false;
3118}
3119
Benjamin Kramer34cb0432013-10-16 17:42:39 +00003120static bool shouldUseFramePointerForTarget(const ArgList &Args,
3121 const llvm::Triple &Triple) {
Dan Gohmanc2853072015-09-03 22:51:53 +00003122 switch (Triple.getArch()) {
3123 case llvm::Triple::xcore:
3124 case llvm::Triple::wasm32:
3125 case llvm::Triple::wasm64:
3126 // XCore never wants frame pointers, regardless of OS.
3127 // WebAssembly never wants frame pointers.
Benjamin Kramer34cb0432013-10-16 17:42:39 +00003128 return false;
Dan Gohmanc2853072015-09-03 22:51:53 +00003129 default:
3130 break;
Benjamin Kramer34cb0432013-10-16 17:42:39 +00003131 }
Reid Kleckner86ea7702015-02-04 23:45:07 +00003132
3133 if (Triple.isOSLinux()) {
3134 switch (Triple.getArch()) {
3135 // Don't use a frame pointer on linux if optimizing for certain targets.
3136 case llvm::Triple::mips64:
3137 case llvm::Triple::mips64el:
3138 case llvm::Triple::mips:
3139 case llvm::Triple::mipsel:
3140 case llvm::Triple::systemz:
3141 case llvm::Triple::x86:
3142 case llvm::Triple::x86_64:
3143 return !areOptimizationsEnabled(Args);
3144 default:
3145 return true;
3146 }
3147 }
3148
3149 if (Triple.isOSWindows()) {
3150 switch (Triple.getArch()) {
3151 case llvm::Triple::x86:
3152 return !areOptimizationsEnabled(Args);
Akira Hatanaka8f5866a2016-02-26 05:07:00 +00003153 case llvm::Triple::x86_64:
3154 return Triple.isOSBinFormatMachO();
Saleem Abdulrasoola8180a22015-10-03 03:39:28 +00003155 case llvm::Triple::arm:
3156 case llvm::Triple::thumb:
3157 // Windows on ARM builds with FPO disabled to aid fast stack walking
3158 return true;
Reid Kleckner86ea7702015-02-04 23:45:07 +00003159 default:
3160 // All other supported Windows ISAs use xdata unwind information, so frame
3161 // pointers are not generally useful.
3162 return false;
3163 }
3164 }
3165
3166 return true;
Benjamin Kramer34cb0432013-10-16 17:42:39 +00003167}
3168
Rafael Espindola224dd632011-12-14 21:02:23 +00003169static bool shouldUseFramePointer(const ArgList &Args,
3170 const llvm::Triple &Triple) {
3171 if (Arg *A = Args.getLastArg(options::OPT_fno_omit_frame_pointer,
3172 options::OPT_fomit_frame_pointer))
3173 return A->getOption().matches(options::OPT_fno_omit_frame_pointer);
Xinliang David Li4dff8752015-11-23 17:30:31 +00003174 if (Args.hasArg(options::OPT_pg))
3175 return true;
Rafael Espindola224dd632011-12-14 21:02:23 +00003176
Benjamin Kramer34cb0432013-10-16 17:42:39 +00003177 return shouldUseFramePointerForTarget(Args, Triple);
Rafael Espindola224dd632011-12-14 21:02:23 +00003178}
3179
Eric Christopherb7d97e92013-04-03 01:58:53 +00003180static bool shouldUseLeafFramePointer(const ArgList &Args,
3181 const llvm::Triple &Triple) {
3182 if (Arg *A = Args.getLastArg(options::OPT_mno_omit_leaf_frame_pointer,
3183 options::OPT_momit_leaf_frame_pointer))
3184 return A->getOption().matches(options::OPT_mno_omit_leaf_frame_pointer);
Xinliang David Li4dff8752015-11-23 17:30:31 +00003185 if (Args.hasArg(options::OPT_pg))
3186 return true;
Eric Christopherb7d97e92013-04-03 01:58:53 +00003187
Filipe Cabecinhasb1e6c2d2015-01-27 18:08:32 +00003188 if (Triple.isPS4CPU())
3189 return false;
3190
Benjamin Kramer34cb0432013-10-16 17:42:39 +00003191 return shouldUseFramePointerForTarget(Args, Triple);
Eric Christopherb7d97e92013-04-03 01:58:53 +00003192}
3193
Rafael Espindolac7367ff2013-08-10 01:40:10 +00003194/// Add a CC1 option to specify the debug compilation directory.
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00003195static void addDebugCompDirArg(const ArgList &Args, ArgStringList &CmdArgs) {
Benjamin Kramer698d7c82013-04-27 08:12:29 +00003196 SmallString<128> cwd;
3197 if (!llvm::sys::fs::current_path(cwd)) {
Chad Rosiera35d5a32013-04-26 20:49:50 +00003198 CmdArgs.push_back("-fdebug-compilation-dir");
3199 CmdArgs.push_back(Args.MakeArgString(cwd));
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00003200 }
3201}
3202
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003203static const char *SplitDebugName(const ArgList &Args, const InputInfo &Input) {
Eric Christopherd3804002013-02-22 20:12:52 +00003204 Arg *FinalOutput = Args.getLastArg(options::OPT_o);
3205 if (FinalOutput && Args.hasArg(options::OPT_c)) {
3206 SmallString<128> T(FinalOutput->getValue());
3207 llvm::sys::path::replace_extension(T, "dwo");
3208 return Args.MakeArgString(T);
3209 } else {
3210 // Use the compilation dir.
Nico Webere8e53112014-05-11 01:04:02 +00003211 SmallString<128> T(
3212 Args.getLastArgValue(options::OPT_fdebug_compilation_dir));
Artem Belevichba558952015-05-06 18:20:23 +00003213 SmallString<128> F(llvm::sys::path::stem(Input.getBaseInput()));
Eric Christopherd3804002013-02-22 20:12:52 +00003214 llvm::sys::path::replace_extension(F, "dwo");
3215 T += F;
3216 return Args.MakeArgString(F);
3217 }
3218}
3219
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003220static void SplitDebugInfo(const ToolChain &TC, Compilation &C, const Tool &T,
3221 const JobAction &JA, const ArgList &Args,
3222 const InputInfo &Output, const char *OutFile) {
Eric Christopher248357f2013-02-21 22:35:01 +00003223 ArgStringList ExtractArgs;
3224 ExtractArgs.push_back("--extract-dwo");
3225
3226 ArgStringList StripArgs;
3227 StripArgs.push_back("--strip-dwo");
3228
3229 // Grabbing the output of the earlier compile step.
3230 StripArgs.push_back(Output.getFilename());
3231 ExtractArgs.push_back(Output.getFilename());
Eric Christopher248357f2013-02-21 22:35:01 +00003232 ExtractArgs.push_back(OutFile);
3233
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003234 const char *Exec = Args.MakeArgString(TC.GetProgramPath("objcopy"));
Justin Lebard98cea82016-01-11 23:15:21 +00003235 InputInfo II(types::TY_Object, Output.getFilename(), Output.getFilename());
Eric Christopher248357f2013-02-21 22:35:01 +00003236
3237 // First extract the dwo sections.
Justin Bognerd3371d82015-07-17 03:35:54 +00003238 C.addCommand(llvm::make_unique<Command>(JA, T, Exec, ExtractArgs, II));
Eric Christopher248357f2013-02-21 22:35:01 +00003239
3240 // Then remove them from the original .o file.
Justin Bognerd3371d82015-07-17 03:35:54 +00003241 C.addCommand(llvm::make_unique<Command>(JA, T, Exec, StripArgs, II));
Eric Christopher248357f2013-02-21 22:35:01 +00003242}
3243
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00003244/// \brief Vectorize at all optimization levels greater than 1 except for -Oz.
Chad Rosier3ba81bd2014-05-02 18:41:57 +00003245/// For -Oz the loop vectorizer is disable, while the slp vectorizer is enabled.
3246static bool shouldEnableVectorizerAtOLevel(const ArgList &Args, bool isSlpVec) {
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00003247 if (Arg *A = Args.getLastArg(options::OPT_O_Group)) {
Rafael Espindolaad70d962013-08-27 16:58:15 +00003248 if (A->getOption().matches(options::OPT_O4) ||
3249 A->getOption().matches(options::OPT_Ofast))
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00003250 return true;
3251
3252 if (A->getOption().matches(options::OPT_O0))
3253 return false;
3254
3255 assert(A->getOption().matches(options::OPT_O) && "Must have a -O flag");
3256
Rafael Espindola91780de2013-08-26 14:05:41 +00003257 // Vectorize -Os.
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00003258 StringRef S(A->getValue());
Rafael Espindola91780de2013-08-26 14:05:41 +00003259 if (S == "s")
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00003260 return true;
3261
Chad Rosier3ba81bd2014-05-02 18:41:57 +00003262 // Don't vectorize -Oz, unless it's the slp vectorizer.
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00003263 if (S == "z")
Chad Rosier3ba81bd2014-05-02 18:41:57 +00003264 return isSlpVec;
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00003265
3266 unsigned OptLevel = 0;
3267 if (S.getAsInteger(10, OptLevel))
3268 return false;
3269
3270 return OptLevel > 1;
3271 }
3272
3273 return false;
3274}
3275
Ben Langmuir2cb4a782014-02-05 22:21:15 +00003276/// Add -x lang to \p CmdArgs for \p Input.
3277static void addDashXForInput(const ArgList &Args, const InputInfo &Input,
3278 ArgStringList &CmdArgs) {
3279 // When using -verify-pch, we don't want to provide the type
3280 // 'precompiled-header' if it was inferred from the file extension
3281 if (Args.hasArg(options::OPT_verify_pch) && Input.getType() == types::TY_PCH)
3282 return;
3283
3284 CmdArgs.push_back("-x");
3285 if (Args.hasArg(options::OPT_rewrite_objc))
3286 CmdArgs.push_back(types::getTypeName(types::TY_PP_ObjCXX));
3287 else
3288 CmdArgs.push_back(types::getTypeName(Input.getType()));
3289}
3290
David Majnemerc371ff02015-03-22 08:39:22 +00003291static VersionTuple getMSCompatibilityVersion(unsigned Version) {
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00003292 if (Version < 100)
David Majnemerc371ff02015-03-22 08:39:22 +00003293 return VersionTuple(Version);
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00003294
3295 if (Version < 10000)
David Majnemerc371ff02015-03-22 08:39:22 +00003296 return VersionTuple(Version / 100, Version % 100);
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00003297
3298 unsigned Build = 0, Factor = 1;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003299 for (; Version > 10000; Version = Version / 10, Factor = Factor * 10)
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00003300 Build = Build + (Version % 10) * Factor;
David Majnemerc371ff02015-03-22 08:39:22 +00003301 return VersionTuple(Version / 100, Version % 100, Build);
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00003302}
3303
Rafael Espindola577637a2015-01-03 00:06:04 +00003304// Claim options we don't want to warn if they are unused. We do this for
Rafael Espindola7a45e872015-01-05 13:44:59 +00003305// options that build systems might add but are unused when assembling or only
3306// running the preprocessor for example.
Rafael Espindola577637a2015-01-03 00:06:04 +00003307static void claimNoWarnArgs(const ArgList &Args) {
3308 // Don't warn about unused -f(no-)?lto. This can happen when we're
Rafael Espindola7a45e872015-01-05 13:44:59 +00003309 // preprocessing, precompiling or assembling.
Teresa Johnson945bc502015-10-15 20:35:53 +00003310 Args.ClaimAllArgs(options::OPT_flto_EQ);
Rafael Espindola577637a2015-01-03 00:06:04 +00003311 Args.ClaimAllArgs(options::OPT_flto);
3312 Args.ClaimAllArgs(options::OPT_fno_lto);
3313}
3314
Ben Langmuir3b7b5402015-02-03 19:28:37 +00003315static void appendUserToPath(SmallVectorImpl<char> &Result) {
3316#ifdef LLVM_ON_UNIX
3317 const char *Username = getenv("LOGNAME");
3318#else
3319 const char *Username = getenv("USERNAME");
3320#endif
3321 if (Username) {
3322 // Validate that LoginName can be used in a path, and get its length.
3323 size_t Len = 0;
3324 for (const char *P = Username; *P; ++P, ++Len) {
Ben Langmuire056ec32015-02-04 18:34:23 +00003325 if (!isAlphanumeric(*P) && *P != '_') {
Ben Langmuir3b7b5402015-02-03 19:28:37 +00003326 Username = nullptr;
3327 break;
3328 }
3329 }
3330
3331 if (Username && Len > 0) {
3332 Result.append(Username, Username + Len);
3333 return;
3334 }
3335 }
3336
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003337// Fallback to user id.
Ben Langmuir3b7b5402015-02-03 19:28:37 +00003338#ifdef LLVM_ON_UNIX
3339 std::string UID = llvm::utostr(getuid());
3340#else
3341 // FIXME: Windows seems to have an 'SID' that might work.
3342 std::string UID = "9999";
3343#endif
3344 Result.append(UID.begin(), UID.end());
3345}
3346
Adrian McCarthye4b26fc2016-05-13 23:20:11 +00003347VersionTuple visualstudio::getMSVCVersion(const Driver *D, const ToolChain &TC,
David Majnemere11d3732015-06-08 00:22:46 +00003348 const llvm::Triple &Triple,
3349 const llvm::opt::ArgList &Args,
3350 bool IsWindowsMSVC) {
3351 if (Args.hasFlag(options::OPT_fms_extensions, options::OPT_fno_ms_extensions,
3352 IsWindowsMSVC) ||
3353 Args.hasArg(options::OPT_fmsc_version) ||
3354 Args.hasArg(options::OPT_fms_compatibility_version)) {
3355 const Arg *MSCVersion = Args.getLastArg(options::OPT_fmsc_version);
3356 const Arg *MSCompatibilityVersion =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003357 Args.getLastArg(options::OPT_fms_compatibility_version);
David Majnemere11d3732015-06-08 00:22:46 +00003358
3359 if (MSCVersion && MSCompatibilityVersion) {
3360 if (D)
3361 D->Diag(diag::err_drv_argument_not_allowed_with)
3362 << MSCVersion->getAsString(Args)
3363 << MSCompatibilityVersion->getAsString(Args);
3364 return VersionTuple();
3365 }
3366
3367 if (MSCompatibilityVersion) {
3368 VersionTuple MSVT;
3369 if (MSVT.tryParse(MSCompatibilityVersion->getValue()) && D)
3370 D->Diag(diag::err_drv_invalid_value)
3371 << MSCompatibilityVersion->getAsString(Args)
3372 << MSCompatibilityVersion->getValue();
3373 return MSVT;
3374 }
3375
3376 if (MSCVersion) {
3377 unsigned Version = 0;
3378 if (StringRef(MSCVersion->getValue()).getAsInteger(10, Version) && D)
3379 D->Diag(diag::err_drv_invalid_value) << MSCVersion->getAsString(Args)
3380 << MSCVersion->getValue();
3381 return getMSCompatibilityVersion(Version);
3382 }
3383
3384 unsigned Major, Minor, Micro;
3385 Triple.getEnvironmentVersion(Major, Minor, Micro);
3386 if (Major || Minor || Micro)
3387 return VersionTuple(Major, Minor, Micro);
3388
Adrian McCarthye4b26fc2016-05-13 23:20:11 +00003389 if (IsWindowsMSVC) {
3390 VersionTuple MSVT = TC.getMSVCVersionFromExe();
3391 if (!MSVT.empty())
3392 return MSVT;
3393
3394 // FIXME: Consider bumping this to 19 (MSVC2015) soon.
3395 return VersionTuple(18);
3396 }
David Majnemere11d3732015-06-08 00:22:46 +00003397 }
3398 return VersionTuple();
3399}
3400
Diego Novilloa0545962015-07-10 18:00:07 +00003401static void addPGOAndCoverageFlags(Compilation &C, const Driver &D,
3402 const InputInfo &Output, const ArgList &Args,
3403 ArgStringList &CmdArgs) {
3404 auto *ProfileGenerateArg = Args.getLastArg(
3405 options::OPT_fprofile_instr_generate,
3406 options::OPT_fprofile_instr_generate_EQ, options::OPT_fprofile_generate,
Diego Novillo758f3f52015-08-05 21:49:51 +00003407 options::OPT_fprofile_generate_EQ,
3408 options::OPT_fno_profile_instr_generate);
3409 if (ProfileGenerateArg &&
3410 ProfileGenerateArg->getOption().matches(
3411 options::OPT_fno_profile_instr_generate))
3412 ProfileGenerateArg = nullptr;
Diego Novilloa0545962015-07-10 18:00:07 +00003413
3414 auto *ProfileUseArg = Args.getLastArg(
3415 options::OPT_fprofile_instr_use, options::OPT_fprofile_instr_use_EQ,
Diego Novillo758f3f52015-08-05 21:49:51 +00003416 options::OPT_fprofile_use, options::OPT_fprofile_use_EQ,
3417 options::OPT_fno_profile_instr_use);
3418 if (ProfileUseArg &&
3419 ProfileUseArg->getOption().matches(options::OPT_fno_profile_instr_use))
3420 ProfileUseArg = nullptr;
Diego Novilloa0545962015-07-10 18:00:07 +00003421
3422 if (ProfileGenerateArg && ProfileUseArg)
3423 D.Diag(diag::err_drv_argument_not_allowed_with)
Renato Golin7c542b42015-07-27 23:44:45 +00003424 << ProfileGenerateArg->getSpelling() << ProfileUseArg->getSpelling();
Diego Novilloa0545962015-07-10 18:00:07 +00003425
Diego Novillo758f3f52015-08-05 21:49:51 +00003426 if (ProfileGenerateArg) {
3427 if (ProfileGenerateArg->getOption().matches(
3428 options::OPT_fprofile_instr_generate_EQ))
Rong Xu9837ef52016-02-04 18:39:09 +00003429 CmdArgs.push_back(Args.MakeArgString(Twine("-fprofile-instrument-path=") +
3430 ProfileGenerateArg->getValue()));
Diego Novillo758f3f52015-08-05 21:49:51 +00003431 else if (ProfileGenerateArg->getOption().matches(
3432 options::OPT_fprofile_generate_EQ)) {
3433 SmallString<128> Path(ProfileGenerateArg->getValue());
3434 llvm::sys::path::append(Path, "default.profraw");
3435 CmdArgs.push_back(
Rong Xu9837ef52016-02-04 18:39:09 +00003436 Args.MakeArgString(Twine("-fprofile-instrument-path=") + Path));
3437 }
3438 // The default is to use Clang Instrumentation.
3439 CmdArgs.push_back("-fprofile-instrument=clang");
Diego Novillo758f3f52015-08-05 21:49:51 +00003440 }
Diego Novilloa0545962015-07-10 18:00:07 +00003441
Diego Novillo758f3f52015-08-05 21:49:51 +00003442 if (ProfileUseArg) {
3443 if (ProfileUseArg->getOption().matches(options::OPT_fprofile_instr_use_EQ))
Rong Xu9c6f1532016-03-02 20:59:36 +00003444 CmdArgs.push_back(Args.MakeArgString(
3445 Twine("-fprofile-instrument-use-path=") + ProfileUseArg->getValue()));
Diego Novillo758f3f52015-08-05 21:49:51 +00003446 else if ((ProfileUseArg->getOption().matches(
3447 options::OPT_fprofile_use_EQ) ||
3448 ProfileUseArg->getOption().matches(
3449 options::OPT_fprofile_instr_use))) {
3450 SmallString<128> Path(
3451 ProfileUseArg->getNumValues() == 0 ? "" : ProfileUseArg->getValue());
3452 if (Path.empty() || llvm::sys::fs::is_directory(Path))
3453 llvm::sys::path::append(Path, "default.profdata");
3454 CmdArgs.push_back(
Rong Xu9c6f1532016-03-02 20:59:36 +00003455 Args.MakeArgString(Twine("-fprofile-instrument-use-path=") + Path));
Diego Novillo758f3f52015-08-05 21:49:51 +00003456 }
Diego Novilloa0545962015-07-10 18:00:07 +00003457 }
3458
3459 if (Args.hasArg(options::OPT_ftest_coverage) ||
3460 Args.hasArg(options::OPT_coverage))
3461 CmdArgs.push_back("-femit-coverage-notes");
3462 if (Args.hasFlag(options::OPT_fprofile_arcs, options::OPT_fno_profile_arcs,
3463 false) ||
3464 Args.hasArg(options::OPT_coverage))
3465 CmdArgs.push_back("-femit-coverage-data");
3466
Diego Novilloc4b94da2015-08-05 23:27:40 +00003467 if (Args.hasFlag(options::OPT_fcoverage_mapping,
3468 options::OPT_fno_coverage_mapping, false) &&
3469 !ProfileGenerateArg)
Diego Novilloa0545962015-07-10 18:00:07 +00003470 D.Diag(diag::err_drv_argument_only_allowed_with)
3471 << "-fcoverage-mapping"
3472 << "-fprofile-instr-generate";
3473
Diego Novilloc4b94da2015-08-05 23:27:40 +00003474 if (Args.hasFlag(options::OPT_fcoverage_mapping,
3475 options::OPT_fno_coverage_mapping, false))
Diego Novilloa0545962015-07-10 18:00:07 +00003476 CmdArgs.push_back("-fcoverage-mapping");
3477
3478 if (C.getArgs().hasArg(options::OPT_c) ||
3479 C.getArgs().hasArg(options::OPT_S)) {
3480 if (Output.isFilename()) {
3481 CmdArgs.push_back("-coverage-file");
3482 SmallString<128> CoverageFilename;
3483 if (Arg *FinalOutput = C.getArgs().getLastArg(options::OPT_o)) {
3484 CoverageFilename = FinalOutput->getValue();
3485 } else {
3486 CoverageFilename = llvm::sys::path::filename(Output.getBaseInput());
3487 }
3488 if (llvm::sys::path::is_relative(CoverageFilename)) {
3489 SmallString<128> Pwd;
3490 if (!llvm::sys::fs::current_path(Pwd)) {
3491 llvm::sys::path::append(Pwd, CoverageFilename);
3492 CoverageFilename.swap(Pwd);
3493 }
3494 }
3495 CmdArgs.push_back(Args.MakeArgString(CoverageFilename));
3496 }
3497 }
3498}
3499
Paul Robinsond083b9a2015-12-16 17:25:27 +00003500static void addPS4ProfileRTArgs(const ToolChain &TC, const ArgList &Args,
3501 ArgStringList &CmdArgs) {
3502 if ((Args.hasFlag(options::OPT_fprofile_arcs, options::OPT_fno_profile_arcs,
3503 false) ||
3504 Args.hasFlag(options::OPT_fprofile_generate,
3505 options::OPT_fno_profile_instr_generate, false) ||
3506 Args.hasFlag(options::OPT_fprofile_generate_EQ,
3507 options::OPT_fno_profile_instr_generate, false) ||
3508 Args.hasFlag(options::OPT_fprofile_instr_generate,
3509 options::OPT_fno_profile_instr_generate, false) ||
3510 Args.hasFlag(options::OPT_fprofile_instr_generate_EQ,
3511 options::OPT_fno_profile_instr_generate, false) ||
3512 Args.hasArg(options::OPT_fcreate_profile) ||
3513 Args.hasArg(options::OPT_coverage)))
3514 CmdArgs.push_back("--dependent-lib=libclang_rt.profile-x86_64.a");
3515}
3516
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003517/// Parses the various -fpic/-fPIC/-fpie/-fPIE arguments. Then,
3518/// smooshes them together with platform defaults, to decide whether
3519/// this compile should be using PIC mode or not. Returns a tuple of
3520/// (RelocationModel, PICLevel, IsPIE).
3521static std::tuple<llvm::Reloc::Model, unsigned, bool>
3522ParsePICArgs(const ToolChain &ToolChain, const llvm::Triple &Triple,
3523 const ArgList &Args) {
3524 // FIXME: why does this code...and so much everywhere else, use both
3525 // ToolChain.getTriple() and Triple?
3526 bool PIE = ToolChain.isPIEDefault();
3527 bool PIC = PIE || ToolChain.isPICDefault();
Bob Wilson0a15e6c2016-01-13 01:19:02 +00003528 // The Darwin/MachO default to use PIC does not apply when using -static.
3529 if (ToolChain.getTriple().isOSBinFormatMachO() &&
3530 Args.hasArg(options::OPT_static))
Bob Wilson2b2a0ae2015-12-18 20:37:54 +00003531 PIE = PIC = false;
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003532 bool IsPICLevelTwo = PIC;
3533
3534 bool KernelOrKext =
3535 Args.hasArg(options::OPT_mkernel, options::OPT_fapple_kext);
3536
3537 // Android-specific defaults for PIC/PIE
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00003538 if (ToolChain.getTriple().isAndroid()) {
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003539 switch (ToolChain.getArch()) {
3540 case llvm::Triple::arm:
3541 case llvm::Triple::armeb:
3542 case llvm::Triple::thumb:
3543 case llvm::Triple::thumbeb:
3544 case llvm::Triple::aarch64:
3545 case llvm::Triple::mips:
3546 case llvm::Triple::mipsel:
3547 case llvm::Triple::mips64:
3548 case llvm::Triple::mips64el:
3549 PIC = true; // "-fpic"
3550 break;
3551
3552 case llvm::Triple::x86:
3553 case llvm::Triple::x86_64:
3554 PIC = true; // "-fPIC"
3555 IsPICLevelTwo = true;
3556 break;
3557
3558 default:
3559 break;
3560 }
3561 }
3562
3563 // OpenBSD-specific defaults for PIE
3564 if (ToolChain.getTriple().getOS() == llvm::Triple::OpenBSD) {
3565 switch (ToolChain.getArch()) {
3566 case llvm::Triple::mips64:
3567 case llvm::Triple::mips64el:
3568 case llvm::Triple::sparcel:
3569 case llvm::Triple::x86:
3570 case llvm::Triple::x86_64:
3571 IsPICLevelTwo = false; // "-fpie"
3572 break;
3573
3574 case llvm::Triple::ppc:
3575 case llvm::Triple::sparc:
3576 case llvm::Triple::sparcv9:
3577 IsPICLevelTwo = true; // "-fPIE"
3578 break;
3579
3580 default:
3581 break;
3582 }
3583 }
3584
3585 // The last argument relating to either PIC or PIE wins, and no
3586 // other argument is used. If the last argument is any flavor of the
3587 // '-fno-...' arguments, both PIC and PIE are disabled. Any PIE
3588 // option implicitly enables PIC at the same level.
3589 Arg *LastPICArg = Args.getLastArg(options::OPT_fPIC, options::OPT_fno_PIC,
3590 options::OPT_fpic, options::OPT_fno_pic,
3591 options::OPT_fPIE, options::OPT_fno_PIE,
3592 options::OPT_fpie, options::OPT_fno_pie);
3593 // Check whether the tool chain trumps the PIC-ness decision. If the PIC-ness
3594 // is forced, then neither PIC nor PIE flags will have no effect.
3595 if (!ToolChain.isPICDefaultForced()) {
3596 if (LastPICArg) {
3597 Option O = LastPICArg->getOption();
3598 if (O.matches(options::OPT_fPIC) || O.matches(options::OPT_fpic) ||
3599 O.matches(options::OPT_fPIE) || O.matches(options::OPT_fpie)) {
3600 PIE = O.matches(options::OPT_fPIE) || O.matches(options::OPT_fpie);
3601 PIC =
3602 PIE || O.matches(options::OPT_fPIC) || O.matches(options::OPT_fpic);
3603 IsPICLevelTwo =
3604 O.matches(options::OPT_fPIE) || O.matches(options::OPT_fPIC);
3605 } else {
3606 PIE = PIC = false;
Filipe Cabecinhasc888e192015-10-14 12:25:43 +00003607 if (Triple.isPS4CPU()) {
3608 Arg *ModelArg = Args.getLastArg(options::OPT_mcmodel_EQ);
3609 StringRef Model = ModelArg ? ModelArg->getValue() : "";
3610 if (Model != "kernel") {
3611 PIC = true;
3612 ToolChain.getDriver().Diag(diag::warn_drv_ps4_force_pic)
3613 << LastPICArg->getSpelling();
3614 }
3615 }
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003616 }
3617 }
3618 }
3619
Filipe Cabecinhasc888e192015-10-14 12:25:43 +00003620 // Introduce a Darwin and PS4-specific hack. If the default is PIC, but the
3621 // PIC level would've been set to level 1, force it back to level 2 PIC
3622 // instead.
3623 if (PIC && (ToolChain.getTriple().isOSDarwin() || Triple.isPS4CPU()))
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003624 IsPICLevelTwo |= ToolChain.isPICDefault();
3625
James Y Knightc4015d32015-08-21 04:14:55 +00003626 // This kernel flags are a trump-card: they will disable PIC/PIE
3627 // generation, independent of the argument order.
Tim Northover6f3ff222015-10-30 16:30:27 +00003628 if (KernelOrKext && ((!Triple.isiOS() || Triple.isOSVersionLT(6)) &&
3629 !Triple.isWatchOS()))
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003630 PIC = PIE = false;
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003631
3632 if (Arg *A = Args.getLastArg(options::OPT_mdynamic_no_pic)) {
3633 // This is a very special mode. It trumps the other modes, almost no one
3634 // uses it, and it isn't even valid on any OS but Darwin.
3635 if (!ToolChain.getTriple().isOSDarwin())
3636 ToolChain.getDriver().Diag(diag::err_drv_unsupported_opt_for_target)
3637 << A->getSpelling() << ToolChain.getTriple().str();
3638
3639 // FIXME: Warn when this flag trumps some other PIC or PIE flag.
3640
3641 // Only a forced PIC mode can cause the actual compile to have PIC defines
3642 // etc., no flags are sufficient. This behavior was selected to closely
3643 // match that of llvm-gcc and Apple GCC before that.
3644 PIC = ToolChain.isPICDefault() && ToolChain.isPICDefaultForced();
3645
3646 return std::make_tuple(llvm::Reloc::DynamicNoPIC, PIC ? 2 : 0, false);
3647 }
3648
3649 if (PIC)
3650 return std::make_tuple(llvm::Reloc::PIC_, IsPICLevelTwo ? 2 : 1, PIE);
3651
3652 return std::make_tuple(llvm::Reloc::Static, 0, false);
3653}
3654
3655static const char *RelocationModelName(llvm::Reloc::Model Model) {
3656 switch (Model) {
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003657 case llvm::Reloc::Static:
3658 return "static";
3659 case llvm::Reloc::PIC_:
3660 return "pic";
3661 case llvm::Reloc::DynamicNoPIC:
3662 return "dynamic-no-pic";
3663 }
Aaron Ballman2ec49282015-08-20 13:31:16 +00003664 llvm_unreachable("Unknown Reloc::Model kind");
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003665}
3666
3667static void AddAssemblerKPIC(const ToolChain &ToolChain, const ArgList &Args,
3668 ArgStringList &CmdArgs) {
3669 llvm::Reloc::Model RelocationModel;
3670 unsigned PICLevel;
3671 bool IsPIE;
3672 std::tie(RelocationModel, PICLevel, IsPIE) =
3673 ParsePICArgs(ToolChain, ToolChain.getTriple(), Args);
3674
3675 if (RelocationModel != llvm::Reloc::Static)
3676 CmdArgs.push_back("-KPIC");
3677}
3678
Daniel Dunbar1a093d22009-03-18 06:00:36 +00003679void Clang::ConstructJob(Compilation &C, const JobAction &JA,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003680 const InputInfo &Output, const InputInfoList &Inputs,
3681 const ArgList &Args, const char *LinkingOutput) const {
James Y Knight2db38f32015-08-15 03:45:25 +00003682 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
3683 const llvm::Triple Triple(TripleStr);
3684
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003685 bool KernelOrKext =
3686 Args.hasArg(options::OPT_mkernel, options::OPT_fapple_kext);
Daniel Dunbar083edf72009-12-21 18:54:17 +00003687 const Driver &D = getToolChain().getDriver();
Daniel Dunbara3246a02009-03-18 08:07:30 +00003688 ArgStringList CmdArgs;
3689
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00003690 bool IsWindowsGNU = getToolChain().getTriple().isWindowsGNUEnvironment();
Nico Webere8e53112014-05-11 01:04:02 +00003691 bool IsWindowsCygnus =
3692 getToolChain().getTriple().isWindowsCygwinEnvironment();
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00003693 bool IsWindowsMSVC = getToolChain().getTriple().isWindowsMSVCEnvironment();
Filipe Cabecinhasc888e192015-10-14 12:25:43 +00003694 bool IsPS4CPU = getToolChain().getTriple().isPS4CPU();
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00003695
Artem Belevich0ff05cd2015-07-13 23:27:56 +00003696 // Check number of inputs for sanity. We need at least one input.
3697 assert(Inputs.size() >= 1 && "Must have at least one input.");
Artem Belevichba558952015-05-06 18:20:23 +00003698 const InputInfo &Input = Inputs[0];
Artem Belevich0ff05cd2015-07-13 23:27:56 +00003699 // CUDA compilation may have multiple inputs (source file + results of
3700 // device-side compilations). All other jobs are expected to have exactly one
3701 // input.
3702 bool IsCuda = types::isCuda(Input.getType());
3703 assert((IsCuda || Inputs.size() == 1) && "Unable to handle multiple inputs.");
Daniel Dunbare521a892009-03-31 20:53:55 +00003704
Daniel Dunbar6c536aa2009-12-11 23:00:49 +00003705 // Invoke ourselves in -cc1 mode.
3706 //
3707 // FIXME: Implement custom jobs for internal actions.
3708 CmdArgs.push_back("-cc1");
3709
Daniel Dunbar624c21b2009-10-30 18:12:20 +00003710 // Add the "effective" target triple.
Daniel Dunbard640be22009-03-31 17:35:15 +00003711 CmdArgs.push_back("-triple");
Daniel Dunbar624c21b2009-10-30 18:12:20 +00003712 CmdArgs.push_back(Args.MakeArgString(TripleStr));
Daniel Dunbarfb58b0a2009-09-10 06:49:20 +00003713
Artem Belevichfa11ab52015-11-17 22:28:46 +00003714 const ToolChain *AuxToolChain = nullptr;
Artem Belevich5e2a3ec2015-11-17 22:28:40 +00003715 if (IsCuda) {
3716 // FIXME: We need a (better) way to pass information about
3717 // particular compilation pass we're constructing here. For now we
3718 // can check which toolchain we're using and pick the other one to
3719 // extract the triple.
Artem Belevich5e2a3ec2015-11-17 22:28:40 +00003720 if (&getToolChain() == C.getCudaDeviceToolChain())
3721 AuxToolChain = C.getCudaHostToolChain();
3722 else if (&getToolChain() == C.getCudaHostToolChain())
3723 AuxToolChain = C.getCudaDeviceToolChain();
3724 else
3725 llvm_unreachable("Can't figure out CUDA compilation mode.");
3726 assert(AuxToolChain != nullptr && "No aux toolchain.");
3727 CmdArgs.push_back("-aux-triple");
3728 CmdArgs.push_back(Args.MakeArgString(AuxToolChain->getTriple().str()));
3729 }
3730
James Y Knight2db38f32015-08-15 03:45:25 +00003731 if (Triple.isOSWindows() && (Triple.getArch() == llvm::Triple::arm ||
3732 Triple.getArch() == llvm::Triple::thumb)) {
3733 unsigned Offset = Triple.getArch() == llvm::Triple::arm ? 4 : 6;
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +00003734 unsigned Version;
James Y Knight2db38f32015-08-15 03:45:25 +00003735 Triple.getArchName().substr(Offset).getAsInteger(10, Version);
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +00003736 if (Version < 7)
James Y Knight2db38f32015-08-15 03:45:25 +00003737 D.Diag(diag::err_target_unsupported_arch) << Triple.getArchName()
Nico Webere8e53112014-05-11 01:04:02 +00003738 << TripleStr;
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +00003739 }
3740
Tim Northover336f1892014-03-29 13:16:12 +00003741 // Push all default warning arguments that are specific to
3742 // the given target. These come before user provided warning options
3743 // are provided.
3744 getToolChain().addClangWarningOptions(CmdArgs);
3745
Daniel Dunbar624c21b2009-10-30 18:12:20 +00003746 // Select the appropriate action.
John McCall5fb5df92012-06-20 06:18:46 +00003747 RewriteKind rewriteKind = RK_None;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003748
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003749 if (isa<AnalyzeJobAction>(JA)) {
3750 assert(JA.getType() == types::TY_Plist && "Invalid output type.");
3751 CmdArgs.push_back("-analyze");
Ted Kremenekf7639e12012-03-06 20:06:33 +00003752 } else if (isa<MigrateJobAction>(JA)) {
3753 CmdArgs.push_back("-migrate");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003754 } else if (isa<PreprocessJobAction>(JA)) {
Daniel Dunbard67a3222009-03-30 06:36:42 +00003755 if (Output.getType() == types::TY_Dependencies)
3756 CmdArgs.push_back("-Eonly");
Fariborz Jahaniane0a75d62013-03-18 19:41:18 +00003757 else {
Daniel Dunbard67a3222009-03-30 06:36:42 +00003758 CmdArgs.push_back("-E");
Fariborz Jahaniane0a75d62013-03-18 19:41:18 +00003759 if (Args.hasArg(options::OPT_rewrite_objc) &&
3760 !Args.hasArg(options::OPT_g_Group))
3761 CmdArgs.push_back("-P");
3762 }
Daniel Dunbarc4343942010-02-03 03:07:56 +00003763 } else if (isa<AssembleJobAction>(JA)) {
3764 CmdArgs.push_back("-emit-obj");
Daniel Dunbar06e2cc32010-05-27 06:18:05 +00003765
David Blaikie9260ed62013-07-25 21:19:01 +00003766 CollectArgsForIntegratedAssembler(C, Args, CmdArgs, D);
Daniel Dunbar7c874332010-11-19 16:23:35 +00003767
3768 // Also ignore explicit -force_cpusubtype_ALL option.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003769 (void)Args.hasArg(options::OPT_force__cpusubtype__ALL);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003770 } else if (isa<PrecompileJobAction>(JA)) {
Argyrios Kyrtzidis90bdfbb2010-08-11 23:27:58 +00003771 // Use PCH if the user requested it.
Daniel Dunbarcbc34b72009-10-15 20:02:44 +00003772 bool UsePCH = D.CCCUsePCH;
Daniel Dunbarcbc34b72009-10-15 20:02:44 +00003773
Aaron Ballman1f10cc52012-07-31 01:21:00 +00003774 if (JA.getType() == types::TY_Nothing)
3775 CmdArgs.push_back("-fsyntax-only");
3776 else if (UsePCH)
Douglas Gregor111af7d2009-04-18 00:34:01 +00003777 CmdArgs.push_back("-emit-pch");
3778 else
3779 CmdArgs.push_back("-emit-pth");
Ben Langmuir9b9a8d32014-02-06 18:53:25 +00003780 } else if (isa<VerifyPCHJobAction>(JA)) {
3781 CmdArgs.push_back("-verify-pch");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003782 } else {
Bob Wilson23a55f12014-12-21 07:00:00 +00003783 assert((isa<CompileJobAction>(JA) || isa<BackendJobAction>(JA)) &&
3784 "Invalid action for clang tool.");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003785 if (JA.getType() == types::TY_Nothing) {
Ben Langmuir9b9a8d32014-02-06 18:53:25 +00003786 CmdArgs.push_back("-fsyntax-only");
Daniel Dunbar24e52992010-06-07 23:28:45 +00003787 } else if (JA.getType() == types::TY_LLVM_IR ||
3788 JA.getType() == types::TY_LTO_IR) {
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003789 CmdArgs.push_back("-emit-llvm");
Daniel Dunbar24e52992010-06-07 23:28:45 +00003790 } else if (JA.getType() == types::TY_LLVM_BC ||
3791 JA.getType() == types::TY_LTO_BC) {
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003792 CmdArgs.push_back("-emit-llvm-bc");
3793 } else if (JA.getType() == types::TY_PP_Asm) {
Daniel Dunbard112f102009-09-17 00:47:53 +00003794 CmdArgs.push_back("-S");
Daniel Dunbar6cdf83c2009-09-01 16:57:46 +00003795 } else if (JA.getType() == types::TY_AST) {
3796 CmdArgs.push_back("-emit-pch");
Douglas Gregorbf7fc9c2013-03-27 16:47:18 +00003797 } else if (JA.getType() == types::TY_ModuleFile) {
3798 CmdArgs.push_back("-module-file-info");
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00003799 } else if (JA.getType() == types::TY_RewrittenObjC) {
3800 CmdArgs.push_back("-rewrite-objc");
John McCall5fb5df92012-06-20 06:18:46 +00003801 rewriteKind = RK_NonFragile;
Fariborz Jahanian73223bb2012-04-02 15:59:19 +00003802 } else if (JA.getType() == types::TY_RewrittenLegacyObjC) {
3803 CmdArgs.push_back("-rewrite-objc");
John McCall5fb5df92012-06-20 06:18:46 +00003804 rewriteKind = RK_Fragile;
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00003805 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003806 assert(JA.getType() == types::TY_PP_Asm && "Unexpected output type!");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003807 }
Duncan P. N. Exon Smithd863f6f2015-04-14 18:30:13 +00003808
3809 // Preserve use-list order by default when emitting bitcode, so that
3810 // loading the bitcode up in 'opt' or 'llc' and running passes gives the
3811 // same result as running passes here. For LTO, we don't need to preserve
3812 // the use-list order, since serialization to bitcode is part of the flow.
Duncan P. N. Exon Smithbb618252015-04-15 01:16:18 +00003813 if (JA.getType() == types::TY_LLVM_BC)
3814 CmdArgs.push_back("-emit-llvm-uselists");
Teresa Johnson945bc502015-10-15 20:35:53 +00003815
3816 if (D.isUsingLTO())
3817 Args.AddLastArg(CmdArgs, options::OPT_flto, options::OPT_flto_EQ);
Daniel Dunbara3246a02009-03-18 08:07:30 +00003818 }
3819
Teresa Johnsonaff22322015-12-07 19:21:34 +00003820 if (const Arg *A = Args.getLastArg(options::OPT_fthinlto_index_EQ)) {
3821 if (!types::isLLVMIR(Input.getType()))
3822 D.Diag(diag::err_drv_argument_only_allowed_with) << A->getAsString(Args)
3823 << "-x ir";
3824 Args.AddLastArg(CmdArgs, options::OPT_fthinlto_index_EQ);
3825 }
3826
Steven Wu574b0f22016-03-01 01:07:58 +00003827 // Embed-bitcode option.
3828 if (C.getDriver().embedBitcodeEnabled() &&
3829 (isa<BackendJobAction>(JA) || isa<AssembleJobAction>(JA))) {
3830 // Add flags implied by -fembed-bitcode.
Steven Wu27fb5222016-05-11 16:26:03 +00003831 Args.AddLastArg(CmdArgs, options::OPT_fembed_bitcode_EQ);
Steven Wu574b0f22016-03-01 01:07:58 +00003832 // Disable all llvm IR level optimizations.
3833 CmdArgs.push_back("-disable-llvm-optzns");
3834 }
3835 if (C.getDriver().embedBitcodeMarkerOnly())
Steven Wu27fb5222016-05-11 16:26:03 +00003836 CmdArgs.push_back("-fembed-bitcode=marker");
Steven Wu574b0f22016-03-01 01:07:58 +00003837
Justin Bognera88f0122014-06-20 22:59:50 +00003838 // We normally speed up the clang process a bit by skipping destructors at
3839 // exit, but when we're generating diagnostics we can rely on some of the
3840 // cleanup.
3841 if (!C.isForDiagnostics())
3842 CmdArgs.push_back("-disable-free");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003843
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003844// Disable the verification pass in -asserts builds.
John McCallbb79b5f2010-02-13 03:50:24 +00003845#ifdef NDEBUG
3846 CmdArgs.push_back("-disable-llvm-verifier");
Mehdi Amini557c20a2016-03-13 21:05:23 +00003847 // Discard LLVM value names in -asserts builds.
3848 CmdArgs.push_back("-discard-value-names");
John McCallbb79b5f2010-02-13 03:50:24 +00003849#endif
3850
Daniel Dunbar3b358a32009-04-08 05:11:16 +00003851 // Set the main file name, so that debug info works even with
3852 // -save-temps.
3853 CmdArgs.push_back("-main-file-name");
Artem Belevichba558952015-05-06 18:20:23 +00003854 CmdArgs.push_back(getBaseInputName(Args, Input));
Daniel Dunbar3b358a32009-04-08 05:11:16 +00003855
Daniel Dunbar17ddaa62009-04-08 18:03:55 +00003856 // Some flags which affect the language (via preprocessor
Bob Wilsondecc03e2012-11-23 06:14:39 +00003857 // defines).
Daniel Dunbar17ddaa62009-04-08 18:03:55 +00003858 if (Args.hasArg(options::OPT_static))
3859 CmdArgs.push_back("-static-define");
3860
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003861 if (isa<AnalyzeJobAction>(JA)) {
Ted Kremenek05e6f5b2009-09-25 05:55:59 +00003862 // Enable region store model by default.
3863 CmdArgs.push_back("-analyzer-store=region");
3864
Ted Kremenek7bea9a12009-12-07 22:26:14 +00003865 // Treat blocks as analysis entry points.
3866 CmdArgs.push_back("-analyzer-opt-analyze-nested-blocks");
3867
Ted Kremenek49c79792011-03-24 00:28:47 +00003868 CmdArgs.push_back("-analyzer-eagerly-assume");
3869
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003870 // Add default argument set.
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00003871 if (!Args.hasArg(options::OPT__analyzer_no_default_checks)) {
Argyrios Kyrtzidisa6d04d52011-02-15 07:42:33 +00003872 CmdArgs.push_back("-analyzer-checker=core");
Ted Kremenek49c79792011-03-24 00:28:47 +00003873
Devin Coughlin65c77082016-01-21 20:09:49 +00003874 if (!IsWindowsMSVC) {
3875 CmdArgs.push_back("-analyzer-checker=unix");
3876 } else {
3877 // Enable "unix" checkers that also work on Windows.
3878 CmdArgs.push_back("-analyzer-checker=unix.API");
3879 CmdArgs.push_back("-analyzer-checker=unix.Malloc");
3880 CmdArgs.push_back("-analyzer-checker=unix.MallocSizeof");
3881 CmdArgs.push_back("-analyzer-checker=unix.MismatchedDeallocator");
3882 CmdArgs.push_back("-analyzer-checker=unix.cstring.BadSizeArg");
3883 CmdArgs.push_back("-analyzer-checker=unix.cstring.NullArg");
3884 }
Ted Kremenek49c79792011-03-24 00:28:47 +00003885
Sean Evesonb38c32b2016-01-06 10:03:58 +00003886 // Disable some unix checkers for PS4.
3887 if (IsPS4CPU) {
3888 CmdArgs.push_back("-analyzer-disable-checker=unix.API");
3889 CmdArgs.push_back("-analyzer-disable-checker=unix.Vfork");
3890 }
3891
Argyrios Kyrtzidisa6d04d52011-02-15 07:42:33 +00003892 if (getToolChain().getTriple().getVendor() == llvm::Triple::Apple)
Ted Kremenek49c79792011-03-24 00:28:47 +00003893 CmdArgs.push_back("-analyzer-checker=osx");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003894
Ted Kremenekb9ff6b22012-01-20 06:00:17 +00003895 CmdArgs.push_back("-analyzer-checker=deadcode");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003896
Artem Belevichba558952015-05-06 18:20:23 +00003897 if (types::isCXX(Input.getType()))
Jordan Rose10ad0812013-04-05 17:55:07 +00003898 CmdArgs.push_back("-analyzer-checker=cplusplus");
3899
Sean Evesonb38c32b2016-01-06 10:03:58 +00003900 if (!IsPS4CPU) {
3901 CmdArgs.push_back(
3902 "-analyzer-checker=security.insecureAPI.UncheckedReturn");
3903 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.getpw");
3904 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.gets");
3905 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.mktemp");
3906 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.mkstemp");
3907 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.vfork");
3908 }
Gabor Horvathe3085992015-09-14 20:34:06 +00003909
3910 // Default nullability checks.
3911 CmdArgs.push_back("-analyzer-checker=nullability.NullPassedToNonnull");
3912 CmdArgs.push_back(
3913 "-analyzer-checker=nullability.NullReturnedFromNonnull");
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00003914 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00003915
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00003916 // Set the output format. The default is plist, for (lame) historical
3917 // reasons.
3918 CmdArgs.push_back("-analyzer-output");
3919 if (Arg *A = Args.getLastArg(options::OPT__analyzer_output))
Richard Smithbd55daf2012-11-01 04:30:05 +00003920 CmdArgs.push_back(A->getValue());
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00003921 else
3922 CmdArgs.push_back("plist");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003923
Ted Kremenekfe449a22010-03-22 22:32:05 +00003924 // Disable the presentation of standard compiler warnings when
3925 // using --analyze. We only want to show static analyzer diagnostics
3926 // or frontend errors.
3927 CmdArgs.push_back("-w");
3928
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003929 // Add -Xanalyzer arguments when running as analyzer.
3930 Args.AddAllArgValues(CmdArgs, options::OPT_Xanalyzer);
Mike Stump11289f42009-09-09 15:08:12 +00003931 }
3932
Daniel Dunbar4eadb602009-09-10 01:21:12 +00003933 CheckCodeGenerationOptions(D, Args);
3934
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003935 llvm::Reloc::Model RelocationModel;
3936 unsigned PICLevel;
3937 bool IsPIE;
3938 std::tie(RelocationModel, PICLevel, IsPIE) =
3939 ParsePICArgs(getToolChain(), Triple, Args);
Peter Collingbourne54d770c2013-04-09 04:35:11 +00003940
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003941 const char *RMName = RelocationModelName(RelocationModel);
3942 if (RMName) {
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003943 CmdArgs.push_back("-mrelocation-model");
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003944 CmdArgs.push_back(RMName);
3945 }
3946 if (PICLevel > 0) {
3947 CmdArgs.push_back("-pic-level");
3948 CmdArgs.push_back(PICLevel == 1 ? "1" : "2");
3949 if (IsPIE) {
3950 CmdArgs.push_back("-pie-level");
3951 CmdArgs.push_back(PICLevel == 1 ? "1" : "2");
Chandler Carruth76a943b2012-11-19 03:52:03 +00003952 }
Daniel Dunbar44e71222009-04-29 18:32:25 +00003953 }
Chandler Carruthc0c04552012-04-08 16:40:35 +00003954
Renato Golin4854d802015-11-09 12:40:41 +00003955 if (Arg *A = Args.getLastArg(options::OPT_meabi)) {
3956 CmdArgs.push_back("-meabi");
3957 CmdArgs.push_back(A->getValue());
3958 }
3959
Jonathan Roelofsb140a102014-10-03 21:57:44 +00003960 CmdArgs.push_back("-mthread-model");
3961 if (Arg *A = Args.getLastArg(options::OPT_mthread_model))
3962 CmdArgs.push_back(A->getValue());
3963 else
3964 CmdArgs.push_back(Args.MakeArgString(getToolChain().getThreadModel()));
3965
Michael Zolotukhinc888dd02015-03-17 20:03:11 +00003966 Args.AddLastArg(CmdArgs, options::OPT_fveclib);
3967
Tanya Lattnerf9d41df2009-11-04 01:18:09 +00003968 if (!Args.hasFlag(options::OPT_fmerge_all_constants,
3969 options::OPT_fno_merge_all_constants))
Chris Lattner9242b332011-04-08 18:06:54 +00003970 CmdArgs.push_back("-fno-merge-all-constants");
Daniel Dunbar306945d2009-09-16 06:17:29 +00003971
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003972 // LLVM Code Generator Options.
3973
Saleem Abdulrasool76a4b952015-01-09 05:10:20 +00003974 if (Args.hasArg(options::OPT_frewrite_map_file) ||
3975 Args.hasArg(options::OPT_frewrite_map_file_EQ)) {
Sean Silva14facf32015-06-09 01:57:17 +00003976 for (const Arg *A : Args.filtered(options::OPT_frewrite_map_file,
3977 options::OPT_frewrite_map_file_EQ)) {
Saleem Abdulrasool76a4b952015-01-09 05:10:20 +00003978 CmdArgs.push_back("-frewrite-map-file");
Sean Silva14facf32015-06-09 01:57:17 +00003979 CmdArgs.push_back(A->getValue());
3980 A->claim();
Saleem Abdulrasool76a4b952015-01-09 05:10:20 +00003981 }
3982 }
3983
Alp Tokerfb8d02b2014-06-05 22:10:59 +00003984 if (Arg *A = Args.getLastArg(options::OPT_Wframe_larger_than_EQ)) {
3985 StringRef v = A->getValue();
3986 CmdArgs.push_back("-mllvm");
3987 CmdArgs.push_back(Args.MakeArgString("-warn-stack-size=" + v));
3988 A->claim();
3989 }
3990
Nirav Daved2f44d82016-04-05 17:50:43 +00003991 if (!Args.hasFlag(options::OPT_fjump_tables, options::OPT_fno_jump_tables,
3992 true))
3993 CmdArgs.push_back("-fno-jump-tables");
3994
Daniel Dunbar0bb03312011-02-09 17:54:19 +00003995 if (Arg *A = Args.getLastArg(options::OPT_mregparm_EQ)) {
3996 CmdArgs.push_back("-mregparm");
Richard Smithbd55daf2012-11-01 04:30:05 +00003997 CmdArgs.push_back(A->getValue());
Daniel Dunbar0bb03312011-02-09 17:54:19 +00003998 }
3999
Nick Lewyckyd3f3e4f2013-06-25 01:49:44 +00004000 if (Arg *A = Args.getLastArg(options::OPT_fpcc_struct_return,
4001 options::OPT_freg_struct_return)) {
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00004002 if (getToolChain().getArch() != llvm::Triple::x86) {
John McCall1fe2a8c2013-06-18 02:46:29 +00004003 D.Diag(diag::err_drv_unsupported_opt_for_target)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004004 << A->getSpelling() << getToolChain().getTriple().str();
John McCall1fe2a8c2013-06-18 02:46:29 +00004005 } else if (A->getOption().matches(options::OPT_fpcc_struct_return)) {
4006 CmdArgs.push_back("-fpcc-struct-return");
4007 } else {
4008 assert(A->getOption().matches(options::OPT_freg_struct_return));
4009 CmdArgs.push_back("-freg-struct-return");
4010 }
4011 }
4012
Roman Divacky65b88cd2011-03-01 17:40:53 +00004013 if (Args.hasFlag(options::OPT_mrtd, options::OPT_mno_rtd, false))
Alexey Bataeva7547182016-05-18 09:06:38 +00004014 CmdArgs.push_back("-fdefault-calling-conv=stdcall");
Roman Divacky65b88cd2011-03-01 17:40:53 +00004015
Rafael Espindola224dd632011-12-14 21:02:23 +00004016 if (shouldUseFramePointer(Args, getToolChain().getTriple()))
Daniel Dunbara1b02a22009-11-29 07:18:39 +00004017 CmdArgs.push_back("-mdisable-fp-elim");
4018 if (!Args.hasFlag(options::OPT_fzero_initialized_in_bss,
4019 options::OPT_fno_zero_initialized_in_bss))
4020 CmdArgs.push_back("-mno-zero-initialized-in-bss");
Chad Rosierb71f6aa2013-04-24 18:09:54 +00004021
4022 bool OFastEnabled = isOptimizationLevelFast(Args);
4023 // If -Ofast is the optimization level, then -fstrict-aliasing should be
4024 // enabled. This alias option is being used to simplify the hasFlag logic.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004025 OptSpecifier StrictAliasingAliasOption =
4026 OFastEnabled ? options::OPT_Ofast : options::OPT_fstrict_aliasing;
Reid Kleckner2a24e3a2014-04-09 20:07:39 +00004027 // We turn strict aliasing off by default if we're in CL mode, since MSVC
4028 // doesn't do any TBAA.
4029 bool TBAAOnByDefault = !getToolChain().getDriver().IsCLMode();
Chad Rosierb71f6aa2013-04-24 18:09:54 +00004030 if (!Args.hasFlag(options::OPT_fstrict_aliasing, StrictAliasingAliasOption,
Reid Kleckner2a24e3a2014-04-09 20:07:39 +00004031 options::OPT_fno_strict_aliasing, TBAAOnByDefault))
Dan Gohman10169b92010-10-14 22:36:56 +00004032 CmdArgs.push_back("-relaxed-aliasing");
Manman Renf5d9d342013-10-11 20:48:38 +00004033 if (!Args.hasFlag(options::OPT_fstruct_path_tbaa,
4034 options::OPT_fno_struct_path_tbaa))
4035 CmdArgs.push_back("-no-struct-path-tbaa");
Chandler Carruth8b4140d2012-03-27 23:58:37 +00004036 if (Args.hasFlag(options::OPT_fstrict_enums, options::OPT_fno_strict_enums,
4037 false))
4038 CmdArgs.push_back("-fstrict-enums");
Piotr Padlewski338c9d02015-09-15 21:46:47 +00004039 if (Args.hasFlag(options::OPT_fstrict_vtable_pointers,
4040 options::OPT_fno_strict_vtable_pointers,
4041 false))
4042 CmdArgs.push_back("-fstrict-vtable-pointers");
Nick Lewycky1c8c4362012-01-23 08:29:12 +00004043 if (!Args.hasFlag(options::OPT_foptimize_sibling_calls,
4044 options::OPT_fno_optimize_sibling_calls))
4045 CmdArgs.push_back("-mdisable-tail-calls");
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00004046
Eric Christopher006208c2013-04-04 06:29:47 +00004047 // Handle segmented stacks.
4048 if (Args.hasArg(options::OPT_fsplit_stack))
4049 CmdArgs.push_back("-split-stacks");
Chad Rosierb71f6aa2013-04-24 18:09:54 +00004050
4051 // If -Ofast is the optimization level, then -ffast-math should be enabled.
4052 // This alias option is being used to simplify the getLastArg logic.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004053 OptSpecifier FastMathAliasOption =
4054 OFastEnabled ? options::OPT_Ofast : options::OPT_ffast_math;
4055
Chandler Carruth306bd2c2012-01-02 14:19:45 +00004056 // Handle various floating point optimization flags, mapping them to the
4057 // appropriate LLVM code generation flags. The pattern for all of these is to
4058 // default off the codegen optimizations, and if any flag enables them and no
4059 // flag disables them after the flag enabling them, enable the codegen
4060 // optimization. This is complicated by several "umbrella" flags.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004061 if (Arg *A = Args.getLastArg(
4062 options::OPT_ffast_math, FastMathAliasOption,
4063 options::OPT_fno_fast_math, options::OPT_ffinite_math_only,
4064 options::OPT_fno_finite_math_only, options::OPT_fhonor_infinities,
4065 options::OPT_fno_honor_infinities))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00004066 if (A->getOption().getID() != options::OPT_fno_fast_math &&
4067 A->getOption().getID() != options::OPT_fno_finite_math_only &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00004068 A->getOption().getID() != options::OPT_fhonor_infinities)
4069 CmdArgs.push_back("-menable-no-infs");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004070 if (Arg *A = Args.getLastArg(
4071 options::OPT_ffast_math, FastMathAliasOption,
4072 options::OPT_fno_fast_math, options::OPT_ffinite_math_only,
4073 options::OPT_fno_finite_math_only, options::OPT_fhonor_nans,
4074 options::OPT_fno_honor_nans))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00004075 if (A->getOption().getID() != options::OPT_fno_fast_math &&
4076 A->getOption().getID() != options::OPT_fno_finite_math_only &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00004077 A->getOption().getID() != options::OPT_fhonor_nans)
4078 CmdArgs.push_back("-menable-no-nans");
4079
Benjamin Kramerc242ef22012-05-02 14:55:48 +00004080 // -fmath-errno is the default on some platforms, e.g. BSD-derived OSes.
4081 bool MathErrno = getToolChain().IsMathErrnoDefault();
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004082 if (Arg *A =
4083 Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
4084 options::OPT_fno_fast_math, options::OPT_fmath_errno,
4085 options::OPT_fno_math_errno)) {
Chandler Carruth0d4b9e62013-05-18 20:47:36 +00004086 // Turning on -ffast_math (with either flag) removes the need for MathErrno.
4087 // However, turning *off* -ffast_math merely restores the toolchain default
4088 // (which may be false).
4089 if (A->getOption().getID() == options::OPT_fno_math_errno ||
4090 A->getOption().getID() == options::OPT_ffast_math ||
4091 A->getOption().getID() == options::OPT_Ofast)
4092 MathErrno = false;
4093 else if (A->getOption().getID() == options::OPT_fmath_errno)
4094 MathErrno = true;
4095 }
Chandler Carruth3634c662012-04-26 02:10:51 +00004096 if (MathErrno)
4097 CmdArgs.push_back("-fmath-errno");
Chandler Carruth306bd2c2012-01-02 14:19:45 +00004098
4099 // There are several flags which require disabling very specific
4100 // optimizations. Any of these being disabled forces us to turn off the
4101 // entire set of LLVM optimizations, so collect them through all the flag
4102 // madness.
4103 bool AssociativeMath = false;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004104 if (Arg *A = Args.getLastArg(
4105 options::OPT_ffast_math, FastMathAliasOption,
4106 options::OPT_fno_fast_math, options::OPT_funsafe_math_optimizations,
4107 options::OPT_fno_unsafe_math_optimizations,
4108 options::OPT_fassociative_math, options::OPT_fno_associative_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00004109 if (A->getOption().getID() != options::OPT_fno_fast_math &&
4110 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00004111 A->getOption().getID() != options::OPT_fno_associative_math)
4112 AssociativeMath = true;
4113 bool ReciprocalMath = false;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004114 if (Arg *A = Args.getLastArg(
4115 options::OPT_ffast_math, FastMathAliasOption,
4116 options::OPT_fno_fast_math, options::OPT_funsafe_math_optimizations,
4117 options::OPT_fno_unsafe_math_optimizations,
4118 options::OPT_freciprocal_math, options::OPT_fno_reciprocal_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00004119 if (A->getOption().getID() != options::OPT_fno_fast_math &&
4120 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00004121 A->getOption().getID() != options::OPT_fno_reciprocal_math)
4122 ReciprocalMath = true;
4123 bool SignedZeros = true;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004124 if (Arg *A = Args.getLastArg(
4125 options::OPT_ffast_math, FastMathAliasOption,
4126 options::OPT_fno_fast_math, options::OPT_funsafe_math_optimizations,
4127 options::OPT_fno_unsafe_math_optimizations,
4128 options::OPT_fsigned_zeros, options::OPT_fno_signed_zeros))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00004129 if (A->getOption().getID() != options::OPT_fno_fast_math &&
4130 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00004131 A->getOption().getID() != options::OPT_fsigned_zeros)
4132 SignedZeros = false;
4133 bool TrappingMath = true;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004134 if (Arg *A = Args.getLastArg(
4135 options::OPT_ffast_math, FastMathAliasOption,
4136 options::OPT_fno_fast_math, options::OPT_funsafe_math_optimizations,
4137 options::OPT_fno_unsafe_math_optimizations,
4138 options::OPT_ftrapping_math, options::OPT_fno_trapping_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00004139 if (A->getOption().getID() != options::OPT_fno_fast_math &&
4140 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00004141 A->getOption().getID() != options::OPT_ftrapping_math)
4142 TrappingMath = false;
4143 if (!MathErrno && AssociativeMath && ReciprocalMath && !SignedZeros &&
4144 !TrappingMath)
4145 CmdArgs.push_back("-menable-unsafe-fp-math");
4146
Sanjay Patel76c9e092015-01-23 16:40:50 +00004147 if (!SignedZeros)
4148 CmdArgs.push_back("-fno-signed-zeros");
Lang Hamesaa53b932012-07-06 00:59:19 +00004149
Sanjay Patel359b1052015-04-09 15:03:23 +00004150 if (ReciprocalMath)
4151 CmdArgs.push_back("-freciprocal-math");
4152
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004153 // Validate and pass through -fp-contract option.
Chad Rosierb71f6aa2013-04-24 18:09:54 +00004154 if (Arg *A = Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
Chad Rosierc30eb1c2012-09-25 22:03:25 +00004155 options::OPT_fno_fast_math,
Lang Hamesaa53b932012-07-06 00:59:19 +00004156 options::OPT_ffp_contract)) {
4157 if (A->getOption().getID() == options::OPT_ffp_contract) {
Richard Smithbd55daf2012-11-01 04:30:05 +00004158 StringRef Val = A->getValue();
Lang Hamesaa53b932012-07-06 00:59:19 +00004159 if (Val == "fast" || Val == "on" || Val == "off") {
4160 CmdArgs.push_back(Args.MakeArgString("-ffp-contract=" + Val));
4161 } else {
4162 D.Diag(diag::err_drv_unsupported_option_argument)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004163 << A->getOption().getName() << Val;
Lang Hamesaa53b932012-07-06 00:59:19 +00004164 }
Chad Rosierb71f6aa2013-04-24 18:09:54 +00004165 } else if (A->getOption().matches(options::OPT_ffast_math) ||
4166 (OFastEnabled && A->getOption().matches(options::OPT_Ofast))) {
Lang Hamesaa53b932012-07-06 00:59:19 +00004167 // If fast-math is set then set the fp-contract mode to fast.
4168 CmdArgs.push_back(Args.MakeArgString("-ffp-contract=fast"));
4169 }
4170 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004171
Sanjay Patel2987c292015-06-11 14:53:41 +00004172 ParseMRecip(getToolChain().getDriver(), Args, CmdArgs);
Lang Hamesaa53b932012-07-06 00:59:19 +00004173
Bob Wilson6a039162012-07-19 03:52:53 +00004174 // We separately look for the '-ffast-math' and '-ffinite-math-only' flags,
4175 // and if we find them, tell the frontend to provide the appropriate
4176 // preprocessor macros. This is distinct from enabling any optimizations as
4177 // these options induce language changes which must survive serialization
4178 // and deserialization, etc.
Chad Rosierb71f6aa2013-04-24 18:09:54 +00004179 if (Arg *A = Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
4180 options::OPT_fno_fast_math))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004181 if (!A->getOption().matches(options::OPT_fno_fast_math))
4182 CmdArgs.push_back("-ffast-math");
Nico Webere8e53112014-05-11 01:04:02 +00004183 if (Arg *A = Args.getLastArg(options::OPT_ffinite_math_only,
4184 options::OPT_fno_fast_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00004185 if (A->getOption().matches(options::OPT_ffinite_math_only))
4186 CmdArgs.push_back("-ffinite-math-only");
Chandler Carruth306bd2c2012-01-02 14:19:45 +00004187
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00004188 // Decide whether to use verbose asm. Verbose assembly is the default on
4189 // toolchains which have the integrated assembler on by default.
Saleem Abdulrasool42e4b592014-02-22 23:37:58 +00004190 bool IsIntegratedAssemblerDefault =
4191 getToolChain().IsIntegratedAssemblerDefault();
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00004192 if (Args.hasFlag(options::OPT_fverbose_asm, options::OPT_fno_verbose_asm,
Saleem Abdulrasool42e4b592014-02-22 23:37:58 +00004193 IsIntegratedAssemblerDefault) ||
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00004194 Args.hasArg(options::OPT_dA))
Daniel Dunbara1b02a22009-11-29 07:18:39 +00004195 CmdArgs.push_back("-masm-verbose");
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00004196
Rafael Espindolab8a12932015-05-22 20:44:03 +00004197 if (!Args.hasFlag(options::OPT_fintegrated_as, options::OPT_fno_integrated_as,
4198 IsIntegratedAssemblerDefault))
Saleem Abdulrasool42e4b592014-02-22 23:37:58 +00004199 CmdArgs.push_back("-no-integrated-as");
4200
Daniel Dunbara1b02a22009-11-29 07:18:39 +00004201 if (Args.hasArg(options::OPT_fdebug_pass_structure)) {
4202 CmdArgs.push_back("-mdebug-pass");
4203 CmdArgs.push_back("Structure");
4204 }
4205 if (Args.hasArg(options::OPT_fdebug_pass_arguments)) {
4206 CmdArgs.push_back("-mdebug-pass");
4207 CmdArgs.push_back("Arguments");
4208 }
4209
Justin Lebar710a35f2016-01-25 22:36:35 +00004210 // Enable -mconstructor-aliases except on darwin, where we have to work around
4211 // a linker bug (see <rdar://problem/7651567>), and CUDA device code, where
4212 // aliases aren't supported.
4213 if (!getToolChain().getTriple().isOSDarwin() &&
4214 !getToolChain().getTriple().isNVPTX())
John McCall8517abc2010-02-19 02:45:38 +00004215 CmdArgs.push_back("-mconstructor-aliases");
NAKAMURA Takumi029d74b2011-02-17 08:50:50 +00004216
John McCall7ef5cb32011-03-18 02:56:14 +00004217 // Darwin's kernel doesn't support guard variables; just die if we
4218 // try to use them.
Bob Wilson6524dd32011-10-14 05:03:44 +00004219 if (KernelOrKext && getToolChain().getTriple().isOSDarwin())
John McCall7ef5cb32011-03-18 02:56:14 +00004220 CmdArgs.push_back("-fforbid-guard-variables");
4221
Akira Hatanaka02028482015-11-12 17:21:22 +00004222 if (Args.hasFlag(options::OPT_mms_bitfields, options::OPT_mno_ms_bitfields,
4223 false)) {
Douglas Gregordbe39272011-02-01 15:15:22 +00004224 CmdArgs.push_back("-mms-bitfields");
4225 }
John McCall8517abc2010-02-19 02:45:38 +00004226
Daniel Dunbar306945d2009-09-16 06:17:29 +00004227 // This is a coarse approximation of what llvm-gcc actually does, both
4228 // -fasynchronous-unwind-tables and -fnon-call-exceptions interact in more
4229 // complicated ways.
4230 bool AsynchronousUnwindTables =
Evgeniy Stepanov7429c592014-02-14 08:56:25 +00004231 Args.hasFlag(options::OPT_fasynchronous_unwind_tables,
4232 options::OPT_fno_asynchronous_unwind_tables,
4233 (getToolChain().IsUnwindTablesDefault() ||
4234 getToolChain().getSanitizerArgs().needsUnwindTables()) &&
4235 !KernelOrKext);
Daniel Dunbar306945d2009-09-16 06:17:29 +00004236 if (Args.hasFlag(options::OPT_funwind_tables, options::OPT_fno_unwind_tables,
4237 AsynchronousUnwindTables))
Daniel Dunbara1b02a22009-11-29 07:18:39 +00004238 CmdArgs.push_back("-munwind-tables");
4239
Chandler Carruth05fb5852012-11-21 23:40:23 +00004240 getToolChain().addClangTargetOptions(Args, CmdArgs);
Rafael Espindola66aa0452012-06-19 01:26:10 +00004241
Daniel Dunbara1b02a22009-11-29 07:18:39 +00004242 if (Arg *A = Args.getLastArg(options::OPT_flimited_precision_EQ)) {
4243 CmdArgs.push_back("-mlimit-float-precision");
Richard Smithbd55daf2012-11-01 04:30:05 +00004244 CmdArgs.push_back(A->getValue());
Daniel Dunbara1b02a22009-11-29 07:18:39 +00004245 }
Daniel Dunbar44e71222009-04-29 18:32:25 +00004246
Daniel Dunbar4dbaaa62009-05-06 03:16:41 +00004247 // FIXME: Handle -mtune=.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004248 (void)Args.hasArg(options::OPT_mtune_EQ);
Daniel Dunbar44e71222009-04-29 18:32:25 +00004249
Benjamin Kramercf4371a2009-08-05 14:30:52 +00004250 if (Arg *A = Args.getLastArg(options::OPT_mcmodel_EQ)) {
Daniel Dunbara1b02a22009-11-29 07:18:39 +00004251 CmdArgs.push_back("-mcode-model");
Richard Smithbd55daf2012-11-01 04:30:05 +00004252 CmdArgs.push_back(A->getValue());
Benjamin Kramercf4371a2009-08-05 14:30:52 +00004253 }
4254
Rafael Espindola22ce34a2013-08-20 22:12:08 +00004255 // Add the target cpu
Renato Golin7c542b42015-07-27 23:44:45 +00004256 std::string CPU = getCPUName(Args, Triple, /*FromAs*/ false);
Rafael Espindola22ce34a2013-08-20 22:12:08 +00004257 if (!CPU.empty()) {
4258 CmdArgs.push_back("-target-cpu");
4259 CmdArgs.push_back(Args.MakeArgString(CPU));
4260 }
4261
Rafael Espindolaeb265472013-08-21 21:59:03 +00004262 if (const Arg *A = Args.getLastArg(options::OPT_mfpmath_EQ)) {
4263 CmdArgs.push_back("-mfpmath");
4264 CmdArgs.push_back(A->getValue());
4265 }
4266
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00004267 // Add the target features
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00004268 getTargetFeatures(getToolChain(), Triple, Args, CmdArgs, false);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00004269
Rafael Espindola22ce34a2013-08-20 22:12:08 +00004270 // Add target specific flags.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004271 switch (getToolChain().getArch()) {
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00004272 default:
4273 break;
Daniel Dunbar4dbaaa62009-05-06 03:16:41 +00004274
Daniel Dunbar0f5c5422009-09-10 04:57:17 +00004275 case llvm::Triple::arm:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00004276 case llvm::Triple::armeb:
Daniel Dunbar0f5c5422009-09-10 04:57:17 +00004277 case llvm::Triple::thumb:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00004278 case llvm::Triple::thumbeb:
Saleem Abdulrasoolce63ce92015-09-19 18:19:44 +00004279 // Use the effective triple, which takes into account the deployment target.
4280 AddARMTargetArgs(Triple, Args, CmdArgs, KernelOrKext);
Daniel Dunbar0f5c5422009-09-10 04:57:17 +00004281 break;
4282
Tim Northover573cbee2014-05-24 12:52:07 +00004283 case llvm::Triple::aarch64:
4284 case llvm::Triple::aarch64_be:
Tim Northover573cbee2014-05-24 12:52:07 +00004285 AddAArch64TargetArgs(Args, CmdArgs);
Tim Northovera2ee4332014-03-29 15:09:45 +00004286 break;
4287
Eric Christopher0b26a612010-03-02 02:41:08 +00004288 case llvm::Triple::mips:
4289 case llvm::Triple::mipsel:
Akira Hatanaka94ab5542011-09-21 02:13:07 +00004290 case llvm::Triple::mips64:
4291 case llvm::Triple::mips64el:
Eric Christopher0b26a612010-03-02 02:41:08 +00004292 AddMIPSTargetArgs(Args, CmdArgs);
4293 break;
4294
Ulrich Weigand8afad612014-07-28 13:17:52 +00004295 case llvm::Triple::ppc:
4296 case llvm::Triple::ppc64:
4297 case llvm::Triple::ppc64le:
4298 AddPPCTargetArgs(Args, CmdArgs);
4299 break;
4300
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00004301 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00004302 case llvm::Triple::sparcel:
Brad Smith10cd0f42014-07-11 20:12:08 +00004303 case llvm::Triple::sparcv9:
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00004304 AddSparcTargetArgs(Args, CmdArgs);
4305 break;
4306
Marcin Koscielnickib31ee6d2016-05-04 23:37:40 +00004307 case llvm::Triple::systemz:
4308 AddSystemZTargetArgs(Args, CmdArgs);
4309 break;
4310
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00004311 case llvm::Triple::x86:
4312 case llvm::Triple::x86_64:
4313 AddX86TargetArgs(Args, CmdArgs);
4314 break;
Tony Linthicum76329bf2011-12-12 21:14:55 +00004315
Jacques Pienaard964cc22016-03-28 21:02:54 +00004316 case llvm::Triple::lanai:
4317 AddLanaiTargetArgs(Args, CmdArgs);
4318 break;
4319
Tony Linthicum76329bf2011-12-12 21:14:55 +00004320 case llvm::Triple::hexagon:
4321 AddHexagonTargetArgs(Args, CmdArgs);
4322 break;
Dan Gohmane3d71e12016-01-07 01:00:21 +00004323
4324 case llvm::Triple::wasm32:
4325 case llvm::Triple::wasm64:
4326 AddWebAssemblyTargetArgs(Args, CmdArgs);
4327 break;
Daniel Dunbar44e71222009-04-29 18:32:25 +00004328 }
4329
Douglas Katzman3459ce22015-10-08 04:24:12 +00004330 // The 'g' groups options involve a somewhat intricate sequence of decisions
4331 // about what to pass from the driver to the frontend, but by the time they
Paul Robinson0334a042015-12-19 19:41:48 +00004332 // reach cc1 they've been factored into three well-defined orthogonal choices:
Douglas Katzman3459ce22015-10-08 04:24:12 +00004333 // * what level of debug info to generate
4334 // * what dwarf version to write
Paul Robinson0334a042015-12-19 19:41:48 +00004335 // * what debugger tuning to use
Douglas Katzman3459ce22015-10-08 04:24:12 +00004336 // This avoids having to monkey around further in cc1 other than to disable
4337 // codeview if not running in a Windows environment. Perhaps even that
4338 // decision should be made in the driver as well though.
Paul Robinson0334a042015-12-19 19:41:48 +00004339 unsigned DwarfVersion = 0;
4340 llvm::DebuggerKind DebuggerTuning = getToolChain().getDefaultDebuggerTuning();
4341 // These two are potentially updated by AddClangCLArgs.
Benjamin Kramer8c305922016-02-02 11:06:51 +00004342 codegenoptions::DebugInfoKind DebugInfoKind = codegenoptions::NoDebugInfo;
Douglas Katzman3459ce22015-10-08 04:24:12 +00004343 bool EmitCodeView = false;
4344
Hans Wennborg75958c42013-08-08 00:17:41 +00004345 // Add clang-cl arguments.
David Majnemercd5855e2016-02-29 01:40:36 +00004346 types::ID InputType = Input.getType();
Hans Wennborg75958c42013-08-08 00:17:41 +00004347 if (getToolChain().getDriver().IsCLMode())
David Majnemercd5855e2016-02-29 01:40:36 +00004348 AddClangCLArgs(Args, InputType, CmdArgs, &DebugInfoKind, &EmitCodeView);
Hans Wennborg75958c42013-08-08 00:17:41 +00004349
Daniel Dunbar976a2f52010-08-11 23:07:47 +00004350 // Pass the linker version in use.
4351 if (Arg *A = Args.getLastArg(options::OPT_mlinker_version_EQ)) {
4352 CmdArgs.push_back("-target-linker-version");
Richard Smithbd55daf2012-11-01 04:30:05 +00004353 CmdArgs.push_back(A->getValue());
Daniel Dunbar976a2f52010-08-11 23:07:47 +00004354 }
4355
Eric Christopherb7d97e92013-04-03 01:58:53 +00004356 if (!shouldUseLeafFramePointer(Args, getToolChain().getTriple()))
Daniel Dunbarbb7ac522010-07-01 01:31:45 +00004357 CmdArgs.push_back("-momit-leaf-frame-pointer");
4358
Daniel Dunbarfcc49a82010-05-12 18:19:58 +00004359 // Explicitly error on some things we know we don't support and can't just
4360 // ignore.
Daniel Dunbar4ed214a2010-09-24 19:39:37 +00004361 if (!Args.hasArg(options::OPT_fallow_unsupported)) {
4362 Arg *Unsupported;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004363 if (types::isCXX(InputType) && getToolChain().getTriple().isOSDarwin() &&
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00004364 getToolChain().getArch() == llvm::Triple::x86) {
Bob Wilson0d45f582011-08-13 23:48:55 +00004365 if ((Unsupported = Args.getLastArg(options::OPT_fapple_kext)) ||
4366 (Unsupported = Args.getLastArg(options::OPT_mkernel)))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004367 D.Diag(diag::err_drv_clang_unsupported_opt_cxx_darwin_i386)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004368 << Unsupported->getOption().getName();
Daniel Dunbar4ed214a2010-09-24 19:39:37 +00004369 }
Daniel Dunbarfcc49a82010-05-12 18:19:58 +00004370 }
4371
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004372 Args.AddAllArgs(CmdArgs, options::OPT_v);
Daniel Dunbard4352752010-08-24 22:44:13 +00004373 Args.AddLastArg(CmdArgs, options::OPT_H);
Chad Rosierbe10f982011-08-02 17:58:04 +00004374 if (D.CCPrintHeaders && !D.CCGenDiagnostics) {
Daniel Dunbarac540b32011-02-02 21:11:35 +00004375 CmdArgs.push_back("-header-include-file");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004376 CmdArgs.push_back(D.CCPrintHeadersFilename ? D.CCPrintHeadersFilename
4377 : "-");
Daniel Dunbarac540b32011-02-02 21:11:35 +00004378 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004379 Args.AddLastArg(CmdArgs, options::OPT_P);
Mike Stump11289f42009-09-09 15:08:12 +00004380 Args.AddLastArg(CmdArgs, options::OPT_print_ivar_layout);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004381
Chad Rosierbe10f982011-08-02 17:58:04 +00004382 if (D.CCLogDiagnostics && !D.CCGenDiagnostics) {
Daniel Dunbar529c03b2011-04-07 18:01:20 +00004383 CmdArgs.push_back("-diagnostic-log-file");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004384 CmdArgs.push_back(D.CCLogDiagnosticsFilename ? D.CCLogDiagnosticsFilename
4385 : "-");
Daniel Dunbar529c03b2011-04-07 18:01:20 +00004386 }
4387
Rafael Espindola08a692a2010-03-07 04:46:18 +00004388 Args.ClaimAllArgs(options::OPT_g_Group);
David Blaikiece3e7a62015-07-30 21:42:22 +00004389 Arg *SplitDwarfArg = Args.getLastArg(options::OPT_gsplit_dwarf);
Alexey Samsonovdda3a7f2012-05-29 08:10:34 +00004390 if (Arg *A = Args.getLastArg(options::OPT_g_Group)) {
Paul Robinson0334a042015-12-19 19:41:48 +00004391 // If the last option explicitly specified a debug-info level, use it.
4392 if (A->getOption().matches(options::OPT_gN_Group)) {
4393 DebugInfoKind = DebugLevelToInfoKind(*A);
4394 // If you say "-gsplit-dwarf -gline-tables-only", -gsplit-dwarf loses.
4395 // But -gsplit-dwarf is not a g_group option, hence we have to check the
4396 // order explicitly. (If -gsplit-dwarf wins, we fix DebugInfoKind later.)
Benjamin Kramer8c305922016-02-02 11:06:51 +00004397 if (SplitDwarfArg && DebugInfoKind < codegenoptions::LimitedDebugInfo &&
Paul Robinson0334a042015-12-19 19:41:48 +00004398 A->getIndex() > SplitDwarfArg->getIndex())
4399 SplitDwarfArg = nullptr;
4400 } else
4401 // For any other 'g' option, use Limited.
Benjamin Kramer8c305922016-02-02 11:06:51 +00004402 DebugInfoKind = codegenoptions::LimitedDebugInfo;
Alexey Samsonovdda3a7f2012-05-29 08:10:34 +00004403 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004404
Paul Robinson0334a042015-12-19 19:41:48 +00004405 // If a debugger tuning argument appeared, remember it.
4406 if (Arg *A = Args.getLastArg(options::OPT_gTune_Group,
4407 options::OPT_ggdbN_Group)) {
4408 if (A->getOption().matches(options::OPT_glldb))
4409 DebuggerTuning = llvm::DebuggerKind::LLDB;
4410 else if (A->getOption().matches(options::OPT_gsce))
4411 DebuggerTuning = llvm::DebuggerKind::SCE;
4412 else
4413 DebuggerTuning = llvm::DebuggerKind::GDB;
4414 }
4415
4416 // If a -gdwarf argument appeared, remember it.
Douglas Katzman3459ce22015-10-08 04:24:12 +00004417 if (Arg *A = Args.getLastArg(options::OPT_gdwarf_2, options::OPT_gdwarf_3,
Eric Christopher3cb592d2015-12-28 19:58:44 +00004418 options::OPT_gdwarf_4, options::OPT_gdwarf_5))
Douglas Katzman3459ce22015-10-08 04:24:12 +00004419 DwarfVersion = DwarfVersionNum(A->getSpelling());
4420
Reid Kleckner124955a2015-08-05 18:51:13 +00004421 // Forward -gcodeview.
Douglas Katzman3459ce22015-10-08 04:24:12 +00004422 // 'EmitCodeView might have been set by CL-compatibility argument parsing.
4423 if (Args.hasArg(options::OPT_gcodeview) || EmitCodeView) {
4424 // DwarfVersion remains at 0 if no explicit choice was made.
4425 CmdArgs.push_back("-gcodeview");
4426 } else if (DwarfVersion == 0 &&
Benjamin Kramer8c305922016-02-02 11:06:51 +00004427 DebugInfoKind != codegenoptions::NoDebugInfo) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00004428 DwarfVersion = getToolChain().GetDefaultDwarfVersion();
4429 }
Reid Kleckner124955a2015-08-05 18:51:13 +00004430
Alexey Samsonovf50a9ff2012-06-21 08:22:39 +00004431 // We ignore flags -gstrict-dwarf and -grecord-gcc-switches for now.
4432 Args.ClaimAllArgs(options::OPT_g_flags_Group);
Filipe Cabecinhasc888e192015-10-14 12:25:43 +00004433
4434 // PS4 defaults to no column info
Diego Novillo94b276d2014-07-10 23:29:28 +00004435 if (Args.hasFlag(options::OPT_gcolumn_info, options::OPT_gno_column_info,
Filipe Cabecinhasc888e192015-10-14 12:25:43 +00004436 /*Default=*/ !IsPS4CPU))
Eric Christophera2f7eb72012-10-18 21:52:18 +00004437 CmdArgs.push_back("-dwarf-column-info");
Alexey Samsonovf50a9ff2012-06-21 08:22:39 +00004438
Eric Christopher138c32b2013-09-13 22:37:55 +00004439 // FIXME: Move backend command line options to the module.
Adrian Prantl6b21ab22015-08-27 19:46:20 +00004440 if (Args.hasArg(options::OPT_gmodules)) {
Benjamin Kramer8c305922016-02-02 11:06:51 +00004441 DebugInfoKind = codegenoptions::LimitedDebugInfo;
Adrian Prantl6b21ab22015-08-27 19:46:20 +00004442 CmdArgs.push_back("-dwarf-ext-refs");
4443 CmdArgs.push_back("-fmodule-format=obj");
4444 }
4445
Eric Christopher2ba5fcb2013-02-05 07:29:57 +00004446 // -gsplit-dwarf should turn on -g and enable the backend dwarf
4447 // splitting and extraction.
Eric Christopherd42fb732013-02-21 22:35:05 +00004448 // FIXME: Currently only works on Linux.
David Blaikiece3e7a62015-07-30 21:42:22 +00004449 if (getToolChain().getTriple().isOSLinux() && SplitDwarfArg) {
Benjamin Kramer8c305922016-02-02 11:06:51 +00004450 DebugInfoKind = codegenoptions::LimitedDebugInfo;
Eric Christopher2ba5fcb2013-02-05 07:29:57 +00004451 CmdArgs.push_back("-backend-option");
4452 CmdArgs.push_back("-split-dwarf=Enable");
4453 }
4454
Douglas Katzman3459ce22015-10-08 04:24:12 +00004455 // After we've dealt with all combinations of things that could
4456 // make DebugInfoKind be other than None or DebugLineTablesOnly,
4457 // figure out if we need to "upgrade" it to standalone debug info.
4458 // We parse these two '-f' options whether or not they will be used,
4459 // to claim them even if you wrote "-fstandalone-debug -gline-tables-only"
4460 bool NeedFullDebug = Args.hasFlag(options::OPT_fstandalone_debug,
4461 options::OPT_fno_standalone_debug,
4462 getToolChain().GetDefaultStandaloneDebug());
Benjamin Kramer8c305922016-02-02 11:06:51 +00004463 if (DebugInfoKind == codegenoptions::LimitedDebugInfo && NeedFullDebug)
4464 DebugInfoKind = codegenoptions::FullDebugInfo;
Paul Robinson0334a042015-12-19 19:41:48 +00004465 RenderDebugEnablingArgs(Args, CmdArgs, DebugInfoKind, DwarfVersion,
4466 DebuggerTuning);
Douglas Katzman3459ce22015-10-08 04:24:12 +00004467
Eric Christopher138c32b2013-09-13 22:37:55 +00004468 // -ggnu-pubnames turns on gnu style pubnames in the backend.
4469 if (Args.hasArg(options::OPT_ggnu_pubnames)) {
4470 CmdArgs.push_back("-backend-option");
4471 CmdArgs.push_back("-generate-gnu-dwarf-pub-sections");
4472 }
Eric Christophereec89c22013-06-18 00:03:50 +00004473
Eric Christopher0d403d22014-02-14 01:27:03 +00004474 // -gdwarf-aranges turns on the emission of the aranges section in the
4475 // backend.
Filipe Cabecinhasc888e192015-10-14 12:25:43 +00004476 // Always enabled on the PS4.
4477 if (Args.hasArg(options::OPT_gdwarf_aranges) || IsPS4CPU) {
Eric Christopher0d403d22014-02-14 01:27:03 +00004478 CmdArgs.push_back("-backend-option");
4479 CmdArgs.push_back("-generate-arange-section");
4480 }
4481
David Blaikief36d9ba2014-01-27 18:52:43 +00004482 if (Args.hasFlag(options::OPT_fdebug_types_section,
4483 options::OPT_fno_debug_types_section, false)) {
David Blaikied74be702014-01-18 02:02:06 +00004484 CmdArgs.push_back("-backend-option");
4485 CmdArgs.push_back("-generate-type-units");
4486 }
Eric Christophereec89c22013-06-18 00:03:50 +00004487
Dan Gohmana5b804b2016-01-07 00:50:27 +00004488 // CloudABI and WebAssembly use -ffunction-sections and -fdata-sections by
4489 // default.
4490 bool UseSeparateSections = Triple.getOS() == llvm::Triple::CloudABI ||
4491 Triple.getArch() == llvm::Triple::wasm32 ||
4492 Triple.getArch() == llvm::Triple::wasm64;
Ed Schouten6e576152015-03-26 17:50:28 +00004493
Evgeniy Stepanov9e7cb332014-02-03 11:11:37 +00004494 if (Args.hasFlag(options::OPT_ffunction_sections,
Ed Schouten6e576152015-03-26 17:50:28 +00004495 options::OPT_fno_function_sections, UseSeparateSections)) {
Evgeniy Stepanov9e7cb332014-02-03 11:11:37 +00004496 CmdArgs.push_back("-ffunction-sections");
4497 }
4498
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004499 if (Args.hasFlag(options::OPT_fdata_sections, options::OPT_fno_data_sections,
4500 UseSeparateSections)) {
Evgeniy Stepanov9e7cb332014-02-03 11:11:37 +00004501 CmdArgs.push_back("-fdata-sections");
4502 }
Rafael Espindola66bfb2752010-05-06 21:06:04 +00004503
Rafael Espindola6b07a1c2015-02-20 18:08:57 +00004504 if (!Args.hasFlag(options::OPT_funique_section_names,
Rafael Espindolab8a12932015-05-22 20:44:03 +00004505 options::OPT_fno_unique_section_names, true))
Rafael Espindola6b07a1c2015-02-20 18:08:57 +00004506 CmdArgs.push_back("-fno-unique-section-names");
4507
Chris Lattner3c77a352010-06-22 00:03:40 +00004508 Args.AddAllArgs(CmdArgs, options::OPT_finstrument_functions);
4509
Diego Novilloa0545962015-07-10 18:00:07 +00004510 addPGOAndCoverageFlags(C, D, Output, Args, CmdArgs);
Nick Lewycky480cb992011-05-04 20:46:58 +00004511
Paul Robinsond083b9a2015-12-16 17:25:27 +00004512 // Add runtime flag for PS4 when PGO or Coverage are enabled.
4513 if (getToolChain().getTriple().isPS4CPU())
4514 addPS4ProfileRTArgs(getToolChain(), Args, CmdArgs);
4515
Daniel Dunbarb25bfde2011-10-11 18:20:10 +00004516 // Pass options for controlling the default header search paths.
4517 if (Args.hasArg(options::OPT_nostdinc)) {
4518 CmdArgs.push_back("-nostdsysteminc");
4519 CmdArgs.push_back("-nobuiltininc");
4520 } else {
Daniel Dunbar0f41eee2011-10-11 18:20:16 +00004521 if (Args.hasArg(options::OPT_nostdlibinc))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004522 CmdArgs.push_back("-nostdsysteminc");
Daniel Dunbarb25bfde2011-10-11 18:20:10 +00004523 Args.AddLastArg(CmdArgs, options::OPT_nostdincxx);
4524 Args.AddLastArg(CmdArgs, options::OPT_nobuiltininc);
4525 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004526
Daniel Dunbar34e0b8c2009-12-15 01:02:52 +00004527 // Pass the path to compiler resource files.
Daniel Dunbar34e0b8c2009-12-15 01:02:52 +00004528 CmdArgs.push_back("-resource-dir");
Daniel Dunbar3f3e2cd2010-01-20 02:35:16 +00004529 CmdArgs.push_back(D.ResourceDir.c_str());
Daniel Dunbar9dc82a22009-04-07 21:42:00 +00004530
Argyrios Kyrtzidis71731d62010-11-03 22:45:23 +00004531 Args.AddLastArg(CmdArgs, options::OPT_working_directory);
4532
Ted Kremenekf7639e12012-03-06 20:06:33 +00004533 bool ARCMTEnabled = false;
Argyrios Kyrtzidis85230d52013-09-17 19:14:29 +00004534 if (!Args.hasArg(options::OPT_fno_objc_arc, options::OPT_fobjc_arc)) {
Argyrios Kyrtzidisc44b93d2011-07-07 04:00:39 +00004535 if (const Arg *A = Args.getLastArg(options::OPT_ccc_arcmt_check,
Argyrios Kyrtzidis7fbd97f2011-07-09 20:00:58 +00004536 options::OPT_ccc_arcmt_modify,
4537 options::OPT_ccc_arcmt_migrate)) {
Ted Kremenekf7639e12012-03-06 20:06:33 +00004538 ARCMTEnabled = true;
John McCalld70fb982011-06-15 23:25:17 +00004539 switch (A->getOption().getID()) {
4540 default:
4541 llvm_unreachable("missed a case");
Argyrios Kyrtzidisc44b93d2011-07-07 04:00:39 +00004542 case options::OPT_ccc_arcmt_check:
John McCalld70fb982011-06-15 23:25:17 +00004543 CmdArgs.push_back("-arcmt-check");
4544 break;
Argyrios Kyrtzidisc44b93d2011-07-07 04:00:39 +00004545 case options::OPT_ccc_arcmt_modify:
John McCalld70fb982011-06-15 23:25:17 +00004546 CmdArgs.push_back("-arcmt-modify");
4547 break;
Argyrios Kyrtzidis7fbd97f2011-07-09 20:00:58 +00004548 case options::OPT_ccc_arcmt_migrate:
4549 CmdArgs.push_back("-arcmt-migrate");
Ted Kremenekf7639e12012-03-06 20:06:33 +00004550 CmdArgs.push_back("-mt-migrate-directory");
Richard Smithbd55daf2012-11-01 04:30:05 +00004551 CmdArgs.push_back(A->getValue());
Argyrios Kyrtzidisd5713632011-07-19 17:20:03 +00004552
4553 Args.AddLastArg(CmdArgs, options::OPT_arcmt_migrate_report_output);
4554 Args.AddLastArg(CmdArgs, options::OPT_arcmt_migrate_emit_arc_errors);
Argyrios Kyrtzidis7fbd97f2011-07-09 20:00:58 +00004555 break;
John McCalld70fb982011-06-15 23:25:17 +00004556 }
4557 }
Argyrios Kyrtzidisb11a1922013-06-24 19:01:18 +00004558 } else {
4559 Args.ClaimAllArgs(options::OPT_ccc_arcmt_check);
4560 Args.ClaimAllArgs(options::OPT_ccc_arcmt_modify);
4561 Args.ClaimAllArgs(options::OPT_ccc_arcmt_migrate);
John McCalld70fb982011-06-15 23:25:17 +00004562 }
Eric Christopher84fbdb42011-08-19 00:30:14 +00004563
Ted Kremenekf7639e12012-03-06 20:06:33 +00004564 if (const Arg *A = Args.getLastArg(options::OPT_ccc_objcmt_migrate)) {
4565 if (ARCMTEnabled) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004566 D.Diag(diag::err_drv_argument_not_allowed_with) << A->getAsString(Args)
4567 << "-ccc-arcmt-migrate";
Ted Kremenekf7639e12012-03-06 20:06:33 +00004568 }
4569 CmdArgs.push_back("-mt-migrate-directory");
Richard Smithbd55daf2012-11-01 04:30:05 +00004570 CmdArgs.push_back(A->getValue());
Ted Kremenekf7639e12012-03-06 20:06:33 +00004571
4572 if (!Args.hasArg(options::OPT_objcmt_migrate_literals,
Fariborz Jahaniand83ef842013-07-09 16:59:14 +00004573 options::OPT_objcmt_migrate_subscripting,
4574 options::OPT_objcmt_migrate_property)) {
Ted Kremenekf7639e12012-03-06 20:06:33 +00004575 // None specified, means enable them all.
4576 CmdArgs.push_back("-objcmt-migrate-literals");
4577 CmdArgs.push_back("-objcmt-migrate-subscripting");
Fariborz Jahaniand83ef842013-07-09 16:59:14 +00004578 CmdArgs.push_back("-objcmt-migrate-property");
Ted Kremenekf7639e12012-03-06 20:06:33 +00004579 } else {
4580 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_literals);
4581 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_subscripting);
Fariborz Jahaniand83ef842013-07-09 16:59:14 +00004582 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_property);
Ted Kremenekf7639e12012-03-06 20:06:33 +00004583 }
Argyrios Kyrtzidis55ecf992013-11-13 23:38:20 +00004584 } else {
4585 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_literals);
4586 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_subscripting);
4587 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_property);
4588 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_all);
4589 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_readonly_property);
4590 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_readwrite_property);
Fariborz Jahanian773fa2c2015-03-03 17:15:38 +00004591 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_property_dot_syntax);
Argyrios Kyrtzidis55ecf992013-11-13 23:38:20 +00004592 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_annotation);
4593 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_instancetype);
4594 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_nsmacros);
4595 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_protocol_conformance);
4596 Args.AddLastArg(CmdArgs, options::OPT_objcmt_atomic_property);
4597 Args.AddLastArg(CmdArgs, options::OPT_objcmt_returns_innerpointer_property);
4598 Args.AddLastArg(CmdArgs, options::OPT_objcmt_ns_nonatomic_iosonly);
Argyrios Kyrtzidis74aa02562013-12-11 01:29:48 +00004599 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_designated_init);
Argyrios Kyrtzidisd5ba86b2013-12-10 18:36:53 +00004600 Args.AddLastArg(CmdArgs, options::OPT_objcmt_whitelist_dir_path);
Ted Kremenekf7639e12012-03-06 20:06:33 +00004601 }
4602
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004603 // Add preprocessing options like -I, -D, etc. if we are using the
4604 // preprocessor.
4605 //
4606 // FIXME: Support -fpreprocessed
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004607 if (types::getPreprocessedType(InputType) != types::TY_INVALID)
Artem Belevichfa11ab52015-11-17 22:28:46 +00004608 AddPreprocessingOptions(C, JA, D, Args, CmdArgs, Output, Inputs,
4609 AuxToolChain);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004610
Rafael Espindolaa7431922011-07-21 23:40:37 +00004611 // Don't warn about "clang -c -DPIC -fPIC test.i" because libtool.m4 assumes
4612 // that "The compiler can only warn and ignore the option if not recognized".
4613 // When building with ccache, it will pass -D options to clang even on
4614 // preprocessed inputs and configure concludes that -fPIC is not supported.
4615 Args.ClaimAllArgs(options::OPT_D);
4616
Alp Toker7874bdc2013-11-15 20:40:58 +00004617 // Manually translate -O4 to -O3; let clang reject others.
Rafael Espindolaad70d962013-08-27 16:58:15 +00004618 if (Arg *A = Args.getLastArg(options::OPT_O_Group)) {
4619 if (A->getOption().matches(options::OPT_O4)) {
4620 CmdArgs.push_back("-O3");
4621 D.Diag(diag::warn_O4_is_O3);
4622 } else {
4623 A->render(Args, CmdArgs);
4624 }
4625 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004626
Sylvestre Ledru2fe501e2014-07-11 11:43:57 +00004627 // Warn about ignored options to clang.
Sean Silva14facf32015-06-09 01:57:17 +00004628 for (const Arg *A :
4629 Args.filtered(options::OPT_clang_ignored_gcc_optimization_f_Group)) {
4630 D.Diag(diag::warn_ignored_gcc_optimization) << A->getAsString(Args);
Douglas Katzman8b50e012015-08-05 18:03:47 +00004631 A->claim();
Sylvestre Ledru2fe501e2014-07-11 11:43:57 +00004632 }
4633
Rafael Espindola577637a2015-01-03 00:06:04 +00004634 claimNoWarnArgs(Args);
Chad Rosier86b82082012-12-12 20:06:31 +00004635
Richard Smith3be1cb22014-08-07 00:24:21 +00004636 Args.AddAllArgs(CmdArgs, options::OPT_R_Group);
Daniel Dunbar945577c2009-10-29 02:24:45 +00004637 Args.AddAllArgs(CmdArgs, options::OPT_W_Group);
Ted Kremenekb22ea2a2012-07-07 05:53:30 +00004638 if (Args.hasFlag(options::OPT_pedantic, options::OPT_no_pedantic, false))
4639 CmdArgs.push_back("-pedantic");
Daniel Dunbar945577c2009-10-29 02:24:45 +00004640 Args.AddLastArg(CmdArgs, options::OPT_pedantic_errors);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004641 Args.AddLastArg(CmdArgs, options::OPT_w);
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004642
4643 // Handle -{std, ansi, trigraphs} -- take the last of -{std, ansi}
Hans Wennborgec993822013-07-31 16:57:56 +00004644 // (-ansi is equivalent to -std=c89 or -std=c++98).
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004645 //
4646 // If a std is supplied, only add -trigraphs if it follows the
4647 // option.
David Majnemer8db91762015-05-18 04:49:30 +00004648 bool ImplyVCPPCXXVer = false;
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004649 if (Arg *Std = Args.getLastArg(options::OPT_std_EQ, options::OPT_ansi)) {
4650 if (Std->getOption().matches(options::OPT_ansi))
Nuno Lopes275225d2009-10-16 14:28:06 +00004651 if (types::isCXX(InputType))
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004652 CmdArgs.push_back("-std=c++98");
Nuno Lopes275225d2009-10-16 14:28:06 +00004653 else
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004654 CmdArgs.push_back("-std=c89");
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004655 else
4656 Std->render(Args, CmdArgs);
4657
Nico Weber00721502014-12-23 22:32:37 +00004658 // If -f(no-)trigraphs appears after the language standard flag, honor it.
Daniel Dunbar3f1a1ff2010-06-14 21:23:08 +00004659 if (Arg *A = Args.getLastArg(options::OPT_std_EQ, options::OPT_ansi,
Nico Weber00721502014-12-23 22:32:37 +00004660 options::OPT_ftrigraphs,
4661 options::OPT_fno_trigraphs))
Daniel Dunbar3f1a1ff2010-06-14 21:23:08 +00004662 if (A != Std)
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004663 A->render(Args, CmdArgs);
Daniel Dunbar72a60902009-04-26 01:10:38 +00004664 } else {
4665 // Honor -std-default.
Daniel Dunbar12998192010-01-29 21:03:02 +00004666 //
4667 // FIXME: Clang doesn't correctly handle -std= when the input language
4668 // doesn't match. For the time being just ignore this for C++ inputs;
4669 // eventually we want to do all the standard defaulting here instead of
4670 // splitting it between the driver and clang -cc1.
4671 if (!types::isCXX(InputType))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004672 Args.AddAllArgsTranslated(CmdArgs, options::OPT_std_default_EQ, "-std=",
4673 /*Joined=*/true);
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00004674 else if (IsWindowsMSVC)
David Majnemer8db91762015-05-18 04:49:30 +00004675 ImplyVCPPCXXVer = true;
Nico Weber723b4f02012-08-30 02:08:31 +00004676
Nico Weber00721502014-12-23 22:32:37 +00004677 Args.AddLastArg(CmdArgs, options::OPT_ftrigraphs,
4678 options::OPT_fno_trigraphs);
Daniel Dunbar72a60902009-04-26 01:10:38 +00004679 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004680
Richard Smith282b4492013-09-04 22:50:31 +00004681 // GCC's behavior for -Wwrite-strings is a bit strange:
4682 // * In C, this "warning flag" changes the types of string literals from
4683 // 'char[N]' to 'const char[N]', and thus triggers an unrelated warning
4684 // for the discarded qualifier.
4685 // * In C++, this is just a normal warning flag.
4686 //
4687 // Implementing this warning correctly in C is hard, so we follow GCC's
4688 // behavior for now. FIXME: Directly diagnose uses of a string literal as
4689 // a non-const char* in C, rather than using this crude hack.
4690 if (!types::isCXX(InputType)) {
Argyrios Kyrtzidis25f2afde2014-02-07 08:33:28 +00004691 // FIXME: This should behave just like a warning flag, and thus should also
4692 // respect -Weverything, -Wno-everything, -Werror=write-strings, and so on.
4693 Arg *WriteStrings =
4694 Args.getLastArg(options::OPT_Wwrite_strings,
4695 options::OPT_Wno_write_strings, options::OPT_w);
4696 if (WriteStrings &&
4697 WriteStrings->getOption().matches(options::OPT_Wwrite_strings))
Richard Smith282b4492013-09-04 22:50:31 +00004698 CmdArgs.push_back("-fconst-strings");
Chandler Carruthb009b142011-04-23 06:30:43 +00004699 }
4700
Chandler Carruth61fbf622011-04-23 09:27:53 +00004701 // GCC provides a macro definition '__DEPRECATED' when -Wdeprecated is active
Chandler Carruth30483fb2011-04-23 19:48:40 +00004702 // during C++ compilation, which it is by default. GCC keeps this define even
4703 // in the presence of '-w', match this behavior bug-for-bug.
4704 if (types::isCXX(InputType) &&
4705 Args.hasFlag(options::OPT_Wdeprecated, options::OPT_Wno_deprecated,
4706 true)) {
4707 CmdArgs.push_back("-fdeprecated-macro");
Chandler Carruth61fbf622011-04-23 09:27:53 +00004708 }
4709
Chandler Carruthe0391482010-05-22 02:21:53 +00004710 // Translate GCC's misnamer '-fasm' arguments to '-fgnu-keywords'.
4711 if (Arg *Asm = Args.getLastArg(options::OPT_fasm, options::OPT_fno_asm)) {
4712 if (Asm->getOption().matches(options::OPT_fasm))
4713 CmdArgs.push_back("-fgnu-keywords");
4714 else
4715 CmdArgs.push_back("-fno-gnu-keywords");
4716 }
4717
Nick Lewycky1d617ac2011-10-17 23:05:52 +00004718 if (ShouldDisableDwarfDirectory(Args, getToolChain()))
4719 CmdArgs.push_back("-fno-dwarf-directory-asm");
4720
Daniel Dunbare246fbe2013-04-16 18:21:19 +00004721 if (ShouldDisableAutolink(Args, getToolChain()))
4722 CmdArgs.push_back("-fno-autolink");
4723
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00004724 // Add in -fdebug-compilation-dir if necessary.
4725 addDebugCompDirArg(Args, CmdArgs);
Nick Lewyckyba743b72011-10-21 02:32:14 +00004726
Saleem Abdulrasool436256a2015-10-12 20:21:08 +00004727 for (const Arg *A : Args.filtered(options::OPT_fdebug_prefix_map_EQ)) {
4728 StringRef Map = A->getValue();
4729 if (Map.find('=') == StringRef::npos)
4730 D.Diag(diag::err_drv_invalid_argument_to_fdebug_prefix_map) << Map;
4731 else
4732 CmdArgs.push_back(Args.MakeArgString("-fdebug-prefix-map=" + Map));
4733 A->claim();
4734 }
4735
Richard Smith9a568822011-11-21 19:36:32 +00004736 if (Arg *A = Args.getLastArg(options::OPT_ftemplate_depth_,
4737 options::OPT_ftemplate_depth_EQ)) {
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004738 CmdArgs.push_back("-ftemplate-depth");
Richard Smithbd55daf2012-11-01 04:30:05 +00004739 CmdArgs.push_back(A->getValue());
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004740 }
4741
Richard Smith79c927b2013-11-06 19:31:51 +00004742 if (Arg *A = Args.getLastArg(options::OPT_foperator_arrow_depth_EQ)) {
4743 CmdArgs.push_back("-foperator-arrow-depth");
4744 CmdArgs.push_back(A->getValue());
4745 }
4746
Richard Smith9a568822011-11-21 19:36:32 +00004747 if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_depth_EQ)) {
4748 CmdArgs.push_back("-fconstexpr-depth");
Richard Smithbd55daf2012-11-01 04:30:05 +00004749 CmdArgs.push_back(A->getValue());
Richard Smith9a568822011-11-21 19:36:32 +00004750 }
4751
Richard Smitha3d3bd22013-05-08 02:12:03 +00004752 if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_steps_EQ)) {
4753 CmdArgs.push_back("-fconstexpr-steps");
4754 CmdArgs.push_back(A->getValue());
4755 }
4756
Richard Smithb3a14522013-02-22 01:59:51 +00004757 if (Arg *A = Args.getLastArg(options::OPT_fbracket_depth_EQ)) {
4758 CmdArgs.push_back("-fbracket-depth");
4759 CmdArgs.push_back(A->getValue());
4760 }
4761
Argyrios Kyrtzidisef6c8da2010-11-18 00:20:36 +00004762 if (Arg *A = Args.getLastArg(options::OPT_Wlarge_by_value_copy_EQ,
4763 options::OPT_Wlarge_by_value_copy_def)) {
Jean-Daniel Dupas73d801c2012-05-04 08:08:37 +00004764 if (A->getNumValues()) {
Richard Smithbd55daf2012-11-01 04:30:05 +00004765 StringRef bytes = A->getValue();
Jean-Daniel Dupas73d801c2012-05-04 08:08:37 +00004766 CmdArgs.push_back(Args.MakeArgString("-Wlarge-by-value-copy=" + bytes));
4767 } else
4768 CmdArgs.push_back("-Wlarge-by-value-copy=64"); // default value
Argyrios Kyrtzidisaf84ec02010-11-17 23:11:54 +00004769 }
4770
Michael J. Spencer929fccd2012-10-22 22:13:48 +00004771 if (Args.hasArg(options::OPT_relocatable_pch))
Daniel Dunbar8bed86c2009-11-20 22:21:36 +00004772 CmdArgs.push_back("-relocatable-pch");
Mike Stump11289f42009-09-09 15:08:12 +00004773
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004774 if (Arg *A = Args.getLastArg(options::OPT_fconstant_string_class_EQ)) {
4775 CmdArgs.push_back("-fconstant-string-class");
Richard Smithbd55daf2012-11-01 04:30:05 +00004776 CmdArgs.push_back(A->getValue());
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004777 }
David Chisnall5778fce2009-08-31 16:41:57 +00004778
Chris Lattnere23003d2010-01-09 21:54:33 +00004779 if (Arg *A = Args.getLastArg(options::OPT_ftabstop_EQ)) {
4780 CmdArgs.push_back("-ftabstop");
Richard Smithbd55daf2012-11-01 04:30:05 +00004781 CmdArgs.push_back(A->getValue());
Chris Lattnere23003d2010-01-09 21:54:33 +00004782 }
4783
Chris Lattnerb35583d2010-04-07 20:49:23 +00004784 CmdArgs.push_back("-ferror-limit");
4785 if (Arg *A = Args.getLastArg(options::OPT_ferror_limit_EQ))
Richard Smithbd55daf2012-11-01 04:30:05 +00004786 CmdArgs.push_back(A->getValue());
Chris Lattnerb35583d2010-04-07 20:49:23 +00004787 else
4788 CmdArgs.push_back("19");
Douglas Gregorffed1cb2010-04-20 07:18:24 +00004789
Chandler Carrutha77a7272010-05-06 04:55:18 +00004790 if (Arg *A = Args.getLastArg(options::OPT_fmacro_backtrace_limit_EQ)) {
4791 CmdArgs.push_back("-fmacro-backtrace-limit");
Richard Smithbd55daf2012-11-01 04:30:05 +00004792 CmdArgs.push_back(A->getValue());
Chandler Carrutha77a7272010-05-06 04:55:18 +00004793 }
4794
4795 if (Arg *A = Args.getLastArg(options::OPT_ftemplate_backtrace_limit_EQ)) {
4796 CmdArgs.push_back("-ftemplate-backtrace-limit");
Richard Smithbd55daf2012-11-01 04:30:05 +00004797 CmdArgs.push_back(A->getValue());
Chandler Carrutha77a7272010-05-06 04:55:18 +00004798 }
4799
Richard Smithf6f003a2011-12-16 19:06:07 +00004800 if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_backtrace_limit_EQ)) {
4801 CmdArgs.push_back("-fconstexpr-backtrace-limit");
Richard Smithbd55daf2012-11-01 04:30:05 +00004802 CmdArgs.push_back(A->getValue());
Richard Smithf6f003a2011-12-16 19:06:07 +00004803 }
4804
Nick Lewycky24653262014-12-16 21:39:02 +00004805 if (Arg *A = Args.getLastArg(options::OPT_fspell_checking_limit_EQ)) {
4806 CmdArgs.push_back("-fspell-checking-limit");
4807 CmdArgs.push_back(A->getValue());
4808 }
4809
Daniel Dunbar2c978472009-11-04 06:24:47 +00004810 // Pass -fmessage-length=.
Daniel Dunbar84bb7932009-11-30 08:40:54 +00004811 CmdArgs.push_back("-fmessage-length");
Daniel Dunbar2c978472009-11-04 06:24:47 +00004812 if (Arg *A = Args.getLastArg(options::OPT_fmessage_length_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00004813 CmdArgs.push_back(A->getValue());
Daniel Dunbar2c978472009-11-04 06:24:47 +00004814 } else {
4815 // If -fmessage-length=N was not specified, determine whether this is a
4816 // terminal and, if so, implicitly define -fmessage-length appropriately.
4817 unsigned N = llvm::sys::Process::StandardErrColumns();
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004818 CmdArgs.push_back(Args.MakeArgString(Twine(N)));
Daniel Dunbar2c978472009-11-04 06:24:47 +00004819 }
4820
John McCallb4a99d32013-02-19 01:57:35 +00004821 // -fvisibility= and -fvisibility-ms-compat are of a piece.
4822 if (const Arg *A = Args.getLastArg(options::OPT_fvisibility_EQ,
4823 options::OPT_fvisibility_ms_compat)) {
4824 if (A->getOption().matches(options::OPT_fvisibility_EQ)) {
4825 CmdArgs.push_back("-fvisibility");
4826 CmdArgs.push_back(A->getValue());
4827 } else {
4828 assert(A->getOption().matches(options::OPT_fvisibility_ms_compat));
4829 CmdArgs.push_back("-fvisibility");
4830 CmdArgs.push_back("hidden");
4831 CmdArgs.push_back("-ftype-visibility");
4832 CmdArgs.push_back("default");
4833 }
Daniel Dunbare357d562009-12-03 18:42:11 +00004834 }
4835
Douglas Gregor08329632010-06-15 17:05:35 +00004836 Args.AddLastArg(CmdArgs, options::OPT_fvisibility_inlines_hidden);
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00004837
Hans Wennborgf60f6af2012-06-28 08:01:44 +00004838 Args.AddLastArg(CmdArgs, options::OPT_ftlsmodel_EQ);
4839
Daniel Dunbare46b52a2010-03-20 04:52:14 +00004840 // -fhosted is default.
Chad Rosier4fab82c2012-03-26 22:04:46 +00004841 if (Args.hasFlag(options::OPT_ffreestanding, options::OPT_fhosted, false) ||
4842 KernelOrKext)
Daniel Dunbare46b52a2010-03-20 04:52:14 +00004843 CmdArgs.push_back("-ffreestanding");
4844
Daniel Dunbare357d562009-12-03 18:42:11 +00004845 // Forward -f (flag) options which we can pass directly.
Daniel Dunbar3a148f22009-04-07 21:51:40 +00004846 Args.AddLastArg(CmdArgs, options::OPT_femit_all_decls);
Daniel Dunbar3a148f22009-04-07 21:51:40 +00004847 Args.AddLastArg(CmdArgs, options::OPT_fheinous_gnu_extensions);
Eric Christopher86050822011-10-25 07:13:06 +00004848 Args.AddLastArg(CmdArgs, options::OPT_fno_operator_names);
Chih-Hung Hsieh2c656c92015-07-28 16:27:56 +00004849 // Emulated TLS is enabled by default on Android, and can be enabled manually
4850 // with -femulated-tls.
NAKAMURA Takumi33ff1dd2016-01-16 03:44:52 +00004851 bool EmulatedTLSDefault = Triple.isAndroid() || Triple.isWindowsCygwinEnvironment();
Chih-Hung Hsieh2c656c92015-07-28 16:27:56 +00004852 if (Args.hasFlag(options::OPT_femulated_tls, options::OPT_fno_emulated_tls,
4853 EmulatedTLSDefault))
4854 CmdArgs.push_back("-femulated-tls");
Ulrich Weigand3c5038a2015-07-30 14:08:36 +00004855 // AltiVec-like language extensions aren't relevant for assembling.
4856 if (!isa<PreprocessJobAction>(JA) || Output.getType() != types::TY_PP_Asm) {
Bill Schmidtb3b804e2013-07-03 15:36:02 +00004857 Args.AddLastArg(CmdArgs, options::OPT_faltivec);
Ulrich Weigand3c5038a2015-07-30 14:08:36 +00004858 Args.AddLastArg(CmdArgs, options::OPT_fzvector);
4859 }
Richard Trieu91844232012-06-26 18:18:47 +00004860 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_show_template_tree);
4861 Args.AddLastArg(CmdArgs, options::OPT_fno_elide_type);
Chad Rosier864dfe12012-03-13 23:45:51 +00004862
Alexey Bataevdb390212015-05-20 04:24:19 +00004863 // Forward flags for OpenMP
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00004864 if (Args.hasFlag(options::OPT_fopenmp, options::OPT_fopenmp_EQ,
4865 options::OPT_fno_openmp, false))
4866 switch (getOpenMPRuntime(getToolChain(), Args)) {
4867 case OMPRT_OMP:
4868 case OMPRT_IOMP5:
4869 // Clang can generate useful OpenMP code for these two runtime libraries.
4870 CmdArgs.push_back("-fopenmp");
Samuel Antaof8b50122015-07-13 22:54:53 +00004871
4872 // If no option regarding the use of TLS in OpenMP codegeneration is
4873 // given, decide a default based on the target. Otherwise rely on the
4874 // options and pass the right information to the frontend.
4875 if (!Args.hasFlag(options::OPT_fopenmp_use_tls,
Alexey Bataev6a43c002015-09-10 12:06:58 +00004876 options::OPT_fnoopenmp_use_tls, /*Default=*/true))
Samuel Antaof8b50122015-07-13 22:54:53 +00004877 CmdArgs.push_back("-fnoopenmp-use-tls");
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00004878 break;
4879 default:
4880 // By default, if Clang doesn't know how to generate useful OpenMP code
4881 // for a specific runtime library, we just don't pass the '-fopenmp' flag
4882 // down to the actual compilation.
4883 // FIXME: It would be better to have a mode which *only* omits IR
4884 // generation based on the OpenMP support so that we get consistent
4885 // semantic analysis, etc.
4886 break;
4887 }
Alexey Bataevdb390212015-05-20 04:24:19 +00004888
Peter Collingbourne32701642013-11-01 18:16:25 +00004889 const SanitizerArgs &Sanitize = getToolChain().getSanitizerArgs();
Peter Collingbourne581f4382015-07-02 01:48:12 +00004890 Sanitize.addArgs(getToolChain(), Args, CmdArgs, InputType);
Richard Smith52be6192012-11-05 22:04:41 +00004891
Eric Christopher459d2712013-02-19 06:16:53 +00004892 // Report an error for -faltivec on anything other than PowerPC.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00004893 if (const Arg *A = Args.getLastArg(options::OPT_faltivec)) {
4894 const llvm::Triple::ArchType Arch = getToolChain().getArch();
4895 if (!(Arch == llvm::Triple::ppc || Arch == llvm::Triple::ppc64 ||
4896 Arch == llvm::Triple::ppc64le))
4897 D.Diag(diag::err_drv_argument_only_allowed_with) << A->getAsString(Args)
4898 << "ppc/ppc64/ppc64le";
4899 }
Chad Rosier864dfe12012-03-13 23:45:51 +00004900
Ulrich Weigand3c5038a2015-07-30 14:08:36 +00004901 // -fzvector is incompatible with -faltivec.
4902 if (Arg *A = Args.getLastArg(options::OPT_fzvector))
4903 if (Args.hasArg(options::OPT_faltivec))
4904 D.Diag(diag::err_drv_argument_not_allowed_with) << A->getAsString(Args)
4905 << "-faltivec";
4906
Daniel Dunbar733b0f82011-03-01 18:49:30 +00004907 if (getToolChain().SupportsProfiling())
4908 Args.AddLastArg(CmdArgs, options::OPT_pg);
Daniel Dunbar35621a92010-03-16 16:57:46 +00004909
4910 // -flax-vector-conversions is default.
4911 if (!Args.hasFlag(options::OPT_flax_vector_conversions,
4912 options::OPT_fno_lax_vector_conversions))
4913 CmdArgs.push_back("-fno-lax-vector-conversions");
4914
John Brawna7b4ec02015-08-10 11:11:28 +00004915 if (Args.getLastArg(options::OPT_fapple_kext) ||
4916 (Args.hasArg(options::OPT_mkernel) && types::isCXX(InputType)))
Fariborz Jahaniana4cfff82011-01-07 01:05:02 +00004917 CmdArgs.push_back("-fapple-kext");
4918
Fariborz Jahaniana4404f22009-05-22 20:17:16 +00004919 Args.AddLastArg(CmdArgs, options::OPT_fobjc_sender_dependent_dispatch);
Chris Lattner69686412009-04-21 05:34:31 +00004920 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_print_source_range_info);
Douglas Gregoreec975c2010-08-19 20:24:43 +00004921 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_parseable_fixits);
Daniel Dunbar3a148f22009-04-07 21:51:40 +00004922 Args.AddLastArg(CmdArgs, options::OPT_ftime_report);
4923 Args.AddLastArg(CmdArgs, options::OPT_ftrapv);
David Chisnalldd84ef12010-09-17 18:29:54 +00004924
4925 if (Arg *A = Args.getLastArg(options::OPT_ftrapv_handler_EQ)) {
4926 CmdArgs.push_back("-ftrapv-handler");
Richard Smithbd55daf2012-11-01 04:30:05 +00004927 CmdArgs.push_back(A->getValue());
David Chisnalldd84ef12010-09-17 18:29:54 +00004928 }
4929
Bob Wilson14adb362012-02-03 06:27:22 +00004930 Args.AddLastArg(CmdArgs, options::OPT_ftrap_function_EQ);
Evan Cheng04c94292011-04-08 21:37:45 +00004931
Chandler Carruth6e501032011-03-27 00:04:55 +00004932 // -fno-strict-overflow implies -fwrapv if it isn't disabled, but
4933 // -fstrict-overflow won't turn off an explicitly enabled -fwrapv.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004934 if (Arg *A = Args.getLastArg(options::OPT_fwrapv, options::OPT_fno_wrapv)) {
Chandler Carruth6e501032011-03-27 00:04:55 +00004935 if (A->getOption().matches(options::OPT_fwrapv))
4936 CmdArgs.push_back("-fwrapv");
4937 } else if (Arg *A = Args.getLastArg(options::OPT_fstrict_overflow,
4938 options::OPT_fno_strict_overflow)) {
4939 if (A->getOption().matches(options::OPT_fno_strict_overflow))
4940 CmdArgs.push_back("-fwrapv");
4941 }
Hal Finkelce0697f2013-11-17 16:03:29 +00004942
4943 if (Arg *A = Args.getLastArg(options::OPT_freroll_loops,
4944 options::OPT_fno_reroll_loops))
4945 if (A->getOption().matches(options::OPT_freroll_loops))
4946 CmdArgs.push_back("-freroll-loops");
4947
Daniel Dunbar3a148f22009-04-07 21:51:40 +00004948 Args.AddLastArg(CmdArgs, options::OPT_fwritable_strings);
Chandler Carruth54c29102013-08-08 08:34:35 +00004949 Args.AddLastArg(CmdArgs, options::OPT_funroll_loops,
4950 options::OPT_fno_unroll_loops);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004951
Daniel Dunbara77eaeb2009-09-03 04:54:28 +00004952 Args.AddLastArg(CmdArgs, options::OPT_pthread);
4953
Daniel Dunbar4930e332009-11-17 08:07:36 +00004954 // -stack-protector=0 is default.
4955 unsigned StackProtectorLevel = 0;
Evgeniy Stepanov368d3072016-04-11 22:27:55 +00004956 if (Arg *A = Args.getLastArg(options::OPT_fno_stack_protector,
4957 options::OPT_fstack_protector_all,
4958 options::OPT_fstack_protector_strong,
4959 options::OPT_fstack_protector)) {
Rafael Espindolace5c6092014-05-22 22:57:39 +00004960 if (A->getOption().matches(options::OPT_fstack_protector)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004961 StackProtectorLevel = std::max<unsigned>(
4962 LangOptions::SSPOn,
4963 getToolChain().GetDefaultStackProtectorLevel(KernelOrKext));
Rafael Espindolace5c6092014-05-22 22:57:39 +00004964 } else if (A->getOption().matches(options::OPT_fstack_protector_strong))
Josh Mageee0fc1a82014-02-11 01:35:14 +00004965 StackProtectorLevel = LangOptions::SSPStrong;
Daniel Dunbar4930e332009-11-17 08:07:36 +00004966 else if (A->getOption().matches(options::OPT_fstack_protector_all))
Josh Mageee0fc1a82014-02-11 01:35:14 +00004967 StackProtectorLevel = LangOptions::SSPReq;
Nico Weberdd473632011-08-23 07:38:27 +00004968 } else {
4969 StackProtectorLevel =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004970 getToolChain().GetDefaultStackProtectorLevel(KernelOrKext);
Nico Weberdd473632011-08-23 07:38:27 +00004971 }
Daniel Dunbar4930e332009-11-17 08:07:36 +00004972 if (StackProtectorLevel) {
4973 CmdArgs.push_back("-stack-protector");
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004974 CmdArgs.push_back(Args.MakeArgString(Twine(StackProtectorLevel)));
Joerg Sonnenberger85e2bbc2012-09-12 13:51:14 +00004975 }
Chad Rosierdb3da832012-08-21 16:16:06 +00004976
Joerg Sonnenberger85e2bbc2012-09-12 13:51:14 +00004977 // --param ssp-buffer-size=
Sean Silva14facf32015-06-09 01:57:17 +00004978 for (const Arg *A : Args.filtered(options::OPT__param)) {
4979 StringRef Str(A->getValue());
Joerg Sonnenberger85e2bbc2012-09-12 13:51:14 +00004980 if (Str.startswith("ssp-buffer-size=")) {
4981 if (StackProtectorLevel) {
Chad Rosierdb3da832012-08-21 16:16:06 +00004982 CmdArgs.push_back("-stack-protector-buffer-size");
4983 // FIXME: Verify the argument is a valid integer.
4984 CmdArgs.push_back(Args.MakeArgString(Str.drop_front(16)));
Chad Rosierdb3da832012-08-21 16:16:06 +00004985 }
Sean Silva14facf32015-06-09 01:57:17 +00004986 A->claim();
Chad Rosierdb3da832012-08-21 16:16:06 +00004987 }
Bill Wendlingd63bbad2009-06-28 07:36:13 +00004988 }
4989
Nick Lewyckyf4d3f7a2011-12-06 03:33:03 +00004990 // Translate -mstackrealign
4991 if (Args.hasFlag(options::OPT_mstackrealign, options::OPT_mno_stackrealign,
Akira Hatanakaaecca042015-09-11 18:55:09 +00004992 false))
Nick Lewyckyf4d3f7a2011-12-06 03:33:03 +00004993 CmdArgs.push_back(Args.MakeArgString("-mstackrealign"));
Nick Lewyckyf4d3f7a2011-12-06 03:33:03 +00004994
Joerg Sonnenbergerdb66ed02011-12-05 23:05:23 +00004995 if (Args.hasArg(options::OPT_mstack_alignment)) {
4996 StringRef alignment = Args.getLastArgValue(options::OPT_mstack_alignment);
4997 CmdArgs.push_back(Args.MakeArgString("-mstack-alignment=" + alignment));
Eric Christopherd5c45f62011-05-02 21:18:22 +00004998 }
Eric Christopher84fbdb42011-08-19 00:30:14 +00004999
Hans Wennborg77dc2362015-01-20 19:45:50 +00005000 if (Args.hasArg(options::OPT_mstack_probe_size)) {
5001 StringRef Size = Args.getLastArgValue(options::OPT_mstack_probe_size);
5002
5003 if (!Size.empty())
5004 CmdArgs.push_back(Args.MakeArgString("-mstack-probe-size=" + Size));
5005 else
5006 CmdArgs.push_back("-mstack-probe-size=0");
5007 }
5008
Oliver Stannarddc2854c2015-09-03 12:40:58 +00005009 switch (getToolChain().getArch()) {
5010 case llvm::Triple::aarch64:
5011 case llvm::Triple::aarch64_be:
5012 case llvm::Triple::arm:
5013 case llvm::Triple::armeb:
5014 case llvm::Triple::thumb:
5015 case llvm::Triple::thumbeb:
Oliver Stannarded8ecc82014-08-27 16:31:57 +00005016 CmdArgs.push_back("-fallow-half-arguments-and-returns");
Oliver Stannarddc2854c2015-09-03 12:40:58 +00005017 break;
5018
5019 default:
5020 break;
5021 }
Oliver Stannarded8ecc82014-08-27 16:31:57 +00005022
Weiming Zhao580dcfb2013-11-13 18:31:23 +00005023 if (Arg *A = Args.getLastArg(options::OPT_mrestrict_it,
5024 options::OPT_mno_restrict_it)) {
5025 if (A->getOption().matches(options::OPT_mrestrict_it)) {
5026 CmdArgs.push_back("-backend-option");
5027 CmdArgs.push_back("-arm-restrict-it");
5028 } else {
5029 CmdArgs.push_back("-backend-option");
5030 CmdArgs.push_back("-arm-no-restrict-it");
5031 }
James Y Knight2db38f32015-08-15 03:45:25 +00005032 } else if (Triple.isOSWindows() &&
5033 (Triple.getArch() == llvm::Triple::arm ||
5034 Triple.getArch() == llvm::Triple::thumb)) {
Saleem Abdulrasool6deb8162014-05-18 06:42:02 +00005035 // Windows on ARM expects restricted IT blocks
5036 CmdArgs.push_back("-backend-option");
5037 CmdArgs.push_back("-arm-restrict-it");
Weiming Zhao580dcfb2013-11-13 18:31:23 +00005038 }
5039
Daniel Dunbard18049a2009-04-07 21:16:11 +00005040 // Forward -f options with positive and negative forms; we translate
5041 // these by hand.
Diego Novillo5c297052013-11-13 12:22:39 +00005042 if (Arg *A = Args.getLastArg(options::OPT_fprofile_sample_use_EQ)) {
5043 StringRef fname = A->getValue();
5044 if (!llvm::sys::fs::exists(fname))
5045 D.Diag(diag::err_drv_no_such_file) << fname;
5046 else
5047 A->render(Args, CmdArgs);
5048 }
Daniel Dunbard18049a2009-04-07 21:16:11 +00005049
Chad Rosier7dbc9cf2016-01-06 14:35:46 +00005050 // -fbuiltin is default unless -mkernel is used.
5051 bool UseBuiltins =
5052 Args.hasFlag(options::OPT_fbuiltin, options::OPT_fno_builtin,
5053 !Args.hasArg(options::OPT_mkernel));
5054 if (!UseBuiltins)
Daniel Dunbar484afa22009-11-19 04:55:23 +00005055 CmdArgs.push_back("-fno-builtin");
Daniel Dunbard18049a2009-04-07 21:16:11 +00005056
Chad Rosier7dbc9cf2016-01-06 14:35:46 +00005057 // -ffreestanding implies -fno-builtin.
5058 if (Args.hasArg(options::OPT_ffreestanding))
5059 UseBuiltins = false;
5060
5061 // Process the -fno-builtin-* options.
5062 for (const auto &Arg : Args) {
5063 const Option &O = Arg->getOption();
5064 if (!O.matches(options::OPT_fno_builtin_))
5065 continue;
5066
5067 Arg->claim();
5068 // If -fno-builtin is specified, then there's no need to pass the option to
5069 // the frontend.
5070 if (!UseBuiltins)
5071 continue;
5072
5073 StringRef FuncName = Arg->getValue();
5074 CmdArgs.push_back(Args.MakeArgString("-fno-builtin-" + FuncName));
5075 }
5076
Nuno Lopes13c88c72009-12-16 16:59:22 +00005077 if (!Args.hasFlag(options::OPT_fassume_sane_operator_new,
5078 options::OPT_fno_assume_sane_operator_new))
5079 CmdArgs.push_back("-fno-assume-sane-operator-new");
5080
Daniel Dunbar4930e332009-11-17 08:07:36 +00005081 // -fblocks=0 is default.
5082 if (Args.hasFlag(options::OPT_fblocks, options::OPT_fno_blocks,
David Chisnallda209912011-02-28 17:11:43 +00005083 getToolChain().IsBlocksDefault()) ||
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005084 (Args.hasArg(options::OPT_fgnu_runtime) &&
5085 Args.hasArg(options::OPT_fobjc_nonfragile_abi) &&
5086 !Args.hasArg(options::OPT_fno_blocks))) {
Daniel Dunbar4930e332009-11-17 08:07:36 +00005087 CmdArgs.push_back("-fblocks");
John McCall7959fee2011-09-09 20:41:01 +00005088
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005089 if (!Args.hasArg(options::OPT_fgnu_runtime) &&
John McCall7959fee2011-09-09 20:41:01 +00005090 !getToolChain().hasBlocksRuntime())
5091 CmdArgs.push_back("-fblocks-runtime-optional");
David Chisnall950a9512009-11-17 19:33:30 +00005092 }
Daniel Dunbard18049a2009-04-07 21:16:11 +00005093
Richard Smith47972af2015-06-16 00:08:24 +00005094 // -fmodules enables the use of precompiled modules (off by default).
Richard Smithffb65082014-09-30 23:10:19 +00005095 // Users can pass -fno-cxx-modules to turn off modules support for
Richard Smith47972af2015-06-16 00:08:24 +00005096 // C++/Objective-C++ programs.
Douglas Gregorc60437f2013-01-16 01:23:41 +00005097 bool HaveModules = false;
Douglas Gregor226173a2012-01-18 15:19:58 +00005098 if (Args.hasFlag(options::OPT_fmodules, options::OPT_fno_modules, false)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005099 bool AllowedInCXX = Args.hasFlag(options::OPT_fcxx_modules,
5100 options::OPT_fno_cxx_modules, true);
Douglas Gregorc60437f2013-01-16 01:23:41 +00005101 if (AllowedInCXX || !types::isCXX(InputType)) {
Douglas Gregor226173a2012-01-18 15:19:58 +00005102 CmdArgs.push_back("-fmodules");
Douglas Gregorc60437f2013-01-16 01:23:41 +00005103 HaveModules = true;
5104 }
5105 }
5106
Richard Smith47972af2015-06-16 00:08:24 +00005107 // -fmodule-maps enables implicit reading of module map files. By default,
5108 // this is enabled if we are using precompiled modules.
Richard Smithcf18b792015-06-16 00:20:23 +00005109 if (Args.hasFlag(options::OPT_fimplicit_module_maps,
5110 options::OPT_fno_implicit_module_maps, HaveModules)) {
Richard Smith47972af2015-06-16 00:08:24 +00005111 CmdArgs.push_back("-fimplicit-module-maps");
Daniel Jasper07e6c402013-08-05 20:26:17 +00005112 }
5113
Daniel Jasperac42b752013-10-21 06:34:34 +00005114 // -fmodules-decluse checks that modules used are declared so (off by
5115 // default).
Daniel Jasperba7f2f72013-09-24 09:14:14 +00005116 if (Args.hasFlag(options::OPT_fmodules_decluse,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005117 options::OPT_fno_modules_decluse, false)) {
Daniel Jasper6e16d542013-09-29 12:40:54 +00005118 CmdArgs.push_back("-fmodules-decluse");
Daniel Jasperba7f2f72013-09-24 09:14:14 +00005119 }
5120
Daniel Jasper962b38e2014-04-11 11:47:45 +00005121 // -fmodules-strict-decluse is like -fmodule-decluse, but also checks that
5122 // all #included headers are part of modules.
5123 if (Args.hasFlag(options::OPT_fmodules_strict_decluse,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005124 options::OPT_fno_modules_strict_decluse, false)) {
Daniel Jasper962b38e2014-04-11 11:47:45 +00005125 CmdArgs.push_back("-fmodules-strict-decluse");
5126 }
5127
Manuel Klimekd2e8b042015-02-20 11:44:41 +00005128 // -fno-implicit-modules turns off implicitly compiling modules on demand.
5129 if (!Args.hasFlag(options::OPT_fimplicit_modules,
5130 options::OPT_fno_implicit_modules)) {
5131 CmdArgs.push_back("-fno-implicit-modules");
Richard Smith8d83d6d2016-03-21 19:06:06 +00005132 } else if (HaveModules) {
5133 // -fmodule-cache-path specifies where our implicitly-built module files
5134 // should be written.
5135 SmallString<128> Path;
5136 if (Arg *A = Args.getLastArg(options::OPT_fmodules_cache_path))
5137 Path = A->getValue();
Justin Bognera88f0122014-06-20 22:59:50 +00005138 if (C.isForDiagnostics()) {
5139 // When generating crash reports, we want to emit the modules along with
5140 // the reproduction sources, so we ignore any provided module path.
Daniel Jasper7450f912015-07-10 08:25:54 +00005141 Path = Output.getFilename();
5142 llvm::sys::path::replace_extension(Path, ".cache");
5143 llvm::sys::path::append(Path, "modules");
5144 } else if (Path.empty()) {
Justin Bognera88f0122014-06-20 22:59:50 +00005145 // No module path was provided: use the default.
Renato Golin7c542b42015-07-27 23:44:45 +00005146 llvm::sys::path::system_temp_directory(/*erasedOnReboot=*/false, Path);
Daniel Jasper7450f912015-07-10 08:25:54 +00005147 llvm::sys::path::append(Path, "org.llvm.clang.");
5148 appendUserToPath(Path);
5149 llvm::sys::path::append(Path, "ModuleCache");
Justin Bognera88f0122014-06-20 22:59:50 +00005150 }
Douglas Gregor4bedb492013-02-07 22:59:12 +00005151 const char Arg[] = "-fmodules-cache-path=";
Daniel Jasper7450f912015-07-10 08:25:54 +00005152 Path.insert(Path.begin(), Arg, Arg + strlen(Arg));
5153 CmdArgs.push_back(Args.MakeArgString(Path));
Justin Bognera88f0122014-06-20 22:59:50 +00005154 }
5155
Richard Smith8d83d6d2016-03-21 19:06:06 +00005156 // -fmodule-name specifies the module that is currently being built (or
5157 // used for header checking by -fmodule-maps).
5158 Args.AddLastArg(CmdArgs, options::OPT_fmodule_name_EQ);
5159
5160 // -fmodule-map-file can be used to specify files containing module
5161 // definitions.
5162 Args.AddAllArgs(CmdArgs, options::OPT_fmodule_map_file);
5163
5164 // -fmodule-file can be used to specify files containing precompiled modules.
5165 if (HaveModules)
5166 Args.AddAllArgs(CmdArgs, options::OPT_fmodule_file);
5167 else
5168 Args.ClaimAllArgs(options::OPT_fmodule_file);
5169
Justin Bognera88f0122014-06-20 22:59:50 +00005170 // When building modules and generating crashdumps, we need to dump a module
5171 // dependency VFS alongside the output.
5172 if (HaveModules && C.isForDiagnostics()) {
5173 SmallString<128> VFSDir(Output.getFilename());
5174 llvm::sys::path::replace_extension(VFSDir, ".cache");
Justin Bogner659ecc32014-10-20 22:47:23 +00005175 // Add the cache directory as a temp so the crash diagnostics pick it up.
5176 C.addTempFile(Args.MakeArgString(VFSDir));
5177
Justin Bognera88f0122014-06-20 22:59:50 +00005178 llvm::sys::path::append(VFSDir, "vfs");
5179 CmdArgs.push_back("-module-dependency-dir");
5180 CmdArgs.push_back(Args.MakeArgString(VFSDir));
Douglas Gregor35b04d62013-02-07 19:01:24 +00005181 }
5182
Richard Smith9887d792014-10-17 01:42:53 +00005183 if (HaveModules)
5184 Args.AddLastArg(CmdArgs, options::OPT_fmodules_user_build_path);
Argyrios Kyrtzidis1594c152014-03-03 08:12:05 +00005185
Douglas Gregor35b04d62013-02-07 19:01:24 +00005186 // Pass through all -fmodules-ignore-macro arguments.
5187 Args.AddAllArgs(CmdArgs, options::OPT_fmodules_ignore_macro);
Douglas Gregor527b1c92013-03-25 21:19:16 +00005188 Args.AddLastArg(CmdArgs, options::OPT_fmodules_prune_interval);
5189 Args.AddLastArg(CmdArgs, options::OPT_fmodules_prune_after);
Douglas Gregor35b04d62013-02-07 19:01:24 +00005190
Dmitri Gribenkof430da42014-02-12 10:33:14 +00005191 Args.AddLastArg(CmdArgs, options::OPT_fbuild_session_timestamp);
5192
Ben Langmuir19e6acb2014-08-01 22:12:21 +00005193 if (Arg *A = Args.getLastArg(options::OPT_fbuild_session_file)) {
5194 if (Args.hasArg(options::OPT_fbuild_session_timestamp))
5195 D.Diag(diag::err_drv_argument_not_allowed_with)
5196 << A->getAsString(Args) << "-fbuild-session-timestamp";
5197
5198 llvm::sys::fs::file_status Status;
5199 if (llvm::sys::fs::status(A->getValue(), Status))
5200 D.Diag(diag::err_drv_no_such_file) << A->getValue();
Benjamin Kramer320fc262015-02-14 18:19:55 +00005201 CmdArgs.push_back(Args.MakeArgString(
5202 "-fbuild-session-timestamp=" +
5203 Twine((uint64_t)Status.getLastModificationTime().toEpochTime())));
Ben Langmuir19e6acb2014-08-01 22:12:21 +00005204 }
5205
Dmitri Gribenkof430da42014-02-12 10:33:14 +00005206 if (Args.getLastArg(options::OPT_fmodules_validate_once_per_build_session)) {
Ben Langmuir19e6acb2014-08-01 22:12:21 +00005207 if (!Args.getLastArg(options::OPT_fbuild_session_timestamp,
5208 options::OPT_fbuild_session_file))
Dmitri Gribenkof430da42014-02-12 10:33:14 +00005209 D.Diag(diag::err_drv_modules_validate_once_requires_timestamp);
5210
5211 Args.AddLastArg(CmdArgs,
5212 options::OPT_fmodules_validate_once_per_build_session);
5213 }
5214
Ben Langmuirdcf73862014-03-12 00:06:17 +00005215 Args.AddLastArg(CmdArgs, options::OPT_fmodules_validate_system_headers);
5216
John McCalldfea9982010-04-09 19:12:06 +00005217 // -faccess-control is default.
John McCall3155f572010-04-09 19:03:51 +00005218 if (Args.hasFlag(options::OPT_fno_access_control,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005219 options::OPT_faccess_control, false))
John McCall3155f572010-04-09 19:03:51 +00005220 CmdArgs.push_back("-fno-access-control");
John McCall59bb1d42010-03-17 01:32:13 +00005221
Anders Carlssond470fef2010-11-21 00:09:52 +00005222 // -felide-constructors is the default.
5223 if (Args.hasFlag(options::OPT_fno_elide_constructors,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005224 options::OPT_felide_constructors, false))
Anders Carlssond470fef2010-11-21 00:09:52 +00005225 CmdArgs.push_back("-fno-elide-constructors");
5226
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00005227 ToolChain::RTTIMode RTTIMode = getToolChain().getRTTIMode();
Filipe Cabecinhas28f353c2015-01-29 23:56:43 +00005228
Filipe Cabecinhasc4732552015-03-20 23:51:15 +00005229 if (KernelOrKext || (types::isCXX(InputType) &&
5230 (RTTIMode == ToolChain::RM_DisabledExplicitly ||
5231 RTTIMode == ToolChain::RM_DisabledImplicitly)))
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00005232 CmdArgs.push_back("-fno-rtti");
Richard Smith52be6192012-11-05 22:04:41 +00005233
Tony Linthicum76329bf2011-12-12 21:14:55 +00005234 // -fshort-enums=0 is default for all architectures except Hexagon.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005235 if (Args.hasFlag(options::OPT_fshort_enums, options::OPT_fno_short_enums,
5236 getToolChain().getArch() == llvm::Triple::hexagon))
Argyrios Kyrtzidis74825bc2010-10-08 00:25:19 +00005237 CmdArgs.push_back("-fshort-enums");
5238
Daniel Dunbard609b7b2009-11-17 06:37:03 +00005239 // -fsigned-char is default.
David Majnemerc3658d22015-05-23 18:48:37 +00005240 if (Arg *A = Args.getLastArg(
5241 options::OPT_fsigned_char, options::OPT_fno_signed_char,
5242 options::OPT_funsigned_char, options::OPT_fno_unsigned_char)) {
5243 if (A->getOption().matches(options::OPT_funsigned_char) ||
5244 A->getOption().matches(options::OPT_fno_signed_char)) {
5245 CmdArgs.push_back("-fno-signed-char");
5246 }
5247 } else if (!isSignedCharDefault(getToolChain().getTriple())) {
Daniel Dunbar5fe08662009-11-29 02:39:08 +00005248 CmdArgs.push_back("-fno-signed-char");
David Majnemerc3658d22015-05-23 18:48:37 +00005249 }
Eli Friedman327f0b52009-06-05 07:21:14 +00005250
Daniel Dunbarfe06df42010-03-20 04:15:41 +00005251 // -fuse-cxa-atexit is default.
Vasileios Kalintirisc744e122015-11-12 15:26:54 +00005252 if (!Args.hasFlag(
5253 options::OPT_fuse_cxa_atexit, options::OPT_fno_use_cxa_atexit,
5254 !IsWindowsCygnus && !IsWindowsGNU &&
5255 getToolChain().getTriple().getOS() != llvm::Triple::Solaris &&
5256 getToolChain().getArch() != llvm::Triple::hexagon &&
5257 getToolChain().getArch() != llvm::Triple::xcore &&
5258 ((getToolChain().getTriple().getVendor() !=
5259 llvm::Triple::MipsTechnologies) ||
5260 getToolChain().getTriple().hasEnvironment())) ||
Chad Rosier4fab82c2012-03-26 22:04:46 +00005261 KernelOrKext)
Daniel Dunbarfe06df42010-03-20 04:15:41 +00005262 CmdArgs.push_back("-fno-use-cxa-atexit");
5263
Daniel Dunbar0730e4f2009-11-17 07:06:20 +00005264 // -fms-extensions=0 is default.
Daniel Dunbar5bdd2992009-11-25 10:14:30 +00005265 if (Args.hasFlag(options::OPT_fms_extensions, options::OPT_fno_ms_extensions,
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00005266 IsWindowsMSVC))
Daniel Dunbar0730e4f2009-11-17 07:06:20 +00005267 CmdArgs.push_back("-fms-extensions");
5268
Reid Kleckner1df0fea2015-02-26 00:17:25 +00005269 // -fno-use-line-directives is default.
5270 if (Args.hasFlag(options::OPT_fuse_line_directives,
5271 options::OPT_fno_use_line_directives, false))
5272 CmdArgs.push_back("-fuse-line-directives");
5273
Francois Pichet1b4f1632011-09-17 04:32:15 +00005274 // -fms-compatibility=0 is default.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005275 if (Args.hasFlag(options::OPT_fms_compatibility,
Douglas Gregor2b4907e2011-10-24 15:49:38 +00005276 options::OPT_fno_ms_compatibility,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005277 (IsWindowsMSVC &&
5278 Args.hasFlag(options::OPT_fms_extensions,
5279 options::OPT_fno_ms_extensions, true))))
Francois Pichet1b4f1632011-09-17 04:32:15 +00005280 CmdArgs.push_back("-fms-compatibility");
5281
David Majnemerc371ff02015-03-22 08:39:22 +00005282 // -fms-compatibility-version=18.00 is default.
David Majnemere11d3732015-06-08 00:22:46 +00005283 VersionTuple MSVT = visualstudio::getMSVCVersion(
Adrian McCarthye4b26fc2016-05-13 23:20:11 +00005284 &D, getToolChain(), getToolChain().getTriple(), Args, IsWindowsMSVC);
David Majnemere11d3732015-06-08 00:22:46 +00005285 if (!MSVT.empty())
David Majnemerc371ff02015-03-22 08:39:22 +00005286 CmdArgs.push_back(
5287 Args.MakeArgString("-fms-compatibility-version=" + MSVT.getAsString()));
Michael J. Spencer4992ca4b2010-10-21 05:21:48 +00005288
David Majnemer8db91762015-05-18 04:49:30 +00005289 bool IsMSVC2015Compatible = MSVT.getMajor() >= 19;
5290 if (ImplyVCPPCXXVer) {
5291 if (IsMSVC2015Compatible)
5292 CmdArgs.push_back("-std=c++14");
5293 else
5294 CmdArgs.push_back("-std=c++11");
5295 }
5296
Eric Christopher5ecce122013-02-18 00:38:31 +00005297 // -fno-borland-extensions is default.
Dawn Perchik68bb1b42010-09-02 23:59:25 +00005298 if (Args.hasFlag(options::OPT_fborland_extensions,
5299 options::OPT_fno_borland_extensions, false))
5300 CmdArgs.push_back("-fborland-extensions");
5301
Saleem Abdulrasoold170c4b2015-10-04 17:51:05 +00005302 // -fno-declspec is default, except for PS4.
5303 if (Args.hasFlag(options::OPT_fdeclspec, options::OPT_fno_declspec,
5304 getToolChain().getTriple().isPS4()))
5305 CmdArgs.push_back("-fdeclspec");
5306 else if (Args.hasArg(options::OPT_fno_declspec))
5307 CmdArgs.push_back("-fno-declspec"); // Explicitly disabling __declspec.
5308
David Majnemerc371ff02015-03-22 08:39:22 +00005309 // -fthreadsafe-static is default, except for MSVC compatibility versions less
5310 // than 19.
5311 if (!Args.hasFlag(options::OPT_fthreadsafe_statics,
5312 options::OPT_fno_threadsafe_statics,
David Majnemer8db91762015-05-18 04:49:30 +00005313 !IsWindowsMSVC || IsMSVC2015Compatible))
David Majnemerc371ff02015-03-22 08:39:22 +00005314 CmdArgs.push_back("-fno-threadsafe-statics");
5315
Francois Pichet02744872011-09-01 16:38:08 +00005316 // -fno-delayed-template-parsing is default, except for Windows where MSVC STL
5317 // needs it.
Francois Pichet1c229c02011-04-22 22:18:13 +00005318 if (Args.hasFlag(options::OPT_fdelayed_template_parsing,
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00005319 options::OPT_fno_delayed_template_parsing, IsWindowsMSVC))
Francois Pichet35bc5de2011-08-26 00:22:34 +00005320 CmdArgs.push_back("-fdelayed-template-parsing");
Francois Pichet1c229c02011-04-22 22:18:13 +00005321
Chandler Carruthe03aa552010-04-17 20:17:31 +00005322 // -fgnu-keywords default varies depending on language; only pass if
5323 // specified.
5324 if (Arg *A = Args.getLastArg(options::OPT_fgnu_keywords,
Daniel Dunbardb059592010-04-24 17:56:39 +00005325 options::OPT_fno_gnu_keywords))
5326 A->render(Args, CmdArgs);
Chandler Carruthe03aa552010-04-17 20:17:31 +00005327
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005328 if (Args.hasFlag(options::OPT_fgnu89_inline, options::OPT_fno_gnu89_inline,
Rafael Espindola922a6242011-06-02 17:30:53 +00005329 false))
Rafael Espindolafb2af642011-06-02 16:13:27 +00005330 CmdArgs.push_back("-fgnu89-inline");
5331
Chad Rosier9c76d242012-03-15 22:31:42 +00005332 if (Args.hasArg(options::OPT_fno_inline))
5333 CmdArgs.push_back("-fno-inline");
5334
Hans Wennborg7a008882016-05-24 20:40:51 +00005335 if (Arg* InlineArg = Args.getLastArg(options::OPT_finline_functions,
5336 options::OPT_fno_inline_functions))
5337 InlineArg->render(Args, CmdArgs);
Chad Rosier80603182012-03-06 18:49:20 +00005338
John McCall5fb5df92012-06-20 06:18:46 +00005339 ObjCRuntime objcRuntime = AddObjCRuntimeArgs(Args, CmdArgs, rewriteKind);
John McCall24fc0de2011-07-06 00:26:06 +00005340
John McCall5fb5df92012-06-20 06:18:46 +00005341 // -fobjc-dispatch-method is only relevant with the nonfragile-abi, and
Fariborz Jahanian15f60cb2014-01-20 19:32:33 +00005342 // legacy is the default. Except for deployment taget of 10.5,
5343 // next runtime is always legacy dispatch and -fno-objc-legacy-dispatch
5344 // gets ignored silently.
5345 if (objcRuntime.isNonFragile()) {
David Chisnall3154e682011-09-30 13:32:35 +00005346 if (!Args.hasFlag(options::OPT_fobjc_legacy_dispatch,
5347 options::OPT_fno_objc_legacy_dispatch,
David Chisnallda225352012-07-04 11:52:24 +00005348 objcRuntime.isLegacyDispatchDefaultForArch(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005349 getToolChain().getArch()))) {
David Chisnall3154e682011-09-30 13:32:35 +00005350 if (getToolChain().UseObjCMixedDispatch())
5351 CmdArgs.push_back("-fobjc-dispatch-method=mixed");
5352 else
5353 CmdArgs.push_back("-fobjc-dispatch-method=non-legacy");
5354 }
5355 }
Rafael Espindolab44676c2013-11-12 04:33:56 +00005356
Fariborz Jahanianfd4ce192013-11-12 17:08:46 +00005357 // When ObjectiveC legacy runtime is in effect on MacOSX,
5358 // turn on the option to do Array/Dictionary subscripting
5359 // by default.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00005360 if (getToolChain().getArch() == llvm::Triple::x86 &&
Fariborz Jahanianff6c97c2013-11-12 20:50:26 +00005361 getToolChain().getTriple().isMacOSX() &&
5362 !getToolChain().getTriple().isMacOSXVersionLT(10, 7) &&
5363 objcRuntime.getKind() == ObjCRuntime::FragileMacOSX &&
Fariborz Jahanianfd4ce192013-11-12 17:08:46 +00005364 objcRuntime.isNeXTFamily())
5365 CmdArgs.push_back("-fobjc-subscripting-legacy-runtime");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005366
Fariborz Jahanian0e3043b2012-11-15 19:02:45 +00005367 // -fencode-extended-block-signature=1 is default.
5368 if (getToolChain().IsEncodeExtendedBlockSignatureDefault()) {
5369 CmdArgs.push_back("-fencode-extended-block-signature");
5370 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005371
John McCall24fc0de2011-07-06 00:26:06 +00005372 // Allow -fno-objc-arr to trump -fobjc-arr/-fobjc-arc.
5373 // NOTE: This logic is duplicated in ToolChains.cpp.
5374 bool ARC = isObjCAutoRefCount(Args);
5375 if (ARC) {
John McCall3deb1ad2012-08-21 02:47:43 +00005376 getToolChain().CheckObjCARC();
Argyrios Kyrtzidis3dbeb552012-02-29 03:43:52 +00005377
John McCall24fc0de2011-07-06 00:26:06 +00005378 CmdArgs.push_back("-fobjc-arc");
5379
Chandler Carruth491db322011-11-04 07:34:47 +00005380 // FIXME: It seems like this entire block, and several around it should be
5381 // wrapped in isObjC, but for now we just use it here as this is where it
5382 // was being used previously.
5383 if (types::isCXX(InputType) && types::isObjC(InputType)) {
5384 if (getToolChain().GetCXXStdlibType(Args) == ToolChain::CST_Libcxx)
5385 CmdArgs.push_back("-fobjc-arc-cxxlib=libc++");
5386 else
5387 CmdArgs.push_back("-fobjc-arc-cxxlib=libstdc++");
5388 }
5389
John McCall24fc0de2011-07-06 00:26:06 +00005390 // Allow the user to enable full exceptions code emission.
5391 // We define off for Objective-CC, on for Objective-C++.
5392 if (Args.hasFlag(options::OPT_fobjc_arc_exceptions,
5393 options::OPT_fno_objc_arc_exceptions,
5394 /*default*/ types::isCXX(InputType)))
5395 CmdArgs.push_back("-fobjc-arc-exceptions");
John McCall460ce582015-10-22 18:38:17 +00005396
John McCall24fc0de2011-07-06 00:26:06 +00005397 }
5398
5399 // -fobjc-infer-related-result-type is the default, except in the Objective-C
5400 // rewriter.
John McCall5fb5df92012-06-20 06:18:46 +00005401 if (rewriteKind != RK_None)
John McCall24fc0de2011-07-06 00:26:06 +00005402 CmdArgs.push_back("-fno-objc-infer-related-result-type");
Eric Christopher84fbdb42011-08-19 00:30:14 +00005403
John McCall24fc0de2011-07-06 00:26:06 +00005404 // Handle -fobjc-gc and -fobjc-gc-only. They are exclusive, and -fobjc-gc-only
5405 // takes precedence.
5406 const Arg *GCArg = Args.getLastArg(options::OPT_fobjc_gc_only);
5407 if (!GCArg)
5408 GCArg = Args.getLastArg(options::OPT_fobjc_gc);
5409 if (GCArg) {
5410 if (ARC) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005411 D.Diag(diag::err_drv_objc_gc_arr) << GCArg->getAsString(Args);
John McCall24fc0de2011-07-06 00:26:06 +00005412 } else if (getToolChain().SupportsObjCGC()) {
5413 GCArg->render(Args, CmdArgs);
5414 } else {
5415 // FIXME: We should move this to a hard error.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005416 D.Diag(diag::warn_drv_objc_gc_unsupported) << GCArg->getAsString(Args);
John McCall24fc0de2011-07-06 00:26:06 +00005417 }
5418 }
5419
John McCallfbe5ed72015-11-05 19:19:56 +00005420 // Pass down -fobjc-weak or -fno-objc-weak if present.
5421 if (types::isObjC(InputType)) {
5422 auto WeakArg = Args.getLastArg(options::OPT_fobjc_weak,
5423 options::OPT_fno_objc_weak);
5424 if (!WeakArg) {
5425 // nothing to do
5426 } else if (GCArg) {
5427 if (WeakArg->getOption().matches(options::OPT_fobjc_weak))
5428 D.Diag(diag::err_objc_weak_with_gc);
5429 } else if (!objcRuntime.allowsWeak()) {
5430 if (WeakArg->getOption().matches(options::OPT_fobjc_weak))
5431 D.Diag(diag::err_objc_weak_unsupported);
5432 } else {
5433 WeakArg->render(Args, CmdArgs);
5434 }
5435 }
5436
Bob Wilsonb111ec92015-03-02 19:01:14 +00005437 if (Args.hasFlag(options::OPT_fapplication_extension,
5438 options::OPT_fno_application_extension, false))
5439 CmdArgs.push_back("-fapplication-extension");
5440
Reid Klecknerc542d372014-06-27 17:02:02 +00005441 // Handle GCC-style exception args.
5442 if (!C.getDriver().IsCLMode())
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005443 addExceptionArgs(Args, InputType, getToolChain(), KernelOrKext, objcRuntime,
5444 CmdArgs);
John McCallb5f652e2011-06-22 00:53:57 +00005445
Tim Northovere931f9f2015-10-30 16:30:41 +00005446 if (getToolChain().UseSjLjExceptions(Args))
John McCallb5f652e2011-06-22 00:53:57 +00005447 CmdArgs.push_back("-fsjlj-exceptions");
5448
5449 // C++ "sane" operator new.
Daniel Dunbar2e3f2c82010-02-01 21:07:25 +00005450 if (!Args.hasFlag(options::OPT_fassume_sane_operator_new,
5451 options::OPT_fno_assume_sane_operator_new))
5452 CmdArgs.push_back("-fno-assume-sane-operator-new");
5453
Reid Kleckner7ffc3fb2015-03-20 00:31:07 +00005454 // -fsized-deallocation is off by default, as it is an ABI-breaking change for
5455 // most platforms.
5456 if (Args.hasFlag(options::OPT_fsized_deallocation,
5457 options::OPT_fno_sized_deallocation, false))
5458 CmdArgs.push_back("-fsized-deallocation");
5459
Daniel Dunbar34d7a992010-04-27 15:34:57 +00005460 // -fconstant-cfstrings is default, and may be subject to argument translation
5461 // on Darwin.
5462 if (!Args.hasFlag(options::OPT_fconstant_cfstrings,
5463 options::OPT_fno_constant_cfstrings) ||
5464 !Args.hasFlag(options::OPT_mconstant_cfstrings,
5465 options::OPT_mno_constant_cfstrings))
5466 CmdArgs.push_back("-fno-constant-cfstrings");
5467
John Thompsoned4e2952009-11-05 20:14:16 +00005468 // -fshort-wchar default varies depending on platform; only
5469 // pass if specified.
Richard Bartonc9b5f352014-02-24 18:43:28 +00005470 if (Arg *A = Args.getLastArg(options::OPT_fshort_wchar,
5471 options::OPT_fno_short_wchar))
Daniel Dunbar2cb4e7a2010-04-27 15:35:03 +00005472 A->render(Args, CmdArgs);
John Thompsoned4e2952009-11-05 20:14:16 +00005473
Hans Wennborg28c96312013-07-31 23:39:13 +00005474 // -fno-pascal-strings is default, only pass non-default.
Daniel Dunbard067f7f2009-04-08 23:54:23 +00005475 if (Args.hasFlag(options::OPT_fpascal_strings,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005476 options::OPT_fno_pascal_strings, false))
Daniel Dunbard18049a2009-04-07 21:16:11 +00005477 CmdArgs.push_back("-fpascal-strings");
NAKAMURA Takumi029d74b2011-02-17 08:50:50 +00005478
Daniel Dunbar096ed292011-10-05 21:04:55 +00005479 // Honor -fpack-struct= and -fpack-struct, if given. Note that
5480 // -fno-pack-struct doesn't apply to -fpack-struct=.
5481 if (Arg *A = Args.getLastArg(options::OPT_fpack_struct_EQ)) {
James Molloycebf75e2012-05-02 07:56:14 +00005482 std::string PackStructStr = "-fpack-struct=";
Richard Smithbd55daf2012-11-01 04:30:05 +00005483 PackStructStr += A->getValue();
James Molloycebf75e2012-05-02 07:56:14 +00005484 CmdArgs.push_back(Args.MakeArgString(PackStructStr));
Daniel Dunbar096ed292011-10-05 21:04:55 +00005485 } else if (Args.hasFlag(options::OPT_fpack_struct,
5486 options::OPT_fno_pack_struct, false)) {
James Molloycebf75e2012-05-02 07:56:14 +00005487 CmdArgs.push_back("-fpack-struct=1");
Daniel Dunbar096ed292011-10-05 21:04:55 +00005488 }
5489
Fariborz Jahanianbcd82af2014-08-05 18:37:48 +00005490 // Handle -fmax-type-align=N and -fno-type-align
5491 bool SkipMaxTypeAlign = Args.hasArg(options::OPT_fno_max_type_align);
5492 if (Arg *A = Args.getLastArg(options::OPT_fmax_type_align_EQ)) {
5493 if (!SkipMaxTypeAlign) {
5494 std::string MaxTypeAlignStr = "-fmax-type-align=";
5495 MaxTypeAlignStr += A->getValue();
5496 CmdArgs.push_back(Args.MakeArgString(MaxTypeAlignStr));
5497 }
5498 } else if (getToolChain().getTriple().isOSDarwin()) {
5499 if (!SkipMaxTypeAlign) {
5500 std::string MaxTypeAlignStr = "-fmax-type-align=16";
5501 CmdArgs.push_back(Args.MakeArgString(MaxTypeAlignStr));
5502 }
5503 }
5504
John Brawna7b4ec02015-08-10 11:11:28 +00005505 // -fcommon is the default unless compiling kernel code or the target says so
5506 bool NoCommonDefault =
5507 KernelOrKext || isNoCommonDefault(getToolChain().getTriple());
5508 if (!Args.hasFlag(options::OPT_fcommon, options::OPT_fno_common,
5509 !NoCommonDefault))
Daniel Dunbard18049a2009-04-07 21:16:11 +00005510 CmdArgs.push_back("-fno-common");
5511
Daniel Dunbar2edd9232009-04-15 02:37:43 +00005512 // -fsigned-bitfields is default, and clang doesn't yet support
Daniel Dunbar6358d682010-10-15 22:30:42 +00005513 // -funsigned-bitfields.
Mike Stump11289f42009-09-09 15:08:12 +00005514 if (!Args.hasFlag(options::OPT_fsigned_bitfields,
Daniel Dunbar2edd9232009-04-15 02:37:43 +00005515 options::OPT_funsigned_bitfields))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00005516 D.Diag(diag::warn_drv_clang_unsupported)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005517 << Args.getLastArg(options::OPT_funsigned_bitfields)->getAsString(Args);
Daniel Dunbar2edd9232009-04-15 02:37:43 +00005518
Daniel Dunbar6358d682010-10-15 22:30:42 +00005519 // -fsigned-bitfields is default, and clang doesn't support -fno-for-scope.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005520 if (!Args.hasFlag(options::OPT_ffor_scope, options::OPT_fno_for_scope))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00005521 D.Diag(diag::err_drv_clang_unsupported)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005522 << Args.getLastArg(options::OPT_fno_for_scope)->getAsString(Args);
Daniel Dunbar6358d682010-10-15 22:30:42 +00005523
Sylvestre Ledru91f380a2014-07-01 17:24:27 +00005524 // -finput_charset=UTF-8 is default. Reject others
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005525 if (Arg *inputCharset = Args.getLastArg(options::OPT_finput_charset_EQ)) {
5526 StringRef value = inputCharset->getValue();
5527 if (value != "UTF-8")
5528 D.Diag(diag::err_drv_invalid_value) << inputCharset->getAsString(Args)
5529 << value;
Sylvestre Ledru91f380a2014-07-01 17:24:27 +00005530 }
5531
Sylvestre Ledrub8198f0222014-08-11 18:09:03 +00005532 // -fexec_charset=UTF-8 is default. Reject others
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005533 if (Arg *execCharset = Args.getLastArg(options::OPT_fexec_charset_EQ)) {
5534 StringRef value = execCharset->getValue();
5535 if (value != "UTF-8")
5536 D.Diag(diag::err_drv_invalid_value) << execCharset->getAsString(Args)
5537 << value;
Sylvestre Ledrub8198f0222014-08-11 18:09:03 +00005538 }
5539
Jeffrey Yasskin460aa542010-06-08 04:56:20 +00005540 // -fcaret-diagnostics is default.
5541 if (!Args.hasFlag(options::OPT_fcaret_diagnostics,
5542 options::OPT_fno_caret_diagnostics, true))
5543 CmdArgs.push_back("-fno-caret-diagnostics");
5544
Daniel Dunbar8281bde2009-04-19 21:09:34 +00005545 // -fdiagnostics-fixit-info is default, only pass non-default.
Mike Stump11289f42009-09-09 15:08:12 +00005546 if (!Args.hasFlag(options::OPT_fdiagnostics_fixit_info,
Daniel Dunbar8281bde2009-04-19 21:09:34 +00005547 options::OPT_fno_diagnostics_fixit_info))
5548 CmdArgs.push_back("-fno-diagnostics-fixit-info");
Eric Christopher84fbdb42011-08-19 00:30:14 +00005549
Daniel Dunbar092f0cc2009-04-16 06:32:38 +00005550 // Enable -fdiagnostics-show-option by default.
Mike Stump11289f42009-09-09 15:08:12 +00005551 if (Args.hasFlag(options::OPT_fdiagnostics_show_option,
Daniel Dunbar092f0cc2009-04-16 06:32:38 +00005552 options::OPT_fno_diagnostics_show_option))
5553 CmdArgs.push_back("-fdiagnostics-show-option");
Daniel Dunbar5ec95022009-11-04 06:24:57 +00005554
Chris Lattnerbf6fac82010-05-04 21:55:25 +00005555 if (const Arg *A =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005556 Args.getLastArg(options::OPT_fdiagnostics_show_category_EQ)) {
Chris Lattnerbf6fac82010-05-04 21:55:25 +00005557 CmdArgs.push_back("-fdiagnostics-show-category");
Richard Smithbd55daf2012-11-01 04:30:05 +00005558 CmdArgs.push_back(A->getValue());
Chris Lattnerbf6fac82010-05-04 21:55:25 +00005559 }
Daniel Dunbarfe6c97b2010-08-24 16:47:49 +00005560
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005561 if (const Arg *A = Args.getLastArg(options::OPT_fdiagnostics_format_EQ)) {
Douglas Gregor643c9222011-05-21 17:07:29 +00005562 CmdArgs.push_back("-fdiagnostics-format");
Richard Smithbd55daf2012-11-01 04:30:05 +00005563 CmdArgs.push_back(A->getValue());
Douglas Gregor643c9222011-05-21 17:07:29 +00005564 }
5565
Chandler Carruthb6766f02011-03-27 01:50:55 +00005566 if (Arg *A = Args.getLastArg(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005567 options::OPT_fdiagnostics_show_note_include_stack,
5568 options::OPT_fno_diagnostics_show_note_include_stack)) {
Chandler Carruthb6766f02011-03-27 01:50:55 +00005569 if (A->getOption().matches(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005570 options::OPT_fdiagnostics_show_note_include_stack))
Chandler Carruthb6766f02011-03-27 01:50:55 +00005571 CmdArgs.push_back("-fdiagnostics-show-note-include-stack");
5572 else
5573 CmdArgs.push_back("-fno-diagnostics-show-note-include-stack");
5574 }
5575
Daniel Dunbar5ec95022009-11-04 06:24:57 +00005576 // Color diagnostics are the default, unless the terminal doesn't support
5577 // them.
Nico Weber7e2da792013-04-17 21:52:44 +00005578 // Support both clang's -f[no-]color-diagnostics and gcc's
5579 // -f[no-]diagnostics-colors[=never|always|auto].
5580 enum { Colors_On, Colors_Off, Colors_Auto } ShowColors = Colors_Auto;
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005581 for (const auto &Arg : Args) {
5582 const Option &O = Arg->getOption();
Nico Weber7e2da792013-04-17 21:52:44 +00005583 if (!O.matches(options::OPT_fcolor_diagnostics) &&
5584 !O.matches(options::OPT_fdiagnostics_color) &&
5585 !O.matches(options::OPT_fno_color_diagnostics) &&
5586 !O.matches(options::OPT_fno_diagnostics_color) &&
5587 !O.matches(options::OPT_fdiagnostics_color_EQ))
5588 continue;
5589
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005590 Arg->claim();
Nico Weber7e2da792013-04-17 21:52:44 +00005591 if (O.matches(options::OPT_fcolor_diagnostics) ||
5592 O.matches(options::OPT_fdiagnostics_color)) {
5593 ShowColors = Colors_On;
5594 } else if (O.matches(options::OPT_fno_color_diagnostics) ||
5595 O.matches(options::OPT_fno_diagnostics_color)) {
5596 ShowColors = Colors_Off;
5597 } else {
5598 assert(O.matches(options::OPT_fdiagnostics_color_EQ));
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005599 StringRef value(Arg->getValue());
Nico Weber7e2da792013-04-17 21:52:44 +00005600 if (value == "always")
5601 ShowColors = Colors_On;
5602 else if (value == "never")
5603 ShowColors = Colors_Off;
5604 else if (value == "auto")
5605 ShowColors = Colors_Auto;
5606 else
5607 getToolChain().getDriver().Diag(diag::err_drv_clang_unsupported)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005608 << ("-fdiagnostics-color=" + value).str();
Nico Weber7e2da792013-04-17 21:52:44 +00005609 }
5610 }
5611 if (ShowColors == Colors_On ||
5612 (ShowColors == Colors_Auto && llvm::sys::Process::StandardErrHasColors()))
Daniel Dunbar5ec95022009-11-04 06:24:57 +00005613 CmdArgs.push_back("-fcolor-diagnostics");
5614
Nico Rieck7857d462013-09-11 00:38:02 +00005615 if (Args.hasArg(options::OPT_fansi_escape_codes))
5616 CmdArgs.push_back("-fansi-escape-codes");
5617
Daniel Dunbardb097022009-06-08 21:13:54 +00005618 if (!Args.hasFlag(options::OPT_fshow_source_location,
5619 options::OPT_fno_show_source_location))
5620 CmdArgs.push_back("-fno-show-source-location");
Daniel Dunbar092f0cc2009-04-16 06:32:38 +00005621
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005622 if (!Args.hasFlag(options::OPT_fshow_column, options::OPT_fno_show_column,
Douglas Gregor643c9222011-05-21 17:07:29 +00005623 true))
5624 CmdArgs.push_back("-fno-show-column");
5625
Douglas Gregor8ed0c0b2010-07-09 17:35:33 +00005626 if (!Args.hasFlag(options::OPT_fspell_checking,
5627 options::OPT_fno_spell_checking))
5628 CmdArgs.push_back("-fno-spell-checking");
Daniel Dunbarfe6c97b2010-08-24 16:47:49 +00005629
Chad Rosierc8e56e82012-12-05 21:08:21 +00005630 // -fno-asm-blocks is default.
5631 if (Args.hasFlag(options::OPT_fasm_blocks, options::OPT_fno_asm_blocks,
5632 false))
5633 CmdArgs.push_back("-fasm-blocks");
Daniel Dunbar473f8a62010-10-18 22:49:46 +00005634
Steven Wucb0d13f2015-01-16 23:05:28 +00005635 // -fgnu-inline-asm is default.
5636 if (!Args.hasFlag(options::OPT_fgnu_inline_asm,
5637 options::OPT_fno_gnu_inline_asm, true))
5638 CmdArgs.push_back("-fno-gnu-inline-asm");
5639
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00005640 // Enable vectorization per default according to the optimization level
5641 // selected. For optimization levels that want vectorization we use the alias
5642 // option to simplify the hasFlag logic.
Chad Rosier3ba81bd2014-05-02 18:41:57 +00005643 bool EnableVec = shouldEnableVectorizerAtOLevel(Args, false);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005644 OptSpecifier VectorizeAliasOption =
5645 EnableVec ? options::OPT_O_Group : options::OPT_fvectorize;
Chad Rosier679b0752013-04-24 18:29:59 +00005646 if (Args.hasFlag(options::OPT_fvectorize, VectorizeAliasOption,
Hal Finkel108c46a2013-08-28 05:21:45 +00005647 options::OPT_fno_vectorize, EnableVec))
Chad Rosier0d3ed6f2012-12-11 17:12:28 +00005648 CmdArgs.push_back("-vectorize-loops");
Chad Rosier0d3ed6f2012-12-11 17:12:28 +00005649
Chad Rosier136d67d2014-04-28 19:30:57 +00005650 // -fslp-vectorize is enabled based on the optimization level selected.
Chad Rosier3ba81bd2014-05-02 18:41:57 +00005651 bool EnableSLPVec = shouldEnableVectorizerAtOLevel(Args, true);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005652 OptSpecifier SLPVectAliasOption =
5653 EnableSLPVec ? options::OPT_O_Group : options::OPT_fslp_vectorize;
Chad Rosier136d67d2014-04-28 19:30:57 +00005654 if (Args.hasFlag(options::OPT_fslp_vectorize, SLPVectAliasOption,
Chad Rosier3ba81bd2014-05-02 18:41:57 +00005655 options::OPT_fno_slp_vectorize, EnableSLPVec))
Nadav Rotem0a2604d2013-04-15 04:57:18 +00005656 CmdArgs.push_back("-vectorize-slp");
Hal Finkel061f1652012-12-11 19:59:32 +00005657
Nadav Rotem6a0dd6b2013-04-15 05:38:41 +00005658 // -fno-slp-vectorize-aggressive is default.
5659 if (Args.hasFlag(options::OPT_fslp_vectorize_aggressive,
Nick Lewyckyd3f3e4f2013-06-25 01:49:44 +00005660 options::OPT_fno_slp_vectorize_aggressive, false))
Nadav Rotem6a0dd6b2013-04-15 05:38:41 +00005661 CmdArgs.push_back("-vectorize-slp-aggressive");
Nadav Rotem6a0dd6b2013-04-15 05:38:41 +00005662
Jeffrey Yasskin2b99c6f2010-06-11 05:57:47 +00005663 if (Arg *A = Args.getLastArg(options::OPT_fshow_overloads_EQ))
5664 A->render(Args, CmdArgs);
5665
Filipe Cabecinhasab731f72016-05-12 16:51:36 +00005666 if (Arg *A = Args.getLastArg(
5667 options::OPT_fsanitize_undefined_strip_path_components_EQ))
5668 A->render(Args, CmdArgs);
5669
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00005670 // -fdollars-in-identifiers default varies depending on platform and
5671 // language; only pass if specified.
Mike Stump11289f42009-09-09 15:08:12 +00005672 if (Arg *A = Args.getLastArg(options::OPT_fdollars_in_identifiers,
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00005673 options::OPT_fno_dollars_in_identifiers)) {
5674 if (A->getOption().matches(options::OPT_fdollars_in_identifiers))
Daniel Dunbar15cef0e2009-12-16 20:10:18 +00005675 CmdArgs.push_back("-fdollars-in-identifiers");
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00005676 else
Daniel Dunbar15cef0e2009-12-16 20:10:18 +00005677 CmdArgs.push_back("-fno-dollars-in-identifiers");
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00005678 }
5679
Daniel Dunbaradeeb052009-05-22 19:02:20 +00005680 // -funit-at-a-time is default, and we don't support -fno-unit-at-a-time for
5681 // practical purposes.
Mike Stump11289f42009-09-09 15:08:12 +00005682 if (Arg *A = Args.getLastArg(options::OPT_funit_at_a_time,
Daniel Dunbaradeeb052009-05-22 19:02:20 +00005683 options::OPT_fno_unit_at_a_time)) {
5684 if (A->getOption().matches(options::OPT_fno_unit_at_a_time))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00005685 D.Diag(diag::warn_drv_clang_unsupported) << A->getAsString(Args);
Daniel Dunbaradeeb052009-05-22 19:02:20 +00005686 }
Eli Friedmanbb0d9a52009-07-14 21:58:17 +00005687
Eli Friedman055c9702011-11-02 01:53:16 +00005688 if (Args.hasFlag(options::OPT_fapple_pragma_pack,
5689 options::OPT_fno_apple_pragma_pack, false))
5690 CmdArgs.push_back("-fapple-pragma-pack");
5691
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005692 // le32-specific flags:
Eli Benderskyc95cfe82013-07-24 18:20:14 +00005693 // -fno-math-builtin: clang should not convert math builtins to intrinsics
5694 // by default.
Chad Rosierf662fb32016-01-26 16:16:53 +00005695 if (getToolChain().getArch() == llvm::Triple::le32) {
Eli Benderskyc95cfe82013-07-24 18:20:14 +00005696 CmdArgs.push_back("-fno-math-builtin");
Chad Rosierf662fb32016-01-26 16:16:53 +00005697 }
Eli Benderskyc95cfe82013-07-24 18:20:14 +00005698
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005699// Default to -fno-builtin-str{cat,cpy} on Darwin for ARM.
5700//
Chad Rosier38fd54e2016-01-26 15:46:29 +00005701// FIXME: Now that PR4941 has been fixed this can be enabled.
Daniel Dunbar4fa08112009-09-10 04:57:27 +00005702#if 0
Bob Wilson6524dd32011-10-14 05:03:44 +00005703 if (getToolChain().getTriple().isOSDarwin() &&
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00005704 (getToolChain().getArch() == llvm::Triple::arm ||
5705 getToolChain().getArch() == llvm::Triple::thumb)) {
Daniel Dunbar2ffe0292009-09-10 03:37:02 +00005706 if (!Args.hasArg(options::OPT_fbuiltin_strcat))
5707 CmdArgs.push_back("-fno-builtin-strcat");
5708 if (!Args.hasArg(options::OPT_fbuiltin_strcpy))
5709 CmdArgs.push_back("-fno-builtin-strcpy");
5710 }
Daniel Dunbar4fa08112009-09-10 04:57:27 +00005711#endif
Daniel Dunbar2ffe0292009-09-10 03:37:02 +00005712
Justin Bognera88f0122014-06-20 22:59:50 +00005713 // Enable rewrite includes if the user's asked for it or if we're generating
5714 // diagnostics.
5715 // TODO: Once -module-dependency-dir works with -frewrite-includes it'd be
5716 // nice to enable this when doing a crashdump for modules as well.
Justin Bogner332a5e52014-06-20 22:16:00 +00005717 if (Args.hasFlag(options::OPT_frewrite_includes,
5718 options::OPT_fno_rewrite_includes, false) ||
Justin Bognera88f0122014-06-20 22:59:50 +00005719 (C.isForDiagnostics() && !HaveModules))
Justin Bogner332a5e52014-06-20 22:16:00 +00005720 CmdArgs.push_back("-frewrite-includes");
5721
Daniel Dunbar8c3d7352011-03-18 21:23:40 +00005722 // Only allow -traditional or -traditional-cpp outside in preprocessing modes.
Mike Stump11289f42009-09-09 15:08:12 +00005723 if (Arg *A = Args.getLastArg(options::OPT_traditional,
Daniel Dunbar8c3d7352011-03-18 21:23:40 +00005724 options::OPT_traditional_cpp)) {
5725 if (isa<PreprocessJobAction>(JA))
5726 CmdArgs.push_back("-traditional-cpp");
Eric Christopher84fbdb42011-08-19 00:30:14 +00005727 else
Chris Lattner0e62c1c2011-07-23 10:55:15 +00005728 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
Daniel Dunbar8c3d7352011-03-18 21:23:40 +00005729 }
Eli Friedmanbb0d9a52009-07-14 21:58:17 +00005730
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005731 Args.AddLastArg(CmdArgs, options::OPT_dM);
Chris Lattnercac63f32009-04-12 01:56:53 +00005732 Args.AddLastArg(CmdArgs, options::OPT_dD);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005733
Ted Kremeneke73d9ed2011-11-11 00:07:43 +00005734 // Handle serialized diagnostics.
5735 if (Arg *A = Args.getLastArg(options::OPT__serialize_diags)) {
5736 CmdArgs.push_back("-serialize-diagnostic-file");
Richard Smithbd55daf2012-11-01 04:30:05 +00005737 CmdArgs.push_back(Args.MakeArgString(A->getValue()));
Ted Kremeneke73d9ed2011-11-11 00:07:43 +00005738 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005739
Ted Kremenekb47e6bc2012-09-13 06:41:18 +00005740 if (Args.hasArg(options::OPT_fretain_comments_from_system_headers))
5741 CmdArgs.push_back("-fretain-comments-from-system-headers");
5742
Dmitri Gribenkoacf2e782013-02-22 14:21:27 +00005743 // Forward -fcomment-block-commands to -cc1.
5744 Args.AddAllArgs(CmdArgs, options::OPT_fcomment_block_commands);
Dmitri Gribenkoa7d16ce2013-04-10 15:35:17 +00005745 // Forward -fparse-all-comments to -cc1.
5746 Args.AddAllArgs(CmdArgs, options::OPT_fparse_all_comments);
Dmitri Gribenkoacf2e782013-02-22 14:21:27 +00005747
John Brawnad31ace2015-09-23 13:55:40 +00005748 // Turn -fplugin=name.so into -load name.so
5749 for (const Arg *A : Args.filtered(options::OPT_fplugin_EQ)) {
5750 CmdArgs.push_back("-load");
5751 CmdArgs.push_back(A->getValue());
5752 A->claim();
5753 }
5754
Daniel Dunbar76fa8402010-04-15 06:09:03 +00005755 // Forward -Xclang arguments to -cc1, and -mllvm arguments to the LLVM option
5756 // parser.
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005757 Args.AddAllArgValues(CmdArgs, options::OPT_Xclang);
Sean Silva14facf32015-06-09 01:57:17 +00005758 for (const Arg *A : Args.filtered(options::OPT_mllvm)) {
5759 A->claim();
Daniel Dunbar88534f42010-04-17 06:10:00 +00005760
Daniel Dunbar76fa8402010-04-15 06:09:03 +00005761 // We translate this by hand to the -cc1 argument, since nightly test uses
5762 // it and developers have been trained to spell it with -mllvm.
Sean Silva14facf32015-06-09 01:57:17 +00005763 if (StringRef(A->getValue(0)) == "-disable-llvm-optzns") {
Daniel Dunbar76fa8402010-04-15 06:09:03 +00005764 CmdArgs.push_back("-disable-llvm-optzns");
Bob Wilson23a55f12014-12-21 07:00:00 +00005765 } else
Sean Silva14facf32015-06-09 01:57:17 +00005766 A->render(Args, CmdArgs);
Daniel Dunbar76fa8402010-04-15 06:09:03 +00005767 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005768
Bob Wilson23a55f12014-12-21 07:00:00 +00005769 // With -save-temps, we want to save the unoptimized bitcode output from the
Steven Wu546a1962015-07-17 20:09:56 +00005770 // CompileJobAction, use -disable-llvm-passes to get pristine IR generated
5771 // by the frontend.
Steven Wu27fb5222016-05-11 16:26:03 +00005772 // When -fembed-bitcode is enabled, optimized bitcode is emitted because it
5773 // has slightly different breakdown between stages.
5774 // FIXME: -fembed-bitcode -save-temps will save optimized bitcode instead of
5775 // pristine IR generated by the frontend. Ideally, a new compile action should
5776 // be added so both IR can be captured.
5777 if (C.getDriver().isSaveTempsEnabled() &&
5778 !C.getDriver().embedBitcodeEnabled() && isa<CompileJobAction>(JA))
Steven Wu546a1962015-07-17 20:09:56 +00005779 CmdArgs.push_back("-disable-llvm-passes");
Bob Wilson23a55f12014-12-21 07:00:00 +00005780
Daniel Dunbard67a3222009-03-30 06:36:42 +00005781 if (Output.getType() == types::TY_Dependencies) {
5782 // Handled with other dependency code.
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005783 } else if (Output.isFilename()) {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005784 CmdArgs.push_back("-o");
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005785 CmdArgs.push_back(Output.getFilename());
5786 } else {
5787 assert(Output.isNothing() && "Invalid output.");
Daniel Dunbara3246a02009-03-18 08:07:30 +00005788 }
5789
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005790 addDashXForInput(Args, Input, CmdArgs);
Ben Langmuir2cb4a782014-02-05 22:21:15 +00005791
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005792 if (Input.isFilename())
5793 CmdArgs.push_back(Input.getFilename());
5794 else
5795 Input.getInputArg().renderAsInput(Args, CmdArgs);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00005796
Chris Lattnere9d7d782009-11-03 19:50:27 +00005797 Args.AddAllArgs(CmdArgs, options::OPT_undef);
5798
Daniel Dunbarb31b76f2010-07-18 21:16:15 +00005799 const char *Exec = getToolChain().getDriver().getClangProgramPath();
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005800
5801 // Optionally embed the -cc1 level arguments into the debug info, for build
5802 // analysis.
5803 if (getToolChain().UseDwarfDebugFlags()) {
Daniel Dunbar7f3d9502010-06-04 18:47:06 +00005804 ArgStringList OriginalArgs;
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005805 for (const auto &Arg : Args)
5806 Arg->render(Args, OriginalArgs);
Daniel Dunbarfe6c97b2010-08-24 16:47:49 +00005807
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +00005808 SmallString<256> Flags;
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005809 Flags += Exec;
Douglas Katzman6bbffc42015-06-25 18:51:37 +00005810 for (const char *OriginalArg : OriginalArgs) {
Bob Wilsond5aad2a2014-11-04 22:28:48 +00005811 SmallString<128> EscapedArg;
Douglas Katzman6bbffc42015-06-25 18:51:37 +00005812 EscapeSpacesAndBackslashes(OriginalArg, EscapedArg);
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005813 Flags += " ";
Bob Wilsond5aad2a2014-11-04 22:28:48 +00005814 Flags += EscapedArg;
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005815 }
5816 CmdArgs.push_back("-dwarf-debug-flags");
Yaron Keren92e1b622015-03-18 10:17:07 +00005817 CmdArgs.push_back(Args.MakeArgString(Flags));
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005818 }
5819
Eric Christopherd3804002013-02-22 20:12:52 +00005820 // Add the split debug info name to the command lines here so we
5821 // can propagate it to the backend.
David Blaikiece3e7a62015-07-30 21:42:22 +00005822 bool SplitDwarf = SplitDwarfArg && getToolChain().getTriple().isOSLinux() &&
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005823 (isa<AssembleJobAction>(JA) || isa<CompileJobAction>(JA) ||
5824 isa<BackendJobAction>(JA));
Eric Christopherd3804002013-02-22 20:12:52 +00005825 const char *SplitDwarfOut;
5826 if (SplitDwarf) {
5827 CmdArgs.push_back("-split-dwarf-file");
Artem Belevichba558952015-05-06 18:20:23 +00005828 SplitDwarfOut = SplitDebugName(Args, Input);
Eric Christopherd3804002013-02-22 20:12:52 +00005829 CmdArgs.push_back(SplitDwarfOut);
5830 }
5831
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005832 // Host-side cuda compilation receives device-side outputs as Inputs[1...].
5833 // Include them with -fcuda-include-gpubinary.
5834 if (IsCuda && Inputs.size() > 1)
Artem Belevich5bde4e02015-07-20 20:02:54 +00005835 for (auto I = std::next(Inputs.begin()), E = Inputs.end(); I != E; ++I) {
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005836 CmdArgs.push_back("-fcuda-include-gpubinary");
Artem Belevich5bde4e02015-07-20 20:02:54 +00005837 CmdArgs.push_back(I->getFilename());
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005838 }
5839
Peter Collingbourne3afb2662016-04-28 17:09:37 +00005840 bool WholeProgramVTables =
5841 Args.hasFlag(options::OPT_fwhole_program_vtables,
5842 options::OPT_fno_whole_program_vtables, false);
5843 if (WholeProgramVTables) {
5844 if (!D.isUsingLTO())
5845 D.Diag(diag::err_drv_argument_only_allowed_with)
5846 << "-fwhole-program-vtables"
5847 << "-flto";
5848 CmdArgs.push_back("-fwhole-program-vtables");
5849 }
5850
Eric Christopherd3804002013-02-22 20:12:52 +00005851 // Finally add the compile command to the compilation.
Hans Wennborg859422a2014-01-13 22:24:42 +00005852 if (Args.hasArg(options::OPT__SLASH_fallback) &&
Hans Wennborg26a44302014-04-25 16:44:17 +00005853 Output.getType() == types::TY_Object &&
5854 (InputType == types::TY_C || InputType == types::TY_CXX)) {
David Blaikiec11bf802014-09-04 16:04:28 +00005855 auto CLCommand =
5856 getCLFallback()->GetCommand(C, JA, Output, Inputs, Args, LinkingOutput);
Justin Bognerd3371d82015-07-17 03:35:54 +00005857 C.addCommand(llvm::make_unique<FallbackCommand>(
5858 JA, *this, Exec, CmdArgs, Inputs, std::move(CLCommand)));
Nico Weber2ca4be92016-03-01 23:16:44 +00005859 } else if (Args.hasArg(options::OPT__SLASH_fallback) &&
5860 isa<PrecompileJobAction>(JA)) {
5861 // In /fallback builds, run the main compilation even if the pch generation
5862 // fails, so that the main compilation's fallback to cl.exe runs.
5863 C.addCommand(llvm::make_unique<ForceSuccessCommand>(JA, *this, Exec,
5864 CmdArgs, Inputs));
Hans Wennborg87cfa712013-09-19 20:32:16 +00005865 } else {
Justin Bognerd3371d82015-07-17 03:35:54 +00005866 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Hans Wennborg87cfa712013-09-19 20:32:16 +00005867 }
5868
Eric Christopherf1545832013-02-22 23:50:16 +00005869 // Handle the debug info splitting at object creation time if we're
5870 // creating an object.
Eric Christopher248357f2013-02-21 22:35:01 +00005871 // TODO: Currently only works on linux with newer objcopy.
Eric Christopher0945a642016-03-24 00:34:02 +00005872 if (SplitDwarf && Output.getType() == types::TY_Object)
Eric Christopherd3804002013-02-22 20:12:52 +00005873 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output, SplitDwarfOut);
Eric Christopher248357f2013-02-21 22:35:01 +00005874
Roman Divacky178e01602011-02-10 16:52:03 +00005875 if (Arg *A = Args.getLastArg(options::OPT_pg))
5876 if (Args.hasArg(options::OPT_fomit_frame_pointer))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005877 D.Diag(diag::err_drv_argument_not_allowed_with) << "-fomit-frame-pointer"
5878 << A->getAsString(Args);
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00005879
Daniel Dunbarc2a71892009-04-03 20:51:31 +00005880 // Claim some arguments which clang supports automatically.
5881
Daniel Dunbar3e0cac62010-04-15 06:18:42 +00005882 // -fpch-preprocess is used with gcc to add a special marker in the output to
5883 // include the PCH file. Clang's PTH solution is completely transparent, so we
5884 // do not need to deal with it at all.
Daniel Dunbarc2a71892009-04-03 20:51:31 +00005885 Args.ClaimAllArgs(options::OPT_fpch_preprocess);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00005886
Daniel Dunbar17731772009-03-23 19:03:36 +00005887 // Claim some arguments which clang doesn't support, but we don't
5888 // care to warn the user about.
Daniel Dunbar44b36ee2009-11-25 11:53:23 +00005889 Args.ClaimAllArgs(options::OPT_clang_ignored_f_Group);
5890 Args.ClaimAllArgs(options::OPT_clang_ignored_m_Group);
Rafael Espindola22f603032011-02-28 23:29:45 +00005891
Rafael Espindolab0092d72013-09-04 19:37:35 +00005892 // Disable warnings for clang -E -emit-llvm foo.c
Rafael Espindolad95a8122011-03-01 05:25:27 +00005893 Args.ClaimAllArgs(options::OPT_emit_llvm);
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005894}
5895
John McCall5fb5df92012-06-20 06:18:46 +00005896/// Add options related to the Objective-C runtime/ABI.
5897///
5898/// Returns true if the runtime is non-fragile.
5899ObjCRuntime Clang::AddObjCRuntimeArgs(const ArgList &args,
5900 ArgStringList &cmdArgs,
5901 RewriteKind rewriteKind) const {
5902 // Look for the controlling runtime option.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005903 Arg *runtimeArg =
5904 args.getLastArg(options::OPT_fnext_runtime, options::OPT_fgnu_runtime,
5905 options::OPT_fobjc_runtime_EQ);
John McCall5fb5df92012-06-20 06:18:46 +00005906
5907 // Just forward -fobjc-runtime= to the frontend. This supercedes
5908 // options about fragility.
5909 if (runtimeArg &&
5910 runtimeArg->getOption().matches(options::OPT_fobjc_runtime_EQ)) {
5911 ObjCRuntime runtime;
Richard Smithbd55daf2012-11-01 04:30:05 +00005912 StringRef value = runtimeArg->getValue();
John McCall5fb5df92012-06-20 06:18:46 +00005913 if (runtime.tryParse(value)) {
5914 getToolChain().getDriver().Diag(diag::err_drv_unknown_objc_runtime)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005915 << value;
John McCall5fb5df92012-06-20 06:18:46 +00005916 }
5917
5918 runtimeArg->render(args, cmdArgs);
5919 return runtime;
5920 }
5921
5922 // Otherwise, we'll need the ABI "version". Version numbers are
5923 // slightly confusing for historical reasons:
5924 // 1 - Traditional "fragile" ABI
5925 // 2 - Non-fragile ABI, version 1
5926 // 3 - Non-fragile ABI, version 2
5927 unsigned objcABIVersion = 1;
5928 // If -fobjc-abi-version= is present, use that to set the version.
5929 if (Arg *abiArg = args.getLastArg(options::OPT_fobjc_abi_version_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00005930 StringRef value = abiArg->getValue();
John McCall5fb5df92012-06-20 06:18:46 +00005931 if (value == "1")
5932 objcABIVersion = 1;
5933 else if (value == "2")
5934 objcABIVersion = 2;
5935 else if (value == "3")
5936 objcABIVersion = 3;
5937 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005938 getToolChain().getDriver().Diag(diag::err_drv_clang_unsupported) << value;
John McCall5fb5df92012-06-20 06:18:46 +00005939 } else {
5940 // Otherwise, determine if we are using the non-fragile ABI.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005941 bool nonFragileABIIsDefault =
5942 (rewriteKind == RK_NonFragile ||
5943 (rewriteKind == RK_None &&
5944 getToolChain().IsObjCNonFragileABIDefault()));
John McCall5fb5df92012-06-20 06:18:46 +00005945 if (args.hasFlag(options::OPT_fobjc_nonfragile_abi,
5946 options::OPT_fno_objc_nonfragile_abi,
5947 nonFragileABIIsDefault)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005948// Determine the non-fragile ABI version to use.
John McCall5fb5df92012-06-20 06:18:46 +00005949#ifdef DISABLE_DEFAULT_NONFRAGILEABI_TWO
5950 unsigned nonFragileABIVersion = 1;
5951#else
5952 unsigned nonFragileABIVersion = 2;
5953#endif
5954
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005955 if (Arg *abiArg =
5956 args.getLastArg(options::OPT_fobjc_nonfragile_abi_version_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00005957 StringRef value = abiArg->getValue();
John McCall5fb5df92012-06-20 06:18:46 +00005958 if (value == "1")
5959 nonFragileABIVersion = 1;
5960 else if (value == "2")
5961 nonFragileABIVersion = 2;
5962 else
5963 getToolChain().getDriver().Diag(diag::err_drv_clang_unsupported)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005964 << value;
John McCall5fb5df92012-06-20 06:18:46 +00005965 }
5966
5967 objcABIVersion = 1 + nonFragileABIVersion;
5968 } else {
5969 objcABIVersion = 1;
5970 }
5971 }
5972
5973 // We don't actually care about the ABI version other than whether
5974 // it's non-fragile.
5975 bool isNonFragile = objcABIVersion != 1;
5976
5977 // If we have no runtime argument, ask the toolchain for its default runtime.
5978 // However, the rewriter only really supports the Mac runtime, so assume that.
5979 ObjCRuntime runtime;
5980 if (!runtimeArg) {
5981 switch (rewriteKind) {
5982 case RK_None:
5983 runtime = getToolChain().getDefaultObjCRuntime(isNonFragile);
5984 break;
5985 case RK_Fragile:
5986 runtime = ObjCRuntime(ObjCRuntime::FragileMacOSX, VersionTuple());
5987 break;
5988 case RK_NonFragile:
5989 runtime = ObjCRuntime(ObjCRuntime::MacOSX, VersionTuple());
5990 break;
5991 }
5992
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005993 // -fnext-runtime
John McCall5fb5df92012-06-20 06:18:46 +00005994 } else if (runtimeArg->getOption().matches(options::OPT_fnext_runtime)) {
5995 // On Darwin, make this use the default behavior for the toolchain.
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00005996 if (getToolChain().getTriple().isOSDarwin()) {
John McCall5fb5df92012-06-20 06:18:46 +00005997 runtime = getToolChain().getDefaultObjCRuntime(isNonFragile);
5998
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005999 // Otherwise, build for a generic macosx port.
John McCall5fb5df92012-06-20 06:18:46 +00006000 } else {
6001 runtime = ObjCRuntime(ObjCRuntime::MacOSX, VersionTuple());
6002 }
6003
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006004 // -fgnu-runtime
John McCall5fb5df92012-06-20 06:18:46 +00006005 } else {
6006 assert(runtimeArg->getOption().matches(options::OPT_fgnu_runtime));
Eric Christopherbce27882015-12-28 21:57:05 +00006007 // Legacy behaviour is to target the gnustep runtime if we are in
David Chisnall314896c2012-07-04 10:37:03 +00006008 // non-fragile mode or the GCC runtime in fragile mode.
6009 if (isNonFragile)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006010 runtime = ObjCRuntime(ObjCRuntime::GNUstep, VersionTuple(1, 6));
David Chisnall314896c2012-07-04 10:37:03 +00006011 else
6012 runtime = ObjCRuntime(ObjCRuntime::GCC, VersionTuple());
John McCall5fb5df92012-06-20 06:18:46 +00006013 }
6014
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006015 cmdArgs.push_back(
6016 args.MakeArgString("-fobjc-runtime=" + runtime.getAsString()));
John McCall5fb5df92012-06-20 06:18:46 +00006017 return runtime;
6018}
6019
Reid Klecknerc542d372014-06-27 17:02:02 +00006020static bool maybeConsumeDash(const std::string &EH, size_t &I) {
6021 bool HaveDash = (I + 1 < EH.size() && EH[I + 1] == '-');
6022 I += HaveDash;
6023 return !HaveDash;
Chandler Carruth095b6962014-06-29 22:42:51 +00006024}
Reid Klecknerc542d372014-06-27 17:02:02 +00006025
Benjamin Kramere003ca22015-10-28 13:54:16 +00006026namespace {
Reid Klecknerc542d372014-06-27 17:02:02 +00006027struct EHFlags {
David Majnemerb8809092016-02-20 09:23:44 +00006028 bool Synch = false;
6029 bool Asynch = false;
6030 bool NoUnwindC = false;
Reid Klecknerc542d372014-06-27 17:02:02 +00006031};
Benjamin Kramere003ca22015-10-28 13:54:16 +00006032} // end anonymous namespace
Reid Klecknerc542d372014-06-27 17:02:02 +00006033
6034/// /EH controls whether to run destructor cleanups when exceptions are
6035/// thrown. There are three modifiers:
6036/// - s: Cleanup after "synchronous" exceptions, aka C++ exceptions.
6037/// - a: Cleanup after "asynchronous" exceptions, aka structured exceptions.
6038/// The 'a' modifier is unimplemented and fundamentally hard in LLVM IR.
David Majnemer960813e2016-02-20 09:23:47 +00006039/// - c: Assume that extern "C" functions are implicitly nounwind.
Reid Klecknerc542d372014-06-27 17:02:02 +00006040/// The default is /EHs-c-, meaning cleanups are disabled.
6041static EHFlags parseClangCLEHFlags(const Driver &D, const ArgList &Args) {
6042 EHFlags EH;
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00006043
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006044 std::vector<std::string> EHArgs =
6045 Args.getAllArgValues(options::OPT__SLASH_EH);
Reid Klecknerc542d372014-06-27 17:02:02 +00006046 for (auto EHVal : EHArgs) {
6047 for (size_t I = 0, E = EHVal.size(); I != E; ++I) {
6048 switch (EHVal[I]) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006049 case 'a':
6050 EH.Asynch = maybeConsumeDash(EHVal, I);
David Majnemer387fccd2016-02-29 01:40:30 +00006051 if (EH.Asynch)
6052 EH.Synch = false;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006053 continue;
6054 case 'c':
David Majnemerb8809092016-02-20 09:23:44 +00006055 EH.NoUnwindC = maybeConsumeDash(EHVal, I);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006056 continue;
6057 case 's':
6058 EH.Synch = maybeConsumeDash(EHVal, I);
David Majnemer387fccd2016-02-29 01:40:30 +00006059 if (EH.Synch)
6060 EH.Asynch = false;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006061 continue;
6062 default:
6063 break;
Reid Klecknerc542d372014-06-27 17:02:02 +00006064 }
6065 D.Diag(clang::diag::err_drv_invalid_value) << "/EH" << EHVal;
6066 break;
6067 }
6068 }
David Majnemerb8809092016-02-20 09:23:44 +00006069 // The /GX, /GX- flags are only processed if there are not /EH flags.
David Majnemera7bdc5a2016-02-22 17:44:51 +00006070 // The default is that /GX is not specified.
David Majnemerb8809092016-02-20 09:23:44 +00006071 if (EHArgs.empty() &&
David Majnemera7bdc5a2016-02-22 17:44:51 +00006072 Args.hasFlag(options::OPT__SLASH_GX, options::OPT__SLASH_GX_,
6073 /*default=*/false)) {
David Majnemerb8809092016-02-20 09:23:44 +00006074 EH.Synch = true;
6075 EH.NoUnwindC = true;
6076 }
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00006077
Reid Klecknerc542d372014-06-27 17:02:02 +00006078 return EH;
6079}
6080
David Majnemercd5855e2016-02-29 01:40:36 +00006081void Clang::AddClangCLArgs(const ArgList &Args, types::ID InputType,
6082 ArgStringList &CmdArgs,
Benjamin Kramer8c305922016-02-02 11:06:51 +00006083 codegenoptions::DebugInfoKind *DebugInfoKind,
Douglas Katzman3459ce22015-10-08 04:24:12 +00006084 bool *EmitCodeView) const {
Hans Wennborg75958c42013-08-08 00:17:41 +00006085 unsigned RTOptionID = options::OPT__SLASH_MT;
6086
Hans Wennborgf1a74252013-09-10 20:18:04 +00006087 if (Args.hasArg(options::OPT__SLASH_LDd))
6088 // The /LDd option implies /MTd. The dependent lib part can be overridden,
6089 // but defining _DEBUG is sticky.
6090 RTOptionID = options::OPT__SLASH_MTd;
6091
Hans Wennborg9cb7d9ba2013-09-18 22:26:39 +00006092 if (Arg *A = Args.getLastArg(options::OPT__SLASH_M_Group))
Hans Wennborg75958c42013-08-08 00:17:41 +00006093 RTOptionID = A->getOption().getID();
Hans Wennborgd9ad0682013-09-11 16:38:41 +00006094
David Majnemere2afb472015-07-24 06:49:13 +00006095 StringRef FlagForCRT;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006096 switch (RTOptionID) {
6097 case options::OPT__SLASH_MD:
6098 if (Args.hasArg(options::OPT__SLASH_LDd))
Hans Wennborg75958c42013-08-08 00:17:41 +00006099 CmdArgs.push_back("-D_DEBUG");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006100 CmdArgs.push_back("-D_MT");
6101 CmdArgs.push_back("-D_DLL");
David Majnemere2afb472015-07-24 06:49:13 +00006102 FlagForCRT = "--dependent-lib=msvcrt";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006103 break;
6104 case options::OPT__SLASH_MDd:
6105 CmdArgs.push_back("-D_DEBUG");
6106 CmdArgs.push_back("-D_MT");
6107 CmdArgs.push_back("-D_DLL");
David Majnemere2afb472015-07-24 06:49:13 +00006108 FlagForCRT = "--dependent-lib=msvcrtd";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006109 break;
6110 case options::OPT__SLASH_MT:
6111 if (Args.hasArg(options::OPT__SLASH_LDd))
Hans Wennborg75958c42013-08-08 00:17:41 +00006112 CmdArgs.push_back("-D_DEBUG");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006113 CmdArgs.push_back("-D_MT");
Peter Collingbourne3afb2662016-04-28 17:09:37 +00006114 CmdArgs.push_back("-flto-visibility-public-std");
David Majnemere2afb472015-07-24 06:49:13 +00006115 FlagForCRT = "--dependent-lib=libcmt";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006116 break;
6117 case options::OPT__SLASH_MTd:
6118 CmdArgs.push_back("-D_DEBUG");
6119 CmdArgs.push_back("-D_MT");
Peter Collingbourne3afb2662016-04-28 17:09:37 +00006120 CmdArgs.push_back("-flto-visibility-public-std");
David Majnemere2afb472015-07-24 06:49:13 +00006121 FlagForCRT = "--dependent-lib=libcmtd";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006122 break;
6123 default:
6124 llvm_unreachable("Unexpected option ID.");
Hans Wennborg75958c42013-08-08 00:17:41 +00006125 }
6126
David Majnemere2afb472015-07-24 06:49:13 +00006127 if (Args.hasArg(options::OPT__SLASH_Zl)) {
6128 CmdArgs.push_back("-D_VC_NODEFAULTLIB");
6129 } else {
6130 CmdArgs.push_back(FlagForCRT.data());
6131
6132 // This provides POSIX compatibility (maps 'open' to '_open'), which most
6133 // users want. The /Za flag to cl.exe turns this off, but it's not
6134 // implemented in clang.
6135 CmdArgs.push_back("--dependent-lib=oldnames");
6136 }
Hans Wennborg614f7072013-08-08 19:54:30 +00006137
Hans Wennborg8858a032014-07-21 23:42:07 +00006138 // Both /showIncludes and /E (and /EP) write to stdout. Allowing both
6139 // would produce interleaved output, so ignore /showIncludes in such cases.
6140 if (!Args.hasArg(options::OPT_E) && !Args.hasArg(options::OPT__SLASH_EP))
6141 if (Arg *A = Args.getLastArg(options::OPT_show_includes))
6142 A->render(Args, CmdArgs);
Hans Wennborg81f74482013-09-10 01:07:07 +00006143
David Majnemerf6072342014-07-01 22:24:56 +00006144 // This controls whether or not we emit RTTI data for polymorphic types.
6145 if (Args.hasFlag(options::OPT__SLASH_GR_, options::OPT__SLASH_GR,
6146 /*default=*/false))
6147 CmdArgs.push_back("-fno-rtti-data");
Hans Wennborg7b0dcef2014-02-25 18:36:22 +00006148
Reid Kleckner124955a2015-08-05 18:51:13 +00006149 // Emit CodeView if -Z7 is present.
Douglas Katzman3459ce22015-10-08 04:24:12 +00006150 *EmitCodeView = Args.hasArg(options::OPT__SLASH_Z7);
Reid Kleckner9ce06a4a2016-02-10 21:28:38 +00006151 if (*EmitCodeView)
6152 *DebugInfoKind = codegenoptions::LimitedDebugInfo;
Douglas Katzman3459ce22015-10-08 04:24:12 +00006153 if (*EmitCodeView)
Reid Kleckner124955a2015-08-05 18:51:13 +00006154 CmdArgs.push_back("-gcodeview");
6155
Reid Klecknerc542d372014-06-27 17:02:02 +00006156 const Driver &D = getToolChain().getDriver();
6157 EHFlags EH = parseClangCLEHFlags(D, Args);
Reid Klecknerdeeddec2015-02-05 18:56:03 +00006158 if (EH.Synch || EH.Asynch) {
David Majnemercd5855e2016-02-29 01:40:36 +00006159 if (types::isCXX(InputType))
6160 CmdArgs.push_back("-fcxx-exceptions");
Reid Klecknerdeeddec2015-02-05 18:56:03 +00006161 CmdArgs.push_back("-fexceptions");
6162 }
David Majnemercd5855e2016-02-29 01:40:36 +00006163 if (types::isCXX(InputType) && EH.Synch && EH.NoUnwindC)
6164 CmdArgs.push_back("-fexternc-nounwind");
Reid Klecknerc542d372014-06-27 17:02:02 +00006165
Hans Wennborge50cec32014-06-13 20:59:54 +00006166 // /EP should expand to -E -P.
6167 if (Args.hasArg(options::OPT__SLASH_EP)) {
6168 CmdArgs.push_back("-E");
6169 CmdArgs.push_back("-P");
6170 }
6171
David Majnemera5b195a2015-02-14 01:35:12 +00006172 unsigned VolatileOptionID;
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00006173 if (getToolChain().getArch() == llvm::Triple::x86_64 ||
6174 getToolChain().getArch() == llvm::Triple::x86)
David Majnemera5b195a2015-02-14 01:35:12 +00006175 VolatileOptionID = options::OPT__SLASH_volatile_ms;
6176 else
6177 VolatileOptionID = options::OPT__SLASH_volatile_iso;
6178
6179 if (Arg *A = Args.getLastArg(options::OPT__SLASH_volatile_Group))
6180 VolatileOptionID = A->getOption().getID();
6181
6182 if (VolatileOptionID == options::OPT__SLASH_volatile_ms)
6183 CmdArgs.push_back("-fms-volatile");
6184
David Majnemer86c318f2014-02-11 21:05:00 +00006185 Arg *MostGeneralArg = Args.getLastArg(options::OPT__SLASH_vmg);
6186 Arg *BestCaseArg = Args.getLastArg(options::OPT__SLASH_vmb);
6187 if (MostGeneralArg && BestCaseArg)
6188 D.Diag(clang::diag::err_drv_argument_not_allowed_with)
6189 << MostGeneralArg->getAsString(Args) << BestCaseArg->getAsString(Args);
6190
6191 if (MostGeneralArg) {
6192 Arg *SingleArg = Args.getLastArg(options::OPT__SLASH_vms);
6193 Arg *MultipleArg = Args.getLastArg(options::OPT__SLASH_vmm);
6194 Arg *VirtualArg = Args.getLastArg(options::OPT__SLASH_vmv);
6195
6196 Arg *FirstConflict = SingleArg ? SingleArg : MultipleArg;
6197 Arg *SecondConflict = VirtualArg ? VirtualArg : MultipleArg;
6198 if (FirstConflict && SecondConflict && FirstConflict != SecondConflict)
6199 D.Diag(clang::diag::err_drv_argument_not_allowed_with)
6200 << FirstConflict->getAsString(Args)
6201 << SecondConflict->getAsString(Args);
6202
6203 if (SingleArg)
6204 CmdArgs.push_back("-fms-memptr-rep=single");
6205 else if (MultipleArg)
6206 CmdArgs.push_back("-fms-memptr-rep=multiple");
6207 else
6208 CmdArgs.push_back("-fms-memptr-rep=virtual");
6209 }
6210
Alexey Bataeva7547182016-05-18 09:06:38 +00006211 if (Args.getLastArg(options::OPT__SLASH_Gd))
6212 CmdArgs.push_back("-fdefault-calling-conv=cdecl");
6213 else if (Args.getLastArg(options::OPT__SLASH_Gr))
6214 CmdArgs.push_back("-fdefault-calling-conv=fastcall");
6215 else if (Args.getLastArg(options::OPT__SLASH_Gz))
6216 CmdArgs.push_back("-fdefault-calling-conv=stdcall");
6217 else if (Args.getLastArg(options::OPT__SLASH_Gv))
6218 CmdArgs.push_back("-fdefault-calling-conv=vectorcall");
6219
Reid Klecknerc0dca6d2014-02-12 23:50:26 +00006220 if (Arg *A = Args.getLastArg(options::OPT_vtordisp_mode_EQ))
6221 A->render(Args, CmdArgs);
6222
Hans Wennborg81f74482013-09-10 01:07:07 +00006223 if (!Args.hasArg(options::OPT_fdiagnostics_format_EQ)) {
6224 CmdArgs.push_back("-fdiagnostics-format");
Hans Wennborgf4aee182013-09-24 00:08:55 +00006225 if (Args.hasArg(options::OPT__SLASH_fallback))
6226 CmdArgs.push_back("msvc-fallback");
6227 else
6228 CmdArgs.push_back("msvc");
Hans Wennborg81f74482013-09-10 01:07:07 +00006229 }
Hans Wennborg75958c42013-08-08 00:17:41 +00006230}
6231
Douglas Katzman95354292015-06-23 20:42:09 +00006232visualstudio::Compiler *Clang::getCLFallback() const {
Hans Wennborg1da044a2014-06-26 19:59:02 +00006233 if (!CLFallback)
Douglas Katzman95354292015-06-23 20:42:09 +00006234 CLFallback.reset(new visualstudio::Compiler(getToolChain()));
Hans Wennborg1da044a2014-06-26 19:59:02 +00006235 return CLFallback.get();
6236}
6237
Daniel Sanders7f933f42015-01-30 17:35:23 +00006238void ClangAs::AddMIPSTargetArgs(const ArgList &Args,
6239 ArgStringList &CmdArgs) const {
6240 StringRef CPUName;
6241 StringRef ABIName;
6242 const llvm::Triple &Triple = getToolChain().getTriple();
6243 mips::getMipsCPUAndABI(Args, Triple, CPUName, ABIName);
6244
6245 CmdArgs.push_back("-target-abi");
6246 CmdArgs.push_back(ABIName.data());
6247}
6248
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00006249void ClangAs::ConstructJob(Compilation &C, const JobAction &JA,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006250 const InputInfo &Output, const InputInfoList &Inputs,
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00006251 const ArgList &Args,
6252 const char *LinkingOutput) const {
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00006253 ArgStringList CmdArgs;
6254
6255 assert(Inputs.size() == 1 && "Unexpected number of inputs.");
6256 const InputInfo &Input = Inputs[0];
6257
James Y Knight2db38f32015-08-15 03:45:25 +00006258 std::string TripleStr =
6259 getToolChain().ComputeEffectiveClangTriple(Args, Input.getType());
6260 const llvm::Triple Triple(TripleStr);
6261
Rafael Espindolacfaadda2010-11-17 22:13:25 +00006262 // Don't warn about "clang -w -c foo.s"
6263 Args.ClaimAllArgs(options::OPT_w);
Rafael Espindolad95a8122011-03-01 05:25:27 +00006264 // and "clang -emit-llvm -c foo.s"
6265 Args.ClaimAllArgs(options::OPT_emit_llvm);
Rafael Espindolacfaadda2010-11-17 22:13:25 +00006266
Rafael Espindola577637a2015-01-03 00:06:04 +00006267 claimNoWarnArgs(Args);
Rafael Espindola16042fc2015-01-02 23:23:52 +00006268
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00006269 // Invoke ourselves in -cc1as mode.
6270 //
6271 // FIXME: Implement custom jobs for internal actions.
6272 CmdArgs.push_back("-cc1as");
6273
6274 // Add the "effective" target triple.
6275 CmdArgs.push_back("-triple");
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00006276 CmdArgs.push_back(Args.MakeArgString(TripleStr));
6277
6278 // Set the output mode, we currently only expect to be used as a real
6279 // assembler.
6280 CmdArgs.push_back("-filetype");
6281 CmdArgs.push_back("obj");
6282
Eric Christopher45f2e712012-12-18 00:31:10 +00006283 // Set the main file name, so that debug info works even with
6284 // -save-temps or preprocessed assembly.
6285 CmdArgs.push_back("-main-file-name");
Artem Belevichba558952015-05-06 18:20:23 +00006286 CmdArgs.push_back(Clang::getBaseInputName(Args, Input));
Eric Christopher45f2e712012-12-18 00:31:10 +00006287
Rafael Espindola22ce34a2013-08-20 22:12:08 +00006288 // Add the target cpu
Renato Golin7c542b42015-07-27 23:44:45 +00006289 std::string CPU = getCPUName(Args, Triple, /*FromAs*/ true);
Rafael Espindola22ce34a2013-08-20 22:12:08 +00006290 if (!CPU.empty()) {
6291 CmdArgs.push_back("-target-cpu");
6292 CmdArgs.push_back(Args.MakeArgString(CPU));
6293 }
6294
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00006295 // Add the target features
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00006296 getTargetFeatures(getToolChain(), Triple, Args, CmdArgs, true);
Jim Grosbach576452b2012-02-10 20:37:10 +00006297
Daniel Dunbar1d733e22011-03-17 17:37:29 +00006298 // Ignore explicit -force_cpusubtype_ALL option.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006299 (void)Args.hasArg(options::OPT_force__cpusubtype__ALL);
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00006300
Jim Grosbachc78c2bc2015-06-23 18:20:13 +00006301 // Pass along any -I options so we get proper .include search paths.
6302 Args.AddAllArgs(CmdArgs, options::OPT_I_Group);
6303
Eric Christopherfc3ee562012-01-10 00:38:01 +00006304 // Determine the original source input.
6305 const Action *SourceAction = &JA;
6306 while (SourceAction->getKind() != Action::InputClass) {
6307 assert(!SourceAction->getInputs().empty() && "unexpected root action!");
6308 SourceAction = SourceAction->getInputs()[0];
6309 }
6310
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00006311 // Forward -g and handle debug info related flags, assuming we are dealing
6312 // with an actual assembly file.
Douglas Katzman3103f252016-04-19 18:55:53 +00006313 bool WantDebug = false;
6314 unsigned DwarfVersion = 0;
6315 Args.ClaimAllArgs(options::OPT_g_Group);
6316 if (Arg *A = Args.getLastArg(options::OPT_g_Group)) {
6317 WantDebug = !A->getOption().matches(options::OPT_g0) &&
6318 !A->getOption().matches(options::OPT_ggdb0);
6319 if (WantDebug)
6320 DwarfVersion = DwarfVersionNum(A->getSpelling());
6321 }
6322 if (DwarfVersion == 0)
6323 DwarfVersion = getToolChain().GetDefaultDwarfVersion();
6324
6325 codegenoptions::DebugInfoKind DebugInfoKind = codegenoptions::NoDebugInfo;
6326
Eric Christopherfc3ee562012-01-10 00:38:01 +00006327 if (SourceAction->getType() == types::TY_Asm ||
6328 SourceAction->getType() == types::TY_PP_Asm) {
Douglas Katzman3103f252016-04-19 18:55:53 +00006329 // You might think that it would be ok to set DebugInfoKind outside of
6330 // the guard for source type, however there is a test which asserts
6331 // that some assembler invocation receives no -debug-info-kind,
6332 // and it's not clear whether that test is just overly restrictive.
6333 DebugInfoKind = (WantDebug ? codegenoptions::LimitedDebugInfo
6334 : codegenoptions::NoDebugInfo);
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00006335 // Add the -fdebug-compilation-dir flag if needed.
6336 addDebugCompDirArg(Args, CmdArgs);
Kevin Enderbyae2ec472013-01-17 21:38:06 +00006337
6338 // Set the AT_producer to the clang version when using the integrated
6339 // assembler on assembly source files.
6340 CmdArgs.push_back("-dwarf-debug-producer");
Bruno Cardoso Lopes34c549e2016-05-02 20:20:49 +00006341 CmdArgs.push_back(Args.MakeArgString(getClangFullVersion()));
Renato Golina74bbc72015-07-22 15:32:36 +00006342
6343 // And pass along -I options
6344 Args.AddAllArgs(CmdArgs, options::OPT_I);
Eric Christopherfc3ee562012-01-10 00:38:01 +00006345 }
Douglas Katzman3103f252016-04-19 18:55:53 +00006346 RenderDebugEnablingArgs(Args, CmdArgs, DebugInfoKind, DwarfVersion,
6347 llvm::DebuggerKind::Default);
Kevin Enderby292dc082011-12-22 19:31:58 +00006348
James Y Knight5bdf7ab2015-08-19 15:12:02 +00006349 // Handle -fPIC et al -- the relocation-model affects the assembler
6350 // for some targets.
6351 llvm::Reloc::Model RelocationModel;
6352 unsigned PICLevel;
6353 bool IsPIE;
6354 std::tie(RelocationModel, PICLevel, IsPIE) =
6355 ParsePICArgs(getToolChain(), Triple, Args);
6356
6357 const char *RMName = RelocationModelName(RelocationModel);
6358 if (RMName) {
6359 CmdArgs.push_back("-mrelocation-model");
6360 CmdArgs.push_back(RMName);
6361 }
6362
Kevin Enderby292dc082011-12-22 19:31:58 +00006363 // Optionally embed the -cc1as level arguments into the debug info, for build
6364 // analysis.
6365 if (getToolChain().UseDwarfDebugFlags()) {
6366 ArgStringList OriginalArgs;
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006367 for (const auto &Arg : Args)
6368 Arg->render(Args, OriginalArgs);
Kevin Enderby292dc082011-12-22 19:31:58 +00006369
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +00006370 SmallString<256> Flags;
Kevin Enderby292dc082011-12-22 19:31:58 +00006371 const char *Exec = getToolChain().getDriver().getClangProgramPath();
6372 Flags += Exec;
Douglas Katzman6bbffc42015-06-25 18:51:37 +00006373 for (const char *OriginalArg : OriginalArgs) {
Bob Wilsond5aad2a2014-11-04 22:28:48 +00006374 SmallString<128> EscapedArg;
Douglas Katzman6bbffc42015-06-25 18:51:37 +00006375 EscapeSpacesAndBackslashes(OriginalArg, EscapedArg);
Kevin Enderby292dc082011-12-22 19:31:58 +00006376 Flags += " ";
Bob Wilsond5aad2a2014-11-04 22:28:48 +00006377 Flags += EscapedArg;
Kevin Enderby292dc082011-12-22 19:31:58 +00006378 }
6379 CmdArgs.push_back("-dwarf-debug-flags");
Yaron Keren92e1b622015-03-18 10:17:07 +00006380 CmdArgs.push_back(Args.MakeArgString(Flags));
Kevin Enderby292dc082011-12-22 19:31:58 +00006381 }
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00006382
6383 // FIXME: Add -static support, once we have it.
6384
Daniel Sanders7f933f42015-01-30 17:35:23 +00006385 // Add target specific flags.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006386 switch (getToolChain().getArch()) {
Daniel Sanders7f933f42015-01-30 17:35:23 +00006387 default:
6388 break;
6389
6390 case llvm::Triple::mips:
6391 case llvm::Triple::mipsel:
6392 case llvm::Triple::mips64:
6393 case llvm::Triple::mips64el:
6394 AddMIPSTargetArgs(Args, CmdArgs);
6395 break;
6396 }
6397
David Blaikie372d9502014-01-17 03:17:40 +00006398 // Consume all the warning flags. Usually this would be handled more
6399 // gracefully by -cc1 (warning about unknown warning flags, etc) but -cc1as
6400 // doesn't handle that so rather than warning about unused flags that are
6401 // actually used, we'll lie by omission instead.
6402 // FIXME: Stop lying and consume only the appropriate driver flags
Eric Christopher5d1caa52016-01-07 02:00:55 +00006403 Args.ClaimAllArgs(options::OPT_W_Group);
David Blaikie372d9502014-01-17 03:17:40 +00006404
David Blaikie9260ed62013-07-25 21:19:01 +00006405 CollectArgsForIntegratedAssembler(C, Args, CmdArgs,
6406 getToolChain().getDriver());
6407
Daniel Dunbar252e8f92011-04-29 17:53:18 +00006408 Args.AddAllArgs(CmdArgs, options::OPT_mllvm);
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00006409
6410 assert(Output.isFilename() && "Unexpected lipo output.");
6411 CmdArgs.push_back("-o");
6412 CmdArgs.push_back(Output.getFilename());
6413
Daniel Dunbarb440f562010-08-02 02:38:21 +00006414 assert(Input.isFilename() && "Invalid input.");
6415 CmdArgs.push_back(Input.getFilename());
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00006416
Daniel Dunbarb31b76f2010-07-18 21:16:15 +00006417 const char *Exec = getToolChain().getDriver().getClangProgramPath();
Justin Bognerd3371d82015-07-17 03:35:54 +00006418 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eric Christophera75018a2013-04-10 21:30:40 +00006419
6420 // Handle the debug info splitting at object creation time if we're
6421 // creating an object.
6422 // TODO: Currently only works on linux with newer objcopy.
6423 if (Args.hasArg(options::OPT_gsplit_dwarf) &&
Cameron Esfahani556d91e2013-09-14 01:09:11 +00006424 getToolChain().getTriple().isOSLinux())
Eric Christophera75018a2013-04-10 21:30:40 +00006425 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output,
Artem Belevichba558952015-05-06 18:20:23 +00006426 SplitDebugName(Args, Input));
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00006427}
6428
Reid Kleckner0290c9c2014-09-15 17:45:39 +00006429void GnuTool::anchor() {}
6430
Daniel Dunbara3246a02009-03-18 08:07:30 +00006431void gcc::Common::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbara3246a02009-03-18 08:07:30 +00006432 const InputInfo &Output,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006433 const InputInfoList &Inputs, const ArgList &Args,
Daniel Dunbara3246a02009-03-18 08:07:30 +00006434 const char *LinkingOutput) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00006435 const Driver &D = getToolChain().getDriver();
Daniel Dunbara3246a02009-03-18 08:07:30 +00006436 ArgStringList CmdArgs;
Daniel Dunbar1a093d22009-03-18 06:00:36 +00006437
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006438 for (const auto &A : Args) {
Michael J. Spencer66e2b202012-10-19 22:37:06 +00006439 if (forwardToGCC(A->getOption())) {
Eric Christopher3f07d852016-01-07 09:03:42 +00006440 // It is unfortunate that we have to claim here, as this means
6441 // we will basically never report anything interesting for
6442 // platforms using a generic gcc, even if we are just using gcc
6443 // to get to the assembler.
6444 A->claim();
6445
Daniel Dunbar939c1212010-08-03 16:14:14 +00006446 // Don't forward any -g arguments to assembly steps.
6447 if (isa<AssembleJobAction>(JA) &&
6448 A->getOption().matches(options::OPT_g_Group))
6449 continue;
6450
NAKAMURA Takumi053704f2013-08-19 11:51:51 +00006451 // Don't forward any -W arguments to assembly and link steps.
6452 if ((isa<AssembleJobAction>(JA) || isa<LinkJobAction>(JA)) &&
6453 A->getOption().matches(options::OPT_W_Group))
6454 continue;
6455
Daniel Dunbara2aedc62009-03-18 10:01:51 +00006456 A->render(Args, CmdArgs);
Daniel Dunbar2da02722009-03-19 07:55:12 +00006457 }
Daniel Dunbara3246a02009-03-18 08:07:30 +00006458 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006459
Daniel Dunbar4e295052010-01-25 22:35:08 +00006460 RenderExtraToolArgs(JA, CmdArgs);
Daniel Dunbara3246a02009-03-18 08:07:30 +00006461
6462 // If using a driver driver, force the arch.
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00006463 if (getToolChain().getTriple().isOSDarwin()) {
Daniel Dunbara3246a02009-03-18 08:07:30 +00006464 CmdArgs.push_back("-arch");
Rafael Espindolaed1233e2014-08-28 21:23:05 +00006465 CmdArgs.push_back(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006466 Args.MakeArgString(getToolChain().getDefaultUniversalArchName()));
Daniel Dunbara3246a02009-03-18 08:07:30 +00006467 }
6468
Daniel Dunbar5716d872009-05-02 21:41:52 +00006469 // Try to force gcc to match the tool chain we want, if we recognize
6470 // the arch.
Daniel Dunbar5bbebfe2009-05-22 02:21:04 +00006471 //
6472 // FIXME: The triple class should directly provide the information we want
6473 // here.
Douglas Katzman38857552015-08-20 18:32:26 +00006474 switch (getToolChain().getArch()) {
6475 default:
6476 break;
6477 case llvm::Triple::x86:
6478 case llvm::Triple::ppc:
Daniel Dunbar5716d872009-05-02 21:41:52 +00006479 CmdArgs.push_back("-m32");
Douglas Katzman38857552015-08-20 18:32:26 +00006480 break;
6481 case llvm::Triple::x86_64:
6482 case llvm::Triple::ppc64:
6483 case llvm::Triple::ppc64le:
Daniel Dunbar5716d872009-05-02 21:41:52 +00006484 CmdArgs.push_back("-m64");
Douglas Katzman38857552015-08-20 18:32:26 +00006485 break;
6486 case llvm::Triple::sparcel:
6487 CmdArgs.push_back("-EL");
6488 break;
6489 }
Daniel Dunbar5716d872009-05-02 21:41:52 +00006490
Daniel Dunbarb440f562010-08-02 02:38:21 +00006491 if (Output.isFilename()) {
Daniel Dunbara3246a02009-03-18 08:07:30 +00006492 CmdArgs.push_back("-o");
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00006493 CmdArgs.push_back(Output.getFilename());
6494 } else {
6495 assert(Output.isNothing() && "Unexpected output");
Daniel Dunbara3246a02009-03-18 08:07:30 +00006496 CmdArgs.push_back("-fsyntax-only");
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00006497 }
Daniel Dunbara3246a02009-03-18 08:07:30 +00006498
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006499 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbara3246a02009-03-18 08:07:30 +00006500
6501 // Only pass -x if gcc will understand it; otherwise hope gcc
6502 // understands the suffix correctly. The main use case this would go
6503 // wrong in is for linker inputs if they happened to have an odd
6504 // suffix; really the only way to get this to happen is a command
6505 // like '-x foobar a.c' which will treat a.c like a linker input.
6506 //
6507 // FIXME: For the linker case specifically, can we safely convert
6508 // inputs into '-Wl,' options?
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006509 for (const auto &II : Inputs) {
Daniel Dunbar6cdf83c2009-09-01 16:57:46 +00006510 // Don't try to pass LLVM or AST inputs to a generic gcc.
Eric Christopherc1984072015-12-08 02:10:19 +00006511 if (types::isLLVMIR(II.getType()))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00006512 D.Diag(diag::err_drv_no_linker_llvm_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006513 << getToolChain().getTripleString();
Daniel Dunbar6cdf83c2009-09-01 16:57:46 +00006514 else if (II.getType() == types::TY_AST)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006515 D.Diag(diag::err_drv_no_ast_support) << getToolChain().getTripleString();
Douglas Gregorbf7fc9c2013-03-27 16:47:18 +00006516 else if (II.getType() == types::TY_ModuleFile)
6517 D.Diag(diag::err_drv_no_module_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006518 << getToolChain().getTripleString();
Daniel Dunbare3e263f2009-05-02 20:14:53 +00006519
Daniel Dunbara3246a02009-03-18 08:07:30 +00006520 if (types::canTypeBeUserSpecified(II.getType())) {
6521 CmdArgs.push_back("-x");
6522 CmdArgs.push_back(types::getTypeName(II.getType()));
6523 }
6524
Daniel Dunbarb440f562010-08-02 02:38:21 +00006525 if (II.isFilename())
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00006526 CmdArgs.push_back(II.getFilename());
Daniel Dunbarf2476752010-09-25 18:10:05 +00006527 else {
6528 const Arg &A = II.getInputArg();
6529
6530 // Reverse translate some rewritten options.
6531 if (A.getOption().matches(options::OPT_Z_reserved_lib_stdcxx)) {
6532 CmdArgs.push_back("-lstdc++");
6533 continue;
6534 }
6535
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00006536 // Don't render as input, we need gcc to do the translations.
Daniel Dunbarf2476752010-09-25 18:10:05 +00006537 A.render(Args, CmdArgs);
6538 }
Daniel Dunbara3246a02009-03-18 08:07:30 +00006539 }
6540
Dylan Noblesmith70e73a32011-04-09 13:31:59 +00006541 const std::string customGCCName = D.getCCCGenericGCCName();
6542 const char *GCCName;
6543 if (!customGCCName.empty())
6544 GCCName = customGCCName.c_str();
Hans Wennborg70850d82013-07-18 20:29:38 +00006545 else if (D.CCCIsCXX()) {
Dylan Noblesmith70e73a32011-04-09 13:31:59 +00006546 GCCName = "g++";
Dylan Noblesmith70e73a32011-04-09 13:31:59 +00006547 } else
6548 GCCName = "gcc";
6549
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006550 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath(GCCName));
Justin Bognerd3371d82015-07-17 03:35:54 +00006551 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar1a093d22009-03-18 06:00:36 +00006552}
6553
Douglas Katzman95354292015-06-23 20:42:09 +00006554void gcc::Preprocessor::RenderExtraToolArgs(const JobAction &JA,
6555 ArgStringList &CmdArgs) const {
Daniel Dunbara3246a02009-03-18 08:07:30 +00006556 CmdArgs.push_back("-E");
Daniel Dunbar1a093d22009-03-18 06:00:36 +00006557}
6558
Douglas Katzman95354292015-06-23 20:42:09 +00006559void gcc::Compiler::RenderExtraToolArgs(const JobAction &JA,
6560 ArgStringList &CmdArgs) const {
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00006561 const Driver &D = getToolChain().getDriver();
6562
Eric Christophercc7ff502015-01-29 00:56:17 +00006563 switch (JA.getType()) {
Daniel Dunbar4e295052010-01-25 22:35:08 +00006564 // If -flto, etc. are present then make sure not to force assembly output.
Eric Christophercc7ff502015-01-29 00:56:17 +00006565 case types::TY_LLVM_IR:
6566 case types::TY_LTO_IR:
6567 case types::TY_LLVM_BC:
6568 case types::TY_LTO_BC:
Daniel Dunbar4e295052010-01-25 22:35:08 +00006569 CmdArgs.push_back("-c");
Eric Christophercc7ff502015-01-29 00:56:17 +00006570 break;
Eric Christopher29a50bc2016-01-06 07:24:45 +00006571 // We assume we've got an "integrated" assembler in that gcc will produce an
6572 // object file itself.
6573 case types::TY_Object:
6574 CmdArgs.push_back("-c");
6575 break;
Eric Christophercc7ff502015-01-29 00:56:17 +00006576 case types::TY_PP_Asm:
Daniel Dunbar4e295052010-01-25 22:35:08 +00006577 CmdArgs.push_back("-S");
Eric Christopher58c21992015-01-30 18:22:23 +00006578 break;
Eric Christophercc7ff502015-01-29 00:56:17 +00006579 case types::TY_Nothing:
6580 CmdArgs.push_back("-fsyntax-only");
6581 break;
6582 default:
6583 D.Diag(diag::err_drv_invalid_gcc_output_type) << getTypeName(JA.getType());
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00006584 }
Daniel Dunbar1a093d22009-03-18 06:00:36 +00006585}
6586
Douglas Katzman95354292015-06-23 20:42:09 +00006587void gcc::Linker::RenderExtraToolArgs(const JobAction &JA,
6588 ArgStringList &CmdArgs) const {
Daniel Dunbara3246a02009-03-18 08:07:30 +00006589 // The types are (hopefully) good enough.
6590}
6591
Tony Linthicum76329bf2011-12-12 21:14:55 +00006592// Hexagon tools start.
Douglas Katzman95354292015-06-23 20:42:09 +00006593void hexagon::Assembler::RenderExtraToolArgs(const JobAction &JA,
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006594 ArgStringList &CmdArgs) const {
6595}
6596
Douglas Katzman95354292015-06-23 20:42:09 +00006597void hexagon::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
6598 const InputInfo &Output,
6599 const InputInfoList &Inputs,
6600 const ArgList &Args,
6601 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00006602 claimNoWarnArgs(Args);
Tony Linthicum76329bf2011-12-12 21:14:55 +00006603
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006604 auto &HTC = static_cast<const toolchains::HexagonToolChain&>(getToolChain());
6605 const Driver &D = HTC.getDriver();
Tony Linthicum76329bf2011-12-12 21:14:55 +00006606 ArgStringList CmdArgs;
6607
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006608 std::string MArchString = "-march=hexagon";
6609 CmdArgs.push_back(Args.MakeArgString(MArchString));
Tony Linthicum76329bf2011-12-12 21:14:55 +00006610
6611 RenderExtraToolArgs(JA, CmdArgs);
6612
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006613 std::string AsName = "hexagon-llvm-mc";
6614 std::string MCpuString = "-mcpu=hexagon" +
6615 toolchains::HexagonToolChain::GetTargetCPUVersion(Args).str();
6616 CmdArgs.push_back("-filetype=obj");
6617 CmdArgs.push_back(Args.MakeArgString(MCpuString));
6618
Tony Linthicum76329bf2011-12-12 21:14:55 +00006619 if (Output.isFilename()) {
6620 CmdArgs.push_back("-o");
6621 CmdArgs.push_back(Output.getFilename());
6622 } else {
6623 assert(Output.isNothing() && "Unexpected output");
6624 CmdArgs.push_back("-fsyntax-only");
6625 }
6626
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006627 if (auto G = toolchains::HexagonToolChain::getSmallDataThreshold(Args)) {
6628 std::string N = llvm::utostr(G.getValue());
6629 CmdArgs.push_back(Args.MakeArgString(std::string("-gpsize=") + N));
6630 }
Tony Linthicum76329bf2011-12-12 21:14:55 +00006631
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006632 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Matthew Curtise5df3812012-12-07 17:23:04 +00006633
Tony Linthicum76329bf2011-12-12 21:14:55 +00006634 // Only pass -x if gcc will understand it; otherwise hope gcc
6635 // understands the suffix correctly. The main use case this would go
6636 // wrong in is for linker inputs if they happened to have an odd
6637 // suffix; really the only way to get this to happen is a command
6638 // like '-x foobar a.c' which will treat a.c like a linker input.
6639 //
6640 // FIXME: For the linker case specifically, can we safely convert
6641 // inputs into '-Wl,' options?
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006642 for (const auto &II : Inputs) {
Tony Linthicum76329bf2011-12-12 21:14:55 +00006643 // Don't try to pass LLVM or AST inputs to a generic gcc.
Eric Christopherc1984072015-12-08 02:10:19 +00006644 if (types::isLLVMIR(II.getType()))
Tony Linthicum76329bf2011-12-12 21:14:55 +00006645 D.Diag(clang::diag::err_drv_no_linker_llvm_support)
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006646 << HTC.getTripleString();
Tony Linthicum76329bf2011-12-12 21:14:55 +00006647 else if (II.getType() == types::TY_AST)
6648 D.Diag(clang::diag::err_drv_no_ast_support)
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006649 << HTC.getTripleString();
Douglas Gregorbf7fc9c2013-03-27 16:47:18 +00006650 else if (II.getType() == types::TY_ModuleFile)
6651 D.Diag(diag::err_drv_no_module_support)
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006652 << HTC.getTripleString();
Tony Linthicum76329bf2011-12-12 21:14:55 +00006653
6654 if (II.isFilename())
6655 CmdArgs.push_back(II.getFilename());
6656 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006657 // Don't render as input, we need gcc to do the translations.
Eric Christopherb0a44f72015-12-08 01:59:51 +00006658 // FIXME: What is this?
Tony Linthicum76329bf2011-12-12 21:14:55 +00006659 II.getInputArg().render(Args, CmdArgs);
6660 }
6661
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006662 auto *Exec = Args.MakeArgString(HTC.GetProgramPath(AsName.c_str()));
Justin Bognerd3371d82015-07-17 03:35:54 +00006663 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Tony Linthicum76329bf2011-12-12 21:14:55 +00006664}
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006665
Douglas Katzman95354292015-06-23 20:42:09 +00006666void hexagon::Linker::RenderExtraToolArgs(const JobAction &JA,
6667 ArgStringList &CmdArgs) const {
Tony Linthicum76329bf2011-12-12 21:14:55 +00006668}
6669
Douglas Katzman54366072015-07-27 16:53:08 +00006670static void
6671constructHexagonLinkArgs(Compilation &C, const JobAction &JA,
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006672 const toolchains::HexagonToolChain &HTC,
Douglas Katzman54366072015-07-27 16:53:08 +00006673 const InputInfo &Output, const InputInfoList &Inputs,
6674 const ArgList &Args, ArgStringList &CmdArgs,
6675 const char *LinkingOutput) {
Tony Linthicum76329bf2011-12-12 21:14:55 +00006676
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006677 const Driver &D = HTC.getDriver();
Matthew Curtise689b052012-12-06 15:46:07 +00006678
Matthew Curtise689b052012-12-06 15:46:07 +00006679 //----------------------------------------------------------------------------
6680 //
6681 //----------------------------------------------------------------------------
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006682 bool IsStatic = Args.hasArg(options::OPT_static);
6683 bool IsShared = Args.hasArg(options::OPT_shared);
6684 bool IsPIE = Args.hasArg(options::OPT_pie);
6685 bool IncStdLib = !Args.hasArg(options::OPT_nostdlib);
6686 bool IncStartFiles = !Args.hasArg(options::OPT_nostartfiles);
6687 bool IncDefLibs = !Args.hasArg(options::OPT_nodefaultlibs);
6688 bool UseG0 = false;
6689 bool UseShared = IsShared && !IsStatic;
Tony Linthicum76329bf2011-12-12 21:14:55 +00006690
Matthew Curtise689b052012-12-06 15:46:07 +00006691 //----------------------------------------------------------------------------
6692 // Silence warnings for various options
6693 //----------------------------------------------------------------------------
Matthew Curtise689b052012-12-06 15:46:07 +00006694 Args.ClaimAllArgs(options::OPT_g_Group);
6695 Args.ClaimAllArgs(options::OPT_emit_llvm);
6696 Args.ClaimAllArgs(options::OPT_w); // Other warning options are already
6697 // handled somewhere else.
6698 Args.ClaimAllArgs(options::OPT_static_libgcc);
6699
6700 //----------------------------------------------------------------------------
6701 //
6702 //----------------------------------------------------------------------------
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006703 if (Args.hasArg(options::OPT_s))
6704 CmdArgs.push_back("-s");
6705
6706 if (Args.hasArg(options::OPT_r))
6707 CmdArgs.push_back("-r");
6708
6709 for (const auto &Opt : HTC.ExtraOpts)
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006710 CmdArgs.push_back(Opt.c_str());
Tony Linthicum76329bf2011-12-12 21:14:55 +00006711
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006712 CmdArgs.push_back("-march=hexagon");
6713 std::string CpuVer =
6714 toolchains::HexagonToolChain::GetTargetCPUVersion(Args).str();
6715 std::string MCpuString = "-mcpu=hexagon" + CpuVer;
6716 CmdArgs.push_back(Args.MakeArgString(MCpuString));
Sebastian Pop86500282012-01-13 20:37:10 +00006717
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006718 if (IsShared) {
Matthew Curtise689b052012-12-06 15:46:07 +00006719 CmdArgs.push_back("-shared");
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006720 // The following should be the default, but doing as hexagon-gcc does.
6721 CmdArgs.push_back("-call_shared");
Tony Linthicum76329bf2011-12-12 21:14:55 +00006722 }
6723
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006724 if (IsStatic)
Matthew Curtise689b052012-12-06 15:46:07 +00006725 CmdArgs.push_back("-static");
Tony Linthicum76329bf2011-12-12 21:14:55 +00006726
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006727 if (IsPIE && !IsShared)
Matthew Curtise8f80a12012-12-06 17:49:03 +00006728 CmdArgs.push_back("-pie");
6729
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006730 if (auto G = toolchains::HexagonToolChain::getSmallDataThreshold(Args)) {
6731 std::string N = llvm::utostr(G.getValue());
6732 CmdArgs.push_back(Args.MakeArgString(std::string("-G") + N));
6733 UseG0 = G.getValue() == 0;
Matthew Curtise8f80a12012-12-06 17:49:03 +00006734 }
6735
Matthew Curtise689b052012-12-06 15:46:07 +00006736 //----------------------------------------------------------------------------
6737 //
6738 //----------------------------------------------------------------------------
6739 CmdArgs.push_back("-o");
6740 CmdArgs.push_back(Output.getFilename());
Tony Linthicum76329bf2011-12-12 21:14:55 +00006741
Matthew Curtise689b052012-12-06 15:46:07 +00006742 //----------------------------------------------------------------------------
6743 // moslib
6744 //----------------------------------------------------------------------------
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006745 std::vector<std::string> OsLibs;
6746 bool HasStandalone = false;
Matthew Curtise689b052012-12-06 15:46:07 +00006747
Sean Silva14facf32015-06-09 01:57:17 +00006748 for (const Arg *A : Args.filtered(options::OPT_moslib_EQ)) {
6749 A->claim();
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006750 OsLibs.emplace_back(A->getValue());
6751 HasStandalone = HasStandalone || (OsLibs.back() == "standalone");
Tony Linthicum76329bf2011-12-12 21:14:55 +00006752 }
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006753 if (OsLibs.empty()) {
6754 OsLibs.push_back("standalone");
6755 HasStandalone = true;
Matthew Curtise689b052012-12-06 15:46:07 +00006756 }
Tony Linthicum76329bf2011-12-12 21:14:55 +00006757
Matthew Curtise689b052012-12-06 15:46:07 +00006758 //----------------------------------------------------------------------------
6759 // Start Files
6760 //----------------------------------------------------------------------------
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006761 const std::string MCpuSuffix = "/" + CpuVer;
6762 const std::string MCpuG0Suffix = MCpuSuffix + "/G0";
6763 const std::string RootDir =
6764 HTC.getHexagonTargetDir(D.InstalledDir, D.PrefixDirs) + "/";
6765 const std::string StartSubDir =
6766 "hexagon/lib" + (UseG0 ? MCpuG0Suffix : MCpuSuffix);
Matthew Curtise689b052012-12-06 15:46:07 +00006767
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006768 auto Find = [&HTC] (const std::string &RootDir, const std::string &SubDir,
6769 const char *Name) -> std::string {
6770 std::string RelName = SubDir + Name;
6771 std::string P = HTC.GetFilePath(RelName.c_str());
6772 if (llvm::sys::fs::exists(P))
6773 return P;
6774 return RootDir + RelName;
6775 };
6776
6777 if (IncStdLib && IncStartFiles) {
6778 if (!IsShared) {
6779 if (HasStandalone) {
6780 std::string Crt0SA = Find(RootDir, StartSubDir, "/crt0_standalone.o");
6781 CmdArgs.push_back(Args.MakeArgString(Crt0SA));
Matthew Curtise689b052012-12-06 15:46:07 +00006782 }
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006783 std::string Crt0 = Find(RootDir, StartSubDir, "/crt0.o");
6784 CmdArgs.push_back(Args.MakeArgString(Crt0));
Matthew Curtise689b052012-12-06 15:46:07 +00006785 }
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006786 std::string Init = UseShared
6787 ? Find(RootDir, StartSubDir + "/pic", "/initS.o")
6788 : Find(RootDir, StartSubDir, "/init.o");
6789 CmdArgs.push_back(Args.MakeArgString(Init));
Matthew Curtise689b052012-12-06 15:46:07 +00006790 }
6791
6792 //----------------------------------------------------------------------------
6793 // Library Search Paths
6794 //----------------------------------------------------------------------------
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006795 const ToolChain::path_list &LibPaths = HTC.getFilePaths();
6796 for (const auto &LibPath : LibPaths)
6797 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + LibPath));
Matthew Curtise689b052012-12-06 15:46:07 +00006798
6799 //----------------------------------------------------------------------------
6800 //
6801 //----------------------------------------------------------------------------
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00006802 Args.AddAllArgs(CmdArgs,
6803 {options::OPT_T_Group, options::OPT_e, options::OPT_s,
6804 options::OPT_t, options::OPT_u_Group});
Matthew Curtise689b052012-12-06 15:46:07 +00006805
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006806 AddLinkerInputs(HTC, Inputs, Args, CmdArgs);
Matthew Curtise689b052012-12-06 15:46:07 +00006807
6808 //----------------------------------------------------------------------------
6809 // Libraries
6810 //----------------------------------------------------------------------------
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006811 if (IncStdLib && IncDefLibs) {
Hans Wennborg70850d82013-07-18 20:29:38 +00006812 if (D.CCCIsCXX()) {
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006813 HTC.AddCXXStdlibLibArgs(Args, CmdArgs);
Matthew Curtise689b052012-12-06 15:46:07 +00006814 CmdArgs.push_back("-lm");
6815 }
6816
6817 CmdArgs.push_back("--start-group");
6818
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006819 if (!IsShared) {
6820 for (const std::string &Lib : OsLibs)
Douglas Katzman2675d012015-06-29 19:12:56 +00006821 CmdArgs.push_back(Args.MakeArgString("-l" + Lib));
Matthew Curtise689b052012-12-06 15:46:07 +00006822 CmdArgs.push_back("-lc");
6823 }
6824 CmdArgs.push_back("-lgcc");
6825
6826 CmdArgs.push_back("--end-group");
6827 }
6828
6829 //----------------------------------------------------------------------------
6830 // End files
6831 //----------------------------------------------------------------------------
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006832 if (IncStdLib && IncStartFiles) {
6833 std::string Fini = UseShared
6834 ? Find(RootDir, StartSubDir + "/pic", "/finiS.o")
6835 : Find(RootDir, StartSubDir, "/fini.o");
6836 CmdArgs.push_back(Args.MakeArgString(Fini));
Matthew Curtise689b052012-12-06 15:46:07 +00006837 }
Ikhlas Ajbar71d19f32015-05-09 02:13:25 +00006838}
6839
Douglas Katzman95354292015-06-23 20:42:09 +00006840void hexagon::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6841 const InputInfo &Output,
6842 const InputInfoList &Inputs,
6843 const ArgList &Args,
6844 const char *LinkingOutput) const {
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006845 auto &HTC = static_cast<const toolchains::HexagonToolChain&>(getToolChain());
Ikhlas Ajbar71d19f32015-05-09 02:13:25 +00006846
6847 ArgStringList CmdArgs;
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006848 constructHexagonLinkArgs(C, JA, HTC, Output, Inputs, Args, CmdArgs,
Ikhlas Ajbar71d19f32015-05-09 02:13:25 +00006849 LinkingOutput);
Matthew Curtise689b052012-12-06 15:46:07 +00006850
Krzysztof Parzyszek1e6e3c62015-12-14 15:03:57 +00006851 std::string Linker = HTC.GetProgramPath("hexagon-link");
David Blaikiec11bf802014-09-04 16:04:28 +00006852 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Linker),
Justin Bognerd3371d82015-07-17 03:35:54 +00006853 CmdArgs, Inputs));
Tony Linthicum76329bf2011-12-12 21:14:55 +00006854}
6855// Hexagon tools end.
6856
Tom Stellard8fa33092015-07-18 01:49:05 +00006857void amdgpu::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6858 const InputInfo &Output,
6859 const InputInfoList &Inputs,
6860 const ArgList &Args,
6861 const char *LinkingOutput) const {
6862
6863 std::string Linker = getToolChain().GetProgramPath(getShortName());
6864 ArgStringList CmdArgs;
Tom Stellard8fa33092015-07-18 01:49:05 +00006865 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Tom Stellardf6699f52016-05-05 17:03:41 +00006866 CmdArgs.push_back("-shared");
6867 CmdArgs.push_back("-o");
Tom Stellard8fa33092015-07-18 01:49:05 +00006868 CmdArgs.push_back(Output.getFilename());
6869 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Linker),
6870 CmdArgs, Inputs));
6871}
6872// AMDGPU tools end.
6873
Dan Gohman52816862015-12-16 23:30:41 +00006874wasm::Linker::Linker(const ToolChain &TC)
6875 : GnuTool("wasm::Linker", "lld", TC) {}
6876
6877bool wasm::Linker::isLinkJob() const {
6878 return true;
6879}
6880
6881bool wasm::Linker::hasIntegratedCPP() const {
6882 return false;
6883}
6884
6885void wasm::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6886 const InputInfo &Output,
6887 const InputInfoList &Inputs,
6888 const ArgList &Args,
6889 const char *LinkingOutput) const {
Dan Gohman57b62c52016-02-22 19:26:15 +00006890
6891 const ToolChain &ToolChain = getToolChain();
6892 const Driver &D = ToolChain.getDriver();
6893 const char *Linker = Args.MakeArgString(ToolChain.GetLinkerPath());
Dan Gohman52816862015-12-16 23:30:41 +00006894 ArgStringList CmdArgs;
6895 CmdArgs.push_back("-flavor");
6896 CmdArgs.push_back("ld");
Dan Gohman1aa58282016-01-06 19:43:32 +00006897
6898 // Enable garbage collection of unused input sections by default, since code
Dan Gohmana5b804b2016-01-07 00:50:27 +00006899 // size is of particular importance. This is significantly facilitated by
6900 // the enabling of -ffunction-sections and -fdata-sections in
6901 // Clang::ConstructJob.
Dan Gohman4e480202016-01-07 00:32:04 +00006902 if (areOptimizationsEnabled(Args))
6903 CmdArgs.push_back("--gc-sections");
Dan Gohman1aa58282016-01-06 19:43:32 +00006904
Dan Gohman57b62c52016-02-22 19:26:15 +00006905 if (Args.hasArg(options::OPT_rdynamic))
6906 CmdArgs.push_back("-export-dynamic");
6907 if (Args.hasArg(options::OPT_s))
6908 CmdArgs.push_back("--strip-all");
6909 if (Args.hasArg(options::OPT_shared))
6910 CmdArgs.push_back("-shared");
6911 if (Args.hasArg(options::OPT_static))
6912 CmdArgs.push_back("-Bstatic");
6913
6914 Args.AddAllArgs(CmdArgs, options::OPT_L);
6915 ToolChain.AddFilePathLibArgs(Args, CmdArgs);
6916
6917 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) {
6918 if (Args.hasArg(options::OPT_shared))
6919 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("rcrt1.o")));
6920 else if (Args.hasArg(options::OPT_pie))
6921 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("Scrt1.o")));
6922 else
6923 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crt1.o")));
6924
6925 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
6926 }
6927
6928 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
6929
6930 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs)) {
6931 if (D.CCCIsCXX())
6932 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
6933
6934 if (Args.hasArg(options::OPT_pthread))
6935 CmdArgs.push_back("-lpthread");
6936
6937 CmdArgs.push_back("-lc");
6938 CmdArgs.push_back("-lcompiler_rt");
6939 }
6940
6941 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles))
6942 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
6943
Dan Gohman52816862015-12-16 23:30:41 +00006944 CmdArgs.push_back("-o");
6945 CmdArgs.push_back(Output.getFilename());
Dan Gohman57b62c52016-02-22 19:26:15 +00006946
Dan Gohman52816862015-12-16 23:30:41 +00006947 C.addCommand(llvm::make_unique<Command>(JA, *this, Linker, CmdArgs, Inputs));
6948}
6949
Renato Golin7c542b42015-07-27 23:44:45 +00006950const std::string arm::getARMArch(StringRef Arch, const llvm::Triple &Triple) {
Gabor Ballabascebcb3b2015-06-11 12:29:56 +00006951 std::string MArch;
Renato Goline17c5802015-07-27 23:44:42 +00006952 if (!Arch.empty())
6953 MArch = Arch;
6954 else
Bernard Ogden31561762013-12-12 13:27:11 +00006955 MArch = Triple.getArchName();
Bradley Smithbbf5a002015-11-18 16:33:48 +00006956 MArch = StringRef(MArch).split("+").first.lower();
John Brawn94fd9632015-05-21 12:19:49 +00006957
6958 // Handle -march=native.
6959 if (MArch == "native") {
6960 std::string CPU = llvm::sys::getHostCPUName();
6961 if (CPU != "generic") {
6962 // Translate the native cpu into the architecture suffix for that CPU.
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006963 StringRef Suffix = arm::getLLVMArchSuffixForARM(CPU, MArch, Triple);
John Brawn94fd9632015-05-21 12:19:49 +00006964 // If there is no valid architecture suffix for this CPU we don't know how
6965 // to handle it, so return no architecture.
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006966 if (Suffix.empty())
John Brawn94fd9632015-05-21 12:19:49 +00006967 MArch = "";
6968 else
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006969 MArch = std::string("arm") + Suffix.str();
John Brawn94fd9632015-05-21 12:19:49 +00006970 }
6971 }
6972
Vladimir Sukharevc6dab752015-05-14 08:25:18 +00006973 return MArch;
6974}
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006975
Vladimir Sukharevc6dab752015-05-14 08:25:18 +00006976/// Get the (LLVM) name of the minimum ARM CPU for the arch we are targeting.
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006977StringRef arm::getARMCPUForMArch(StringRef Arch, const llvm::Triple &Triple) {
Renato Goline17c5802015-07-27 23:44:42 +00006978 std::string MArch = getARMArch(Arch, Triple);
John Brawn94fd9632015-05-21 12:19:49 +00006979 // getARMCPUForArch defaults to the triple if MArch is empty, but empty MArch
6980 // here means an -march=native that we can't handle, so instead return no CPU.
6981 if (MArch.empty())
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006982 return StringRef();
Bernard Ogden31561762013-12-12 13:27:11 +00006983
John Brawna95c1a82015-05-08 12:52:18 +00006984 // We need to return an empty string here on invalid MArch values as the
6985 // various places that call this function can't cope with a null result.
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006986 return Triple.getARMCPUForArch(MArch);
Bernard Ogden31561762013-12-12 13:27:11 +00006987}
6988
6989/// getARMTargetCPU - Get the (LLVM) name of the ARM cpu we are targeting.
Renato Golin7c542b42015-07-27 23:44:45 +00006990std::string arm::getARMTargetCPU(StringRef CPU, StringRef Arch,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006991 const llvm::Triple &Triple) {
Bernard Ogden31561762013-12-12 13:27:11 +00006992 // FIXME: Warn on inconsistent use of -mcpu and -march.
6993 // If we have -mcpu=, use that.
Renato Goline17c5802015-07-27 23:44:42 +00006994 if (!CPU.empty()) {
Bradley Smithbbf5a002015-11-18 16:33:48 +00006995 std::string MCPU = StringRef(CPU).split("+").first.lower();
Bernard Ogden31561762013-12-12 13:27:11 +00006996 // Handle -mcpu=native.
6997 if (MCPU == "native")
Rafael Espindola9c5ef122013-12-12 15:39:05 +00006998 return llvm::sys::getHostCPUName();
Bernard Ogden31561762013-12-12 13:27:11 +00006999 else
Rafael Espindola80d333b2013-12-12 15:48:19 +00007000 return MCPU;
Bernard Ogden31561762013-12-12 13:27:11 +00007001 }
7002
Renato Goline17c5802015-07-27 23:44:42 +00007003 return getARMCPUForMArch(Arch, Triple);
Bernard Ogden31561762013-12-12 13:27:11 +00007004}
7005
7006/// getLLVMArchSuffixForARM - Get the LLVM arch name to use for a particular
Vladimir Sukharevc6dab752015-05-14 08:25:18 +00007007/// CPU (or Arch, if CPU is generic).
Bernard Ogden31561762013-12-12 13:27:11 +00007008// FIXME: This is redundant with -mcpu, why does LLVM use this.
Vladimir Sukharev64f68242015-09-23 09:29:32 +00007009StringRef arm::getLLVMArchSuffixForARM(StringRef CPU, StringRef Arch,
7010 const llvm::Triple &Triple) {
7011 unsigned ArchKind;
Vladimir Sukharev64f68242015-09-23 09:29:32 +00007012 if (CPU == "generic") {
Vladimir Sukhareva317dfb2015-09-24 10:06:44 +00007013 std::string ARMArch = tools::arm::getARMArch(Arch, Triple);
Vladimir Sukharev2eef4b52015-09-24 09:55:08 +00007014 ArchKind = llvm::ARM::parseArch(ARMArch);
Vladimir Sukharev64f68242015-09-23 09:29:32 +00007015 if (ArchKind == llvm::ARM::AK_INVALID)
7016 // In case of generic Arch, i.e. "arm",
7017 // extract arch from default cpu of the Triple
Vladimir Sukharev2eef4b52015-09-24 09:55:08 +00007018 ArchKind = llvm::ARM::parseCPUArch(Triple.getARMCPUForArch(ARMArch));
Vladimir Sukharev64f68242015-09-23 09:29:32 +00007019 } else {
Tim Northover6f3ff222015-10-30 16:30:27 +00007020 // FIXME: horrible hack to get around the fact that Cortex-A7 is only an
7021 // armv7k triple if it's actually been specified via "-arch armv7k".
7022 ArchKind = (Arch == "armv7k" || Arch == "thumbv7k")
Aaron Ballman43059102015-11-04 14:43:43 +00007023 ? (unsigned)llvm::ARM::AK_ARMV7K
Tim Northover6f3ff222015-10-30 16:30:27 +00007024 : llvm::ARM::parseCPUArch(CPU);
Vladimir Sukharev64f68242015-09-23 09:29:32 +00007025 }
Renato Golin3c007252015-05-28 15:05:53 +00007026 if (ArchKind == llvm::ARM::AK_INVALID)
7027 return "";
Chandler Carruthaa0caeb2015-08-30 02:16:36 +00007028 return llvm::ARM::getSubArch(ArchKind);
Bernard Ogden31561762013-12-12 13:27:11 +00007029}
7030
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007031void arm::appendEBLinkFlags(const ArgList &Args, ArgStringList &CmdArgs,
Vladimir Sukharevc6dab752015-05-14 08:25:18 +00007032 const llvm::Triple &Triple) {
Joerg Sonnenberger1689d3f2015-01-28 23:30:39 +00007033 if (Args.hasArg(options::OPT_r))
7034 return;
7035
John Brawn94fd9632015-05-21 12:19:49 +00007036 // ARMv7 (and later) and ARMv6-M do not support BE-32, so instruct the linker
7037 // to generate BE-8 executables.
7038 if (getARMSubArchVersionNumber(Triple) >= 7 || isARMMProfile(Triple))
7039 CmdArgs.push_back("--be8");
Joerg Sonnenberger1689d3f2015-01-28 23:30:39 +00007040}
7041
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00007042mips::NanEncoding mips::getSupportedNanEncoding(StringRef &CPU) {
Daniel Sanderse0395a72015-09-24 10:22:17 +00007043 // Strictly speaking, mips32r2 and mips64r2 are NanLegacy-only since Nan2008
7044 // was first introduced in Release 3. However, other compilers have
7045 // traditionally allowed it for Release 2 so we should do the same.
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00007046 return (NanEncoding)llvm::StringSwitch<int>(CPU)
7047 .Case("mips1", NanLegacy)
7048 .Case("mips2", NanLegacy)
7049 .Case("mips3", NanLegacy)
7050 .Case("mips4", NanLegacy)
7051 .Case("mips5", NanLegacy)
7052 .Case("mips32", NanLegacy)
Daniel Sanderse0395a72015-09-24 10:22:17 +00007053 .Case("mips32r2", NanLegacy | Nan2008)
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00007054 .Case("mips32r3", NanLegacy | Nan2008)
7055 .Case("mips32r5", NanLegacy | Nan2008)
7056 .Case("mips32r6", Nan2008)
7057 .Case("mips64", NanLegacy)
Daniel Sanderse0395a72015-09-24 10:22:17 +00007058 .Case("mips64r2", NanLegacy | Nan2008)
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00007059 .Case("mips64r3", NanLegacy | Nan2008)
7060 .Case("mips64r5", NanLegacy | Nan2008)
7061 .Case("mips64r6", Nan2008)
7062 .Default(NanLegacy);
7063}
7064
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00007065bool mips::hasMipsAbiArg(const ArgList &Args, const char *Value) {
7066 Arg *A = Args.getLastArg(options::OPT_mabi_EQ);
7067 return A && (A->getValue() == StringRef(Value));
7068}
7069
Simon Atanasyand95c67d2014-08-13 14:34:14 +00007070bool mips::isUCLibc(const ArgList &Args) {
7071 Arg *A = Args.getLastArg(options::OPT_m_libc_Group);
Rafael Espindolad3d657c2014-08-13 17:15:42 +00007072 return A && A->getOption().matches(options::OPT_muclibc);
Simon Atanasyand95c67d2014-08-13 14:34:14 +00007073}
7074
Daniel Sanders2bf13662014-07-10 14:40:57 +00007075bool mips::isNaN2008(const ArgList &Args, const llvm::Triple &Triple) {
Daniel Sanders3b92c5b2014-06-24 15:04:16 +00007076 if (Arg *NaNArg = Args.getLastArg(options::OPT_mnan_EQ))
7077 return llvm::StringSwitch<bool>(NaNArg->getValue())
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007078 .Case("2008", true)
7079 .Case("legacy", false)
7080 .Default(false);
Daniel Sanders3b92c5b2014-06-24 15:04:16 +00007081
7082 // NaN2008 is the default for MIPS32r6/MIPS64r6.
Daniel Sanders2bf13662014-07-10 14:40:57 +00007083 return llvm::StringSwitch<bool>(getCPUName(Args, Triple))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007084 .Cases("mips32r6", "mips64r6", true)
7085 .Default(false);
Daniel Sanders3b92c5b2014-06-24 15:04:16 +00007086
7087 return false;
7088}
7089
Petar Jovanovic3ca16222016-05-18 12:46:06 +00007090bool mips::isFP64ADefault(const llvm::Triple &Triple, StringRef CPUName) {
7091 if (!Triple.isAndroid())
7092 return false;
7093
7094 // Android MIPS32R6 defaults to FP64A.
7095 return llvm::StringSwitch<bool>(CPUName)
7096 .Case("mips32r6", true)
7097 .Default(false);
7098}
7099
Daniel Sanders379d44b2014-07-16 11:52:23 +00007100bool mips::isFPXXDefault(const llvm::Triple &Triple, StringRef CPUName,
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00007101 StringRef ABIName, mips::FloatABI FloatABI) {
Daniel Sanders379d44b2014-07-16 11:52:23 +00007102 if (Triple.getVendor() != llvm::Triple::ImaginationTechnologies &&
Petar Jovanovic3ca16222016-05-18 12:46:06 +00007103 Triple.getVendor() != llvm::Triple::MipsTechnologies &&
7104 !Triple.isAndroid())
Daniel Sanders379d44b2014-07-16 11:52:23 +00007105 return false;
7106
7107 if (ABIName != "32")
7108 return false;
7109
Toma Tabacu94ea6862015-06-16 13:54:13 +00007110 // FPXX shouldn't be used if either -msoft-float or -mfloat-abi=soft is
7111 // present.
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00007112 if (FloatABI == mips::FloatABI::Soft)
Toma Tabacu94ea6862015-06-16 13:54:13 +00007113 return false;
7114
Daniel Sanders379d44b2014-07-16 11:52:23 +00007115 return llvm::StringSwitch<bool>(CPUName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007116 .Cases("mips2", "mips3", "mips4", "mips5", true)
7117 .Cases("mips32", "mips32r2", "mips32r3", "mips32r5", true)
7118 .Cases("mips64", "mips64r2", "mips64r3", "mips64r5", true)
7119 .Default(false);
Daniel Sanders379d44b2014-07-16 11:52:23 +00007120}
7121
Toma Tabacu94ea6862015-06-16 13:54:13 +00007122bool mips::shouldUseFPXX(const ArgList &Args, const llvm::Triple &Triple,
7123 StringRef CPUName, StringRef ABIName,
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00007124 mips::FloatABI FloatABI) {
Toma Tabacu94ea6862015-06-16 13:54:13 +00007125 bool UseFPXX = isFPXXDefault(Triple, CPUName, ABIName, FloatABI);
7126
7127 // FPXX shouldn't be used if -msingle-float is present.
7128 if (Arg *A = Args.getLastArg(options::OPT_msingle_float,
7129 options::OPT_mdouble_float))
7130 if (A->getOption().matches(options::OPT_msingle_float))
7131 UseFPXX = false;
7132
7133 return UseFPXX;
7134}
7135
Tim Northover157d9112014-01-16 08:48:16 +00007136llvm::Triple::ArchType darwin::getArchTypeForMachOArchName(StringRef Str) {
Rafael Espindoladcbf6982012-10-31 18:51:07 +00007137 // See arch(3) and llvm-gcc's driver-driver.c. We don't implement support for
7138 // archs which Darwin doesn't use.
7139
7140 // The matching this routine does is fairly pointless, since it is neither the
7141 // complete architecture list, nor a reasonable subset. The problem is that
7142 // historically the driver driver accepts this and also ties its -march=
7143 // handling to the architecture name, so we need to be careful before removing
7144 // support for it.
7145
7146 // This code must be kept in sync with Clang's Darwin specific argument
7147 // translation.
7148
7149 return llvm::StringSwitch<llvm::Triple::ArchType>(Str)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007150 .Cases("ppc", "ppc601", "ppc603", "ppc604", "ppc604e", llvm::Triple::ppc)
7151 .Cases("ppc750", "ppc7400", "ppc7450", "ppc970", llvm::Triple::ppc)
7152 .Case("ppc64", llvm::Triple::ppc64)
7153 .Cases("i386", "i486", "i486SX", "i586", "i686", llvm::Triple::x86)
7154 .Cases("pentium", "pentpro", "pentIIm3", "pentIIm5", "pentium4",
7155 llvm::Triple::x86)
7156 .Cases("x86_64", "x86_64h", llvm::Triple::x86_64)
7157 // This is derived from the driver driver.
7158 .Cases("arm", "armv4t", "armv5", "armv6", "armv6m", llvm::Triple::arm)
7159 .Cases("armv7", "armv7em", "armv7k", "armv7m", llvm::Triple::arm)
7160 .Cases("armv7s", "xscale", llvm::Triple::arm)
7161 .Case("arm64", llvm::Triple::aarch64)
7162 .Case("r600", llvm::Triple::r600)
7163 .Case("amdgcn", llvm::Triple::amdgcn)
7164 .Case("nvptx", llvm::Triple::nvptx)
7165 .Case("nvptx64", llvm::Triple::nvptx64)
7166 .Case("amdil", llvm::Triple::amdil)
7167 .Case("spir", llvm::Triple::spir)
7168 .Default(llvm::Triple::UnknownArch);
Rafael Espindoladcbf6982012-10-31 18:51:07 +00007169}
Tony Linthicum76329bf2011-12-12 21:14:55 +00007170
Tim Northover157d9112014-01-16 08:48:16 +00007171void darwin::setTripleTypeForMachOArchName(llvm::Triple &T, StringRef Str) {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007172 const llvm::Triple::ArchType Arch = getArchTypeForMachOArchName(Str);
Tim Northover157d9112014-01-16 08:48:16 +00007173 T.setArch(Arch);
7174
7175 if (Str == "x86_64h")
7176 T.setArchName(Str);
7177 else if (Str == "armv6m" || Str == "armv7m" || Str == "armv7em") {
7178 T.setOS(llvm::Triple::UnknownOS);
Saleem Abdulrasool29b82b62014-03-06 20:47:19 +00007179 T.setObjectFormat(llvm::Triple::MachO);
Tim Northover157d9112014-01-16 08:48:16 +00007180 }
7181}
7182
Bob Wilsondecc03e2012-11-23 06:14:39 +00007183const char *Clang::getBaseInputName(const ArgList &Args,
Artem Belevichba558952015-05-06 18:20:23 +00007184 const InputInfo &Input) {
7185 return Args.MakeArgString(llvm::sys::path::filename(Input.getBaseInput()));
Daniel Dunbarafec1f52009-03-29 18:40:18 +00007186}
7187
Bob Wilsondecc03e2012-11-23 06:14:39 +00007188const char *Clang::getBaseInputStem(const ArgList &Args,
7189 const InputInfoList &Inputs) {
Artem Belevichba558952015-05-06 18:20:23 +00007190 const char *Str = getBaseInputName(Args, Inputs[0]);
Daniel Dunbarafec1f52009-03-29 18:40:18 +00007191
Chris Lattner906bb902011-01-16 08:14:11 +00007192 if (const char *End = strrchr(Str, '.'))
Daniel Dunbar1c28f1e2009-09-09 22:32:48 +00007193 return Args.MakeArgString(std::string(Str, End));
Daniel Dunbarafec1f52009-03-29 18:40:18 +00007194
7195 return Str;
7196}
7197
Bob Wilsondecc03e2012-11-23 06:14:39 +00007198const char *Clang::getDependencyFileName(const ArgList &Args,
7199 const InputInfoList &Inputs) {
Daniel Dunbarafec1f52009-03-29 18:40:18 +00007200 // FIXME: Think about this more.
7201 std::string Res;
7202
7203 if (Arg *OutputOpt = Args.getLastArg(options::OPT_o)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00007204 std::string Str(OutputOpt->getValue());
Daniel Dunbarafec1f52009-03-29 18:40:18 +00007205 Res = Str.substr(0, Str.rfind('.'));
Chad Rosier6fdf38b2011-08-17 23:08:45 +00007206 } else {
Bob Wilsondecc03e2012-11-23 06:14:39 +00007207 Res = getBaseInputStem(Args, Inputs);
Chad Rosier6fdf38b2011-08-17 23:08:45 +00007208 }
Daniel Dunbar1c28f1e2009-09-09 22:32:48 +00007209 return Args.MakeArgString(Res + ".d");
Daniel Dunbarafec1f52009-03-29 18:40:18 +00007210}
7211
Douglas Katzman95354292015-06-23 20:42:09 +00007212void cloudabi::Linker::ConstructJob(Compilation &C, const JobAction &JA,
7213 const InputInfo &Output,
7214 const InputInfoList &Inputs,
7215 const ArgList &Args,
7216 const char *LinkingOutput) const {
Ed Schouten3c3e58c2015-03-26 11:13:44 +00007217 const ToolChain &ToolChain = getToolChain();
7218 const Driver &D = ToolChain.getDriver();
7219 ArgStringList CmdArgs;
7220
7221 // Silence warning for "clang -g foo.o -o foo"
7222 Args.ClaimAllArgs(options::OPT_g_Group);
7223 // and "clang -emit-llvm foo.o -o foo"
7224 Args.ClaimAllArgs(options::OPT_emit_llvm);
7225 // and for "clang -w foo.o -o foo". Other warning options are already
7226 // handled somewhere else.
7227 Args.ClaimAllArgs(options::OPT_w);
7228
7229 if (!D.SysRoot.empty())
7230 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
7231
7232 // CloudABI only supports static linkage.
7233 CmdArgs.push_back("-Bstatic");
Ed Schouten506f2952016-04-06 15:37:06 +00007234
7235 // CloudABI uses Position Independent Executables exclusively.
7236 CmdArgs.push_back("-pie");
7237 CmdArgs.push_back("--no-dynamic-linker");
7238 CmdArgs.push_back("-zrelro");
7239
Ed Schouten3c3e58c2015-03-26 11:13:44 +00007240 CmdArgs.push_back("--eh-frame-hdr");
7241 CmdArgs.push_back("--gc-sections");
7242
7243 if (Output.isFilename()) {
7244 CmdArgs.push_back("-o");
7245 CmdArgs.push_back(Output.getFilename());
7246 } else {
7247 assert(Output.isNothing() && "Invalid output.");
7248 }
7249
Douglas Katzman78b37b02015-11-17 20:28:07 +00007250 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) {
Ed Schouten3c3e58c2015-03-26 11:13:44 +00007251 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crt0.o")));
7252 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtbegin.o")));
7253 }
7254
7255 Args.AddAllArgs(CmdArgs, options::OPT_L);
Douglas Katzman6059ef92015-11-17 17:41:23 +00007256 ToolChain.AddFilePathLibArgs(Args, CmdArgs);
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00007257 Args.AddAllArgs(CmdArgs,
7258 {options::OPT_T_Group, options::OPT_e, options::OPT_s,
7259 options::OPT_t, options::OPT_Z_Flag, options::OPT_r});
Ed Schouten3c3e58c2015-03-26 11:13:44 +00007260
Teresa Johnson945bc502015-10-15 20:35:53 +00007261 if (D.isUsingLTO())
7262 AddGoldPlugin(ToolChain, Args, CmdArgs, D.getLTOMode() == LTOK_Thin);
Ed Schouten3c3e58c2015-03-26 11:13:44 +00007263
7264 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
7265
Douglas Katzman78b37b02015-11-17 20:28:07 +00007266 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs)) {
Ed Schouten3c3e58c2015-03-26 11:13:44 +00007267 if (D.CCCIsCXX())
7268 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
7269 CmdArgs.push_back("-lc");
7270 CmdArgs.push_back("-lcompiler_rt");
7271 }
7272
Douglas Katzman78b37b02015-11-17 20:28:07 +00007273 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles))
Ed Schouten3c3e58c2015-03-26 11:13:44 +00007274 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtend.o")));
7275
7276 const char *Exec = Args.MakeArgString(ToolChain.GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007277 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Ed Schouten3c3e58c2015-03-26 11:13:44 +00007278}
7279
Douglas Katzman95354292015-06-23 20:42:09 +00007280void darwin::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
7281 const InputInfo &Output,
7282 const InputInfoList &Inputs,
7283 const ArgList &Args,
7284 const char *LinkingOutput) const {
Daniel Dunbarbe220842009-03-20 16:06:39 +00007285 ArgStringList CmdArgs;
7286
7287 assert(Inputs.size() == 1 && "Unexpected number of inputs.");
7288 const InputInfo &Input = Inputs[0];
7289
Daniel Dunbardc8355e2011-04-12 23:59:20 +00007290 // Determine the original source input.
7291 const Action *SourceAction = &JA;
7292 while (SourceAction->getKind() != Action::InputClass) {
7293 assert(!SourceAction->getInputs().empty() && "unexpected root action!");
7294 SourceAction = SourceAction->getInputs()[0];
7295 }
7296
Eric Christopherf5a8f492015-12-08 00:10:10 +00007297 // If -fno-integrated-as is used add -Q to the darwin assember driver to make
Kevin Enderby319baa42013-11-18 23:30:29 +00007298 // sure it runs its system assembler not clang's integrated assembler.
David Fang073a7c92013-12-10 22:51:25 +00007299 // Applicable to darwin11+ and Xcode 4+. darwin<10 lacked integrated-as.
7300 // FIXME: at run-time detect assembler capabilities or rely on version
Eric Christopherf5a8f492015-12-08 00:10:10 +00007301 // information forwarded by -target-assembler-version.
Saleem Abdulrasoolcfeb90d2014-02-23 00:40:30 +00007302 if (Args.hasArg(options::OPT_fno_integrated_as)) {
David Fangadcdde02013-12-10 23:13:11 +00007303 const llvm::Triple &T(getToolChain().getTriple());
7304 if (!(T.isMacOSX() && T.isMacOSXVersionLT(10, 7)))
David Fang073a7c92013-12-10 22:51:25 +00007305 CmdArgs.push_back("-Q");
7306 }
Kevin Enderby319baa42013-11-18 23:30:29 +00007307
Daniel Dunbardc8355e2011-04-12 23:59:20 +00007308 // Forward -g, assuming we are dealing with an actual assembly file.
Eric Christopher84fbdb42011-08-19 00:30:14 +00007309 if (SourceAction->getType() == types::TY_Asm ||
Daniel Dunbardc8355e2011-04-12 23:59:20 +00007310 SourceAction->getType() == types::TY_PP_Asm) {
Daniel Dunbar5c9c1182009-04-01 00:27:44 +00007311 if (Args.hasArg(options::OPT_gstabs))
7312 CmdArgs.push_back("--gstabs");
7313 else if (Args.hasArg(options::OPT_g_Group))
Bob Wilson126c4912011-11-02 05:10:45 +00007314 CmdArgs.push_back("-g");
Daniel Dunbar5c9c1182009-04-01 00:27:44 +00007315 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00007316
Daniel Dunbarbe220842009-03-20 16:06:39 +00007317 // Derived from asm spec.
Tim Northover157d9112014-01-16 08:48:16 +00007318 AddMachOArch(Args, CmdArgs);
Daniel Dunbarbe220842009-03-20 16:06:39 +00007319
Daniel Dunbar6d484762010-07-22 01:47:22 +00007320 // Use -force_cpusubtype_ALL on x86 by default.
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00007321 if (getToolChain().getArch() == llvm::Triple::x86 ||
7322 getToolChain().getArch() == llvm::Triple::x86_64 ||
Daniel Dunbar3571dd92009-09-09 18:36:27 +00007323 Args.hasArg(options::OPT_force__cpusubtype__ALL))
7324 CmdArgs.push_back("-force_cpusubtype_ALL");
7325
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00007326 if (getToolChain().getArch() != llvm::Triple::x86_64 &&
Daniel Dunbarbd847cc2012-10-15 22:23:53 +00007327 (((Args.hasArg(options::OPT_mkernel) ||
Eric Christopher248357f2013-02-21 22:35:01 +00007328 Args.hasArg(options::OPT_fapple_kext)) &&
Tim Northover157d9112014-01-16 08:48:16 +00007329 getMachOToolChain().isKernelStatic()) ||
Daniel Dunbarbd847cc2012-10-15 22:23:53 +00007330 Args.hasArg(options::OPT_static)))
Daniel Dunbard067f7f2009-04-08 23:54:23 +00007331 CmdArgs.push_back("-static");
7332
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007333 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbarbe220842009-03-20 16:06:39 +00007334
7335 assert(Output.isFilename() && "Unexpected lipo output.");
7336 CmdArgs.push_back("-o");
7337 CmdArgs.push_back(Output.getFilename());
7338
Daniel Dunbarb440f562010-08-02 02:38:21 +00007339 assert(Input.isFilename() && "Invalid input.");
7340 CmdArgs.push_back(Input.getFilename());
Daniel Dunbarbe220842009-03-20 16:06:39 +00007341
7342 // asm_final spec is empty.
7343
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007344 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00007345 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbarbe220842009-03-20 16:06:39 +00007346}
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00007347
Tim Northover157d9112014-01-16 08:48:16 +00007348void darwin::MachOTool::anchor() {}
David Blaikie68e081d2011-12-20 02:48:34 +00007349
Tim Northover157d9112014-01-16 08:48:16 +00007350void darwin::MachOTool::AddMachOArch(const ArgList &Args,
7351 ArgStringList &CmdArgs) const {
7352 StringRef ArchName = getMachOToolChain().getMachOArchName(Args);
Daniel Dunbardcc3b652010-01-22 02:04:58 +00007353
Daniel Dunbarc1964212009-03-26 16:23:12 +00007354 // Derived from darwin_arch spec.
7355 CmdArgs.push_back("-arch");
Daniel Dunbardcc3b652010-01-22 02:04:58 +00007356 CmdArgs.push_back(Args.MakeArgString(ArchName));
Daniel Dunbar91dbfd62009-09-04 18:35:31 +00007357
Daniel Dunbardcc3b652010-01-22 02:04:58 +00007358 // FIXME: Is this needed anymore?
7359 if (ArchName == "arm")
Daniel Dunbar91dbfd62009-09-04 18:35:31 +00007360 CmdArgs.push_back("-force_cpusubtype_ALL");
Daniel Dunbarc1964212009-03-26 16:23:12 +00007361}
7362
Douglas Katzman95354292015-06-23 20:42:09 +00007363bool darwin::Linker::NeedsTempPath(const InputInfoList &Inputs) const {
Bill Wendling3b2000f2012-10-02 18:02:50 +00007364 // We only need to generate a temp path for LTO if we aren't compiling object
7365 // files. When compiling source files, we run 'dsymutil' after linking. We
7366 // don't run 'dsymutil' when compiling object files.
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007367 for (const auto &Input : Inputs)
7368 if (Input.getType() != types::TY_Object)
Bill Wendling3b2000f2012-10-02 18:02:50 +00007369 return true;
7370
7371 return false;
7372}
7373
Douglas Katzman95354292015-06-23 20:42:09 +00007374void darwin::Linker::AddLinkArgs(Compilation &C, const ArgList &Args,
7375 ArgStringList &CmdArgs,
7376 const InputInfoList &Inputs) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00007377 const Driver &D = getToolChain().getDriver();
Tim Northover157d9112014-01-16 08:48:16 +00007378 const toolchains::MachO &MachOTC = getMachOToolChain();
Daniel Dunbarc1964212009-03-26 16:23:12 +00007379
Bruno Cardoso Lopes8ed5cac2016-03-31 02:45:46 +00007380 unsigned Version[5] = {0, 0, 0, 0, 0};
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00007381 if (Arg *A = Args.getLastArg(options::OPT_mlinker_version_EQ)) {
Bruno Cardoso Lopes8ed5cac2016-03-31 02:45:46 +00007382 if (!Driver::GetReleaseVersion(A->getValue(), Version))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007383 D.Diag(diag::err_drv_invalid_version_number) << A->getAsString(Args);
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00007384 }
7385
Bob Wilson5a4f3ea2014-01-14 01:56:31 +00007386 // Newer linkers support -demangle. Pass it if supported and not disabled by
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00007387 // the user.
Bob Wilson5a4f3ea2014-01-14 01:56:31 +00007388 if (Version[0] >= 100 && !Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
7389 CmdArgs.push_back("-demangle");
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00007390
Bob Wilson3d27dad2013-08-02 22:25:34 +00007391 if (Args.hasArg(options::OPT_rdynamic) && Version[0] >= 137)
7392 CmdArgs.push_back("-export_dynamic");
7393
Bob Wilsonb111ec92015-03-02 19:01:14 +00007394 // If we are using App Extension restrictions, pass a flag to the linker
7395 // telling it that the compiled code has been audited.
7396 if (Args.hasFlag(options::OPT_fapplication_extension,
7397 options::OPT_fno_application_extension, false))
7398 CmdArgs.push_back("-application_extension");
7399
Teresa Johnson945bc502015-10-15 20:35:53 +00007400 if (D.isUsingLTO()) {
Bruno Cardoso Lopesa5efe3a2015-10-02 15:10:33 +00007401 // If we are using LTO, then automatically create a temporary file path for
7402 // the linker to use, so that it's lifetime will extend past a possible
7403 // dsymutil step.
7404 if (Version[0] >= 116 && NeedsTempPath(Inputs)) {
7405 const char *TmpPath = C.getArgs().MakeArgString(
7406 D.GetTemporaryPath("cc", types::getTypeTempSuffix(types::TY_Object)));
7407 C.addTempFile(TmpPath);
7408 CmdArgs.push_back("-object_path_lto");
7409 CmdArgs.push_back(TmpPath);
7410 }
7411
7412 // Use -lto_library option to specify the libLTO.dylib path. Try to find
7413 // it in clang installed libraries. If not found, the option is not used
7414 // and 'ld' will use its default mechanism to search for libLTO.dylib.
7415 if (Version[0] >= 133) {
7416 // Search for libLTO in <InstalledDir>/../lib/libLTO.dylib
7417 StringRef P = llvm::sys::path::parent_path(D.getInstalledDir());
7418 SmallString<128> LibLTOPath(P);
7419 llvm::sys::path::append(LibLTOPath, "lib");
7420 llvm::sys::path::append(LibLTOPath, "libLTO.dylib");
7421 if (llvm::sys::fs::exists(LibLTOPath)) {
7422 CmdArgs.push_back("-lto_library");
7423 CmdArgs.push_back(C.getArgs().MakeArgString(LibLTOPath));
7424 } else {
7425 D.Diag(diag::warn_drv_lto_libpath);
7426 }
7427 }
Daniel Dunbaref889c72011-06-21 20:55:11 +00007428 }
7429
Daniel Dunbarc1964212009-03-26 16:23:12 +00007430 // Derived from the "link" spec.
7431 Args.AddAllArgs(CmdArgs, options::OPT_static);
7432 if (!Args.hasArg(options::OPT_static))
7433 CmdArgs.push_back("-dynamic");
7434 if (Args.hasArg(options::OPT_fgnu_runtime)) {
7435 // FIXME: gcc replaces -lobjc in forward args with -lobjc-gnu
7436 // here. How do we wish to handle such things?
7437 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00007438
Daniel Dunbarc1964212009-03-26 16:23:12 +00007439 if (!Args.hasArg(options::OPT_dynamiclib)) {
Tim Northover157d9112014-01-16 08:48:16 +00007440 AddMachOArch(Args, CmdArgs);
Daniel Dunbara48823f2010-01-22 02:04:52 +00007441 // FIXME: Why do this only on this path?
Daniel Dunbar93d7acf2010-01-22 03:37:33 +00007442 Args.AddLastArg(CmdArgs, options::OPT_force__cpusubtype__ALL);
Daniel Dunbarc1964212009-03-26 16:23:12 +00007443
7444 Args.AddLastArg(CmdArgs, options::OPT_bundle);
7445 Args.AddAllArgs(CmdArgs, options::OPT_bundle__loader);
7446 Args.AddAllArgs(CmdArgs, options::OPT_client__name);
7447
7448 Arg *A;
7449 if ((A = Args.getLastArg(options::OPT_compatibility__version)) ||
7450 (A = Args.getLastArg(options::OPT_current__version)) ||
7451 (A = Args.getLastArg(options::OPT_install__name)))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007452 D.Diag(diag::err_drv_argument_only_allowed_with) << A->getAsString(Args)
7453 << "-dynamiclib";
Daniel Dunbarc1964212009-03-26 16:23:12 +00007454
7455 Args.AddLastArg(CmdArgs, options::OPT_force__flat__namespace);
7456 Args.AddLastArg(CmdArgs, options::OPT_keep__private__externs);
7457 Args.AddLastArg(CmdArgs, options::OPT_private__bundle);
7458 } else {
7459 CmdArgs.push_back("-dylib");
7460
7461 Arg *A;
7462 if ((A = Args.getLastArg(options::OPT_bundle)) ||
7463 (A = Args.getLastArg(options::OPT_bundle__loader)) ||
7464 (A = Args.getLastArg(options::OPT_client__name)) ||
7465 (A = Args.getLastArg(options::OPT_force__flat__namespace)) ||
7466 (A = Args.getLastArg(options::OPT_keep__private__externs)) ||
7467 (A = Args.getLastArg(options::OPT_private__bundle)))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007468 D.Diag(diag::err_drv_argument_not_allowed_with) << A->getAsString(Args)
7469 << "-dynamiclib";
Daniel Dunbard067f7f2009-04-08 23:54:23 +00007470
Daniel Dunbarc1964212009-03-26 16:23:12 +00007471 Args.AddAllArgsTranslated(CmdArgs, options::OPT_compatibility__version,
7472 "-dylib_compatibility_version");
7473 Args.AddAllArgsTranslated(CmdArgs, options::OPT_current__version,
7474 "-dylib_current_version");
7475
Tim Northover157d9112014-01-16 08:48:16 +00007476 AddMachOArch(Args, CmdArgs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00007477
7478 Args.AddAllArgsTranslated(CmdArgs, options::OPT_install__name,
7479 "-dylib_install_name");
7480 }
7481
7482 Args.AddLastArg(CmdArgs, options::OPT_all__load);
7483 Args.AddAllArgs(CmdArgs, options::OPT_allowable__client);
7484 Args.AddLastArg(CmdArgs, options::OPT_bind__at__load);
Tim Northover157d9112014-01-16 08:48:16 +00007485 if (MachOTC.isTargetIOSBased())
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00007486 Args.AddLastArg(CmdArgs, options::OPT_arch__errors__fatal);
Daniel Dunbarc1964212009-03-26 16:23:12 +00007487 Args.AddLastArg(CmdArgs, options::OPT_dead__strip);
7488 Args.AddLastArg(CmdArgs, options::OPT_no__dead__strip__inits__and__terms);
7489 Args.AddAllArgs(CmdArgs, options::OPT_dylib__file);
7490 Args.AddLastArg(CmdArgs, options::OPT_dynamic);
7491 Args.AddAllArgs(CmdArgs, options::OPT_exported__symbols__list);
7492 Args.AddLastArg(CmdArgs, options::OPT_flat__namespace);
Daniel Dunbar044a3902011-06-28 20:16:02 +00007493 Args.AddAllArgs(CmdArgs, options::OPT_force__load);
Daniel Dunbarc1964212009-03-26 16:23:12 +00007494 Args.AddAllArgs(CmdArgs, options::OPT_headerpad__max__install__names);
7495 Args.AddAllArgs(CmdArgs, options::OPT_image__base);
7496 Args.AddAllArgs(CmdArgs, options::OPT_init);
7497
Daniel Dunbarc44d3132011-04-28 21:23:41 +00007498 // Add the deployment target.
Tim Northover157d9112014-01-16 08:48:16 +00007499 MachOTC.addMinVersionArgs(Args, CmdArgs);
Daniel Dunbarc44d3132011-04-28 21:23:41 +00007500
Daniel Dunbarc1964212009-03-26 16:23:12 +00007501 Args.AddLastArg(CmdArgs, options::OPT_nomultidefs);
7502 Args.AddLastArg(CmdArgs, options::OPT_multi__module);
7503 Args.AddLastArg(CmdArgs, options::OPT_single__module);
7504 Args.AddAllArgs(CmdArgs, options::OPT_multiply__defined);
7505 Args.AddAllArgs(CmdArgs, options::OPT_multiply__defined__unused);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00007506
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007507 if (const Arg *A =
7508 Args.getLastArg(options::OPT_fpie, options::OPT_fPIE,
7509 options::OPT_fno_pie, options::OPT_fno_PIE)) {
Daniel Dunbaraf68a882010-07-13 23:31:40 +00007510 if (A->getOption().matches(options::OPT_fpie) ||
7511 A->getOption().matches(options::OPT_fPIE))
7512 CmdArgs.push_back("-pie");
7513 else
7514 CmdArgs.push_back("-no_pie");
7515 }
Steven Wu574b0f22016-03-01 01:07:58 +00007516 // for embed-bitcode, use -bitcode_bundle in linker command
7517 if (C.getDriver().embedBitcodeEnabled() ||
7518 C.getDriver().embedBitcodeMarkerOnly()) {
7519 // Check if the toolchain supports bitcode build flow.
7520 if (MachOTC.SupportsEmbeddedBitcode())
7521 CmdArgs.push_back("-bitcode_bundle");
7522 else
7523 D.Diag(diag::err_drv_bitcode_unsupported_on_toolchain);
7524 }
Daniel Dunbarc1964212009-03-26 16:23:12 +00007525
7526 Args.AddLastArg(CmdArgs, options::OPT_prebind);
7527 Args.AddLastArg(CmdArgs, options::OPT_noprebind);
7528 Args.AddLastArg(CmdArgs, options::OPT_nofixprebinding);
7529 Args.AddLastArg(CmdArgs, options::OPT_prebind__all__twolevel__modules);
7530 Args.AddLastArg(CmdArgs, options::OPT_read__only__relocs);
7531 Args.AddAllArgs(CmdArgs, options::OPT_sectcreate);
7532 Args.AddAllArgs(CmdArgs, options::OPT_sectorder);
7533 Args.AddAllArgs(CmdArgs, options::OPT_seg1addr);
7534 Args.AddAllArgs(CmdArgs, options::OPT_segprot);
7535 Args.AddAllArgs(CmdArgs, options::OPT_segaddr);
7536 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__only__addr);
7537 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__write__addr);
7538 Args.AddAllArgs(CmdArgs, options::OPT_seg__addr__table);
7539 Args.AddAllArgs(CmdArgs, options::OPT_seg__addr__table__filename);
7540 Args.AddAllArgs(CmdArgs, options::OPT_sub__library);
7541 Args.AddAllArgs(CmdArgs, options::OPT_sub__umbrella);
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00007542
Daniel Dunbar84384642011-05-02 21:03:47 +00007543 // Give --sysroot= preference, over the Apple specific behavior to also use
7544 // --isysroot as the syslibroot.
Sebastian Pop980920a2012-04-16 04:16:43 +00007545 StringRef sysroot = C.getSysRoot();
7546 if (sysroot != "") {
Daniel Dunbar84384642011-05-02 21:03:47 +00007547 CmdArgs.push_back("-syslibroot");
Sebastian Pop980920a2012-04-16 04:16:43 +00007548 CmdArgs.push_back(C.getArgs().MakeArgString(sysroot));
Daniel Dunbar84384642011-05-02 21:03:47 +00007549 } else if (const Arg *A = Args.getLastArg(options::OPT_isysroot)) {
7550 CmdArgs.push_back("-syslibroot");
Richard Smithbd55daf2012-11-01 04:30:05 +00007551 CmdArgs.push_back(A->getValue());
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00007552 }
7553
Daniel Dunbarc1964212009-03-26 16:23:12 +00007554 Args.AddLastArg(CmdArgs, options::OPT_twolevel__namespace);
7555 Args.AddLastArg(CmdArgs, options::OPT_twolevel__namespace__hints);
7556 Args.AddAllArgs(CmdArgs, options::OPT_umbrella);
7557 Args.AddAllArgs(CmdArgs, options::OPT_undefined);
7558 Args.AddAllArgs(CmdArgs, options::OPT_unexported__symbols__list);
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00007559 Args.AddAllArgs(CmdArgs, options::OPT_weak__reference__mismatches);
Daniel Dunbarc1964212009-03-26 16:23:12 +00007560 Args.AddLastArg(CmdArgs, options::OPT_X_Flag);
7561 Args.AddAllArgs(CmdArgs, options::OPT_y);
7562 Args.AddLastArg(CmdArgs, options::OPT_w);
7563 Args.AddAllArgs(CmdArgs, options::OPT_pagezero__size);
7564 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__);
7565 Args.AddLastArg(CmdArgs, options::OPT_seglinkedit);
7566 Args.AddLastArg(CmdArgs, options::OPT_noseglinkedit);
7567 Args.AddAllArgs(CmdArgs, options::OPT_sectalign);
7568 Args.AddAllArgs(CmdArgs, options::OPT_sectobjectsymbols);
7569 Args.AddAllArgs(CmdArgs, options::OPT_segcreate);
7570 Args.AddLastArg(CmdArgs, options::OPT_whyload);
7571 Args.AddLastArg(CmdArgs, options::OPT_whatsloaded);
7572 Args.AddAllArgs(CmdArgs, options::OPT_dylinker__install__name);
7573 Args.AddLastArg(CmdArgs, options::OPT_dylinker);
7574 Args.AddLastArg(CmdArgs, options::OPT_Mach);
7575}
7576
Douglas Katzman95354292015-06-23 20:42:09 +00007577void darwin::Linker::ConstructJob(Compilation &C, const JobAction &JA,
7578 const InputInfo &Output,
7579 const InputInfoList &Inputs,
7580 const ArgList &Args,
7581 const char *LinkingOutput) const {
Daniel Dunbarc1964212009-03-26 16:23:12 +00007582 assert(Output.getType() == types::TY_Image && "Invalid linker output type.");
Daniel Dunbarc09988d2009-09-08 16:39:16 +00007583
Reid Kleckner0290c9c2014-09-15 17:45:39 +00007584 // If the number of arguments surpasses the system limits, we will encode the
7585 // input files in a separate file, shortening the command line. To this end,
7586 // build a list of input file names that can be passed via a file with the
7587 // -filelist linker option.
7588 llvm::opt::ArgStringList InputFileList;
7589
Daniel Dunbarc1964212009-03-26 16:23:12 +00007590 // The logic here is derived from gcc's behavior; most of which
7591 // comes from specs (starting with link_command). Consult gcc for
7592 // more information.
Daniel Dunbarc1964212009-03-26 16:23:12 +00007593 ArgStringList CmdArgs;
7594
Argyrios Kyrtzidis741fab12011-10-07 22:58:08 +00007595 /// Hack(tm) to ignore linking errors when we are doing ARC migration.
7596 if (Args.hasArg(options::OPT_ccc_arcmt_check,
7597 options::OPT_ccc_arcmt_migrate)) {
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007598 for (const auto &Arg : Args)
7599 Arg->claim();
Argyrios Kyrtzidis741fab12011-10-07 22:58:08 +00007600 const char *Exec =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007601 Args.MakeArgString(getToolChain().GetProgramPath("touch"));
Argyrios Kyrtzidis741fab12011-10-07 22:58:08 +00007602 CmdArgs.push_back(Output.getFilename());
Justin Bognerd3371d82015-07-17 03:35:54 +00007603 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, None));
Argyrios Kyrtzidis741fab12011-10-07 22:58:08 +00007604 return;
7605 }
7606
Daniel Dunbarc1964212009-03-26 16:23:12 +00007607 // I'm not sure why this particular decomposition exists in gcc, but
7608 // we follow suite for ease of comparison.
Bill Wendling3b2000f2012-10-02 18:02:50 +00007609 AddLinkArgs(C, Args, CmdArgs, Inputs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00007610
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00007611 // It seems that the 'e' option is completely ignored for dynamic executables
7612 // (the default), and with static executables, the last one wins, as expected.
7613 Args.AddAllArgs(CmdArgs, {options::OPT_d_Flag, options::OPT_s, options::OPT_t,
7614 options::OPT_Z_Flag, options::OPT_u_Group,
7615 options::OPT_e, options::OPT_r});
Daniel Dunbarc1964212009-03-26 16:23:12 +00007616
Daniel Dunbar767bbab2010-10-18 22:08:36 +00007617 // Forward -ObjC when either -ObjC or -ObjC++ is used, to force loading
7618 // members of static archive libraries which implement Objective-C classes or
7619 // categories.
7620 if (Args.hasArg(options::OPT_ObjC) || Args.hasArg(options::OPT_ObjCXX))
7621 CmdArgs.push_back("-ObjC");
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00007622
Daniel Dunbarc1964212009-03-26 16:23:12 +00007623 CmdArgs.push_back("-o");
7624 CmdArgs.push_back(Output.getFilename());
7625
Douglas Katzman78b37b02015-11-17 20:28:07 +00007626 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles))
Tim Northover157d9112014-01-16 08:48:16 +00007627 getMachOToolChain().addStartObjectFileArgs(Args, CmdArgs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00007628
Peter Collingbournec4122c12015-06-15 21:08:13 +00007629 // SafeStack requires its own runtime libraries
7630 // These libraries should be linked first, to make sure the
7631 // __safestack_init constructor executes before everything else
7632 if (getToolChain().getSanitizerArgs().needsSafeStackRt()) {
7633 getMachOToolChain().AddLinkRuntimeLib(Args, CmdArgs,
7634 "libclang_rt.safestack_osx.a",
7635 /*AlwaysLink=*/true);
7636 }
7637
Daniel Dunbarc1964212009-03-26 16:23:12 +00007638 Args.AddAllArgs(CmdArgs, options::OPT_L);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00007639
Douglas Gregor9295df02012-05-15 21:00:27 +00007640 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Reid Kleckner0290c9c2014-09-15 17:45:39 +00007641 // Build the input file for -filelist (list of linker input files) in case we
7642 // need it later
7643 for (const auto &II : Inputs) {
7644 if (!II.isFilename()) {
7645 // This is a linker input argument.
7646 // We cannot mix input arguments and file names in a -filelist input, thus
7647 // we prematurely stop our list (remaining files shall be passed as
7648 // arguments).
7649 if (InputFileList.size() > 0)
7650 break;
7651
7652 continue;
7653 }
7654
7655 InputFileList.push_back(II.getFilename());
7656 }
7657
Douglas Katzman78b37b02015-11-17 20:28:07 +00007658 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs))
Joerg Sonnenberger5c3f9d52015-09-23 20:07:56 +00007659 addOpenMPRuntime(CmdArgs, getToolChain(), Args);
7660
Douglas Katzman78b37b02015-11-17 20:28:07 +00007661 if (isObjCRuntimeLinked(Args) &&
7662 !Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs)) {
Tim Northover157d9112014-01-16 08:48:16 +00007663 // We use arclite library for both ARC and subscripting support.
7664 getMachOToolChain().AddLinkARCArgs(Args, CmdArgs);
7665
Bob Wilson7dda0cd2012-04-21 00:21:42 +00007666 CmdArgs.push_back("-framework");
7667 CmdArgs.push_back("Foundation");
Ted Kremeneke65b0862012-03-06 20:05:56 +00007668 // Link libobj.
7669 CmdArgs.push_back("-lobjc");
John McCall24fc0de2011-07-06 00:26:06 +00007670 }
John McCall31168b02011-06-15 23:02:42 +00007671
Daniel Dunbarc1964212009-03-26 16:23:12 +00007672 if (LinkingOutput) {
7673 CmdArgs.push_back("-arch_multiple");
7674 CmdArgs.push_back("-final_output");
7675 CmdArgs.push_back(LinkingOutput);
7676 }
7677
Daniel Dunbarc1964212009-03-26 16:23:12 +00007678 if (Args.hasArg(options::OPT_fnested_functions))
7679 CmdArgs.push_back("-allow_stack_execute");
Daniel Dunbard067f7f2009-04-08 23:54:23 +00007680
Justin Bognerc7701242015-05-12 05:44:36 +00007681 getMachOToolChain().addProfileRTLibs(Args, CmdArgs);
7682
Douglas Katzman78b37b02015-11-17 20:28:07 +00007683 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00007684 if (getToolChain().getDriver().CCCIsCXX())
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00007685 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Daniel Dunbarad0f62b2009-04-08 06:06:21 +00007686
Daniel Dunbarc1964212009-03-26 16:23:12 +00007687 // link_ssp spec is empty.
7688
Daniel Dunbar26d482a2009-09-18 08:15:03 +00007689 // Let the tool chain choose which runtime library to link.
Tim Northover157d9112014-01-16 08:48:16 +00007690 getMachOToolChain().AddLinkRuntimeLibArgs(Args, CmdArgs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00007691 }
7692
Douglas Katzman78b37b02015-11-17 20:28:07 +00007693 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) {
Daniel Dunbarc1964212009-03-26 16:23:12 +00007694 // endfile_spec is empty.
7695 }
7696
7697 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
7698 Args.AddAllArgs(CmdArgs, options::OPT_F);
7699
Steven Wu3ffb61b2015-02-06 18:08:29 +00007700 // -iframework should be forwarded as -F.
Sean Silva14facf32015-06-09 01:57:17 +00007701 for (const Arg *A : Args.filtered(options::OPT_iframework))
7702 CmdArgs.push_back(Args.MakeArgString(std::string("-F") + A->getValue()));
Steven Wu3ffb61b2015-02-06 18:08:29 +00007703
Douglas Katzman78b37b02015-11-17 20:28:07 +00007704 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs)) {
Michael Zolotukhind0cf6c82015-03-17 22:13:05 +00007705 if (Arg *A = Args.getLastArg(options::OPT_fveclib)) {
7706 if (A->getValue() == StringRef("Accelerate")) {
7707 CmdArgs.push_back("-framework");
7708 CmdArgs.push_back("Accelerate");
7709 }
7710 }
7711 }
7712
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007713 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Reid Kleckner0290c9c2014-09-15 17:45:39 +00007714 std::unique_ptr<Command> Cmd =
Justin Bognerd3371d82015-07-17 03:35:54 +00007715 llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs);
Reid Kleckner0290c9c2014-09-15 17:45:39 +00007716 Cmd->setInputFileList(std::move(InputFileList));
7717 C.addCommand(std::move(Cmd));
Daniel Dunbarc1964212009-03-26 16:23:12 +00007718}
7719
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00007720void darwin::Lipo::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00007721 const InputInfo &Output,
Daniel Dunbard067f7f2009-04-08 23:54:23 +00007722 const InputInfoList &Inputs,
7723 const ArgList &Args,
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00007724 const char *LinkingOutput) const {
7725 ArgStringList CmdArgs;
7726
7727 CmdArgs.push_back("-create");
7728 assert(Output.isFilename() && "Unexpected lipo output.");
Daniel Dunbar06686ab2009-03-24 00:24:37 +00007729
7730 CmdArgs.push_back("-output");
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00007731 CmdArgs.push_back(Output.getFilename());
Daniel Dunbar06686ab2009-03-24 00:24:37 +00007732
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007733 for (const auto &II : Inputs) {
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00007734 assert(II.isFilename() && "Unexpected lipo input.");
7735 CmdArgs.push_back(II.getFilename());
7736 }
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007737
7738 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("lipo"));
Justin Bognerd3371d82015-07-17 03:35:54 +00007739 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00007740}
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007741
Daniel Dunbar88299622010-06-04 18:28:36 +00007742void darwin::Dsymutil::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00007743 const InputInfo &Output,
Daniel Dunbar88299622010-06-04 18:28:36 +00007744 const InputInfoList &Inputs,
7745 const ArgList &Args,
7746 const char *LinkingOutput) const {
7747 ArgStringList CmdArgs;
7748
Daniel Dunbareb86b042011-05-09 17:23:16 +00007749 CmdArgs.push_back("-o");
7750 CmdArgs.push_back(Output.getFilename());
7751
Daniel Dunbar88299622010-06-04 18:28:36 +00007752 assert(Inputs.size() == 1 && "Unable to handle multiple inputs.");
7753 const InputInfo &Input = Inputs[0];
7754 assert(Input.isFilename() && "Unexpected dsymutil input.");
7755 CmdArgs.push_back(Input.getFilename());
7756
Daniel Dunbar88299622010-06-04 18:28:36 +00007757 const char *Exec =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007758 Args.MakeArgString(getToolChain().GetProgramPath("dsymutil"));
Justin Bognerd3371d82015-07-17 03:35:54 +00007759 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar88299622010-06-04 18:28:36 +00007760}
7761
Eric Christopher551ef452011-08-23 17:56:55 +00007762void darwin::VerifyDebug::ConstructJob(Compilation &C, const JobAction &JA,
Eric Christopher45f2e712012-12-18 00:31:10 +00007763 const InputInfo &Output,
7764 const InputInfoList &Inputs,
7765 const ArgList &Args,
7766 const char *LinkingOutput) const {
Eric Christopher551ef452011-08-23 17:56:55 +00007767 ArgStringList CmdArgs;
7768 CmdArgs.push_back("--verify");
Eric Christopher36222212012-02-06 19:13:09 +00007769 CmdArgs.push_back("--debug-info");
7770 CmdArgs.push_back("--eh-frame");
Eric Christopher65c05fa2012-02-06 19:43:51 +00007771 CmdArgs.push_back("--quiet");
Eric Christopher551ef452011-08-23 17:56:55 +00007772
7773 assert(Inputs.size() == 1 && "Unable to handle multiple inputs.");
7774 const InputInfo &Input = Inputs[0];
7775 assert(Input.isFilename() && "Unexpected verify input");
7776
7777 // Grabbing the output of the earlier dsymutil run.
7778 CmdArgs.push_back(Input.getFilename());
7779
7780 const char *Exec =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007781 Args.MakeArgString(getToolChain().GetProgramPath("dwarfdump"));
Justin Bognerd3371d82015-07-17 03:35:54 +00007782 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eric Christopher551ef452011-08-23 17:56:55 +00007783}
7784
Douglas Katzman95354292015-06-23 20:42:09 +00007785void solaris::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
David Chisnallf571cde2012-02-15 13:39:01 +00007786 const InputInfo &Output,
7787 const InputInfoList &Inputs,
7788 const ArgList &Args,
7789 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007790 claimNoWarnArgs(Args);
David Chisnallf571cde2012-02-15 13:39:01 +00007791 ArgStringList CmdArgs;
7792
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007793 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
David Chisnallf571cde2012-02-15 13:39:01 +00007794
7795 CmdArgs.push_back("-o");
7796 CmdArgs.push_back(Output.getFilename());
7797
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007798 for (const auto &II : Inputs)
David Chisnallf571cde2012-02-15 13:39:01 +00007799 CmdArgs.push_back(II.getFilename());
David Chisnallf571cde2012-02-15 13:39:01 +00007800
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007801 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00007802 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
David Chisnallf571cde2012-02-15 13:39:01 +00007803}
7804
Douglas Katzman95354292015-06-23 20:42:09 +00007805void solaris::Linker::ConstructJob(Compilation &C, const JobAction &JA,
7806 const InputInfo &Output,
7807 const InputInfoList &Inputs,
7808 const ArgList &Args,
7809 const char *LinkingOutput) const {
David Chisnallf571cde2012-02-15 13:39:01 +00007810 ArgStringList CmdArgs;
7811
David Chisnall272a0712012-02-29 15:06:12 +00007812 // Demangle C++ names in errors
7813 CmdArgs.push_back("-C");
7814
Douglas Katzman78b37b02015-11-17 20:28:07 +00007815 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_shared)) {
David Chisnallf571cde2012-02-15 13:39:01 +00007816 CmdArgs.push_back("-e");
7817 CmdArgs.push_back("_start");
7818 }
7819
7820 if (Args.hasArg(options::OPT_static)) {
7821 CmdArgs.push_back("-Bstatic");
7822 CmdArgs.push_back("-dn");
7823 } else {
7824 CmdArgs.push_back("-Bdynamic");
7825 if (Args.hasArg(options::OPT_shared)) {
7826 CmdArgs.push_back("-shared");
7827 } else {
7828 CmdArgs.push_back("--dynamic-linker");
Rafael Espindolac53c5b12015-08-31 19:17:51 +00007829 CmdArgs.push_back(
7830 Args.MakeArgString(getToolChain().GetFilePath("ld.so.1")));
David Chisnallf571cde2012-02-15 13:39:01 +00007831 }
7832 }
7833
7834 if (Output.isFilename()) {
7835 CmdArgs.push_back("-o");
7836 CmdArgs.push_back(Output.getFilename());
7837 } else {
7838 assert(Output.isNothing() && "Invalid output.");
7839 }
7840
Douglas Katzman78b37b02015-11-17 20:28:07 +00007841 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) {
Rafael Espindolac53c5b12015-08-31 19:17:51 +00007842 if (!Args.hasArg(options::OPT_shared))
7843 CmdArgs.push_back(
7844 Args.MakeArgString(getToolChain().GetFilePath("crt1.o")));
7845
7846 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
7847 CmdArgs.push_back(
7848 Args.MakeArgString(getToolChain().GetFilePath("values-Xa.o")));
7849 CmdArgs.push_back(
7850 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
David Chisnallf571cde2012-02-15 13:39:01 +00007851 }
7852
Douglas Katzman6059ef92015-11-17 17:41:23 +00007853 getToolChain().AddFilePathLibArgs(Args, CmdArgs);
David Chisnallf571cde2012-02-15 13:39:01 +00007854
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00007855 Args.AddAllArgs(CmdArgs, {options::OPT_L, options::OPT_T_Group,
7856 options::OPT_e, options::OPT_r});
David Chisnallf571cde2012-02-15 13:39:01 +00007857
7858 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
7859
Douglas Katzman78b37b02015-11-17 20:28:07 +00007860 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00007861 if (getToolChain().getDriver().CCCIsCXX())
David Chisnall3d127c72012-04-10 11:49:50 +00007862 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
David Chisnall1026fb02012-02-15 18:24:31 +00007863 CmdArgs.push_back("-lgcc_s");
Rafael Espindola8d4d9d2f2015-09-14 19:30:53 +00007864 CmdArgs.push_back("-lc");
David Chisnall0c52c0f2012-02-28 17:10:04 +00007865 if (!Args.hasArg(options::OPT_shared)) {
7866 CmdArgs.push_back("-lgcc");
David Chisnallc73fb892012-02-28 20:06:45 +00007867 CmdArgs.push_back("-lm");
David Chisnall0c52c0f2012-02-28 17:10:04 +00007868 }
David Chisnallf571cde2012-02-15 13:39:01 +00007869 }
7870
Douglas Katzman78b37b02015-11-17 20:28:07 +00007871 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) {
Rafael Espindolac53c5b12015-08-31 19:17:51 +00007872 CmdArgs.push_back(
7873 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
David Chisnallf571cde2012-02-15 13:39:01 +00007874 }
Rafael Espindolac53c5b12015-08-31 19:17:51 +00007875 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
David Chisnallf571cde2012-02-15 13:39:01 +00007876
Xinliang David Li69306c02015-10-22 06:15:31 +00007877 getToolChain().addProfileRTLibs(Args, CmdArgs);
David Chisnallf571cde2012-02-15 13:39:01 +00007878
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007879 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007880 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
David Chisnallf571cde2012-02-15 13:39:01 +00007881}
7882
Douglas Katzman95354292015-06-23 20:42:09 +00007883void openbsd::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
7884 const InputInfo &Output,
7885 const InputInfoList &Inputs,
7886 const ArgList &Args,
7887 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007888 claimNoWarnArgs(Args);
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007889 ArgStringList CmdArgs;
7890
Rafael Espindolacc126272014-02-28 01:55:21 +00007891 switch (getToolChain().getArch()) {
7892 case llvm::Triple::x86:
7893 // When building 32-bit code on OpenBSD/amd64, we have to explicitly
7894 // instruct as in the base system to assemble 32-bit code.
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007895 CmdArgs.push_back("--32");
Rafael Espindolacc126272014-02-28 01:55:21 +00007896 break;
7897
7898 case llvm::Triple::ppc:
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007899 CmdArgs.push_back("-mppc");
7900 CmdArgs.push_back("-many");
Rafael Espindolacc126272014-02-28 01:55:21 +00007901 break;
7902
7903 case llvm::Triple::sparc:
Joerg Sonnenberger5c1ac902015-11-10 00:40:29 +00007904 case llvm::Triple::sparcel: {
Rafael Espindolacc126272014-02-28 01:55:21 +00007905 CmdArgs.push_back("-32");
Joerg Sonnenberger5c1ac902015-11-10 00:40:29 +00007906 std::string CPU = getCPUName(Args, getToolChain().getTriple());
7907 CmdArgs.push_back(getSparcAsmModeForCPU(CPU, getToolChain().getTriple()));
7908 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Rafael Espindolacc126272014-02-28 01:55:21 +00007909 break;
Joerg Sonnenberger5c1ac902015-11-10 00:40:29 +00007910 }
Rafael Espindolacc126272014-02-28 01:55:21 +00007911
Joerg Sonnenberger5c1ac902015-11-10 00:40:29 +00007912 case llvm::Triple::sparcv9: {
Rafael Espindolacc126272014-02-28 01:55:21 +00007913 CmdArgs.push_back("-64");
Joerg Sonnenberger5c1ac902015-11-10 00:40:29 +00007914 std::string CPU = getCPUName(Args, getToolChain().getTriple());
7915 CmdArgs.push_back(getSparcAsmModeForCPU(CPU, getToolChain().getTriple()));
7916 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Rafael Espindolacc126272014-02-28 01:55:21 +00007917 break;
Joerg Sonnenberger5c1ac902015-11-10 00:40:29 +00007918 }
Rafael Espindolacc126272014-02-28 01:55:21 +00007919
7920 case llvm::Triple::mips64:
7921 case llvm::Triple::mips64el: {
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007922 StringRef CPUName;
7923 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00007924 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007925
7926 CmdArgs.push_back("-mabi");
7927 CmdArgs.push_back(getGnuCompatibleMipsABIName(ABIName).data());
7928
7929 if (getToolChain().getArch() == llvm::Triple::mips64)
7930 CmdArgs.push_back("-EB");
7931 else
7932 CmdArgs.push_back("-EL");
7933
Joerg Sonnenberger5c1ac902015-11-10 00:40:29 +00007934 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Rafael Espindolacc126272014-02-28 01:55:21 +00007935 break;
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007936 }
7937
Rafael Espindolacc126272014-02-28 01:55:21 +00007938 default:
7939 break;
7940 }
7941
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007942 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007943
7944 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00007945 CmdArgs.push_back(Output.getFilename());
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007946
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007947 for (const auto &II : Inputs)
Daniel Dunbarb440f562010-08-02 02:38:21 +00007948 CmdArgs.push_back(II.getFilename());
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007949
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007950 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00007951 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007952}
7953
Douglas Katzman95354292015-06-23 20:42:09 +00007954void openbsd::Linker::ConstructJob(Compilation &C, const JobAction &JA,
7955 const InputInfo &Output,
7956 const InputInfoList &Inputs,
7957 const ArgList &Args,
7958 const char *LinkingOutput) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00007959 const Driver &D = getToolChain().getDriver();
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007960 ArgStringList CmdArgs;
7961
Rafael Espindolaaadd30e2012-12-31 22:41:36 +00007962 // Silence warning for "clang -g foo.o -o foo"
7963 Args.ClaimAllArgs(options::OPT_g_Group);
7964 // and "clang -emit-llvm foo.o -o foo"
7965 Args.ClaimAllArgs(options::OPT_emit_llvm);
7966 // and for "clang -w foo.o -o foo". Other warning options are already
7967 // handled somewhere else.
7968 Args.ClaimAllArgs(options::OPT_w);
7969
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007970 if (getToolChain().getArch() == llvm::Triple::mips64)
7971 CmdArgs.push_back("-EB");
7972 else if (getToolChain().getArch() == llvm::Triple::mips64el)
7973 CmdArgs.push_back("-EL");
7974
Douglas Katzman78b37b02015-11-17 20:28:07 +00007975 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_shared)) {
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007976 CmdArgs.push_back("-e");
7977 CmdArgs.push_back("__start");
7978 }
7979
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007980 if (Args.hasArg(options::OPT_static)) {
7981 CmdArgs.push_back("-Bstatic");
7982 } else {
Rafael Espindola7ba97af2010-11-11 02:17:51 +00007983 if (Args.hasArg(options::OPT_rdynamic))
7984 CmdArgs.push_back("-export-dynamic");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007985 CmdArgs.push_back("--eh-frame-hdr");
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007986 CmdArgs.push_back("-Bdynamic");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007987 if (Args.hasArg(options::OPT_shared)) {
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007988 CmdArgs.push_back("-shared");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007989 } else {
7990 CmdArgs.push_back("-dynamic-linker");
7991 CmdArgs.push_back("/usr/libexec/ld.so");
7992 }
7993 }
7994
Rafael Espindola044f7832013-06-05 04:28:55 +00007995 if (Args.hasArg(options::OPT_nopie))
7996 CmdArgs.push_back("-nopie");
7997
Daniel Dunbarb440f562010-08-02 02:38:21 +00007998 if (Output.isFilename()) {
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007999 CmdArgs.push_back("-o");
8000 CmdArgs.push_back(Output.getFilename());
8001 } else {
8002 assert(Output.isNothing() && "Invalid output.");
8003 }
8004
Douglas Katzman78b37b02015-11-17 20:28:07 +00008005 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) {
Daniel Dunbar10de9e62009-06-29 20:52:51 +00008006 if (!Args.hasArg(options::OPT_shared)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008007 if (Args.hasArg(options::OPT_pg))
8008 CmdArgs.push_back(
8009 Args.MakeArgString(getToolChain().GetFilePath("gcrt0.o")));
Eli Friedman3715d1f2011-12-15 02:15:56 +00008010 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008011 CmdArgs.push_back(
8012 Args.MakeArgString(getToolChain().GetFilePath("crt0.o")));
8013 CmdArgs.push_back(
8014 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00008015 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008016 CmdArgs.push_back(
8017 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00008018 }
8019 }
8020
Edward O'Callaghan5c521462009-10-28 15:13:08 +00008021 std::string Triple = getToolChain().getTripleString();
8022 if (Triple.substr(0, 6) == "x86_64")
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00008023 Triple.replace(0, 6, "amd64");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008024 CmdArgs.push_back(
8025 Args.MakeArgString("-L/usr/lib/gcc-lib/" + Triple + "/4.2.1"));
Daniel Dunbara8888ac2009-08-03 01:28:59 +00008026
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00008027 Args.AddAllArgs(CmdArgs, {options::OPT_L, options::OPT_T_Group,
8028 options::OPT_e, options::OPT_s, options::OPT_t,
8029 options::OPT_Z_Flag, options::OPT_r});
Daniel Dunbar10de9e62009-06-29 20:52:51 +00008030
Daniel Dunbar54423b22010-09-17 00:24:54 +00008031 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Daniel Dunbar10de9e62009-06-29 20:52:51 +00008032
Douglas Katzman78b37b02015-11-17 20:28:07 +00008033 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00008034 if (D.CCCIsCXX()) {
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00008035 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008036 if (Args.hasArg(options::OPT_pg))
Eli Friedman3715d1f2011-12-15 02:15:56 +00008037 CmdArgs.push_back("-lm_p");
8038 else
8039 CmdArgs.push_back("-lm");
Daniel Dunbarea3813f2010-08-01 23:13:54 +00008040 }
8041
Daniel Dunbara8888ac2009-08-03 01:28:59 +00008042 // FIXME: For some reason GCC passes -lgcc before adding
8043 // the default system libraries. Just mimic this for now.
8044 CmdArgs.push_back("-lgcc");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00008045
Eric Christopher17674ec2012-09-13 06:32:34 +00008046 if (Args.hasArg(options::OPT_pthread)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008047 if (!Args.hasArg(options::OPT_shared) && Args.hasArg(options::OPT_pg))
8048 CmdArgs.push_back("-lpthread_p");
Eric Christopher17674ec2012-09-13 06:32:34 +00008049 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008050 CmdArgs.push_back("-lpthread");
Eric Christopher17674ec2012-09-13 06:32:34 +00008051 }
8052
Chandler Carruth45661652011-12-17 22:32:42 +00008053 if (!Args.hasArg(options::OPT_shared)) {
Eric Christopher17674ec2012-09-13 06:32:34 +00008054 if (Args.hasArg(options::OPT_pg))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008055 CmdArgs.push_back("-lc_p");
Eli Friedman3715d1f2011-12-15 02:15:56 +00008056 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008057 CmdArgs.push_back("-lc");
Chandler Carruth45661652011-12-17 22:32:42 +00008058 }
Eric Christopher17674ec2012-09-13 06:32:34 +00008059
Daniel Dunbara8888ac2009-08-03 01:28:59 +00008060 CmdArgs.push_back("-lgcc");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00008061 }
8062
Douglas Katzman78b37b02015-11-17 20:28:07 +00008063 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) {
Daniel Dunbar10de9e62009-06-29 20:52:51 +00008064 if (!Args.hasArg(options::OPT_shared))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008065 CmdArgs.push_back(
8066 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00008067 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008068 CmdArgs.push_back(
8069 Args.MakeArgString(getToolChain().GetFilePath("crtendS.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00008070 }
8071
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008072 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00008073 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00008074}
Ed Schoutene33194b2009-04-02 19:13:12 +00008075
Douglas Katzman95354292015-06-23 20:42:09 +00008076void bitrig::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
8077 const InputInfo &Output,
8078 const InputInfoList &Inputs,
8079 const ArgList &Args,
8080 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00008081 claimNoWarnArgs(Args);
Eli Friedman9fa28852012-08-08 23:57:20 +00008082 ArgStringList CmdArgs;
8083
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008084 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Eli Friedman9fa28852012-08-08 23:57:20 +00008085
8086 CmdArgs.push_back("-o");
8087 CmdArgs.push_back(Output.getFilename());
8088
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008089 for (const auto &II : Inputs)
Eli Friedman9fa28852012-08-08 23:57:20 +00008090 CmdArgs.push_back(II.getFilename());
Eli Friedman9fa28852012-08-08 23:57:20 +00008091
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008092 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00008093 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eli Friedman9fa28852012-08-08 23:57:20 +00008094}
8095
Douglas Katzman95354292015-06-23 20:42:09 +00008096void bitrig::Linker::ConstructJob(Compilation &C, const JobAction &JA,
8097 const InputInfo &Output,
8098 const InputInfoList &Inputs,
8099 const ArgList &Args,
8100 const char *LinkingOutput) const {
Eli Friedman9fa28852012-08-08 23:57:20 +00008101 const Driver &D = getToolChain().getDriver();
8102 ArgStringList CmdArgs;
8103
Douglas Katzman78b37b02015-11-17 20:28:07 +00008104 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_shared)) {
Eli Friedman9fa28852012-08-08 23:57:20 +00008105 CmdArgs.push_back("-e");
8106 CmdArgs.push_back("__start");
8107 }
8108
8109 if (Args.hasArg(options::OPT_static)) {
8110 CmdArgs.push_back("-Bstatic");
8111 } else {
8112 if (Args.hasArg(options::OPT_rdynamic))
8113 CmdArgs.push_back("-export-dynamic");
8114 CmdArgs.push_back("--eh-frame-hdr");
8115 CmdArgs.push_back("-Bdynamic");
8116 if (Args.hasArg(options::OPT_shared)) {
8117 CmdArgs.push_back("-shared");
8118 } else {
8119 CmdArgs.push_back("-dynamic-linker");
8120 CmdArgs.push_back("/usr/libexec/ld.so");
8121 }
8122 }
8123
8124 if (Output.isFilename()) {
8125 CmdArgs.push_back("-o");
8126 CmdArgs.push_back(Output.getFilename());
8127 } else {
8128 assert(Output.isNothing() && "Invalid output.");
8129 }
8130
Douglas Katzman78b37b02015-11-17 20:28:07 +00008131 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) {
Eli Friedman9fa28852012-08-08 23:57:20 +00008132 if (!Args.hasArg(options::OPT_shared)) {
8133 if (Args.hasArg(options::OPT_pg))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008134 CmdArgs.push_back(
8135 Args.MakeArgString(getToolChain().GetFilePath("gcrt0.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00008136 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008137 CmdArgs.push_back(
8138 Args.MakeArgString(getToolChain().GetFilePath("crt0.o")));
8139 CmdArgs.push_back(
8140 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00008141 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008142 CmdArgs.push_back(
8143 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00008144 }
8145 }
8146
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00008147 Args.AddAllArgs(CmdArgs,
8148 {options::OPT_L, options::OPT_T_Group, options::OPT_e});
Eli Friedman9fa28852012-08-08 23:57:20 +00008149
8150 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
8151
Douglas Katzman78b37b02015-11-17 20:28:07 +00008152 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00008153 if (D.CCCIsCXX()) {
Eli Friedman9fa28852012-08-08 23:57:20 +00008154 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
8155 if (Args.hasArg(options::OPT_pg))
8156 CmdArgs.push_back("-lm_p");
8157 else
8158 CmdArgs.push_back("-lm");
8159 }
8160
Rafael Espindola1ad26f02012-10-23 17:07:31 +00008161 if (Args.hasArg(options::OPT_pthread)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008162 if (!Args.hasArg(options::OPT_shared) && Args.hasArg(options::OPT_pg))
Rafael Espindola1ad26f02012-10-23 17:07:31 +00008163 CmdArgs.push_back("-lpthread_p");
8164 else
8165 CmdArgs.push_back("-lpthread");
8166 }
8167
Eli Friedman9fa28852012-08-08 23:57:20 +00008168 if (!Args.hasArg(options::OPT_shared)) {
8169 if (Args.hasArg(options::OPT_pg))
8170 CmdArgs.push_back("-lc_p");
8171 else
8172 CmdArgs.push_back("-lc");
8173 }
8174
Benjamin Kramerb2ccade2013-10-21 12:33:55 +00008175 StringRef MyArch;
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008176 switch (getToolChain().getArch()) {
Benjamin Kramerb2ccade2013-10-21 12:33:55 +00008177 case llvm::Triple::arm:
8178 MyArch = "arm";
8179 break;
8180 case llvm::Triple::x86:
8181 MyArch = "i386";
8182 break;
8183 case llvm::Triple::x86_64:
8184 MyArch = "amd64";
8185 break;
8186 default:
8187 llvm_unreachable("Unsupported architecture");
8188 }
8189 CmdArgs.push_back(Args.MakeArgString("-lclang_rt." + MyArch));
Eli Friedman9fa28852012-08-08 23:57:20 +00008190 }
8191
Douglas Katzman78b37b02015-11-17 20:28:07 +00008192 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) {
Eli Friedman9fa28852012-08-08 23:57:20 +00008193 if (!Args.hasArg(options::OPT_shared))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008194 CmdArgs.push_back(
8195 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00008196 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008197 CmdArgs.push_back(
8198 Args.MakeArgString(getToolChain().GetFilePath("crtendS.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00008199 }
Eli Friedman5bb2ba02012-08-09 22:42:04 +00008200
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008201 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00008202 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eli Friedman9fa28852012-08-08 23:57:20 +00008203}
8204
Douglas Katzman95354292015-06-23 20:42:09 +00008205void freebsd::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
8206 const InputInfo &Output,
8207 const InputInfoList &Inputs,
8208 const ArgList &Args,
8209 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00008210 claimNoWarnArgs(Args);
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00008211 ArgStringList CmdArgs;
8212
Daniel Dunbard854c8d2009-04-01 19:36:32 +00008213 // When building 32-bit code on FreeBSD/amd64, we have to explicitly
8214 // instruct as in the base system to assemble 32-bit code.
Joerg Sonnenberger9d3e4f62015-11-10 00:23:12 +00008215 switch (getToolChain().getArch()) {
8216 default:
8217 break;
8218 case llvm::Triple::x86:
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00008219 CmdArgs.push_back("--32");
Joerg Sonnenberger9d3e4f62015-11-10 00:23:12 +00008220 break;
8221 case llvm::Triple::ppc:
Roman Divacky00859c22011-06-04 07:37:31 +00008222 CmdArgs.push_back("-a32");
Joerg Sonnenberger9d3e4f62015-11-10 00:23:12 +00008223 break;
8224 case llvm::Triple::mips:
8225 case llvm::Triple::mipsel:
8226 case llvm::Triple::mips64:
8227 case llvm::Triple::mips64el: {
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00008228 StringRef CPUName;
8229 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00008230 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00008231
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00008232 CmdArgs.push_back("-march");
8233 CmdArgs.push_back(CPUName.data());
8234
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00008235 CmdArgs.push_back("-mabi");
Simon Atanasyan0da400c2013-02-27 14:55:49 +00008236 CmdArgs.push_back(getGnuCompatibleMipsABIName(ABIName).data());
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00008237
8238 if (getToolChain().getArch() == llvm::Triple::mips ||
8239 getToolChain().getArch() == llvm::Triple::mips64)
8240 CmdArgs.push_back("-EB");
8241 else
8242 CmdArgs.push_back("-EL");
8243
Dimitry Andric46f338c2015-12-27 10:36:44 +00008244 if (Arg *A = Args.getLastArg(options::OPT_G)) {
8245 StringRef v = A->getValue();
8246 CmdArgs.push_back(Args.MakeArgString("-G" + v));
8247 A->claim();
8248 }
8249
James Y Knight5bdf7ab2015-08-19 15:12:02 +00008250 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Joerg Sonnenberger9d3e4f62015-11-10 00:23:12 +00008251 break;
8252 }
8253 case llvm::Triple::arm:
8254 case llvm::Triple::armeb:
8255 case llvm::Triple::thumb:
8256 case llvm::Triple::thumbeb: {
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00008257 arm::FloatABI ABI = arm::getARMFloatABI(getToolChain(), Args);
Renato Golinf4421f72014-02-19 10:44:07 +00008258
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +00008259 if (ABI == arm::FloatABI::Hard)
Renato Golinf4421f72014-02-19 10:44:07 +00008260 CmdArgs.push_back("-mfpu=vfp");
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +00008261 else
Renato Golinf4421f72014-02-19 10:44:07 +00008262 CmdArgs.push_back("-mfpu=softvfp");
Renato Golinf4421f72014-02-19 10:44:07 +00008263
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008264 switch (getToolChain().getTriple().getEnvironment()) {
Renato Golinf4421f72014-02-19 10:44:07 +00008265 case llvm::Triple::GNUEABIHF:
Rafael Espindola0f207ed2012-12-13 04:17:14 +00008266 case llvm::Triple::GNUEABI:
8267 case llvm::Triple::EABI:
Anton Korobeynikov2bed8472013-03-18 07:59:20 +00008268 CmdArgs.push_back("-meabi=5");
Rafael Espindola0f207ed2012-12-13 04:17:14 +00008269 break;
8270
8271 default:
8272 CmdArgs.push_back("-matpcs");
8273 }
Joerg Sonnenberger9d3e4f62015-11-10 00:23:12 +00008274 break;
8275 }
8276 case llvm::Triple::sparc:
8277 case llvm::Triple::sparcel:
Joerg Sonnenberger5c1ac902015-11-10 00:40:29 +00008278 case llvm::Triple::sparcv9: {
8279 std::string CPU = getCPUName(Args, getToolChain().getTriple());
8280 CmdArgs.push_back(getSparcAsmModeForCPU(CPU, getToolChain().getTriple()));
James Y Knight5bdf7ab2015-08-19 15:12:02 +00008281 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Joerg Sonnenberger9d3e4f62015-11-10 00:23:12 +00008282 break;
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00008283 }
Joerg Sonnenberger5c1ac902015-11-10 00:40:29 +00008284 }
Eric Christopher0b26a612010-03-02 02:41:08 +00008285
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008286 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00008287
8288 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00008289 CmdArgs.push_back(Output.getFilename());
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00008290
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008291 for (const auto &II : Inputs)
Daniel Dunbarb440f562010-08-02 02:38:21 +00008292 CmdArgs.push_back(II.getFilename());
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00008293
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008294 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00008295 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00008296}
Daniel Dunbard854c8d2009-04-01 19:36:32 +00008297
Douglas Katzman95354292015-06-23 20:42:09 +00008298void freebsd::Linker::ConstructJob(Compilation &C, const JobAction &JA,
8299 const InputInfo &Output,
8300 const InputInfoList &Inputs,
8301 const ArgList &Args,
8302 const char *LinkingOutput) const {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008303 const toolchains::FreeBSD &ToolChain =
8304 static_cast<const toolchains::FreeBSD &>(getToolChain());
Roman Divackyafe2f232012-08-28 15:09:03 +00008305 const Driver &D = ToolChain.getDriver();
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008306 const llvm::Triple::ArchType Arch = ToolChain.getArch();
Alexey Samsonove65ceb92014-02-25 13:26:03 +00008307 const bool IsPIE =
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008308 !Args.hasArg(options::OPT_shared) &&
8309 (Args.hasArg(options::OPT_pie) || ToolChain.isPIEDefault());
Daniel Dunbard854c8d2009-04-01 19:36:32 +00008310 ArgStringList CmdArgs;
David Chisnall5f99f482012-07-29 15:24:44 +00008311
8312 // Silence warning for "clang -g foo.o -o foo"
8313 Args.ClaimAllArgs(options::OPT_g_Group);
8314 // and "clang -emit-llvm foo.o -o foo"
8315 Args.ClaimAllArgs(options::OPT_emit_llvm);
8316 // and for "clang -w foo.o -o foo". Other warning options are already
8317 // handled somewhere else.
8318 Args.ClaimAllArgs(options::OPT_w);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00008319
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00008320 if (!D.SysRoot.empty())
8321 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
8322
Alexey Samsonove65ceb92014-02-25 13:26:03 +00008323 if (IsPIE)
Roman Divackyafe2f232012-08-28 15:09:03 +00008324 CmdArgs.push_back("-pie");
8325
Ed Maste1bc232d2016-04-12 21:11:46 +00008326 CmdArgs.push_back("--eh-frame-hdr");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00008327 if (Args.hasArg(options::OPT_static)) {
8328 CmdArgs.push_back("-Bstatic");
8329 } else {
Rafael Espindola7ba97af2010-11-11 02:17:51 +00008330 if (Args.hasArg(options::OPT_rdynamic))
8331 CmdArgs.push_back("-export-dynamic");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00008332 if (Args.hasArg(options::OPT_shared)) {
8333 CmdArgs.push_back("-Bshareable");
8334 } else {
8335 CmdArgs.push_back("-dynamic-linker");
8336 CmdArgs.push_back("/libexec/ld-elf.so.1");
8337 }
Roman Divackyafe2f232012-08-28 15:09:03 +00008338 if (ToolChain.getTriple().getOSMajorVersion() >= 9) {
David Chisnall5f99f482012-07-29 15:24:44 +00008339 if (Arch == llvm::Triple::arm || Arch == llvm::Triple::sparc ||
8340 Arch == llvm::Triple::x86 || Arch == llvm::Triple::x86_64) {
8341 CmdArgs.push_back("--hash-style=both");
8342 }
8343 }
8344 CmdArgs.push_back("--enable-new-dtags");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00008345 }
8346
8347 // When building 32-bit code on FreeBSD/amd64, we have to explicitly
8348 // instruct ld in the base system to link 32-bit code.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008349 if (Arch == llvm::Triple::x86) {
Daniel Dunbard854c8d2009-04-01 19:36:32 +00008350 CmdArgs.push_back("-m");
8351 CmdArgs.push_back("elf_i386_fbsd");
8352 }
8353
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008354 if (Arch == llvm::Triple::ppc) {
Roman Divacky5e300b82011-06-04 07:40:24 +00008355 CmdArgs.push_back("-m");
Roman Divackyd150ad32011-11-21 16:50:32 +00008356 CmdArgs.push_back("elf32ppc_fbsd");
Roman Divacky5e300b82011-06-04 07:40:24 +00008357 }
8358
Dimitry Andric904895f2015-12-27 06:47:09 +00008359 if (Arg *A = Args.getLastArg(options::OPT_G)) {
8360 if (ToolChain.getArch() == llvm::Triple::mips ||
8361 ToolChain.getArch() == llvm::Triple::mipsel ||
8362 ToolChain.getArch() == llvm::Triple::mips64 ||
8363 ToolChain.getArch() == llvm::Triple::mips64el) {
8364 StringRef v = A->getValue();
8365 CmdArgs.push_back(Args.MakeArgString("-G" + v));
8366 A->claim();
8367 }
8368 }
8369
Daniel Dunbarb440f562010-08-02 02:38:21 +00008370 if (Output.isFilename()) {
Daniel Dunbard854c8d2009-04-01 19:36:32 +00008371 CmdArgs.push_back("-o");
8372 CmdArgs.push_back(Output.getFilename());
8373 } else {
8374 assert(Output.isNothing() && "Invalid output.");
8375 }
8376
Douglas Katzman78b37b02015-11-17 20:28:07 +00008377 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) {
Craig Topper92fc2df2014-05-17 16:56:41 +00008378 const char *crt1 = nullptr;
Daniel Dunbard854c8d2009-04-01 19:36:32 +00008379 if (!Args.hasArg(options::OPT_shared)) {
Roman Divacky66f22762011-02-10 16:59:40 +00008380 if (Args.hasArg(options::OPT_pg))
Roman Divackyafe2f232012-08-28 15:09:03 +00008381 crt1 = "gcrt1.o";
Alexey Samsonove65ceb92014-02-25 13:26:03 +00008382 else if (IsPIE)
Roman Divackyafe2f232012-08-28 15:09:03 +00008383 crt1 = "Scrt1.o";
8384 else
8385 crt1 = "crt1.o";
Daniel Dunbard854c8d2009-04-01 19:36:32 +00008386 }
Roman Divackyafe2f232012-08-28 15:09:03 +00008387 if (crt1)
8388 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crt1)));
8389
8390 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
8391
Craig Topper92fc2df2014-05-17 16:56:41 +00008392 const char *crtbegin = nullptr;
Roman Divackyafe2f232012-08-28 15:09:03 +00008393 if (Args.hasArg(options::OPT_static))
8394 crtbegin = "crtbeginT.o";
Alexey Samsonove65ceb92014-02-25 13:26:03 +00008395 else if (Args.hasArg(options::OPT_shared) || IsPIE)
Roman Divackyafe2f232012-08-28 15:09:03 +00008396 crtbegin = "crtbeginS.o";
8397 else
8398 crtbegin = "crtbegin.o";
8399
8400 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtbegin)));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00008401 }
8402
8403 Args.AddAllArgs(CmdArgs, options::OPT_L);
Douglas Katzman6059ef92015-11-17 17:41:23 +00008404 ToolChain.AddFilePathLibArgs(Args, CmdArgs);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00008405 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
8406 Args.AddAllArgs(CmdArgs, options::OPT_e);
David Chisnall589a4942010-08-15 22:58:12 +00008407 Args.AddAllArgs(CmdArgs, options::OPT_s);
8408 Args.AddAllArgs(CmdArgs, options::OPT_t);
8409 Args.AddAllArgs(CmdArgs, options::OPT_Z_Flag);
8410 Args.AddAllArgs(CmdArgs, options::OPT_r);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00008411
Teresa Johnson945bc502015-10-15 20:35:53 +00008412 if (D.isUsingLTO())
8413 AddGoldPlugin(ToolChain, Args, CmdArgs, D.getLTOMode() == LTOK_Thin);
Roman Divackyf0d7f942013-11-10 09:31:43 +00008414
Alexey Samsonov52550342014-09-15 19:58:40 +00008415 bool NeedsSanitizerDeps = addSanitizerRuntimes(ToolChain, Args, CmdArgs);
Roman Divackyafe2f232012-08-28 15:09:03 +00008416 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00008417
Douglas Katzman78b37b02015-11-17 20:28:07 +00008418 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs)) {
Dimitry Andric0cc6f472015-10-18 13:32:20 +00008419 addOpenMPRuntime(CmdArgs, ToolChain, Args);
Hans Wennborg70850d82013-07-18 20:29:38 +00008420 if (D.CCCIsCXX()) {
Roman Divackyafe2f232012-08-28 15:09:03 +00008421 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
Roman Divacky66f22762011-02-10 16:59:40 +00008422 if (Args.hasArg(options::OPT_pg))
8423 CmdArgs.push_back("-lm_p");
8424 else
8425 CmdArgs.push_back("-lm");
Daniel Dunbar4b8ef282010-02-17 08:07:51 +00008426 }
Alexey Samsonov52550342014-09-15 19:58:40 +00008427 if (NeedsSanitizerDeps)
8428 linkSanitizerRuntimeDeps(ToolChain, CmdArgs);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00008429 // FIXME: For some reason GCC passes -lgcc and -lgcc_s before adding
8430 // the default system libraries. Just mimic this for now.
Roman Divacky66f22762011-02-10 16:59:40 +00008431 if (Args.hasArg(options::OPT_pg))
8432 CmdArgs.push_back("-lgcc_p");
8433 else
8434 CmdArgs.push_back("-lgcc");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00008435 if (Args.hasArg(options::OPT_static)) {
8436 CmdArgs.push_back("-lgcc_eh");
Roman Divacky66f22762011-02-10 16:59:40 +00008437 } else if (Args.hasArg(options::OPT_pg)) {
8438 CmdArgs.push_back("-lgcc_eh_p");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00008439 } else {
8440 CmdArgs.push_back("--as-needed");
8441 CmdArgs.push_back("-lgcc_s");
8442 CmdArgs.push_back("--no-as-needed");
8443 }
8444
Matt Beaumont-Gay1fe49152011-02-10 20:35:01 +00008445 if (Args.hasArg(options::OPT_pthread)) {
Roman Divacky66f22762011-02-10 16:59:40 +00008446 if (Args.hasArg(options::OPT_pg))
8447 CmdArgs.push_back("-lpthread_p");
8448 else
8449 CmdArgs.push_back("-lpthread");
Matt Beaumont-Gay1fe49152011-02-10 20:35:01 +00008450 }
Daniel Dunbard854c8d2009-04-01 19:36:32 +00008451
Roman Divacky66f22762011-02-10 16:59:40 +00008452 if (Args.hasArg(options::OPT_pg)) {
8453 if (Args.hasArg(options::OPT_shared))
8454 CmdArgs.push_back("-lc");
8455 else
8456 CmdArgs.push_back("-lc_p");
8457 CmdArgs.push_back("-lgcc_p");
8458 } else {
8459 CmdArgs.push_back("-lc");
8460 CmdArgs.push_back("-lgcc");
8461 }
8462
Daniel Dunbard854c8d2009-04-01 19:36:32 +00008463 if (Args.hasArg(options::OPT_static)) {
8464 CmdArgs.push_back("-lgcc_eh");
Roman Divacky66f22762011-02-10 16:59:40 +00008465 } else if (Args.hasArg(options::OPT_pg)) {
8466 CmdArgs.push_back("-lgcc_eh_p");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00008467 } else {
8468 CmdArgs.push_back("--as-needed");
8469 CmdArgs.push_back("-lgcc_s");
8470 CmdArgs.push_back("--no-as-needed");
8471 }
8472 }
8473
Douglas Katzman78b37b02015-11-17 20:28:07 +00008474 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) {
Alexey Samsonove65ceb92014-02-25 13:26:03 +00008475 if (Args.hasArg(options::OPT_shared) || IsPIE)
Roman Divackyafe2f232012-08-28 15:09:03 +00008476 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtendS.o")));
Roman Divackya3c50242012-09-07 13:36:21 +00008477 else
8478 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtend.o")));
Roman Divackyafe2f232012-08-28 15:09:03 +00008479 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00008480 }
8481
Xinliang David Li69306c02015-10-22 06:15:31 +00008482 ToolChain.addProfileRTLibs(Args, CmdArgs);
Nick Lewycky82fe5f42011-05-24 21:54:59 +00008483
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008484 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00008485 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00008486}
Daniel Dunbarcc912342009-05-02 18:28:39 +00008487
Douglas Katzman95354292015-06-23 20:42:09 +00008488void netbsd::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00008489 const InputInfo &Output,
8490 const InputInfoList &Inputs,
8491 const ArgList &Args,
8492 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00008493 claimNoWarnArgs(Args);
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00008494 ArgStringList CmdArgs;
8495
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00008496 // GNU as needs different flags for creating the correct output format
8497 // on architectures with different ABIs or optional feature sets.
8498 switch (getToolChain().getArch()) {
8499 case llvm::Triple::x86:
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00008500 CmdArgs.push_back("--32");
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00008501 break;
8502 case llvm::Triple::arm:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00008503 case llvm::Triple::armeb:
8504 case llvm::Triple::thumb:
8505 case llvm::Triple::thumbeb: {
Renato Goline17c5802015-07-27 23:44:42 +00008506 StringRef MArch, MCPU;
Renato Golin7c542b42015-07-27 23:44:45 +00008507 getARMArchCPUFromArgs(Args, MArch, MCPU, /*FromAs*/ true);
8508 std::string Arch =
8509 arm::getARMTargetCPU(MCPU, MArch, getToolChain().getTriple());
Renato Goline17c5802015-07-27 23:44:42 +00008510 CmdArgs.push_back(Args.MakeArgString("-mcpu=" + Arch));
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00008511 break;
Joerg Sonnenberger1f94da52013-12-05 21:07:29 +00008512 }
8513
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00008514 case llvm::Triple::mips:
8515 case llvm::Triple::mipsel:
8516 case llvm::Triple::mips64:
8517 case llvm::Triple::mips64el: {
Joerg Sonnenberger21baded2013-12-08 13:54:58 +00008518 StringRef CPUName;
8519 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00008520 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Joerg Sonnenberger21baded2013-12-08 13:54:58 +00008521
8522 CmdArgs.push_back("-march");
8523 CmdArgs.push_back(CPUName.data());
8524
8525 CmdArgs.push_back("-mabi");
8526 CmdArgs.push_back(getGnuCompatibleMipsABIName(ABIName).data());
8527
8528 if (getToolChain().getArch() == llvm::Triple::mips ||
8529 getToolChain().getArch() == llvm::Triple::mips64)
8530 CmdArgs.push_back("-EB");
8531 else
8532 CmdArgs.push_back("-EL");
8533
James Y Knight5bdf7ab2015-08-19 15:12:02 +00008534 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00008535 break;
8536 }
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00008537
8538 case llvm::Triple::sparc:
Joerg Sonnenbergerec353d32015-11-09 23:39:45 +00008539 case llvm::Triple::sparcel: {
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00008540 CmdArgs.push_back("-32");
Joerg Sonnenbergerec353d32015-11-09 23:39:45 +00008541 std::string CPU = getCPUName(Args, getToolChain().getTriple());
8542 CmdArgs.push_back(getSparcAsmModeForCPU(CPU, getToolChain().getTriple()));
James Y Knight5bdf7ab2015-08-19 15:12:02 +00008543 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00008544 break;
Joerg Sonnenbergerec353d32015-11-09 23:39:45 +00008545 }
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00008546
Joerg Sonnenbergerec353d32015-11-09 23:39:45 +00008547 case llvm::Triple::sparcv9: {
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00008548 CmdArgs.push_back("-64");
Joerg Sonnenbergerec353d32015-11-09 23:39:45 +00008549 std::string CPU = getCPUName(Args, getToolChain().getTriple());
8550 CmdArgs.push_back(getSparcAsmModeForCPU(CPU, getToolChain().getTriple()));
James Y Knight5bdf7ab2015-08-19 15:12:02 +00008551 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00008552 break;
Joerg Sonnenbergerec353d32015-11-09 23:39:45 +00008553 }
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00008554
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00008555 default:
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008556 break;
Joerg Sonnenberger21baded2013-12-08 13:54:58 +00008557 }
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00008558
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008559 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00008560
8561 CmdArgs.push_back("-o");
8562 CmdArgs.push_back(Output.getFilename());
8563
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008564 for (const auto &II : Inputs)
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00008565 CmdArgs.push_back(II.getFilename());
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00008566
David Chisnallddbd68f2011-09-27 22:03:18 +00008567 const char *Exec = Args.MakeArgString((getToolChain().GetProgramPath("as")));
Justin Bognerd3371d82015-07-17 03:35:54 +00008568 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00008569}
8570
Douglas Katzman95354292015-06-23 20:42:09 +00008571void netbsd::Linker::ConstructJob(Compilation &C, const JobAction &JA,
8572 const InputInfo &Output,
8573 const InputInfoList &Inputs,
8574 const ArgList &Args,
8575 const char *LinkingOutput) const {
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00008576 const Driver &D = getToolChain().getDriver();
8577 ArgStringList CmdArgs;
8578
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00008579 if (!D.SysRoot.empty())
8580 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
8581
Joerg Sonnenberger52be0b42014-03-13 00:42:01 +00008582 CmdArgs.push_back("--eh-frame-hdr");
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00008583 if (Args.hasArg(options::OPT_static)) {
8584 CmdArgs.push_back("-Bstatic");
8585 } else {
8586 if (Args.hasArg(options::OPT_rdynamic))
8587 CmdArgs.push_back("-export-dynamic");
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00008588 if (Args.hasArg(options::OPT_shared)) {
8589 CmdArgs.push_back("-Bshareable");
8590 } else {
8591 CmdArgs.push_back("-dynamic-linker");
8592 CmdArgs.push_back("/libexec/ld.elf_so");
8593 }
8594 }
8595
Joerg Sonnenberger6cd7deb2014-02-02 22:50:34 +00008596 // Many NetBSD architectures support more than one ABI.
8597 // Determine the correct emulation for ld.
8598 switch (getToolChain().getArch()) {
8599 case llvm::Triple::x86:
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00008600 CmdArgs.push_back("-m");
8601 CmdArgs.push_back("elf_i386");
Joerg Sonnenberger6cd7deb2014-02-02 22:50:34 +00008602 break;
8603 case llvm::Triple::arm:
8604 case llvm::Triple::thumb:
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00008605 CmdArgs.push_back("-m");
8606 switch (getToolChain().getTriple().getEnvironment()) {
8607 case llvm::Triple::EABI:
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00008608 case llvm::Triple::GNUEABI:
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00008609 CmdArgs.push_back("armelf_nbsd_eabi");
8610 break;
Joerg Sonnenberger83a33c02014-02-06 21:04:32 +00008611 case llvm::Triple::EABIHF:
8612 case llvm::Triple::GNUEABIHF:
8613 CmdArgs.push_back("armelf_nbsd_eabihf");
8614 break;
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00008615 default:
8616 CmdArgs.push_back("armelf_nbsd");
8617 break;
8618 }
Joerg Sonnenberger6cd7deb2014-02-02 22:50:34 +00008619 break;
Joerg Sonnenbergerb7045342014-08-14 19:12:41 +00008620 case llvm::Triple::armeb:
8621 case llvm::Triple::thumbeb:
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008622 arm::appendEBLinkFlags(
8623 Args, CmdArgs,
John Brawn94fd9632015-05-21 12:19:49 +00008624 llvm::Triple(getToolChain().ComputeEffectiveClangTriple(Args)));
Joerg Sonnenbergerb7045342014-08-14 19:12:41 +00008625 CmdArgs.push_back("-m");
8626 switch (getToolChain().getTriple().getEnvironment()) {
8627 case llvm::Triple::EABI:
8628 case llvm::Triple::GNUEABI:
8629 CmdArgs.push_back("armelfb_nbsd_eabi");
8630 break;
8631 case llvm::Triple::EABIHF:
8632 case llvm::Triple::GNUEABIHF:
8633 CmdArgs.push_back("armelfb_nbsd_eabihf");
8634 break;
8635 default:
8636 CmdArgs.push_back("armelfb_nbsd");
8637 break;
8638 }
8639 break;
Joerg Sonnenbergere7f97592014-02-02 22:59:16 +00008640 case llvm::Triple::mips64:
8641 case llvm::Triple::mips64el:
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00008642 if (mips::hasMipsAbiArg(Args, "32")) {
Joerg Sonnenbergere7f97592014-02-02 22:59:16 +00008643 CmdArgs.push_back("-m");
8644 if (getToolChain().getArch() == llvm::Triple::mips64)
8645 CmdArgs.push_back("elf32btsmip");
8646 else
8647 CmdArgs.push_back("elf32ltsmip");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008648 } else if (mips::hasMipsAbiArg(Args, "64")) {
8649 CmdArgs.push_back("-m");
8650 if (getToolChain().getArch() == llvm::Triple::mips64)
8651 CmdArgs.push_back("elf64btsmip");
8652 else
8653 CmdArgs.push_back("elf64ltsmip");
8654 }
8655 break;
Joerg Sonnenbergerdd13b302014-08-13 14:17:32 +00008656 case llvm::Triple::ppc:
8657 CmdArgs.push_back("-m");
8658 CmdArgs.push_back("elf32ppc_nbsd");
8659 break;
8660
8661 case llvm::Triple::ppc64:
8662 case llvm::Triple::ppc64le:
8663 CmdArgs.push_back("-m");
8664 CmdArgs.push_back("elf64ppc");
8665 break;
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00008666
8667 case llvm::Triple::sparc:
8668 CmdArgs.push_back("-m");
8669 CmdArgs.push_back("elf32_sparc");
8670 break;
8671
8672 case llvm::Triple::sparcv9:
8673 CmdArgs.push_back("-m");
8674 CmdArgs.push_back("elf64_sparc");
8675 break;
8676
Joerg Sonnenberger6cd7deb2014-02-02 22:50:34 +00008677 default:
8678 break;
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00008679 }
8680
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00008681 if (Output.isFilename()) {
8682 CmdArgs.push_back("-o");
8683 CmdArgs.push_back(Output.getFilename());
8684 } else {
8685 assert(Output.isNothing() && "Invalid output.");
8686 }
8687
Douglas Katzman78b37b02015-11-17 20:28:07 +00008688 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) {
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00008689 if (!Args.hasArg(options::OPT_shared)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008690 CmdArgs.push_back(
8691 Args.MakeArgString(getToolChain().GetFilePath("crt0.o")));
8692 CmdArgs.push_back(
8693 Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
8694 CmdArgs.push_back(
8695 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00008696 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008697 CmdArgs.push_back(
8698 Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
8699 CmdArgs.push_back(
8700 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.o")));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00008701 }
8702 }
8703
8704 Args.AddAllArgs(CmdArgs, options::OPT_L);
8705 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
8706 Args.AddAllArgs(CmdArgs, options::OPT_e);
8707 Args.AddAllArgs(CmdArgs, options::OPT_s);
8708 Args.AddAllArgs(CmdArgs, options::OPT_t);
8709 Args.AddAllArgs(CmdArgs, options::OPT_Z_Flag);
8710 Args.AddAllArgs(CmdArgs, options::OPT_r);
8711
8712 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
8713
Joerg Sonnenbergera4435632013-10-14 20:13:05 +00008714 unsigned Major, Minor, Micro;
8715 getToolChain().getTriple().getOSVersion(Major, Minor, Micro);
8716 bool useLibgcc = true;
Joerg Sonnenberger21156e82016-02-11 23:35:03 +00008717 if (Major >= 7 || Major == 0) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008718 switch (getToolChain().getArch()) {
Joerg Sonnenberger323cea92014-08-09 18:28:36 +00008719 case llvm::Triple::aarch64:
Joerg Sonnenberger1ea66472014-05-07 08:45:26 +00008720 case llvm::Triple::arm:
8721 case llvm::Triple::armeb:
8722 case llvm::Triple::thumb:
8723 case llvm::Triple::thumbeb:
Joerg Sonnenbergerc8887572014-07-25 20:57:24 +00008724 case llvm::Triple::ppc:
Joerg Sonnenbergerdd13b302014-08-13 14:17:32 +00008725 case llvm::Triple::ppc64:
8726 case llvm::Triple::ppc64le:
Joerg Sonnenberger059613c2016-02-11 23:18:36 +00008727 case llvm::Triple::sparc:
8728 case llvm::Triple::sparcv9:
Joerg Sonnenbergerd769a1e2014-01-18 00:50:49 +00008729 case llvm::Triple::x86:
8730 case llvm::Triple::x86_64:
Joerg Sonnenbergera4435632013-10-14 20:13:05 +00008731 useLibgcc = false;
Joerg Sonnenbergerd769a1e2014-01-18 00:50:49 +00008732 break;
8733 default:
8734 break;
8735 }
Joerg Sonnenbergera4435632013-10-14 20:13:05 +00008736 }
8737
Douglas Katzman78b37b02015-11-17 20:28:07 +00008738 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs)) {
Joerg Sonnenberger27a69a22015-09-23 20:11:00 +00008739 addOpenMPRuntime(CmdArgs, getToolChain(), Args);
Hans Wennborg70850d82013-07-18 20:29:38 +00008740 if (D.CCCIsCXX()) {
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00008741 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
8742 CmdArgs.push_back("-lm");
8743 }
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00008744 if (Args.hasArg(options::OPT_pthread))
8745 CmdArgs.push_back("-lpthread");
8746 CmdArgs.push_back("-lc");
8747
Joerg Sonnenbergera4435632013-10-14 20:13:05 +00008748 if (useLibgcc) {
8749 if (Args.hasArg(options::OPT_static)) {
8750 // libgcc_eh depends on libc, so resolve as much as possible,
8751 // pull in any new requirements from libc and then get the rest
8752 // of libgcc.
8753 CmdArgs.push_back("-lgcc_eh");
8754 CmdArgs.push_back("-lc");
8755 CmdArgs.push_back("-lgcc");
8756 } else {
8757 CmdArgs.push_back("-lgcc");
8758 CmdArgs.push_back("--as-needed");
8759 CmdArgs.push_back("-lgcc_s");
8760 CmdArgs.push_back("--no-as-needed");
8761 }
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00008762 }
8763 }
8764
Douglas Katzman78b37b02015-11-17 20:28:07 +00008765 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) {
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00008766 if (!Args.hasArg(options::OPT_shared))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008767 CmdArgs.push_back(
8768 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00008769 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008770 CmdArgs.push_back(
8771 Args.MakeArgString(getToolChain().GetFilePath("crtendS.o")));
8772 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00008773 }
8774
Xinliang David Li69306c02015-10-22 06:15:31 +00008775 getToolChain().addProfileRTLibs(Args, CmdArgs);
Nick Lewycky82fe5f42011-05-24 21:54:59 +00008776
Logan Chieneb9162f2014-06-26 14:23:45 +00008777 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00008778 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00008779}
8780
Douglas Katzman95354292015-06-23 20:42:09 +00008781void gnutools::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
8782 const InputInfo &Output,
8783 const InputInfoList &Inputs,
8784 const ArgList &Args,
8785 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00008786 claimNoWarnArgs(Args);
8787
James Y Knight2db38f32015-08-15 03:45:25 +00008788 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
8789 llvm::Triple Triple = llvm::Triple(TripleStr);
8790
Rafael Espindola92b00932010-08-10 00:25:48 +00008791 ArgStringList CmdArgs;
8792
James Y Knight5bdf7ab2015-08-19 15:12:02 +00008793 llvm::Reloc::Model RelocationModel;
8794 unsigned PICLevel;
8795 bool IsPIE;
8796 std::tie(RelocationModel, PICLevel, IsPIE) =
8797 ParsePICArgs(getToolChain(), Triple, Args);
8798
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008799 switch (getToolChain().getArch()) {
8800 default:
8801 break;
Rafael Espindola92b00932010-08-10 00:25:48 +00008802 // Add --32/--64 to make sure we get the format we want.
8803 // This is incomplete
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008804 case llvm::Triple::x86:
Rafael Espindola92b00932010-08-10 00:25:48 +00008805 CmdArgs.push_back("--32");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008806 break;
8807 case llvm::Triple::x86_64:
Zinovy Nis1db95732014-07-10 15:27:19 +00008808 if (getToolChain().getTriple().getEnvironment() == llvm::Triple::GNUX32)
8809 CmdArgs.push_back("--x32");
8810 else
8811 CmdArgs.push_back("--64");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008812 break;
8813 case llvm::Triple::ppc:
Eli Friedman4a4932c2011-11-28 23:46:52 +00008814 CmdArgs.push_back("-a32");
8815 CmdArgs.push_back("-mppc");
8816 CmdArgs.push_back("-many");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008817 break;
8818 case llvm::Triple::ppc64:
Eli Friedman4a4932c2011-11-28 23:46:52 +00008819 CmdArgs.push_back("-a64");
8820 CmdArgs.push_back("-mppc64");
8821 CmdArgs.push_back("-many");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008822 break;
8823 case llvm::Triple::ppc64le:
Bill Schmidt778d3872013-07-26 01:36:11 +00008824 CmdArgs.push_back("-a64");
Will Schmidtc1fc1902014-03-24 17:10:37 +00008825 CmdArgs.push_back("-mppc64");
Bill Schmidt778d3872013-07-26 01:36:11 +00008826 CmdArgs.push_back("-many");
Will Schmidtc1fc1902014-03-24 17:10:37 +00008827 CmdArgs.push_back("-mlittle-endian");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008828 break;
8829 case llvm::Triple::sparc:
Joerg Sonnenberger5c1ac902015-11-10 00:40:29 +00008830 case llvm::Triple::sparcel: {
Jakob Stoklund Olesen2490e552014-01-10 03:51:29 +00008831 CmdArgs.push_back("-32");
Joerg Sonnenberger5c1ac902015-11-10 00:40:29 +00008832 std::string CPU = getCPUName(Args, getToolChain().getTriple());
8833 CmdArgs.push_back(getSparcAsmModeForCPU(CPU, getToolChain().getTriple()));
8834 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008835 break;
Joerg Sonnenberger5c1ac902015-11-10 00:40:29 +00008836 }
8837 case llvm::Triple::sparcv9: {
Jakob Stoklund Olesen2490e552014-01-10 03:51:29 +00008838 CmdArgs.push_back("-64");
Joerg Sonnenberger5c1ac902015-11-10 00:40:29 +00008839 std::string CPU = getCPUName(Args, getToolChain().getTriple());
8840 CmdArgs.push_back(getSparcAsmModeForCPU(CPU, getToolChain().getTriple()));
8841 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008842 break;
Joerg Sonnenberger5c1ac902015-11-10 00:40:29 +00008843 }
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008844 case llvm::Triple::arm:
8845 case llvm::Triple::armeb:
8846 case llvm::Triple::thumb:
8847 case llvm::Triple::thumbeb: {
James Y Knight2db38f32015-08-15 03:45:25 +00008848 const llvm::Triple &Triple2 = getToolChain().getTriple();
8849 switch (Triple2.getSubArch()) {
Scott Douglass3205f522015-03-23 10:54:24 +00008850 case llvm::Triple::ARMSubArch_v7:
Rafael Espindola92b00932010-08-10 00:25:48 +00008851 CmdArgs.push_back("-mfpu=neon");
Scott Douglass3205f522015-03-23 10:54:24 +00008852 break;
8853 case llvm::Triple::ARMSubArch_v8:
Bernard Ogdena58ef052013-10-24 18:32:41 +00008854 CmdArgs.push_back("-mfpu=crypto-neon-fp-armv8");
Scott Douglass3205f522015-03-23 10:54:24 +00008855 break;
8856 default:
8857 break;
8858 }
Evgeniy Stepanoved943f62012-04-20 09:03:40 +00008859
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00008860 switch (arm::getARMFloatABI(getToolChain(), Args)) {
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +00008861 case arm::FloatABI::Invalid: llvm_unreachable("must have an ABI!");
8862 case arm::FloatABI::Soft:
8863 CmdArgs.push_back(Args.MakeArgString("-mfloat-abi=soft"));
8864 break;
8865 case arm::FloatABI::SoftFP:
8866 CmdArgs.push_back(Args.MakeArgString("-mfloat-abi=softfp"));
8867 break;
8868 case arm::FloatABI::Hard:
8869 CmdArgs.push_back(Args.MakeArgString("-mfloat-abi=hard"));
8870 break;
8871 }
Evgeniy Stepanov582911a2012-04-24 09:05:31 +00008872
8873 Args.AddLastArg(CmdArgs, options::OPT_march_EQ);
Ana Pazosdd6068d2013-12-06 22:43:17 +00008874
8875 // FIXME: remove krait check when GNU tools support krait cpu
Stephen Hinese3f91e32016-03-04 20:57:22 +00008876 // for now replace it with -mcpu=cortex-a15 to avoid a lower
Ana Pazosdd6068d2013-12-06 22:43:17 +00008877 // march from being picked in the absence of a cpu flag.
8878 Arg *A;
8879 if ((A = Args.getLastArg(options::OPT_mcpu_EQ)) &&
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008880 StringRef(A->getValue()).lower() == "krait")
Stephen Hinese3f91e32016-03-04 20:57:22 +00008881 CmdArgs.push_back("-mcpu=cortex-a15");
Ana Pazosdd6068d2013-12-06 22:43:17 +00008882 else
8883 Args.AddLastArg(CmdArgs, options::OPT_mcpu_EQ);
Evgeniy Stepanov582911a2012-04-24 09:05:31 +00008884 Args.AddLastArg(CmdArgs, options::OPT_mfpu_EQ);
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008885 break;
8886 }
8887 case llvm::Triple::mips:
8888 case llvm::Triple::mipsel:
8889 case llvm::Triple::mips64:
8890 case llvm::Triple::mips64el: {
Simon Atanasyan571d7bd2012-04-07 22:31:29 +00008891 StringRef CPUName;
8892 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00008893 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Daniel Sanders379d44b2014-07-16 11:52:23 +00008894 ABIName = getGnuCompatibleMipsABIName(ABIName);
Akira Hatanaka5e9dde32011-11-30 19:31:38 +00008895
Simon Atanasyan571d7bd2012-04-07 22:31:29 +00008896 CmdArgs.push_back("-march");
8897 CmdArgs.push_back(CPUName.data());
8898
Simon Atanasyan571d7bd2012-04-07 22:31:29 +00008899 CmdArgs.push_back("-mabi");
Daniel Sanders379d44b2014-07-16 11:52:23 +00008900 CmdArgs.push_back(ABIName.data());
8901
Daniel Sanders54d8ee62014-07-23 12:06:13 +00008902 // -mno-shared should be emitted unless -fpic, -fpie, -fPIC, -fPIE,
8903 // or -mshared (not implemented) is in effect.
James Y Knight5bdf7ab2015-08-19 15:12:02 +00008904 if (RelocationModel == llvm::Reloc::Static)
Daniel Sanders54d8ee62014-07-23 12:06:13 +00008905 CmdArgs.push_back("-mno-shared");
8906
Daniel Sanders379d44b2014-07-16 11:52:23 +00008907 // LLVM doesn't support -mplt yet and acts as if it is always given.
8908 // However, -mplt has no effect with the N64 ABI.
8909 CmdArgs.push_back(ABIName == "64" ? "-KPIC" : "-call_nonpic");
Simon Atanasyan2390aa12012-04-06 19:15:24 +00008910
8911 if (getToolChain().getArch() == llvm::Triple::mips ||
8912 getToolChain().getArch() == llvm::Triple::mips64)
8913 CmdArgs.push_back("-EB");
8914 else
8915 CmdArgs.push_back("-EL");
Simon Atanasyan217dc2d2012-05-29 19:07:33 +00008916
Simon Atanasyan22127ce2013-09-24 09:09:16 +00008917 if (Arg *A = Args.getLastArg(options::OPT_mnan_EQ)) {
8918 if (StringRef(A->getValue()) == "2008")
8919 CmdArgs.push_back(Args.MakeArgString("-mnan=2008"));
8920 }
8921
Daniel Sanders379d44b2014-07-16 11:52:23 +00008922 // Add the last -mfp32/-mfpxx/-mfp64 or -mfpxx if it is enabled by default.
8923 if (Arg *A = Args.getLastArg(options::OPT_mfp32, options::OPT_mfpxx,
8924 options::OPT_mfp64)) {
8925 A->claim();
8926 A->render(Args, CmdArgs);
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00008927 } else if (mips::shouldUseFPXX(
8928 Args, getToolChain().getTriple(), CPUName, ABIName,
8929 getMipsFloatABI(getToolChain().getDriver(), Args)))
Daniel Sanders379d44b2014-07-16 11:52:23 +00008930 CmdArgs.push_back("-mfpxx");
8931
8932 // Pass on -mmips16 or -mno-mips16. However, the assembler equivalent of
8933 // -mno-mips16 is actually -no-mips16.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008934 if (Arg *A =
8935 Args.getLastArg(options::OPT_mips16, options::OPT_mno_mips16)) {
Daniel Sanders379d44b2014-07-16 11:52:23 +00008936 if (A->getOption().matches(options::OPT_mips16)) {
8937 A->claim();
8938 A->render(Args, CmdArgs);
8939 } else {
8940 A->claim();
8941 CmdArgs.push_back("-no-mips16");
8942 }
8943 }
8944
Simon Atanasyan036d16d2013-04-30 07:47:13 +00008945 Args.AddLastArg(CmdArgs, options::OPT_mmicromips,
8946 options::OPT_mno_micromips);
8947 Args.AddLastArg(CmdArgs, options::OPT_mdsp, options::OPT_mno_dsp);
8948 Args.AddLastArg(CmdArgs, options::OPT_mdspr2, options::OPT_mno_dspr2);
8949
Simon Atanasyanbd986632013-11-26 11:58:04 +00008950 if (Arg *A = Args.getLastArg(options::OPT_mmsa, options::OPT_mno_msa)) {
8951 // Do not use AddLastArg because not all versions of MIPS assembler
8952 // support -mmsa / -mno-msa options.
8953 if (A->getOption().matches(options::OPT_mmsa))
8954 CmdArgs.push_back(Args.MakeArgString("-mmsa"));
8955 }
8956
Daniel Sanders379d44b2014-07-16 11:52:23 +00008957 Args.AddLastArg(CmdArgs, options::OPT_mhard_float,
8958 options::OPT_msoft_float);
8959
Toma Tabacub36d6102015-06-11 12:13:18 +00008960 Args.AddLastArg(CmdArgs, options::OPT_mdouble_float,
8961 options::OPT_msingle_float);
8962
Daniel Sanders379d44b2014-07-16 11:52:23 +00008963 Args.AddLastArg(CmdArgs, options::OPT_modd_spreg,
8964 options::OPT_mno_odd_spreg);
8965
Joerg Sonnenberger5c1ac902015-11-10 00:40:29 +00008966 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008967 break;
8968 }
8969 case llvm::Triple::systemz: {
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00008970 // Always pass an -march option, since our default of z10 is later
8971 // than the GNU assembler's default.
8972 StringRef CPUName = getSystemZTargetCPU(Args);
8973 CmdArgs.push_back(Args.MakeArgString("-march=" + CPUName));
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008974 break;
8975 }
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00008976 }
8977
Renato Golina74bbc72015-07-22 15:32:36 +00008978 Args.AddAllArgs(CmdArgs, options::OPT_I);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008979 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Rafael Espindola92b00932010-08-10 00:25:48 +00008980
8981 CmdArgs.push_back("-o");
8982 CmdArgs.push_back(Output.getFilename());
8983
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008984 for (const auto &II : Inputs)
Rafael Espindola92b00932010-08-10 00:25:48 +00008985 CmdArgs.push_back(II.getFilename());
Rafael Espindola92b00932010-08-10 00:25:48 +00008986
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008987 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00008988 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eric Christopher30aa6b62013-06-05 23:58:15 +00008989
8990 // Handle the debug info splitting at object creation time if we're
8991 // creating an object.
8992 // TODO: Currently only works on linux with newer objcopy.
8993 if (Args.hasArg(options::OPT_gsplit_dwarf) &&
Cameron Esfahani556d91e2013-09-14 01:09:11 +00008994 getToolChain().getTriple().isOSLinux())
Eric Christopher30aa6b62013-06-05 23:58:15 +00008995 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output,
Artem Belevichba558952015-05-06 18:20:23 +00008996 SplitDebugName(Args, Inputs[0]));
Rafael Espindola92b00932010-08-10 00:25:48 +00008997}
8998
Benjamin Kramer9299637dc2014-03-04 19:31:42 +00008999static void AddLibgcc(const llvm::Triple &Triple, const Driver &D,
Evgeniy Stepanov77866712012-04-25 08:59:22 +00009000 ArgStringList &CmdArgs, const ArgList &Args) {
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00009001 bool isAndroid = Triple.isAndroid();
Reid Kleckner0213a472015-07-22 16:01:38 +00009002 bool isCygMing = Triple.isOSCygMing();
Chandler Carruth58d6eb62013-03-04 02:07:55 +00009003 bool StaticLibgcc = Args.hasArg(options::OPT_static_libgcc) ||
9004 Args.hasArg(options::OPT_static);
Hans Wennborg70850d82013-07-18 20:29:38 +00009005 if (!D.CCCIsCXX())
Rafael Espindolacc354322011-10-17 21:39:04 +00009006 CmdArgs.push_back("-lgcc");
9007
Logan Chien3d3373c2012-11-19 12:04:11 +00009008 if (StaticLibgcc || isAndroid) {
Hans Wennborg70850d82013-07-18 20:29:38 +00009009 if (D.CCCIsCXX())
Rafael Espindolacc354322011-10-17 21:39:04 +00009010 CmdArgs.push_back("-lgcc");
9011 } else {
Reid Kleckner0213a472015-07-22 16:01:38 +00009012 if (!D.CCCIsCXX() && !isCygMing)
Rafael Espindolacc354322011-10-17 21:39:04 +00009013 CmdArgs.push_back("--as-needed");
9014 CmdArgs.push_back("-lgcc_s");
Reid Kleckner0213a472015-07-22 16:01:38 +00009015 if (!D.CCCIsCXX() && !isCygMing)
Rafael Espindolacc354322011-10-17 21:39:04 +00009016 CmdArgs.push_back("--no-as-needed");
9017 }
9018
Evgeniy Stepanov77866712012-04-25 08:59:22 +00009019 if (StaticLibgcc && !isAndroid)
Rafael Espindolacc354322011-10-17 21:39:04 +00009020 CmdArgs.push_back("-lgcc_eh");
Hans Wennborg70850d82013-07-18 20:29:38 +00009021 else if (!Args.hasArg(options::OPT_shared) && D.CCCIsCXX())
Rafael Espindolacc354322011-10-17 21:39:04 +00009022 CmdArgs.push_back("-lgcc");
Logan Chien3d3373c2012-11-19 12:04:11 +00009023
9024 // According to Android ABI, we have to link with libdl if we are
9025 // linking with non-static libgcc.
9026 //
9027 // NOTE: This fixes a link error on Android MIPS as well. The non-static
9028 // libgcc for MIPS relies on _Unwind_Find_FDE and dl_iterate_phdr from libdl.
9029 if (isAndroid && !StaticLibgcc)
9030 CmdArgs.push_back("-ldl");
Rafael Espindolacc354322011-10-17 21:39:04 +00009031}
9032
Renato Golinc4b49242014-02-13 10:01:16 +00009033static void AddRunTimeLibs(const ToolChain &TC, const Driver &D,
Saleem Abdulrasool2e46ebe2014-12-30 22:52:06 +00009034 ArgStringList &CmdArgs, const ArgList &Args) {
Renato Golinc4b49242014-02-13 10:01:16 +00009035 // Make use of compiler-rt if --rtlib option is used
9036 ToolChain::RuntimeLibType RLT = TC.GetRuntimeLibType(Args);
9037
Saleem Abdulrasool8d7ade72014-12-30 02:10:36 +00009038 switch (RLT) {
Renato Golinc4b49242014-02-13 10:01:16 +00009039 case ToolChain::RLT_CompilerRT:
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009040 switch (TC.getTriple().getOS()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009041 default:
9042 llvm_unreachable("unsupported OS");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009043 case llvm::Triple::Win32:
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009044 case llvm::Triple::Linux:
Saleem Abdulrasool8d7ade72014-12-30 02:10:36 +00009045 addClangRT(TC, Args, CmdArgs);
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009046 break;
9047 }
Renato Golinc4b49242014-02-13 10:01:16 +00009048 break;
9049 case ToolChain::RLT_Libgcc:
Andrey Turetskiya4868572016-03-14 11:19:43 +00009050 // Make sure libgcc is not used under MSVC environment by default
9051 if (TC.getTriple().isKnownWindowsMSVCEnvironment()) {
9052 // Issue error diagnostic if libgcc is explicitly specified
9053 // through command line as --rtlib option argument.
9054 if (Args.hasArg(options::OPT_rtlib_EQ)) {
9055 TC.getDriver().Diag(diag::err_drv_unsupported_rtlib_for_platform)
9056 << Args.getLastArg(options::OPT_rtlib_EQ)->getValue() << "MSVC";
9057 }
9058 } else
9059 AddLibgcc(TC.getTriple(), D, CmdArgs, Args);
Renato Golinc4b49242014-02-13 10:01:16 +00009060 break;
Renato Golinc4b49242014-02-13 10:01:16 +00009061 }
9062}
9063
Rafael Espindola1e085772014-08-15 17:14:35 +00009064static const char *getLDMOption(const llvm::Triple &T, const ArgList &Args) {
9065 switch (T.getArch()) {
9066 case llvm::Triple::x86:
9067 return "elf_i386";
9068 case llvm::Triple::aarch64:
9069 return "aarch64linux";
9070 case llvm::Triple::aarch64_be:
9071 return "aarch64_be_linux";
9072 case llvm::Triple::arm:
9073 case llvm::Triple::thumb:
9074 return "armelf_linux_eabi";
9075 case llvm::Triple::armeb:
9076 case llvm::Triple::thumbeb:
9077 return "armebelf_linux_eabi"; /* TODO: check which NAME. */
9078 case llvm::Triple::ppc:
9079 return "elf32ppclinux";
9080 case llvm::Triple::ppc64:
9081 return "elf64ppc";
9082 case llvm::Triple::ppc64le:
9083 return "elf64lppc";
9084 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00009085 case llvm::Triple::sparcel:
Rafael Espindola1e085772014-08-15 17:14:35 +00009086 return "elf32_sparc";
9087 case llvm::Triple::sparcv9:
9088 return "elf64_sparc";
9089 case llvm::Triple::mips:
9090 return "elf32btsmip";
9091 case llvm::Triple::mipsel:
9092 return "elf32ltsmip";
9093 case llvm::Triple::mips64:
9094 if (mips::hasMipsAbiArg(Args, "n32"))
9095 return "elf32btsmipn32";
9096 return "elf64btsmip";
9097 case llvm::Triple::mips64el:
9098 if (mips::hasMipsAbiArg(Args, "n32"))
9099 return "elf32ltsmipn32";
9100 return "elf64ltsmip";
9101 case llvm::Triple::systemz:
9102 return "elf64_s390";
9103 case llvm::Triple::x86_64:
9104 if (T.getEnvironment() == llvm::Triple::GNUX32)
9105 return "elf32_x86_64";
9106 return "elf_x86_64";
9107 default:
9108 llvm_unreachable("Unexpected arch");
9109 }
9110}
9111
Douglas Katzman95354292015-06-23 20:42:09 +00009112void gnutools::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9113 const InputInfo &Output,
9114 const InputInfoList &Inputs,
9115 const ArgList &Args,
9116 const char *LinkingOutput) const {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00009117 const toolchains::Linux &ToolChain =
9118 static_cast<const toolchains::Linux &>(getToolChain());
Rafael Espindolac8f008f2010-11-07 20:14:31 +00009119 const Driver &D = ToolChain.getDriver();
James Y Knight2db38f32015-08-15 03:45:25 +00009120
9121 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
9122 llvm::Triple Triple = llvm::Triple(TripleStr);
9123
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00009124 const llvm::Triple::ArchType Arch = ToolChain.getArch();
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00009125 const bool isAndroid = ToolChain.getTriple().isAndroid();
Peter Collingbourne54d770c2013-04-09 04:35:11 +00009126 const bool IsPIE =
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00009127 !Args.hasArg(options::OPT_shared) && !Args.hasArg(options::OPT_static) &&
9128 (Args.hasArg(options::OPT_pie) || ToolChain.isPIEDefault());
Vasileios Kalintirisc744e122015-11-12 15:26:54 +00009129 const bool HasCRTBeginEndFiles =
9130 ToolChain.getTriple().hasEnvironment() ||
9131 (ToolChain.getTriple().getVendor() != llvm::Triple::MipsTechnologies);
Evgeniy Stepanov77866712012-04-25 08:59:22 +00009132
Rafael Espindolac8f008f2010-11-07 20:14:31 +00009133 ArgStringList CmdArgs;
9134
Rafael Espindolad1002f62010-11-15 18:28:16 +00009135 // Silence warning for "clang -g foo.o -o foo"
9136 Args.ClaimAllArgs(options::OPT_g_Group);
Rafael Espindolad95a8122011-03-01 05:25:27 +00009137 // and "clang -emit-llvm foo.o -o foo"
9138 Args.ClaimAllArgs(options::OPT_emit_llvm);
David Chisnall5f99f482012-07-29 15:24:44 +00009139 // and for "clang -w foo.o -o foo". Other warning options are already
Rafael Espindolaf92614c2010-11-17 20:37:10 +00009140 // handled somewhere else.
9141 Args.ClaimAllArgs(options::OPT_w);
Rafael Espindolad1002f62010-11-15 18:28:16 +00009142
Peter Collingbourne39719a72015-11-20 20:49:39 +00009143 const char *Exec = Args.MakeArgString(ToolChain.GetLinkerPath());
9144 if (llvm::sys::path::filename(Exec) == "lld") {
Vasileios Kalintirisc744e122015-11-12 15:26:54 +00009145 CmdArgs.push_back("-flavor");
Rafael Espindola156aac02015-11-16 09:12:12 +00009146 CmdArgs.push_back("old-gnu");
Vasileios Kalintirisc744e122015-11-12 15:26:54 +00009147 CmdArgs.push_back("-target");
9148 CmdArgs.push_back(Args.MakeArgString(getToolChain().getTripleString()));
9149 }
9150
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00009151 if (!D.SysRoot.empty())
9152 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00009153
Peter Collingbourne54d770c2013-04-09 04:35:11 +00009154 if (IsPIE)
Rafael Espindolad47ac232010-11-17 22:26:15 +00009155 CmdArgs.push_back("-pie");
9156
Rafael Espindola1c76c592010-11-07 22:57:16 +00009157 if (Args.hasArg(options::OPT_rdynamic))
9158 CmdArgs.push_back("-export-dynamic");
9159
Rafael Espindola34d77dc2010-11-11 19:34:42 +00009160 if (Args.hasArg(options::OPT_s))
9161 CmdArgs.push_back("-s");
9162
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00009163 if (Arch == llvm::Triple::armeb || Arch == llvm::Triple::thumbeb)
James Y Knight2db38f32015-08-15 03:45:25 +00009164 arm::appendEBLinkFlags(Args, CmdArgs, Triple);
Joerg Sonnenberger1689d3f2015-01-28 23:30:39 +00009165
NAKAMURA Takumi557fb622014-06-29 16:00:11 +00009166 for (const auto &Opt : ToolChain.ExtraOpts)
9167 CmdArgs.push_back(Opt.c_str());
Rafael Espindolac8f008f2010-11-07 20:14:31 +00009168
9169 if (!Args.hasArg(options::OPT_static)) {
9170 CmdArgs.push_back("--eh-frame-hdr");
9171 }
9172
9173 CmdArgs.push_back("-m");
Rafael Espindola1e085772014-08-15 17:14:35 +00009174 CmdArgs.push_back(getLDMOption(ToolChain.getTriple(), Args));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00009175
9176 if (Args.hasArg(options::OPT_static)) {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00009177 if (Arch == llvm::Triple::arm || Arch == llvm::Triple::armeb ||
9178 Arch == llvm::Triple::thumb || Arch == llvm::Triple::thumbeb)
Rafael Espindolac8f008f2010-11-07 20:14:31 +00009179 CmdArgs.push_back("-Bstatic");
9180 else
9181 CmdArgs.push_back("-static");
9182 } else if (Args.hasArg(options::OPT_shared)) {
9183 CmdArgs.push_back("-shared");
9184 }
9185
Saleem Abdulrasoolf56c6d82016-02-07 06:03:38 +00009186 if (!Args.hasArg(options::OPT_static)) {
9187 if (Args.hasArg(options::OPT_rdynamic))
9188 CmdArgs.push_back("-export-dynamic");
9189
9190 if (!Args.hasArg(options::OPT_shared)) {
9191 const std::string Loader =
Saleem Abdulrasool783fc632016-05-22 03:12:19 +00009192 D.DyldPrefix + ToolChain.getDynamicLinker(Args);
Saleem Abdulrasoolf56c6d82016-02-07 06:03:38 +00009193 CmdArgs.push_back("-dynamic-linker");
9194 CmdArgs.push_back(Args.MakeArgString(Loader));
9195 }
NAKAMURA Takumi557fb622014-06-29 16:00:11 +00009196 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00009197
9198 CmdArgs.push_back("-o");
9199 CmdArgs.push_back(Output.getFilename());
9200
Douglas Katzman78b37b02015-11-17 20:28:07 +00009201 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) {
Evgeniy Stepanov77866712012-04-25 08:59:22 +00009202 if (!isAndroid) {
Craig Topper92fc2df2014-05-17 16:56:41 +00009203 const char *crt1 = nullptr;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009204 if (!Args.hasArg(options::OPT_shared)) {
Eric Christopherac021742013-06-07 23:25:01 +00009205 if (Args.hasArg(options::OPT_pg))
9206 crt1 = "gcrt1.o";
9207 else if (IsPIE)
Evgeniy Stepanov77866712012-04-25 08:59:22 +00009208 crt1 = "Scrt1.o";
9209 else
9210 crt1 = "crt1.o";
9211 }
9212 if (crt1)
9213 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crt1)));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00009214
Evgeniy Stepanov77866712012-04-25 08:59:22 +00009215 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
9216 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00009217
Rafael Espindola9aa60e92010-11-12 03:00:39 +00009218 const char *crtbegin;
9219 if (Args.hasArg(options::OPT_static))
Evgeniy Stepanov77866712012-04-25 08:59:22 +00009220 crtbegin = isAndroid ? "crtbegin_static.o" : "crtbeginT.o";
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00009221 else if (Args.hasArg(options::OPT_shared))
Evgeniy Stepanov77866712012-04-25 08:59:22 +00009222 crtbegin = isAndroid ? "crtbegin_so.o" : "crtbeginS.o";
Peter Collingbourne54d770c2013-04-09 04:35:11 +00009223 else if (IsPIE)
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00009224 crtbegin = isAndroid ? "crtbegin_dynamic.o" : "crtbeginS.o";
Rafael Espindola9aa60e92010-11-12 03:00:39 +00009225 else
Evgeniy Stepanov77866712012-04-25 08:59:22 +00009226 crtbegin = isAndroid ? "crtbegin_dynamic.o" : "crtbegin.o";
Vasileios Kalintirisc744e122015-11-12 15:26:54 +00009227
9228 if (HasCRTBeginEndFiles)
9229 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtbegin)));
Benjamin Kramer058666a2012-10-04 19:42:20 +00009230
9231 // Add crtfastmath.o if available and fast math is enabled.
9232 ToolChain.AddFastMathRuntimeIfAvailable(Args, CmdArgs);
Rafael Espindola9aa60e92010-11-12 03:00:39 +00009233 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00009234
9235 Args.AddAllArgs(CmdArgs, options::OPT_L);
Reid Kleckner69071442014-06-26 01:08:54 +00009236 Args.AddAllArgs(CmdArgs, options::OPT_u);
Rafael Espindolac8f008f2010-11-07 20:14:31 +00009237
Douglas Katzman6059ef92015-11-17 17:41:23 +00009238 ToolChain.AddFilePathLibArgs(Args, CmdArgs);
Rafael Espindolac8f008f2010-11-07 20:14:31 +00009239
Teresa Johnson945bc502015-10-15 20:35:53 +00009240 if (D.isUsingLTO())
9241 AddGoldPlugin(ToolChain, Args, CmdArgs, D.getLTOMode() == LTOK_Thin);
Chandler Carruth953fb082013-01-13 11:46:33 +00009242
Nick Lewycky2fe6aab2012-08-17 03:39:16 +00009243 if (Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
9244 CmdArgs.push_back("--no-demangle");
9245
Alexey Samsonov52550342014-09-15 19:58:40 +00009246 bool NeedsSanitizerDeps = addSanitizerRuntimes(ToolChain, Args, CmdArgs);
Rafael Espindolac8f008f2010-11-07 20:14:31 +00009247 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
Chandler Carruthe4458b32013-06-24 09:38:45 +00009248 // The profile runtime also needs access to system libraries.
Xinliang David Li69306c02015-10-22 06:15:31 +00009249 getToolChain().addProfileRTLibs(Args, CmdArgs);
Chandler Carruthe4458b32013-06-24 09:38:45 +00009250
Douglas Katzman78b37b02015-11-17 20:28:07 +00009251 if (D.CCCIsCXX() &&
9252 !Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs)) {
Rafael Espindola70b8d762011-10-17 22:14:51 +00009253 bool OnlyLibstdcxxStatic = Args.hasArg(options::OPT_static_libstdcxx) &&
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009254 !Args.hasArg(options::OPT_static);
Rafael Espindola70b8d762011-10-17 22:14:51 +00009255 if (OnlyLibstdcxxStatic)
9256 CmdArgs.push_back("-Bstatic");
Rafael Espindolac8f008f2010-11-07 20:14:31 +00009257 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
Rafael Espindola70b8d762011-10-17 22:14:51 +00009258 if (OnlyLibstdcxxStatic)
9259 CmdArgs.push_back("-Bdynamic");
Rafael Espindolac8f008f2010-11-07 20:14:31 +00009260 CmdArgs.push_back("-lm");
9261 }
Chandler Carruth7e7dd472015-03-07 10:01:29 +00009262 // Silence warnings when linking C code with a C++ '-stdlib' argument.
9263 Args.ClaimAllArgs(options::OPT_stdlib_EQ);
Rafael Espindolac8f008f2010-11-07 20:14:31 +00009264
Rafael Espindola9aa60e92010-11-12 03:00:39 +00009265 if (!Args.hasArg(options::OPT_nostdlib)) {
Chandler Carruth94a32012012-05-14 18:31:18 +00009266 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
9267 if (Args.hasArg(options::OPT_static))
9268 CmdArgs.push_back("--start-group");
Nick Lewycky97864da2011-06-04 06:27:06 +00009269
Alexey Samsonov52550342014-09-15 19:58:40 +00009270 if (NeedsSanitizerDeps)
9271 linkSanitizerRuntimeDeps(ToolChain, CmdArgs);
9272
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00009273 bool WantPthread = Args.hasArg(options::OPT_pthread) ||
9274 Args.hasArg(options::OPT_pthreads);
9275
9276 if (Args.hasFlag(options::OPT_fopenmp, options::OPT_fopenmp_EQ,
9277 options::OPT_fno_openmp, false)) {
9278 // OpenMP runtimes implies pthreads when using the GNU toolchain.
9279 // FIXME: Does this really make sense for all GNU toolchains?
9280 WantPthread = true;
9281
9282 // Also link the particular OpenMP runtimes.
9283 switch (getOpenMPRuntime(ToolChain, Args)) {
9284 case OMPRT_OMP:
9285 CmdArgs.push_back("-lomp");
9286 break;
9287 case OMPRT_GOMP:
Richard Smith31d1de22015-05-20 22:48:44 +00009288 CmdArgs.push_back("-lgomp");
9289
9290 // FIXME: Exclude this for platforms with libgomp that don't require
9291 // librt. Most modern Linux platforms require it, but some may not.
9292 CmdArgs.push_back("-lrt");
9293 break;
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00009294 case OMPRT_IOMP5:
Richard Smith31d1de22015-05-20 22:48:44 +00009295 CmdArgs.push_back("-liomp5");
9296 break;
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00009297 case OMPRT_Unknown:
9298 // Already diagnosed.
Richard Smith31d1de22015-05-20 22:48:44 +00009299 break;
9300 }
Chandler Carruth01538002013-01-17 13:19:29 +00009301 }
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00009302
Renato Golinc4b49242014-02-13 10:01:16 +00009303 AddRunTimeLibs(ToolChain, D, CmdArgs, Args);
Rafael Espindola9aa60e92010-11-12 03:00:39 +00009304
Richard Smith31d1de22015-05-20 22:48:44 +00009305 if (WantPthread && !isAndroid)
Chandler Carruth94a32012012-05-14 18:31:18 +00009306 CmdArgs.push_back("-lpthread");
9307
Rafael Espindolab17bc532016-01-25 18:29:16 +00009308 if (Args.hasArg(options::OPT_fsplit_stack))
9309 CmdArgs.push_back("--wrap=pthread_create");
9310
Chandler Carruth94a32012012-05-14 18:31:18 +00009311 CmdArgs.push_back("-lc");
9312
9313 if (Args.hasArg(options::OPT_static))
9314 CmdArgs.push_back("--end-group");
9315 else
Renato Golinc4b49242014-02-13 10:01:16 +00009316 AddRunTimeLibs(ToolChain, D, CmdArgs, Args);
Chandler Carruth94a32012012-05-14 18:31:18 +00009317 }
Rafael Espindolad47ac232010-11-17 22:26:15 +00009318
Rafael Espindola81937ec2010-12-01 01:52:43 +00009319 if (!Args.hasArg(options::OPT_nostartfiles)) {
9320 const char *crtend;
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00009321 if (Args.hasArg(options::OPT_shared))
Evgeniy Stepanov77866712012-04-25 08:59:22 +00009322 crtend = isAndroid ? "crtend_so.o" : "crtendS.o";
Peter Collingbourne54d770c2013-04-09 04:35:11 +00009323 else if (IsPIE)
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00009324 crtend = isAndroid ? "crtend_android.o" : "crtendS.o";
Rafael Espindola81937ec2010-12-01 01:52:43 +00009325 else
Evgeniy Stepanov77866712012-04-25 08:59:22 +00009326 crtend = isAndroid ? "crtend_android.o" : "crtend.o";
Rafael Espindola9aa60e92010-11-12 03:00:39 +00009327
Vasileios Kalintirisc744e122015-11-12 15:26:54 +00009328 if (HasCRTBeginEndFiles)
9329 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtend)));
Evgeniy Stepanov77866712012-04-25 08:59:22 +00009330 if (!isAndroid)
9331 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
Rafael Espindola81937ec2010-12-01 01:52:43 +00009332 }
Sumanth Gundapanenib79fdff2015-12-02 19:12:41 +00009333 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00009334
Peter Collingbourne39719a72015-11-20 20:49:39 +00009335 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Saleem Abdulrasoola4a474b2014-06-29 06:11:14 +00009336}
9337
Derek Schuff6ab52fa2015-03-30 20:31:33 +00009338// NaCl ARM assembly (inline or standalone) can be written with a set of macros
9339// for the various SFI requirements like register masking. The assembly tool
9340// inserts the file containing the macros as an input into all the assembly
9341// jobs.
Douglas Katzman95354292015-06-23 20:42:09 +00009342void nacltools::AssemblerARM::ConstructJob(Compilation &C, const JobAction &JA,
9343 const InputInfo &Output,
9344 const InputInfoList &Inputs,
9345 const ArgList &Args,
9346 const char *LinkingOutput) const {
Douglas Katzman54366072015-07-27 16:53:08 +00009347 const toolchains::NaClToolChain &ToolChain =
9348 static_cast<const toolchains::NaClToolChain &>(getToolChain());
Justin Lebard98cea82016-01-11 23:15:21 +00009349 InputInfo NaClMacros(types::TY_PP_Asm, ToolChain.GetNaClArmMacrosPath(),
Derek Schuff6ab52fa2015-03-30 20:31:33 +00009350 "nacl-arm-macros.s");
9351 InputInfoList NewInputs;
9352 NewInputs.push_back(NaClMacros);
9353 NewInputs.append(Inputs.begin(), Inputs.end());
Douglas Katzman95354292015-06-23 20:42:09 +00009354 gnutools::Assembler::ConstructJob(C, JA, Output, NewInputs, Args,
9355 LinkingOutput);
Derek Schuff6ab52fa2015-03-30 20:31:33 +00009356}
9357
Douglas Katzman750cfc52015-06-29 18:42:16 +00009358// This is quite similar to gnutools::Linker::ConstructJob with changes that
Derek Schuff6ab52fa2015-03-30 20:31:33 +00009359// we use static by default, do not yet support sanitizers or LTO, and a few
9360// others. Eventually we can support more of that and hopefully migrate back
Douglas Katzman750cfc52015-06-29 18:42:16 +00009361// to gnutools::Linker.
Douglas Katzman95354292015-06-23 20:42:09 +00009362void nacltools::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9363 const InputInfo &Output,
9364 const InputInfoList &Inputs,
9365 const ArgList &Args,
9366 const char *LinkingOutput) const {
Derek Schuff6ab52fa2015-03-30 20:31:33 +00009367
Douglas Katzman54366072015-07-27 16:53:08 +00009368 const toolchains::NaClToolChain &ToolChain =
9369 static_cast<const toolchains::NaClToolChain &>(getToolChain());
Derek Schuff6ab52fa2015-03-30 20:31:33 +00009370 const Driver &D = ToolChain.getDriver();
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00009371 const llvm::Triple::ArchType Arch = ToolChain.getArch();
Derek Schuff6ab52fa2015-03-30 20:31:33 +00009372 const bool IsStatic =
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00009373 !Args.hasArg(options::OPT_dynamic) && !Args.hasArg(options::OPT_shared);
Derek Schuff6ab52fa2015-03-30 20:31:33 +00009374
9375 ArgStringList CmdArgs;
9376
9377 // Silence warning for "clang -g foo.o -o foo"
9378 Args.ClaimAllArgs(options::OPT_g_Group);
9379 // and "clang -emit-llvm foo.o -o foo"
9380 Args.ClaimAllArgs(options::OPT_emit_llvm);
9381 // and for "clang -w foo.o -o foo". Other warning options are already
9382 // handled somewhere else.
9383 Args.ClaimAllArgs(options::OPT_w);
9384
9385 if (!D.SysRoot.empty())
9386 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
9387
9388 if (Args.hasArg(options::OPT_rdynamic))
9389 CmdArgs.push_back("-export-dynamic");
9390
9391 if (Args.hasArg(options::OPT_s))
9392 CmdArgs.push_back("-s");
9393
Douglas Katzman54366072015-07-27 16:53:08 +00009394 // NaClToolChain doesn't have ExtraOpts like Linux; the only relevant flag
9395 // from there is --build-id, which we do want.
Derek Schuff6ab52fa2015-03-30 20:31:33 +00009396 CmdArgs.push_back("--build-id");
9397
9398 if (!IsStatic)
9399 CmdArgs.push_back("--eh-frame-hdr");
9400
9401 CmdArgs.push_back("-m");
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00009402 if (Arch == llvm::Triple::x86)
Derek Schuff6ab52fa2015-03-30 20:31:33 +00009403 CmdArgs.push_back("elf_i386_nacl");
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00009404 else if (Arch == llvm::Triple::arm)
Derek Schuff6ab52fa2015-03-30 20:31:33 +00009405 CmdArgs.push_back("armelf_nacl");
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00009406 else if (Arch == llvm::Triple::x86_64)
Derek Schuff6ab52fa2015-03-30 20:31:33 +00009407 CmdArgs.push_back("elf_x86_64_nacl");
Petar Jovanovic26a4a402015-07-08 13:07:31 +00009408 else if (Arch == llvm::Triple::mipsel)
9409 CmdArgs.push_back("mipselelf_nacl");
Derek Schuff6ab52fa2015-03-30 20:31:33 +00009410 else
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00009411 D.Diag(diag::err_target_unsupported_arch) << ToolChain.getArchName()
9412 << "Native Client";
Derek Schuff6ab52fa2015-03-30 20:31:33 +00009413
9414 if (IsStatic)
9415 CmdArgs.push_back("-static");
9416 else if (Args.hasArg(options::OPT_shared))
9417 CmdArgs.push_back("-shared");
9418
9419 CmdArgs.push_back("-o");
9420 CmdArgs.push_back(Output.getFilename());
Douglas Katzman78b37b02015-11-17 20:28:07 +00009421 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) {
Derek Schuff6ab52fa2015-03-30 20:31:33 +00009422 if (!Args.hasArg(options::OPT_shared))
9423 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crt1.o")));
9424 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
9425
9426 const char *crtbegin;
9427 if (IsStatic)
9428 crtbegin = "crtbeginT.o";
9429 else if (Args.hasArg(options::OPT_shared))
9430 crtbegin = "crtbeginS.o";
9431 else
9432 crtbegin = "crtbegin.o";
9433 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtbegin)));
9434 }
9435
9436 Args.AddAllArgs(CmdArgs, options::OPT_L);
9437 Args.AddAllArgs(CmdArgs, options::OPT_u);
9438
Douglas Katzman6059ef92015-11-17 17:41:23 +00009439 ToolChain.AddFilePathLibArgs(Args, CmdArgs);
Derek Schuff6ab52fa2015-03-30 20:31:33 +00009440
9441 if (Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
9442 CmdArgs.push_back("--no-demangle");
9443
9444 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
9445
Douglas Katzman78b37b02015-11-17 20:28:07 +00009446 if (D.CCCIsCXX() &&
9447 !Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009448 bool OnlyLibstdcxxStatic =
9449 Args.hasArg(options::OPT_static_libstdcxx) && !IsStatic;
Derek Schuff6ab52fa2015-03-30 20:31:33 +00009450 if (OnlyLibstdcxxStatic)
9451 CmdArgs.push_back("-Bstatic");
9452 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
9453 if (OnlyLibstdcxxStatic)
9454 CmdArgs.push_back("-Bdynamic");
9455 CmdArgs.push_back("-lm");
9456 }
9457
9458 if (!Args.hasArg(options::OPT_nostdlib)) {
9459 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
9460 // Always use groups, since it has no effect on dynamic libraries.
9461 CmdArgs.push_back("--start-group");
9462 CmdArgs.push_back("-lc");
9463 // NaCl's libc++ currently requires libpthread, so just always include it
9464 // in the group for C++.
9465 if (Args.hasArg(options::OPT_pthread) ||
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009466 Args.hasArg(options::OPT_pthreads) || D.CCCIsCXX()) {
Petar Jovanovic26a4a402015-07-08 13:07:31 +00009467 // Gold, used by Mips, handles nested groups differently than ld, and
9468 // without '-lnacl' it prefers symbols from libpthread.a over libnacl.a,
9469 // which is not a desired behaviour here.
9470 // See https://sourceware.org/ml/binutils/2015-03/msg00034.html
9471 if (getToolChain().getArch() == llvm::Triple::mipsel)
9472 CmdArgs.push_back("-lnacl");
9473
Derek Schuff6ab52fa2015-03-30 20:31:33 +00009474 CmdArgs.push_back("-lpthread");
9475 }
9476
9477 CmdArgs.push_back("-lgcc");
9478 CmdArgs.push_back("--as-needed");
9479 if (IsStatic)
9480 CmdArgs.push_back("-lgcc_eh");
9481 else
9482 CmdArgs.push_back("-lgcc_s");
9483 CmdArgs.push_back("--no-as-needed");
Petar Jovanovic26a4a402015-07-08 13:07:31 +00009484
9485 // Mips needs to create and use pnacl_legacy library that contains
9486 // definitions from bitcode/pnaclmm.c and definitions for
9487 // __nacl_tp_tls_offset() and __nacl_tp_tdb_offset().
9488 if (getToolChain().getArch() == llvm::Triple::mipsel)
9489 CmdArgs.push_back("-lpnacl_legacy");
9490
Derek Schuff6ab52fa2015-03-30 20:31:33 +00009491 CmdArgs.push_back("--end-group");
9492 }
9493
9494 if (!Args.hasArg(options::OPT_nostartfiles)) {
9495 const char *crtend;
9496 if (Args.hasArg(options::OPT_shared))
9497 crtend = "crtendS.o";
9498 else
9499 crtend = "crtend.o";
9500
9501 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtend)));
9502 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
9503 }
9504 }
9505
Peter Collingbourne39719a72015-11-20 20:49:39 +00009506 const char *Exec = Args.MakeArgString(ToolChain.GetLinkerPath());
9507 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Derek Schuff6ab52fa2015-03-30 20:31:33 +00009508}
9509
Douglas Katzman95354292015-06-23 20:42:09 +00009510void minix::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
9511 const InputInfo &Output,
9512 const InputInfoList &Inputs,
9513 const ArgList &Args,
9514 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00009515 claimNoWarnArgs(Args);
Chris Lattner3e2ee142010-07-07 16:01:42 +00009516 ArgStringList CmdArgs;
9517
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009518 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Chris Lattner3e2ee142010-07-07 16:01:42 +00009519
9520 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00009521 CmdArgs.push_back(Output.getFilename());
Chris Lattner3e2ee142010-07-07 16:01:42 +00009522
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009523 for (const auto &II : Inputs)
Daniel Dunbarb440f562010-08-02 02:38:21 +00009524 CmdArgs.push_back(II.getFilename());
Chris Lattner3e2ee142010-07-07 16:01:42 +00009525
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009526 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009527 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Chris Lattner3e2ee142010-07-07 16:01:42 +00009528}
9529
Douglas Katzman95354292015-06-23 20:42:09 +00009530void minix::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9531 const InputInfo &Output,
9532 const InputInfoList &Inputs,
9533 const ArgList &Args,
9534 const char *LinkingOutput) const {
Chris Lattner3e2ee142010-07-07 16:01:42 +00009535 const Driver &D = getToolChain().getDriver();
9536 ArgStringList CmdArgs;
9537
Daniel Dunbarb440f562010-08-02 02:38:21 +00009538 if (Output.isFilename()) {
Chris Lattner3e2ee142010-07-07 16:01:42 +00009539 CmdArgs.push_back("-o");
9540 CmdArgs.push_back(Output.getFilename());
9541 } else {
9542 assert(Output.isNothing() && "Invalid output.");
9543 }
9544
Douglas Katzman78b37b02015-11-17 20:28:07 +00009545 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009546 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crt1.o")));
9547 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
9548 CmdArgs.push_back(
9549 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
9550 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
Eli Friedman83de5132011-12-08 23:54:21 +00009551 }
Chris Lattner3e2ee142010-07-07 16:01:42 +00009552
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00009553 Args.AddAllArgs(CmdArgs,
9554 {options::OPT_L, options::OPT_T_Group, options::OPT_e});
Chris Lattner3e2ee142010-07-07 16:01:42 +00009555
Daniel Dunbar54423b22010-09-17 00:24:54 +00009556 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Chris Lattner3e2ee142010-07-07 16:01:42 +00009557
Xinliang David Li69306c02015-10-22 06:15:31 +00009558 getToolChain().addProfileRTLibs(Args, CmdArgs);
Eli Friedman83de5132011-12-08 23:54:21 +00009559
Douglas Katzman78b37b02015-11-17 20:28:07 +00009560 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00009561 if (D.CCCIsCXX()) {
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00009562 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Chris Lattner3e2ee142010-07-07 16:01:42 +00009563 CmdArgs.push_back("-lm");
9564 }
Chris Lattner3e2ee142010-07-07 16:01:42 +00009565 }
9566
Douglas Katzman78b37b02015-11-17 20:28:07 +00009567 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) {
Eli Friedman83de5132011-12-08 23:54:21 +00009568 if (Args.hasArg(options::OPT_pthread))
9569 CmdArgs.push_back("-lpthread");
9570 CmdArgs.push_back("-lc");
9571 CmdArgs.push_back("-lCompilerRT-Generic");
9572 CmdArgs.push_back("-L/usr/pkg/compiler-rt/lib");
9573 CmdArgs.push_back(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009574 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Chris Lattner3e2ee142010-07-07 16:01:42 +00009575 }
9576
Logan Chieneb9162f2014-06-26 14:23:45 +00009577 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00009578 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Chris Lattner3e2ee142010-07-07 16:01:42 +00009579}
9580
Daniel Dunbarcc912342009-05-02 18:28:39 +00009581/// DragonFly Tools
9582
9583// For now, DragonFly Assemble does just about the same as for
9584// FreeBSD, but this may change soon.
Douglas Katzman95354292015-06-23 20:42:09 +00009585void dragonfly::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
9586 const InputInfo &Output,
9587 const InputInfoList &Inputs,
9588 const ArgList &Args,
9589 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00009590 claimNoWarnArgs(Args);
Daniel Dunbarcc912342009-05-02 18:28:39 +00009591 ArgStringList CmdArgs;
9592
9593 // When building 32-bit code on DragonFly/pc64, we have to explicitly
9594 // instruct as in the base system to assemble 32-bit code.
Rafael Espindola35ca7d92012-10-07 04:44:33 +00009595 if (getToolChain().getArch() == llvm::Triple::x86)
Daniel Dunbarcc912342009-05-02 18:28:39 +00009596 CmdArgs.push_back("--32");
9597
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009598 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbarcc912342009-05-02 18:28:39 +00009599
9600 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00009601 CmdArgs.push_back(Output.getFilename());
Daniel Dunbarcc912342009-05-02 18:28:39 +00009602
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009603 for (const auto &II : Inputs)
Daniel Dunbarb440f562010-08-02 02:38:21 +00009604 CmdArgs.push_back(II.getFilename());
Daniel Dunbarcc912342009-05-02 18:28:39 +00009605
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009606 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009607 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbarcc912342009-05-02 18:28:39 +00009608}
9609
Douglas Katzman95354292015-06-23 20:42:09 +00009610void dragonfly::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9611 const InputInfo &Output,
9612 const InputInfoList &Inputs,
9613 const ArgList &Args,
9614 const char *LinkingOutput) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00009615 const Driver &D = getToolChain().getDriver();
Daniel Dunbarcc912342009-05-02 18:28:39 +00009616 ArgStringList CmdArgs;
John McCall65b8da02013-04-11 22:55:55 +00009617
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00009618 if (!D.SysRoot.empty())
9619 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
9620
John McCall65b8da02013-04-11 22:55:55 +00009621 CmdArgs.push_back("--eh-frame-hdr");
Daniel Dunbarcc912342009-05-02 18:28:39 +00009622 if (Args.hasArg(options::OPT_static)) {
9623 CmdArgs.push_back("-Bstatic");
9624 } else {
John McCall65b8da02013-04-11 22:55:55 +00009625 if (Args.hasArg(options::OPT_rdynamic))
9626 CmdArgs.push_back("-export-dynamic");
Daniel Dunbarcc912342009-05-02 18:28:39 +00009627 if (Args.hasArg(options::OPT_shared))
9628 CmdArgs.push_back("-Bshareable");
9629 else {
9630 CmdArgs.push_back("-dynamic-linker");
9631 CmdArgs.push_back("/usr/libexec/ld-elf.so.2");
9632 }
Dimitry Andricf59a2b32015-12-27 10:01:44 +00009633 CmdArgs.push_back("--hash-style=gnu");
9634 CmdArgs.push_back("--enable-new-dtags");
Daniel Dunbarcc912342009-05-02 18:28:39 +00009635 }
9636
9637 // When building 32-bit code on DragonFly/pc64, we have to explicitly
9638 // instruct ld in the base system to link 32-bit code.
Rafael Espindola35ca7d92012-10-07 04:44:33 +00009639 if (getToolChain().getArch() == llvm::Triple::x86) {
Daniel Dunbarcc912342009-05-02 18:28:39 +00009640 CmdArgs.push_back("-m");
9641 CmdArgs.push_back("elf_i386");
9642 }
9643
Daniel Dunbarb440f562010-08-02 02:38:21 +00009644 if (Output.isFilename()) {
Daniel Dunbarcc912342009-05-02 18:28:39 +00009645 CmdArgs.push_back("-o");
9646 CmdArgs.push_back(Output.getFilename());
9647 } else {
9648 assert(Output.isNothing() && "Invalid output.");
9649 }
9650
Douglas Katzman78b37b02015-11-17 20:28:07 +00009651 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) {
Daniel Dunbarcc912342009-05-02 18:28:39 +00009652 if (!Args.hasArg(options::OPT_shared)) {
John McCall65b8da02013-04-11 22:55:55 +00009653 if (Args.hasArg(options::OPT_pg))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009654 CmdArgs.push_back(
9655 Args.MakeArgString(getToolChain().GetFilePath("gcrt1.o")));
John McCall65b8da02013-04-11 22:55:55 +00009656 else {
9657 if (Args.hasArg(options::OPT_pie))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009658 CmdArgs.push_back(
9659 Args.MakeArgString(getToolChain().GetFilePath("Scrt1.o")));
John McCall65b8da02013-04-11 22:55:55 +00009660 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009661 CmdArgs.push_back(
9662 Args.MakeArgString(getToolChain().GetFilePath("crt1.o")));
John McCall65b8da02013-04-11 22:55:55 +00009663 }
Daniel Dunbarcc912342009-05-02 18:28:39 +00009664 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009665 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
John McCall65b8da02013-04-11 22:55:55 +00009666 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_pie))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009667 CmdArgs.push_back(
9668 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.o")));
John McCall65b8da02013-04-11 22:55:55 +00009669 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009670 CmdArgs.push_back(
9671 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
Daniel Dunbarcc912342009-05-02 18:28:39 +00009672 }
9673
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00009674 Args.AddAllArgs(CmdArgs,
9675 {options::OPT_L, options::OPT_T_Group, options::OPT_e});
Daniel Dunbarcc912342009-05-02 18:28:39 +00009676
Daniel Dunbar54423b22010-09-17 00:24:54 +00009677 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Daniel Dunbarcc912342009-05-02 18:28:39 +00009678
Douglas Katzman78b37b02015-11-17 20:28:07 +00009679 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs)) {
Dimitry Andricf59a2b32015-12-27 10:01:44 +00009680 CmdArgs.push_back("-L/usr/lib/gcc50");
Daniel Dunbarcc912342009-05-02 18:28:39 +00009681
9682 if (!Args.hasArg(options::OPT_static)) {
Dimitry Andricf59a2b32015-12-27 10:01:44 +00009683 CmdArgs.push_back("-rpath");
9684 CmdArgs.push_back("/usr/lib/gcc50");
Daniel Dunbarcc912342009-05-02 18:28:39 +00009685 }
9686
Hans Wennborg70850d82013-07-18 20:29:38 +00009687 if (D.CCCIsCXX()) {
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00009688 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Rafael Espindola38360b32010-07-20 12:59:03 +00009689 CmdArgs.push_back("-lm");
9690 }
9691
Daniel Dunbarcc912342009-05-02 18:28:39 +00009692 if (Args.hasArg(options::OPT_pthread))
Mike Stump0a65b632009-10-31 20:11:46 +00009693 CmdArgs.push_back("-lpthread");
Daniel Dunbarcc912342009-05-02 18:28:39 +00009694
9695 if (!Args.hasArg(options::OPT_nolibc)) {
9696 CmdArgs.push_back("-lc");
9697 }
9698
Dimitry Andricf59a2b32015-12-27 10:01:44 +00009699 if (Args.hasArg(options::OPT_static) ||
9700 Args.hasArg(options::OPT_static_libgcc)) {
John McCall65b8da02013-04-11 22:55:55 +00009701 CmdArgs.push_back("-lgcc");
9702 CmdArgs.push_back("-lgcc_eh");
Dimitry Andricf59a2b32015-12-27 10:01:44 +00009703 } else {
9704 if (Args.hasArg(options::OPT_shared_libgcc)) {
John McCall65b8da02013-04-11 22:55:55 +00009705 CmdArgs.push_back("-lgcc_pic");
9706 if (!Args.hasArg(options::OPT_shared))
9707 CmdArgs.push_back("-lgcc");
Dimitry Andricf59a2b32015-12-27 10:01:44 +00009708 } else {
John McCall65b8da02013-04-11 22:55:55 +00009709 CmdArgs.push_back("-lgcc");
9710 CmdArgs.push_back("--as-needed");
9711 CmdArgs.push_back("-lgcc_pic");
9712 CmdArgs.push_back("--no-as-needed");
John McCall65b8da02013-04-11 22:55:55 +00009713 }
Daniel Dunbarcc912342009-05-02 18:28:39 +00009714 }
9715 }
9716
Douglas Katzman78b37b02015-11-17 20:28:07 +00009717 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) {
John McCall65b8da02013-04-11 22:55:55 +00009718 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_pie))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009719 CmdArgs.push_back(
9720 Args.MakeArgString(getToolChain().GetFilePath("crtendS.o")));
John McCall65b8da02013-04-11 22:55:55 +00009721 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009722 CmdArgs.push_back(
9723 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
9724 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
Daniel Dunbarcc912342009-05-02 18:28:39 +00009725 }
9726
Xinliang David Li69306c02015-10-22 06:15:31 +00009727 getToolChain().addProfileRTLibs(Args, CmdArgs);
Nick Lewycky82fe5f42011-05-24 21:54:59 +00009728
Logan Chieneb9162f2014-06-26 14:23:45 +00009729 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00009730 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbarcc912342009-05-02 18:28:39 +00009731}
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009732
Zachary Turner0eaf8fc2014-10-22 20:40:28 +00009733// Try to find Exe from a Visual Studio distribution. This first tries to find
9734// an installed copy of Visual Studio and, failing that, looks in the PATH,
9735// making sure that whatever executable that's found is not a same-named exe
9736// from clang itself to prevent clang from falling back to itself.
9737static std::string FindVisualStudioExecutable(const ToolChain &TC,
9738 const char *Exe,
9739 const char *ClangProgramPath) {
9740 const auto &MSVC = static_cast<const toolchains::MSVCToolChain &>(TC);
9741 std::string visualStudioBinDir;
9742 if (MSVC.getVisualStudioBinariesFolder(ClangProgramPath,
9743 visualStudioBinDir)) {
9744 SmallString<128> FilePath(visualStudioBinDir);
9745 llvm::sys::path::append(FilePath, Exe);
9746 if (llvm::sys::fs::can_execute(FilePath.c_str()))
9747 return FilePath.str();
9748 }
9749
9750 return Exe;
9751}
9752
Douglas Katzman95354292015-06-23 20:42:09 +00009753void visualstudio::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9754 const InputInfo &Output,
9755 const InputInfoList &Inputs,
9756 const ArgList &Args,
9757 const char *LinkingOutput) const {
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009758 ArgStringList CmdArgs;
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009759 const ToolChain &TC = getToolChain();
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009760
Saleem Abdulrasool9a215462014-12-19 23:56:31 +00009761 assert((Output.isFilename() || Output.isNothing()) && "invalid output");
9762 if (Output.isFilename())
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009763 CmdArgs.push_back(
9764 Args.MakeArgString(std::string("-out:") + Output.getFilename()));
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009765
Douglas Katzman78b37b02015-11-17 20:28:07 +00009766 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles) &&
9767 !C.getDriver().IsCLMode())
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009768 CmdArgs.push_back("-defaultlib:libcmt");
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009769
Zachary Turner10d75b22014-10-22 20:40:43 +00009770 if (!llvm::sys::Process::GetEnv("LIB")) {
9771 // If the VC environment hasn't been configured (perhaps because the user
9772 // did not run vcvarsall), try to build a consistent link environment. If
Nico Webere93bcd12015-03-11 00:05:26 +00009773 // the environment variable is set however, assume the user knows what
9774 // they're doing.
Zachary Turner10d75b22014-10-22 20:40:43 +00009775 std::string VisualStudioDir;
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009776 const auto &MSVC = static_cast<const toolchains::MSVCToolChain &>(TC);
Zachary Turner10d75b22014-10-22 20:40:43 +00009777 if (MSVC.getVisualStudioInstallDir(VisualStudioDir)) {
9778 SmallString<128> LibDir(VisualStudioDir);
9779 llvm::sys::path::append(LibDir, "VC", "lib");
9780 switch (MSVC.getArch()) {
9781 case llvm::Triple::x86:
9782 // x86 just puts the libraries directly in lib
9783 break;
9784 case llvm::Triple::x86_64:
9785 llvm::sys::path::append(LibDir, "amd64");
9786 break;
9787 case llvm::Triple::arm:
9788 llvm::sys::path::append(LibDir, "arm");
9789 break;
9790 default:
9791 break;
9792 }
9793 CmdArgs.push_back(
9794 Args.MakeArgString(std::string("-libpath:") + LibDir.c_str()));
Reid Kleckner7531f7d2015-09-11 00:09:39 +00009795
9796 if (MSVC.useUniversalCRT(VisualStudioDir)) {
9797 std::string UniversalCRTLibPath;
9798 if (MSVC.getUniversalCRTLibraryPath(UniversalCRTLibPath))
9799 CmdArgs.push_back(Args.MakeArgString(std::string("-libpath:") +
9800 UniversalCRTLibPath.c_str()));
9801 }
Zachary Turner10d75b22014-10-22 20:40:43 +00009802 }
9803
9804 std::string WindowsSdkLibPath;
9805 if (MSVC.getWindowsSDKLibraryPath(WindowsSdkLibPath))
9806 CmdArgs.push_back(Args.MakeArgString(std::string("-libpath:") +
9807 WindowsSdkLibPath.c_str()));
9808 }
9809
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009810 CmdArgs.push_back("-nologo");
9811
Reid Kleckner124955a2015-08-05 18:51:13 +00009812 if (Args.hasArg(options::OPT_g_Group, options::OPT__SLASH_Z7))
Hans Wennborgbbb5f072014-04-25 16:24:19 +00009813 CmdArgs.push_back("-debug");
Hans Wennborgbbb5f072014-04-25 16:24:19 +00009814
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009815 bool DLL = Args.hasArg(options::OPT__SLASH_LD, options::OPT__SLASH_LDd,
Hans Wennborge4c47f22015-03-04 23:16:21 +00009816 options::OPT_shared);
Hans Wennborgf1a74252013-09-10 20:18:04 +00009817 if (DLL) {
9818 CmdArgs.push_back(Args.MakeArgString("-dll"));
9819
9820 SmallString<128> ImplibName(Output.getFilename());
9821 llvm::sys::path::replace_extension(ImplibName, "lib");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009822 CmdArgs.push_back(Args.MakeArgString(std::string("-implib:") + ImplibName));
Hans Wennborgf1a74252013-09-10 20:18:04 +00009823 }
9824
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009825 if (TC.getSanitizerArgs().needsAsanRt()) {
Hans Wennborg0517e752013-08-28 17:36:07 +00009826 CmdArgs.push_back(Args.MakeArgString("-debug"));
Hans Wennborgd024c1c2013-08-30 10:50:52 +00009827 CmdArgs.push_back(Args.MakeArgString("-incremental:no"));
Timur Iskhodzhanov6903e102014-08-26 10:08:24 +00009828 if (Args.hasArg(options::OPT__SLASH_MD, options::OPT__SLASH_MDd)) {
Saleem Abdulrasoolb48f1fe2015-10-29 03:36:42 +00009829 for (const auto &Lib : {"asan_dynamic", "asan_dynamic_runtime_thunk"})
9830 CmdArgs.push_back(TC.getCompilerRTArgString(Args, Lib));
Timur Iskhodzhanov651725e2014-09-12 14:01:30 +00009831 // Make sure the dynamic runtime thunk is not optimized out at link time
9832 // to ensure proper SEH handling.
9833 CmdArgs.push_back(Args.MakeArgString("-include:___asan_seh_interceptor"));
Timur Iskhodzhanov6903e102014-08-26 10:08:24 +00009834 } else if (DLL) {
Xinliang David Li69306c02015-10-22 06:15:31 +00009835 CmdArgs.push_back(TC.getCompilerRTArgString(Args, "asan_dll_thunk"));
Alexey Samsonov6424e022014-05-12 20:20:20 +00009836 } else {
Saleem Abdulrasoolb48f1fe2015-10-29 03:36:42 +00009837 for (const auto &Lib : {"asan", "asan_cxx"})
9838 CmdArgs.push_back(TC.getCompilerRTArgString(Args, Lib));
Alexey Samsonov6424e022014-05-12 20:20:20 +00009839 }
Hans Wennborg65f17522013-08-27 18:10:21 +00009840 }
9841
Hans Wennborg2e274592013-08-13 23:38:57 +00009842 Args.AddAllArgValues(CmdArgs, options::OPT__SLASH_link);
Michael J. Spencere2f49362012-06-18 16:56:04 +00009843
Alexey Bataevc7e84352015-08-19 04:49:01 +00009844 if (Args.hasFlag(options::OPT_fopenmp, options::OPT_fopenmp_EQ,
9845 options::OPT_fno_openmp, false)) {
9846 CmdArgs.push_back("-nodefaultlib:vcomp.lib");
9847 CmdArgs.push_back("-nodefaultlib:vcompd.lib");
9848 CmdArgs.push_back(Args.MakeArgString(std::string("-libpath:") +
9849 TC.getDriver().Dir + "/../lib"));
9850 switch (getOpenMPRuntime(getToolChain(), Args)) {
9851 case OMPRT_OMP:
9852 CmdArgs.push_back("-defaultlib:libomp.lib");
9853 break;
9854 case OMPRT_IOMP5:
9855 CmdArgs.push_back("-defaultlib:libiomp5md.lib");
9856 break;
9857 case OMPRT_GOMP:
9858 break;
9859 case OMPRT_Unknown:
9860 // Already diagnosed.
9861 break;
9862 }
9863 }
9864
Andrey Turetskiya4868572016-03-14 11:19:43 +00009865 // Add compiler-rt lib in case if it was explicitly
9866 // specified as an argument for --rtlib option.
9867 if (!Args.hasArg(options::OPT_nostdlib)) {
9868 AddRunTimeLibs(TC, TC.getDriver(), CmdArgs, Args);
9869 }
9870
Reid Kleckner337188f2014-09-16 19:22:00 +00009871 // Add filenames, libraries, and other linker inputs.
9872 for (const auto &Input : Inputs) {
9873 if (Input.isFilename()) {
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009874 CmdArgs.push_back(Input.getFilename());
Reid Kleckner337188f2014-09-16 19:22:00 +00009875 continue;
9876 }
9877
9878 const Arg &A = Input.getInputArg();
9879
9880 // Render -l options differently for the MSVC linker.
9881 if (A.getOption().matches(options::OPT_l)) {
9882 StringRef Lib = A.getValue();
9883 const char *LinkLibArg;
9884 if (Lib.endswith(".lib"))
9885 LinkLibArg = Args.MakeArgString(Lib);
9886 else
9887 LinkLibArg = Args.MakeArgString(Lib + ".lib");
9888 CmdArgs.push_back(LinkLibArg);
9889 continue;
9890 }
9891
9892 // Otherwise, this is some other kind of linker input option like -Wl, -z,
9893 // or -L. Render it, even if MSVC doesn't understand it.
9894 A.renderAsInput(Args, CmdArgs);
9895 }
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009896
Nathan Slingerlande8ddf9e2016-01-05 18:27:06 +00009897 TC.addProfileRTLibs(Args, CmdArgs);
9898
Zachary Turner719f58c2014-12-01 23:06:47 +00009899 // We need to special case some linker paths. In the case of lld, we need to
9900 // translate 'lld' into 'lld-link', and in the case of the regular msvc
9901 // linker, we need to use a special search algorithm.
9902 llvm::SmallString<128> linkPath;
9903 StringRef Linker = Args.getLastArgValue(options::OPT_fuse_ld_EQ, "link");
9904 if (Linker.equals_lower("lld"))
9905 Linker = "lld-link";
9906
9907 if (Linker.equals_lower("link")) {
9908 // If we're using the MSVC linker, it's not sufficient to just use link
9909 // from the program PATH, because other environments like GnuWin32 install
9910 // their own link.exe which may come first.
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009911 linkPath = FindVisualStudioExecutable(TC, "link.exe",
Zachary Turner719f58c2014-12-01 23:06:47 +00009912 C.getDriver().getClangProgramPath());
9913 } else {
9914 linkPath = Linker;
9915 llvm::sys::path::replace_extension(linkPath, "exe");
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009916 linkPath = TC.GetProgramPath(linkPath.c_str());
Zachary Turner719f58c2014-12-01 23:06:47 +00009917 }
9918
Zachary Turner0eaf8fc2014-10-22 20:40:28 +00009919 const char *Exec = Args.MakeArgString(linkPath);
Justin Bognerd3371d82015-07-17 03:35:54 +00009920 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009921}
Hans Wennborg87cfa712013-09-19 20:32:16 +00009922
Douglas Katzman95354292015-06-23 20:42:09 +00009923void visualstudio::Compiler::ConstructJob(Compilation &C, const JobAction &JA,
9924 const InputInfo &Output,
9925 const InputInfoList &Inputs,
9926 const ArgList &Args,
9927 const char *LinkingOutput) const {
Hans Wennborg87cfa712013-09-19 20:32:16 +00009928 C.addCommand(GetCommand(C, JA, Output, Inputs, Args, LinkingOutput));
9929}
9930
Douglas Katzman95354292015-06-23 20:42:09 +00009931std::unique_ptr<Command> visualstudio::Compiler::GetCommand(
David Blaikiec11bf802014-09-04 16:04:28 +00009932 Compilation &C, const JobAction &JA, const InputInfo &Output,
9933 const InputInfoList &Inputs, const ArgList &Args,
9934 const char *LinkingOutput) const {
Hans Wennborg87cfa712013-09-19 20:32:16 +00009935 ArgStringList CmdArgs;
Hans Wennborg263c2132013-09-24 17:36:21 +00009936 CmdArgs.push_back("/nologo");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009937 CmdArgs.push_back("/c"); // Compile only.
Hans Wennborg87cfa712013-09-19 20:32:16 +00009938 CmdArgs.push_back("/W0"); // No warnings.
9939
9940 // The goal is to be able to invoke this tool correctly based on
9941 // any flag accepted by clang-cl.
9942
9943 // These are spelled the same way in clang and cl.exe,.
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00009944 Args.AddAllArgs(CmdArgs, {options::OPT_D, options::OPT_U, options::OPT_I});
Hans Wennborgb6331dc2013-09-24 18:17:21 +00009945
9946 // Optimization level.
David Majnemer015ce0f2015-07-27 07:32:11 +00009947 if (Arg *A = Args.getLastArg(options::OPT_fbuiltin, options::OPT_fno_builtin))
9948 CmdArgs.push_back(A->getOption().getID() == options::OPT_fbuiltin ? "/Oi"
9949 : "/Oi-");
Hans Wennborgb6331dc2013-09-24 18:17:21 +00009950 if (Arg *A = Args.getLastArg(options::OPT_O, options::OPT_O0)) {
9951 if (A->getOption().getID() == options::OPT_O0) {
9952 CmdArgs.push_back("/Od");
9953 } else {
David Majnemer015ce0f2015-07-27 07:32:11 +00009954 CmdArgs.push_back("/Og");
9955
Hans Wennborgb6331dc2013-09-24 18:17:21 +00009956 StringRef OptLevel = A->getValue();
David Majnemer015ce0f2015-07-27 07:32:11 +00009957 if (OptLevel == "s" || OptLevel == "z")
9958 CmdArgs.push_back("/Os");
9959 else
9960 CmdArgs.push_back("/Ot");
9961
9962 CmdArgs.push_back("/Ob2");
Hans Wennborgb6331dc2013-09-24 18:17:21 +00009963 }
9964 }
David Majnemer015ce0f2015-07-27 07:32:11 +00009965 if (Arg *A = Args.getLastArg(options::OPT_fomit_frame_pointer,
9966 options::OPT_fno_omit_frame_pointer))
9967 CmdArgs.push_back(A->getOption().getID() == options::OPT_fomit_frame_pointer
9968 ? "/Oy"
9969 : "/Oy-");
9970 if (!Args.hasArg(options::OPT_fwritable_strings))
9971 CmdArgs.push_back("/GF");
Hans Wennborg87cfa712013-09-19 20:32:16 +00009972
Nico Weber3f8dafb2015-03-12 19:37:10 +00009973 // Flags for which clang-cl has an alias.
Hans Wennborg87cfa712013-09-19 20:32:16 +00009974 // FIXME: How can we ensure this stays in sync with relevant clang-cl options?
9975
David Majnemerf6072342014-07-01 22:24:56 +00009976 if (Args.hasFlag(options::OPT__SLASH_GR_, options::OPT__SLASH_GR,
9977 /*default=*/false))
9978 CmdArgs.push_back("/GR-");
Hans Wennborg5149a3b2014-03-25 14:48:54 +00009979 if (Arg *A = Args.getLastArg(options::OPT_ffunction_sections,
9980 options::OPT_fno_function_sections))
9981 CmdArgs.push_back(A->getOption().getID() == options::OPT_ffunction_sections
9982 ? "/Gy"
9983 : "/Gy-");
David Majnemerdc7a47c2014-04-07 16:14:38 +00009984 if (Arg *A = Args.getLastArg(options::OPT_fdata_sections,
9985 options::OPT_fno_data_sections))
David Majnemer6c684a72014-04-07 16:19:27 +00009986 CmdArgs.push_back(
9987 A->getOption().getID() == options::OPT_fdata_sections ? "/Gw" : "/Gw-");
Hans Wennborg87cfa712013-09-19 20:32:16 +00009988 if (Args.hasArg(options::OPT_fsyntax_only))
9989 CmdArgs.push_back("/Zs");
Reid Kleckner124955a2015-08-05 18:51:13 +00009990 if (Args.hasArg(options::OPT_g_Flag, options::OPT_gline_tables_only,
9991 options::OPT__SLASH_Z7))
Reid Klecknerc688daf2014-02-19 22:05:59 +00009992 CmdArgs.push_back("/Z7");
Hans Wennborg87cfa712013-09-19 20:32:16 +00009993
Nico Weber3f8dafb2015-03-12 19:37:10 +00009994 std::vector<std::string> Includes =
9995 Args.getAllArgValues(options::OPT_include);
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009996 for (const auto &Include : Includes)
9997 CmdArgs.push_back(Args.MakeArgString(std::string("/FI") + Include));
Hans Wennborg260ff402013-09-27 17:54:18 +00009998
Hans Wennborg87cfa712013-09-19 20:32:16 +00009999 // Flags that can simply be passed through.
10000 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_LD);
10001 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_LDd);
David Majnemerb8809092016-02-20 09:23:44 +000010002 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_GX);
10003 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_GX_);
Reid Klecknerc542d372014-06-27 17:02:02 +000010004 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_EH);
David Majnemerbac941c2015-07-25 06:07:59 +000010005 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_Zl);
Hans Wennborg87cfa712013-09-19 20:32:16 +000010006
10007 // The order of these flags is relevant, so pick the last one.
10008 if (Arg *A = Args.getLastArg(options::OPT__SLASH_MD, options::OPT__SLASH_MDd,
10009 options::OPT__SLASH_MT, options::OPT__SLASH_MTd))
10010 A->render(Args, CmdArgs);
10011
Ehsan Akhgarid8518332016-01-25 21:14:52 +000010012 // Pass through all unknown arguments so that the fallback command can see
10013 // them too.
10014 Args.AddAllArgs(CmdArgs, options::OPT_UNKNOWN);
10015
Hans Wennborg87cfa712013-09-19 20:32:16 +000010016 // Input filename.
10017 assert(Inputs.size() == 1);
10018 const InputInfo &II = Inputs[0];
10019 assert(II.getType() == types::TY_C || II.getType() == types::TY_CXX);
10020 CmdArgs.push_back(II.getType() == types::TY_C ? "/Tc" : "/Tp");
10021 if (II.isFilename())
10022 CmdArgs.push_back(II.getFilename());
10023 else
10024 II.getInputArg().renderAsInput(Args, CmdArgs);
10025
10026 // Output filename.
10027 assert(Output.getType() == types::TY_Object);
Douglas Katzmana67e50c2015-06-26 15:47:46 +000010028 const char *Fo =
10029 Args.MakeArgString(std::string("/Fo") + Output.getFilename());
Hans Wennborg87cfa712013-09-19 20:32:16 +000010030 CmdArgs.push_back(Fo);
10031
Hans Wennborg188382e2013-09-20 18:16:35 +000010032 const Driver &D = getToolChain().getDriver();
Zachary Turner0eaf8fc2014-10-22 20:40:28 +000010033 std::string Exec = FindVisualStudioExecutable(getToolChain(), "cl.exe",
10034 D.getClangProgramPath());
David Blaikiec11bf802014-09-04 16:04:28 +000010035 return llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Exec),
Justin Bognerd3371d82015-07-17 03:35:54 +000010036 CmdArgs, Inputs);
Hans Wennborg87cfa712013-09-19 20:32:16 +000010037}
Robert Lyttoncf1dd692013-10-11 10:29:40 +000010038
Yaron Keren1c0070c2015-07-02 04:45:27 +000010039/// MinGW Tools
10040void MinGW::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
10041 const InputInfo &Output,
10042 const InputInfoList &Inputs,
10043 const ArgList &Args,
10044 const char *LinkingOutput) const {
10045 claimNoWarnArgs(Args);
10046 ArgStringList CmdArgs;
10047
10048 if (getToolChain().getArch() == llvm::Triple::x86) {
10049 CmdArgs.push_back("--32");
10050 } else if (getToolChain().getArch() == llvm::Triple::x86_64) {
10051 CmdArgs.push_back("--64");
10052 }
10053
10054 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
10055
10056 CmdArgs.push_back("-o");
10057 CmdArgs.push_back(Output.getFilename());
10058
10059 for (const auto &II : Inputs)
10060 CmdArgs.push_back(II.getFilename());
10061
10062 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +000010063 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Yaron Keren1c0070c2015-07-02 04:45:27 +000010064
10065 if (Args.hasArg(options::OPT_gsplit_dwarf))
10066 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output,
10067 SplitDebugName(Args, Inputs[0]));
10068}
10069
10070void MinGW::Linker::AddLibGCC(const ArgList &Args,
10071 ArgStringList &CmdArgs) const {
10072 if (Args.hasArg(options::OPT_mthreads))
10073 CmdArgs.push_back("-lmingwthrd");
10074 CmdArgs.push_back("-lmingw32");
Reid Kleckner0213a472015-07-22 16:01:38 +000010075
Yaron Kerenaa281332015-08-09 00:24:07 +000010076 // Make use of compiler-rt if --rtlib option is used
10077 ToolChain::RuntimeLibType RLT = getToolChain().GetRuntimeLibType(Args);
10078 if (RLT == ToolChain::RLT_Libgcc) {
10079 bool Static = Args.hasArg(options::OPT_static_libgcc) ||
10080 Args.hasArg(options::OPT_static);
10081 bool Shared = Args.hasArg(options::OPT_shared);
10082 bool CXX = getToolChain().getDriver().CCCIsCXX();
10083
10084 if (Static || (!CXX && !Shared)) {
10085 CmdArgs.push_back("-lgcc");
10086 CmdArgs.push_back("-lgcc_eh");
10087 } else {
10088 CmdArgs.push_back("-lgcc_s");
10089 CmdArgs.push_back("-lgcc");
10090 }
10091 } else {
10092 AddRunTimeLibs(getToolChain(), getToolChain().getDriver(), CmdArgs, Args);
10093 }
Reid Kleckner0213a472015-07-22 16:01:38 +000010094
Yaron Keren1c0070c2015-07-02 04:45:27 +000010095 CmdArgs.push_back("-lmoldname");
10096 CmdArgs.push_back("-lmingwex");
10097 CmdArgs.push_back("-lmsvcrt");
10098}
10099
10100void MinGW::Linker::ConstructJob(Compilation &C, const JobAction &JA,
10101 const InputInfo &Output,
10102 const InputInfoList &Inputs,
10103 const ArgList &Args,
10104 const char *LinkingOutput) const {
10105 const ToolChain &TC = getToolChain();
10106 const Driver &D = TC.getDriver();
10107 // const SanitizerArgs &Sanitize = TC.getSanitizerArgs();
10108
10109 ArgStringList CmdArgs;
10110
10111 // Silence warning for "clang -g foo.o -o foo"
10112 Args.ClaimAllArgs(options::OPT_g_Group);
10113 // and "clang -emit-llvm foo.o -o foo"
10114 Args.ClaimAllArgs(options::OPT_emit_llvm);
10115 // and for "clang -w foo.o -o foo". Other warning options are already
10116 // handled somewhere else.
10117 Args.ClaimAllArgs(options::OPT_w);
10118
Yaron Keren2ffb36e2015-07-14 05:23:34 +000010119 StringRef LinkerName = Args.getLastArgValue(options::OPT_fuse_ld_EQ, "ld");
10120 if (LinkerName.equals_lower("lld")) {
10121 CmdArgs.push_back("-flavor");
Martell Maloneaac044e2015-11-22 05:40:06 +000010122 CmdArgs.push_back("gnu");
Yaron Kerena7fa79f2015-11-15 08:06:27 +000010123 } else if (!LinkerName.equals_lower("ld")) {
10124 D.Diag(diag::err_drv_unsupported_linker) << LinkerName;
Yaron Keren2ffb36e2015-07-14 05:23:34 +000010125 }
10126
Yaron Keren1c0070c2015-07-02 04:45:27 +000010127 if (!D.SysRoot.empty())
10128 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
10129
10130 if (Args.hasArg(options::OPT_s))
10131 CmdArgs.push_back("-s");
10132
10133 CmdArgs.push_back("-m");
10134 if (TC.getArch() == llvm::Triple::x86)
10135 CmdArgs.push_back("i386pe");
10136 if (TC.getArch() == llvm::Triple::x86_64)
10137 CmdArgs.push_back("i386pep");
Yaron Keren2ffb36e2015-07-14 05:23:34 +000010138 if (TC.getArch() == llvm::Triple::arm)
10139 CmdArgs.push_back("thumb2pe");
Yaron Keren1c0070c2015-07-02 04:45:27 +000010140
10141 if (Args.hasArg(options::OPT_mwindows)) {
10142 CmdArgs.push_back("--subsystem");
10143 CmdArgs.push_back("windows");
10144 } else if (Args.hasArg(options::OPT_mconsole)) {
10145 CmdArgs.push_back("--subsystem");
10146 CmdArgs.push_back("console");
10147 }
10148
10149 if (Args.hasArg(options::OPT_static))
10150 CmdArgs.push_back("-Bstatic");
10151 else {
10152 if (Args.hasArg(options::OPT_mdll))
10153 CmdArgs.push_back("--dll");
10154 else if (Args.hasArg(options::OPT_shared))
10155 CmdArgs.push_back("--shared");
10156 CmdArgs.push_back("-Bdynamic");
10157 if (Args.hasArg(options::OPT_mdll) || Args.hasArg(options::OPT_shared)) {
10158 CmdArgs.push_back("-e");
10159 if (TC.getArch() == llvm::Triple::x86)
10160 CmdArgs.push_back("_DllMainCRTStartup@12");
10161 else
10162 CmdArgs.push_back("DllMainCRTStartup");
10163 CmdArgs.push_back("--enable-auto-image-base");
10164 }
10165 }
10166
10167 CmdArgs.push_back("-o");
10168 CmdArgs.push_back(Output.getFilename());
10169
10170 Args.AddAllArgs(CmdArgs, options::OPT_e);
10171 // FIXME: add -N, -n flags
10172 Args.AddLastArg(CmdArgs, options::OPT_r);
10173 Args.AddLastArg(CmdArgs, options::OPT_s);
10174 Args.AddLastArg(CmdArgs, options::OPT_t);
10175 Args.AddAllArgs(CmdArgs, options::OPT_u_Group);
10176 Args.AddLastArg(CmdArgs, options::OPT_Z_Flag);
10177
Douglas Katzman78b37b02015-11-17 20:28:07 +000010178 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) {
Yaron Keren1c0070c2015-07-02 04:45:27 +000010179 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_mdll)) {
10180 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("dllcrt2.o")));
10181 } else {
10182 if (Args.hasArg(options::OPT_municode))
10183 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crt2u.o")));
10184 else
10185 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crt2.o")));
10186 }
10187 if (Args.hasArg(options::OPT_pg))
10188 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("gcrt2.o")));
10189 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crtbegin.o")));
10190 }
10191
10192 Args.AddAllArgs(CmdArgs, options::OPT_L);
Douglas Katzman6059ef92015-11-17 17:41:23 +000010193 TC.AddFilePathLibArgs(Args, CmdArgs);
Yaron Keren1c0070c2015-07-02 04:45:27 +000010194 AddLinkerInputs(TC, Inputs, Args, CmdArgs);
10195
10196 // TODO: Add ASan stuff here
10197
10198 // TODO: Add profile stuff here
10199
Douglas Katzman78b37b02015-11-17 20:28:07 +000010200 if (D.CCCIsCXX() &&
10201 !Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs)) {
Yaron Keren1c0070c2015-07-02 04:45:27 +000010202 bool OnlyLibstdcxxStatic = Args.hasArg(options::OPT_static_libstdcxx) &&
10203 !Args.hasArg(options::OPT_static);
10204 if (OnlyLibstdcxxStatic)
10205 CmdArgs.push_back("-Bstatic");
10206 TC.AddCXXStdlibLibArgs(Args, CmdArgs);
10207 if (OnlyLibstdcxxStatic)
10208 CmdArgs.push_back("-Bdynamic");
10209 }
10210
10211 if (!Args.hasArg(options::OPT_nostdlib)) {
10212 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
10213 if (Args.hasArg(options::OPT_static))
10214 CmdArgs.push_back("--start-group");
10215
10216 if (Args.hasArg(options::OPT_fstack_protector) ||
10217 Args.hasArg(options::OPT_fstack_protector_strong) ||
10218 Args.hasArg(options::OPT_fstack_protector_all)) {
10219 CmdArgs.push_back("-lssp_nonshared");
10220 CmdArgs.push_back("-lssp");
10221 }
10222 if (Args.hasArg(options::OPT_fopenmp))
10223 CmdArgs.push_back("-lgomp");
10224
10225 AddLibGCC(Args, CmdArgs);
10226
10227 if (Args.hasArg(options::OPT_pg))
10228 CmdArgs.push_back("-lgmon");
10229
Yaron Kerenadce68e2015-07-06 18:52:19 +000010230 if (Args.hasArg(options::OPT_pthread))
10231 CmdArgs.push_back("-lpthread");
Yaron Keren1c0070c2015-07-02 04:45:27 +000010232
10233 // add system libraries
10234 if (Args.hasArg(options::OPT_mwindows)) {
10235 CmdArgs.push_back("-lgdi32");
10236 CmdArgs.push_back("-lcomdlg32");
10237 }
10238 CmdArgs.push_back("-ladvapi32");
10239 CmdArgs.push_back("-lshell32");
10240 CmdArgs.push_back("-luser32");
10241 CmdArgs.push_back("-lkernel32");
10242
10243 if (Args.hasArg(options::OPT_static))
10244 CmdArgs.push_back("--end-group");
Yaron Keren2ffb36e2015-07-14 05:23:34 +000010245 else if (!LinkerName.equals_lower("lld"))
Yaron Keren1c0070c2015-07-02 04:45:27 +000010246 AddLibGCC(Args, CmdArgs);
10247 }
10248
10249 if (!Args.hasArg(options::OPT_nostartfiles)) {
10250 // Add crtfastmath.o if available and fast math is enabled.
10251 TC.AddFastMathRuntimeIfAvailable(Args, CmdArgs);
10252
10253 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crtend.o")));
10254 }
10255 }
Yaron Keren2ffb36e2015-07-14 05:23:34 +000010256 const char *Exec = Args.MakeArgString(TC.GetProgramPath(LinkerName.data()));
Justin Bognerd3371d82015-07-17 03:35:54 +000010257 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Yaron Keren1c0070c2015-07-02 04:45:27 +000010258}
10259
Robert Lyttoncf1dd692013-10-11 10:29:40 +000010260/// XCore Tools
10261// We pass assemble and link construction to the xcc tool.
10262
Douglas Katzman95354292015-06-23 20:42:09 +000010263void XCore::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
10264 const InputInfo &Output,
10265 const InputInfoList &Inputs,
10266 const ArgList &Args,
10267 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +000010268 claimNoWarnArgs(Args);
Robert Lyttoncf1dd692013-10-11 10:29:40 +000010269 ArgStringList CmdArgs;
10270
10271 CmdArgs.push_back("-o");
10272 CmdArgs.push_back(Output.getFilename());
10273
10274 CmdArgs.push_back("-c");
10275
Robert Lytton9e8c1a42014-02-13 10:40:12 +000010276 if (Args.hasArg(options::OPT_v))
10277 CmdArgs.push_back("-v");
10278
Robert Lytton894d25c2014-05-02 09:33:25 +000010279 if (Arg *A = Args.getLastArg(options::OPT_g_Group))
10280 if (!A->getOption().matches(options::OPT_g0))
10281 CmdArgs.push_back("-g");
Robert Lytton9e8c1a42014-02-13 10:40:12 +000010282
Robert Lytton8e95d4e2014-02-11 10:34:45 +000010283 if (Args.hasFlag(options::OPT_fverbose_asm, options::OPT_fno_verbose_asm,
10284 false))
10285 CmdArgs.push_back("-fverbose-asm");
Robert Lyttoncf1dd692013-10-11 10:29:40 +000010286
Douglas Katzmana67e50c2015-06-26 15:47:46 +000010287 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Robert Lyttoncf1dd692013-10-11 10:29:40 +000010288
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +000010289 for (const auto &II : Inputs)
Robert Lyttoncf1dd692013-10-11 10:29:40 +000010290 CmdArgs.push_back(II.getFilename());
Robert Lyttoncf1dd692013-10-11 10:29:40 +000010291
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +000010292 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("xcc"));
Justin Bognerd3371d82015-07-17 03:35:54 +000010293 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Robert Lyttoncf1dd692013-10-11 10:29:40 +000010294}
10295
Douglas Katzman95354292015-06-23 20:42:09 +000010296void XCore::Linker::ConstructJob(Compilation &C, const JobAction &JA,
10297 const InputInfo &Output,
10298 const InputInfoList &Inputs,
10299 const ArgList &Args,
10300 const char *LinkingOutput) const {
Robert Lyttoncf1dd692013-10-11 10:29:40 +000010301 ArgStringList CmdArgs;
10302
10303 if (Output.isFilename()) {
10304 CmdArgs.push_back("-o");
10305 CmdArgs.push_back(Output.getFilename());
10306 } else {
10307 assert(Output.isNothing() && "Invalid output.");
10308 }
10309
Robert Lytton9e8c1a42014-02-13 10:40:12 +000010310 if (Args.hasArg(options::OPT_v))
10311 CmdArgs.push_back("-v");
10312
Reid Kleckner0bb1fc42015-07-10 22:25:44 +000010313 // Pass -fexceptions through to the linker if it was present.
10314 if (Args.hasFlag(options::OPT_fexceptions, options::OPT_fno_exceptions,
10315 false))
Robert Lyttonf7e03c12014-02-13 10:34:44 +000010316 CmdArgs.push_back("-fexceptions");
10317
Robert Lyttoncf1dd692013-10-11 10:29:40 +000010318 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
10319
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +000010320 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("xcc"));
Justin Bognerd3371d82015-07-17 03:35:54 +000010321 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Robert Lyttoncf1dd692013-10-11 10:29:40 +000010322}
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +000010323
Douglas Katzman95354292015-06-23 20:42:09 +000010324void CrossWindows::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
10325 const InputInfo &Output,
10326 const InputInfoList &Inputs,
10327 const ArgList &Args,
10328 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +000010329 claimNoWarnArgs(Args);
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +000010330 const auto &TC =
10331 static_cast<const toolchains::CrossWindowsToolChain &>(getToolChain());
10332 ArgStringList CmdArgs;
10333 const char *Exec;
10334
10335 switch (TC.getArch()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +000010336 default:
10337 llvm_unreachable("unsupported architecture");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +000010338 case llvm::Triple::arm:
10339 case llvm::Triple::thumb:
10340 break;
10341 case llvm::Triple::x86:
10342 CmdArgs.push_back("--32");
10343 break;
10344 case llvm::Triple::x86_64:
10345 CmdArgs.push_back("--64");
10346 break;
10347 }
10348
10349 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
10350
10351 CmdArgs.push_back("-o");
10352 CmdArgs.push_back(Output.getFilename());
10353
10354 for (const auto &Input : Inputs)
10355 CmdArgs.push_back(Input.getFilename());
10356
10357 const std::string Assembler = TC.GetProgramPath("as");
10358 Exec = Args.MakeArgString(Assembler);
10359
Justin Bognerd3371d82015-07-17 03:35:54 +000010360 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +000010361}
10362
Douglas Katzman95354292015-06-23 20:42:09 +000010363void CrossWindows::Linker::ConstructJob(Compilation &C, const JobAction &JA,
10364 const InputInfo &Output,
10365 const InputInfoList &Inputs,
10366 const ArgList &Args,
10367 const char *LinkingOutput) const {
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +000010368 const auto &TC =
10369 static_cast<const toolchains::CrossWindowsToolChain &>(getToolChain());
10370 const llvm::Triple &T = TC.getTriple();
10371 const Driver &D = TC.getDriver();
10372 SmallString<128> EntryPoint;
10373 ArgStringList CmdArgs;
10374 const char *Exec;
10375
10376 // Silence warning for "clang -g foo.o -o foo"
10377 Args.ClaimAllArgs(options::OPT_g_Group);
10378 // and "clang -emit-llvm foo.o -o foo"
10379 Args.ClaimAllArgs(options::OPT_emit_llvm);
10380 // and for "clang -w foo.o -o foo"
10381 Args.ClaimAllArgs(options::OPT_w);
10382 // Other warning options are already handled somewhere else.
10383
10384 if (!D.SysRoot.empty())
10385 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
10386
10387 if (Args.hasArg(options::OPT_pie))
10388 CmdArgs.push_back("-pie");
10389 if (Args.hasArg(options::OPT_rdynamic))
10390 CmdArgs.push_back("-export-dynamic");
10391 if (Args.hasArg(options::OPT_s))
10392 CmdArgs.push_back("--strip-all");
10393
10394 CmdArgs.push_back("-m");
10395 switch (TC.getArch()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +000010396 default:
10397 llvm_unreachable("unsupported architecture");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +000010398 case llvm::Triple::arm:
10399 case llvm::Triple::thumb:
10400 // FIXME: this is incorrect for WinCE
10401 CmdArgs.push_back("thumb2pe");
10402 break;
10403 case llvm::Triple::x86:
10404 CmdArgs.push_back("i386pe");
10405 EntryPoint.append("_");
10406 break;
10407 case llvm::Triple::x86_64:
10408 CmdArgs.push_back("i386pep");
10409 break;
10410 }
10411
10412 if (Args.hasArg(options::OPT_shared)) {
10413 switch (T.getArch()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +000010414 default:
10415 llvm_unreachable("unsupported architecture");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +000010416 case llvm::Triple::arm:
10417 case llvm::Triple::thumb:
10418 case llvm::Triple::x86_64:
10419 EntryPoint.append("_DllMainCRTStartup");
10420 break;
10421 case llvm::Triple::x86:
10422 EntryPoint.append("_DllMainCRTStartup@12");
10423 break;
10424 }
10425
10426 CmdArgs.push_back("-shared");
10427 CmdArgs.push_back("-Bdynamic");
10428
10429 CmdArgs.push_back("--enable-auto-image-base");
10430
10431 CmdArgs.push_back("--entry");
10432 CmdArgs.push_back(Args.MakeArgString(EntryPoint));
10433 } else {
10434 EntryPoint.append("mainCRTStartup");
10435
10436 CmdArgs.push_back(Args.hasArg(options::OPT_static) ? "-Bstatic"
10437 : "-Bdynamic");
10438
Douglas Katzman78b37b02015-11-17 20:28:07 +000010439 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) {
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +000010440 CmdArgs.push_back("--entry");
10441 CmdArgs.push_back(Args.MakeArgString(EntryPoint));
10442 }
10443
10444 // FIXME: handle subsystem
10445 }
10446
10447 // NOTE: deal with multiple definitions on Windows (e.g. COMDAT)
Saleem Abdulrasool56dd1ac2014-10-28 03:15:02 +000010448 CmdArgs.push_back("--allow-multiple-definition");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +000010449
10450 CmdArgs.push_back("-o");
10451 CmdArgs.push_back(Output.getFilename());
10452
10453 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_rdynamic)) {
10454 SmallString<261> ImpLib(Output.getFilename());
10455 llvm::sys::path::replace_extension(ImpLib, ".lib");
10456
10457 CmdArgs.push_back("--out-implib");
10458 CmdArgs.push_back(Args.MakeArgString(ImpLib));
10459 }
10460
Douglas Katzman78b37b02015-11-17 20:28:07 +000010461 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) {
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +000010462 const std::string CRTPath(D.SysRoot + "/usr/lib/");
10463 const char *CRTBegin;
10464
10465 CRTBegin =
10466 Args.hasArg(options::OPT_shared) ? "crtbeginS.obj" : "crtbegin.obj";
10467 CmdArgs.push_back(Args.MakeArgString(CRTPath + CRTBegin));
10468 }
10469
10470 Args.AddAllArgs(CmdArgs, options::OPT_L);
Douglas Katzman6059ef92015-11-17 17:41:23 +000010471 TC.AddFilePathLibArgs(Args, CmdArgs);
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +000010472 AddLinkerInputs(TC, Inputs, Args, CmdArgs);
10473
10474 if (D.CCCIsCXX() && !Args.hasArg(options::OPT_nostdlib) &&
10475 !Args.hasArg(options::OPT_nodefaultlibs)) {
10476 bool StaticCXX = Args.hasArg(options::OPT_static_libstdcxx) &&
10477 !Args.hasArg(options::OPT_static);
10478 if (StaticCXX)
10479 CmdArgs.push_back("-Bstatic");
10480 TC.AddCXXStdlibLibArgs(Args, CmdArgs);
10481 if (StaticCXX)
10482 CmdArgs.push_back("-Bdynamic");
10483 }
10484
10485 if (!Args.hasArg(options::OPT_nostdlib)) {
10486 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
10487 // TODO handle /MT[d] /MD[d]
10488 CmdArgs.push_back("-lmsvcrt");
10489 AddRunTimeLibs(TC, D, CmdArgs, Args);
10490 }
10491 }
10492
Saleem Abdulrasoolbb2e5e42015-10-29 03:36:45 +000010493 if (TC.getSanitizerArgs().needsAsanRt()) {
10494 // TODO handle /MT[d] /MD[d]
10495 if (Args.hasArg(options::OPT_shared)) {
10496 CmdArgs.push_back(TC.getCompilerRTArgString(Args, "asan_dll_thunk"));
10497 } else {
10498 for (const auto &Lib : {"asan_dynamic", "asan_dynamic_runtime_thunk"})
10499 CmdArgs.push_back(TC.getCompilerRTArgString(Args, Lib));
Marcin Koscielnicki10721432016-05-12 10:27:59 +000010500 // Make sure the dynamic runtime thunk is not optimized out at link time
10501 // to ensure proper SEH handling.
10502 CmdArgs.push_back(Args.MakeArgString("--undefined"));
10503 CmdArgs.push_back(Args.MakeArgString(TC.getArch() == llvm::Triple::x86
10504 ? "___asan_seh_interceptor"
10505 : "__asan_seh_interceptor"));
Saleem Abdulrasoolbb2e5e42015-10-29 03:36:45 +000010506 }
10507 }
10508
Saleem Abdulrasoolfd80f832015-10-28 04:45:58 +000010509 Exec = Args.MakeArgString(TC.GetLinkerPath());
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +000010510
Justin Bognerd3371d82015-07-17 03:35:54 +000010511 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +000010512}
Douglas Katzman84a75642015-06-19 14:55:19 +000010513
Douglas Katzman95354292015-06-23 20:42:09 +000010514void tools::SHAVE::Compiler::ConstructJob(Compilation &C, const JobAction &JA,
10515 const InputInfo &Output,
10516 const InputInfoList &Inputs,
10517 const ArgList &Args,
10518 const char *LinkingOutput) const {
Douglas Katzman84a75642015-06-19 14:55:19 +000010519 ArgStringList CmdArgs;
Douglas Katzman84a75642015-06-19 14:55:19 +000010520 assert(Inputs.size() == 1);
10521 const InputInfo &II = Inputs[0];
Douglas Katzman9dc4c622015-11-20 04:58:12 +000010522 assert(II.getType() == types::TY_C || II.getType() == types::TY_CXX ||
10523 II.getType() == types::TY_PP_CXX);
Douglas Katzman84a75642015-06-19 14:55:19 +000010524
Douglas Katzman9dc4c622015-11-20 04:58:12 +000010525 if (JA.getKind() == Action::PreprocessJobClass) {
10526 Args.ClaimAllArgs();
10527 CmdArgs.push_back("-E");
10528 } else {
10529 assert(Output.getType() == types::TY_PP_Asm); // Require preprocessed asm.
10530 CmdArgs.push_back("-S");
10531 CmdArgs.push_back("-fno-exceptions"); // Always do this even if unspecified.
10532 }
Douglas Katzman9dc4c622015-11-20 04:58:12 +000010533 CmdArgs.push_back("-DMYRIAD2");
Douglas Katzman84a75642015-06-19 14:55:19 +000010534
Douglas Katzmanf6071112015-08-03 14:34:22 +000010535 // Append all -I, -iquote, -isystem paths, defines/undefines,
10536 // 'f' flags, optimize flags, and warning options.
10537 // These are spelled the same way in clang and moviCompile.
Douglas Katzman38dca882015-09-08 19:29:55 +000010538 Args.AddAllArgs(CmdArgs, {options::OPT_I_Group, options::OPT_clang_i_Group,
Douglas Katzman642e5f92015-11-16 15:38:40 +000010539 options::OPT_std_EQ, options::OPT_D, options::OPT_U,
Douglas Katzman38dca882015-09-08 19:29:55 +000010540 options::OPT_f_Group, options::OPT_f_clang_Group,
10541 options::OPT_g_Group, options::OPT_M_Group,
Douglas Katzman4c125082016-03-15 16:41:31 +000010542 options::OPT_O_Group, options::OPT_W_Group,
10543 options::OPT_mcpu_EQ});
Douglas Katzman38dca882015-09-08 19:29:55 +000010544
10545 // If we're producing a dependency file, and assembly is the final action,
10546 // then the name of the target in the dependency file should be the '.o'
10547 // file, not the '.s' file produced by this step. For example, instead of
10548 // /tmp/mumble.s: mumble.c .../someheader.h
10549 // the filename on the lefthand side should be "mumble.o"
10550 if (Args.getLastArg(options::OPT_MF) && !Args.getLastArg(options::OPT_MT) &&
10551 C.getActions().size() == 1 &&
10552 C.getActions()[0]->getKind() == Action::AssembleJobClass) {
10553 Arg *A = Args.getLastArg(options::OPT_o);
10554 if (A) {
10555 CmdArgs.push_back("-MT");
10556 CmdArgs.push_back(Args.MakeArgString(A->getValue()));
10557 }
10558 }
10559
Douglas Katzman84a75642015-06-19 14:55:19 +000010560 CmdArgs.push_back(II.getFilename());
10561 CmdArgs.push_back("-o");
10562 CmdArgs.push_back(Output.getFilename());
10563
10564 std::string Exec =
10565 Args.MakeArgString(getToolChain().GetProgramPath("moviCompile"));
Justin Bognerd3371d82015-07-17 03:35:54 +000010566 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Exec),
10567 CmdArgs, Inputs));
Douglas Katzman84a75642015-06-19 14:55:19 +000010568}
10569
Douglas Katzman95354292015-06-23 20:42:09 +000010570void tools::SHAVE::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
10571 const InputInfo &Output,
10572 const InputInfoList &Inputs,
10573 const ArgList &Args,
10574 const char *LinkingOutput) const {
Douglas Katzman84a75642015-06-19 14:55:19 +000010575 ArgStringList CmdArgs;
10576
10577 assert(Inputs.size() == 1);
10578 const InputInfo &II = Inputs[0];
10579 assert(II.getType() == types::TY_PP_Asm); // Require preprocessed asm input.
10580 assert(Output.getType() == types::TY_Object);
10581
10582 CmdArgs.push_back("-no6thSlotCompression");
Douglas Katzman4c125082016-03-15 16:41:31 +000010583 const Arg *CPUArg = Args.getLastArg(options::OPT_mcpu_EQ);
10584 if (CPUArg)
10585 CmdArgs.push_back(
10586 Args.MakeArgString("-cv:" + StringRef(CPUArg->getValue())));
Douglas Katzman84a75642015-06-19 14:55:19 +000010587 CmdArgs.push_back("-noSPrefixing");
10588 CmdArgs.push_back("-a"); // Mystery option.
Douglas Katzmanae2f3582015-09-11 21:13:46 +000010589 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
10590 for (const Arg *A : Args.filtered(options::OPT_I, options::OPT_isystem)) {
10591 A->claim();
Douglas Katzman84a75642015-06-19 14:55:19 +000010592 CmdArgs.push_back(
Douglas Katzmanae2f3582015-09-11 21:13:46 +000010593 Args.MakeArgString(std::string("-i:") + A->getValue(0)));
Douglas Katzman84a75642015-06-19 14:55:19 +000010594 }
10595 CmdArgs.push_back("-elf"); // Output format.
10596 CmdArgs.push_back(II.getFilename());
10597 CmdArgs.push_back(
10598 Args.MakeArgString(std::string("-o:") + Output.getFilename()));
10599
10600 std::string Exec =
10601 Args.MakeArgString(getToolChain().GetProgramPath("moviAsm"));
Justin Bognerd3371d82015-07-17 03:35:54 +000010602 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Exec),
10603 CmdArgs, Inputs));
Douglas Katzman84a75642015-06-19 14:55:19 +000010604}
Douglas Katzmand6e597c2015-09-17 19:56:40 +000010605
10606void tools::Myriad::Linker::ConstructJob(Compilation &C, const JobAction &JA,
10607 const InputInfo &Output,
10608 const InputInfoList &Inputs,
10609 const ArgList &Args,
10610 const char *LinkingOutput) const {
10611 const auto &TC =
10612 static_cast<const toolchains::MyriadToolChain &>(getToolChain());
10613 const llvm::Triple &T = TC.getTriple();
10614 ArgStringList CmdArgs;
Eric Christopher3f5d2bc2015-12-08 00:10:13 +000010615 bool UseStartfiles =
10616 !Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles);
Douglas Katzman78b37b02015-11-17 20:28:07 +000010617 bool UseDefaultLibs =
10618 !Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs);
Douglas Katzmand6e597c2015-09-17 19:56:40 +000010619
Douglas Katzmand6e597c2015-09-17 19:56:40 +000010620 if (T.getArch() == llvm::Triple::sparc)
10621 CmdArgs.push_back("-EB");
10622 else // SHAVE assumes little-endian, and sparcel is expressly so.
10623 CmdArgs.push_back("-EL");
10624
10625 // The remaining logic is mostly like gnutools::Linker::ConstructJob,
10626 // but we never pass through a --sysroot option and various other bits.
10627 // For example, there are no sanitizers (yet) nor gold linker.
10628
10629 // Eat some arguments that may be present but have no effect.
10630 Args.ClaimAllArgs(options::OPT_g_Group);
10631 Args.ClaimAllArgs(options::OPT_w);
10632 Args.ClaimAllArgs(options::OPT_static_libgcc);
10633
10634 if (Args.hasArg(options::OPT_s)) // Pass the 'strip' option.
10635 CmdArgs.push_back("-s");
10636
10637 CmdArgs.push_back("-o");
10638 CmdArgs.push_back(Output.getFilename());
10639
10640 if (UseStartfiles) {
10641 // If you want startfiles, it means you want the builtin crti and crtbegin,
10642 // but not crt0. Myriad link commands provide their own crt0.o as needed.
Douglas Katzman674a3122015-11-18 16:24:46 +000010643 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crti.o")));
10644 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crtbegin.o")));
Douglas Katzmand6e597c2015-09-17 19:56:40 +000010645 }
10646
10647 Args.AddAllArgs(CmdArgs, {options::OPT_L, options::OPT_T_Group,
10648 options::OPT_e, options::OPT_s, options::OPT_t,
10649 options::OPT_Z_Flag, options::OPT_r});
10650
Douglas Katzman674a3122015-11-18 16:24:46 +000010651 TC.AddFilePathLibArgs(Args, CmdArgs);
Douglas Katzmand6e597c2015-09-17 19:56:40 +000010652
10653 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
10654
Douglas Katzman9e31cb92015-10-02 18:39:08 +000010655 if (UseDefaultLibs) {
Douglas Katzman795f57f2015-10-09 20:26:20 +000010656 if (C.getDriver().CCCIsCXX())
10657 CmdArgs.push_back("-lstdc++");
Douglas Katzman9e31cb92015-10-02 18:39:08 +000010658 if (T.getOS() == llvm::Triple::RTEMS) {
10659 CmdArgs.push_back("--start-group");
10660 CmdArgs.push_back("-lc");
10661 // You must provide your own "-L" option to enable finding these.
10662 CmdArgs.push_back("-lrtemscpu");
10663 CmdArgs.push_back("-lrtemsbsp");
10664 CmdArgs.push_back("--end-group");
10665 } else {
10666 CmdArgs.push_back("-lc");
10667 }
Douglas Katzman9e31cb92015-10-02 18:39:08 +000010668 CmdArgs.push_back("-lgcc");
Douglas Katzmand6e597c2015-09-17 19:56:40 +000010669 }
Douglas Katzmand6e597c2015-09-17 19:56:40 +000010670 if (UseStartfiles) {
Douglas Katzman674a3122015-11-18 16:24:46 +000010671 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crtend.o")));
10672 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crtn.o")));
Douglas Katzmand6e597c2015-09-17 19:56:40 +000010673 }
10674
10675 std::string Exec =
10676 Args.MakeArgString(TC.GetProgramPath("sparc-myriad-elf-ld"));
10677 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Exec),
10678 CmdArgs, Inputs));
10679}
Filipe Cabecinhasc888e192015-10-14 12:25:43 +000010680
10681void PS4cpu::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
10682 const InputInfo &Output,
10683 const InputInfoList &Inputs,
10684 const ArgList &Args,
10685 const char *LinkingOutput) const {
10686 claimNoWarnArgs(Args);
10687 ArgStringList CmdArgs;
10688
10689 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
10690
10691 CmdArgs.push_back("-o");
10692 CmdArgs.push_back(Output.getFilename());
10693
10694 assert(Inputs.size() == 1 && "Unexpected number of inputs.");
10695 const InputInfo &Input = Inputs[0];
10696 assert(Input.isFilename() && "Invalid input.");
10697 CmdArgs.push_back(Input.getFilename());
10698
10699 const char *Exec =
Paul Robinson9d613612016-05-16 17:22:25 +000010700 Args.MakeArgString(getToolChain().GetProgramPath("orbis-as"));
Filipe Cabecinhasc888e192015-10-14 12:25:43 +000010701 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
10702}
10703
Filipe Cabecinhasc888e192015-10-14 12:25:43 +000010704static void AddPS4SanitizerArgs(const ToolChain &TC, ArgStringList &CmdArgs) {
10705 const SanitizerArgs &SanArgs = TC.getSanitizerArgs();
10706 if (SanArgs.needsUbsanRt()) {
10707 CmdArgs.push_back("-lSceDbgUBSanitizer_stub_weak");
10708 }
10709 if (SanArgs.needsAsanRt()) {
10710 CmdArgs.push_back("-lSceDbgAddressSanitizer_stub_weak");
10711 }
10712}
10713
10714static void ConstructPS4LinkJob(const Tool &T, Compilation &C,
10715 const JobAction &JA, const InputInfo &Output,
10716 const InputInfoList &Inputs,
10717 const ArgList &Args,
10718 const char *LinkingOutput) {
10719 const toolchains::FreeBSD &ToolChain =
10720 static_cast<const toolchains::FreeBSD &>(T.getToolChain());
10721 const Driver &D = ToolChain.getDriver();
10722 ArgStringList CmdArgs;
10723
10724 // Silence warning for "clang -g foo.o -o foo"
10725 Args.ClaimAllArgs(options::OPT_g_Group);
10726 // and "clang -emit-llvm foo.o -o foo"
10727 Args.ClaimAllArgs(options::OPT_emit_llvm);
10728 // and for "clang -w foo.o -o foo". Other warning options are already
10729 // handled somewhere else.
10730 Args.ClaimAllArgs(options::OPT_w);
10731
10732 if (!D.SysRoot.empty())
10733 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
10734
10735 if (Args.hasArg(options::OPT_pie))
10736 CmdArgs.push_back("-pie");
10737
10738 if (Args.hasArg(options::OPT_rdynamic))
10739 CmdArgs.push_back("-export-dynamic");
10740 if (Args.hasArg(options::OPT_shared))
10741 CmdArgs.push_back("--oformat=so");
10742
10743 if (Output.isFilename()) {
10744 CmdArgs.push_back("-o");
10745 CmdArgs.push_back(Output.getFilename());
10746 } else {
10747 assert(Output.isNothing() && "Invalid output.");
10748 }
10749
Filipe Cabecinhas82cd6af2015-10-16 15:07:48 +000010750 AddPS4SanitizerArgs(ToolChain, CmdArgs);
10751
Filipe Cabecinhasc888e192015-10-14 12:25:43 +000010752 Args.AddAllArgs(CmdArgs, options::OPT_L);
10753 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
10754 Args.AddAllArgs(CmdArgs, options::OPT_e);
10755 Args.AddAllArgs(CmdArgs, options::OPT_s);
10756 Args.AddAllArgs(CmdArgs, options::OPT_t);
10757 Args.AddAllArgs(CmdArgs, options::OPT_r);
10758
10759 if (Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
10760 CmdArgs.push_back("--no-demangle");
10761
10762 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
10763
10764 if (Args.hasArg(options::OPT_pthread)) {
10765 CmdArgs.push_back("-lpthread");
10766 }
10767
Paul Robinson9d613612016-05-16 17:22:25 +000010768 const char *Exec = Args.MakeArgString(ToolChain.GetProgramPath("orbis-ld"));
Filipe Cabecinhasc888e192015-10-14 12:25:43 +000010769
10770 C.addCommand(llvm::make_unique<Command>(JA, T, Exec, CmdArgs, Inputs));
10771}
10772
10773static void ConstructGoldLinkJob(const Tool &T, Compilation &C,
10774 const JobAction &JA, const InputInfo &Output,
10775 const InputInfoList &Inputs,
10776 const ArgList &Args,
10777 const char *LinkingOutput) {
10778 const toolchains::FreeBSD &ToolChain =
10779 static_cast<const toolchains::FreeBSD &>(T.getToolChain());
10780 const Driver &D = ToolChain.getDriver();
10781 ArgStringList CmdArgs;
10782
10783 // Silence warning for "clang -g foo.o -o foo"
10784 Args.ClaimAllArgs(options::OPT_g_Group);
10785 // and "clang -emit-llvm foo.o -o foo"
10786 Args.ClaimAllArgs(options::OPT_emit_llvm);
10787 // and for "clang -w foo.o -o foo". Other warning options are already
10788 // handled somewhere else.
10789 Args.ClaimAllArgs(options::OPT_w);
10790
10791 if (!D.SysRoot.empty())
10792 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
10793
10794 if (Args.hasArg(options::OPT_pie))
10795 CmdArgs.push_back("-pie");
10796
10797 if (Args.hasArg(options::OPT_static)) {
10798 CmdArgs.push_back("-Bstatic");
10799 } else {
10800 if (Args.hasArg(options::OPT_rdynamic))
10801 CmdArgs.push_back("-export-dynamic");
10802 CmdArgs.push_back("--eh-frame-hdr");
10803 if (Args.hasArg(options::OPT_shared)) {
10804 CmdArgs.push_back("-Bshareable");
10805 } else {
10806 CmdArgs.push_back("-dynamic-linker");
10807 CmdArgs.push_back("/libexec/ld-elf.so.1");
10808 }
10809 CmdArgs.push_back("--enable-new-dtags");
10810 }
10811
10812 if (Output.isFilename()) {
10813 CmdArgs.push_back("-o");
10814 CmdArgs.push_back(Output.getFilename());
10815 } else {
10816 assert(Output.isNothing() && "Invalid output.");
10817 }
10818
Filipe Cabecinhas82cd6af2015-10-16 15:07:48 +000010819 AddPS4SanitizerArgs(ToolChain, CmdArgs);
10820
Douglas Katzman78b37b02015-11-17 20:28:07 +000010821 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) {
Eugene Zelenkod4304d22015-11-04 21:37:17 +000010822 const char *crt1 = nullptr;
Filipe Cabecinhasc888e192015-10-14 12:25:43 +000010823 if (!Args.hasArg(options::OPT_shared)) {
10824 if (Args.hasArg(options::OPT_pg))
10825 crt1 = "gcrt1.o";
10826 else if (Args.hasArg(options::OPT_pie))
10827 crt1 = "Scrt1.o";
10828 else
10829 crt1 = "crt1.o";
10830 }
10831 if (crt1)
10832 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crt1)));
10833
10834 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
10835
Eugene Zelenkod4304d22015-11-04 21:37:17 +000010836 const char *crtbegin = nullptr;
Filipe Cabecinhasc888e192015-10-14 12:25:43 +000010837 if (Args.hasArg(options::OPT_static))
10838 crtbegin = "crtbeginT.o";
10839 else if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_pie))
10840 crtbegin = "crtbeginS.o";
10841 else
10842 crtbegin = "crtbegin.o";
10843
10844 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtbegin)));
10845 }
10846
10847 Args.AddAllArgs(CmdArgs, options::OPT_L);
Douglas Katzman6059ef92015-11-17 17:41:23 +000010848 ToolChain.AddFilePathLibArgs(Args, CmdArgs);
Filipe Cabecinhasc888e192015-10-14 12:25:43 +000010849 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
10850 Args.AddAllArgs(CmdArgs, options::OPT_e);
10851 Args.AddAllArgs(CmdArgs, options::OPT_s);
10852 Args.AddAllArgs(CmdArgs, options::OPT_t);
10853 Args.AddAllArgs(CmdArgs, options::OPT_r);
10854
10855 if (Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
10856 CmdArgs.push_back("--no-demangle");
10857
10858 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
10859
Douglas Katzman78b37b02015-11-17 20:28:07 +000010860 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nodefaultlibs)) {
Filipe Cabecinhasc888e192015-10-14 12:25:43 +000010861 // For PS4, we always want to pass libm, libstdc++ and libkernel
10862 // libraries for both C and C++ compilations.
10863 CmdArgs.push_back("-lkernel");
10864 if (D.CCCIsCXX()) {
10865 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
10866 if (Args.hasArg(options::OPT_pg))
10867 CmdArgs.push_back("-lm_p");
10868 else
10869 CmdArgs.push_back("-lm");
10870 }
10871 // FIXME: For some reason GCC passes -lgcc and -lgcc_s before adding
10872 // the default system libraries. Just mimic this for now.
10873 if (Args.hasArg(options::OPT_pg))
10874 CmdArgs.push_back("-lgcc_p");
10875 else
10876 CmdArgs.push_back("-lcompiler_rt");
10877 if (Args.hasArg(options::OPT_static)) {
10878 CmdArgs.push_back("-lstdc++");
10879 } else if (Args.hasArg(options::OPT_pg)) {
10880 CmdArgs.push_back("-lgcc_eh_p");
10881 } else {
10882 CmdArgs.push_back("--as-needed");
10883 CmdArgs.push_back("-lstdc++");
10884 CmdArgs.push_back("--no-as-needed");
10885 }
10886
10887 if (Args.hasArg(options::OPT_pthread)) {
10888 if (Args.hasArg(options::OPT_pg))
10889 CmdArgs.push_back("-lpthread_p");
10890 else
10891 CmdArgs.push_back("-lpthread");
10892 }
10893
10894 if (Args.hasArg(options::OPT_pg)) {
10895 if (Args.hasArg(options::OPT_shared))
10896 CmdArgs.push_back("-lc");
10897 else {
10898 if (Args.hasArg(options::OPT_static)) {
10899 CmdArgs.push_back("--start-group");
10900 CmdArgs.push_back("-lc_p");
10901 CmdArgs.push_back("-lpthread_p");
10902 CmdArgs.push_back("--end-group");
10903 } else {
10904 CmdArgs.push_back("-lc_p");
10905 }
10906 }
10907 CmdArgs.push_back("-lgcc_p");
10908 } else {
10909 if (Args.hasArg(options::OPT_static)) {
10910 CmdArgs.push_back("--start-group");
10911 CmdArgs.push_back("-lc");
10912 CmdArgs.push_back("-lpthread");
10913 CmdArgs.push_back("--end-group");
10914 } else {
10915 CmdArgs.push_back("-lc");
10916 }
10917 CmdArgs.push_back("-lcompiler_rt");
10918 }
10919
10920 if (Args.hasArg(options::OPT_static)) {
10921 CmdArgs.push_back("-lstdc++");
10922 } else if (Args.hasArg(options::OPT_pg)) {
10923 CmdArgs.push_back("-lgcc_eh_p");
10924 } else {
10925 CmdArgs.push_back("--as-needed");
10926 CmdArgs.push_back("-lstdc++");
10927 CmdArgs.push_back("--no-as-needed");
10928 }
10929 }
10930
Douglas Katzman78b37b02015-11-17 20:28:07 +000010931 if (!Args.hasArg(options::OPT_nostdlib, options::OPT_nostartfiles)) {
Filipe Cabecinhasc888e192015-10-14 12:25:43 +000010932 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_pie))
10933 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtendS.o")));
10934 else
10935 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtend.o")));
10936 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
10937 }
10938
Filipe Cabecinhasc888e192015-10-14 12:25:43 +000010939 const char *Exec =
10940#ifdef LLVM_ON_WIN32
Paul Robinson9d613612016-05-16 17:22:25 +000010941 Args.MakeArgString(ToolChain.GetProgramPath("orbis-ld.gold"));
Filipe Cabecinhasc888e192015-10-14 12:25:43 +000010942#else
Paul Robinson9d613612016-05-16 17:22:25 +000010943 Args.MakeArgString(ToolChain.GetProgramPath("orbis-ld"));
Filipe Cabecinhasc888e192015-10-14 12:25:43 +000010944#endif
10945
10946 C.addCommand(llvm::make_unique<Command>(JA, T, Exec, CmdArgs, Inputs));
10947}
10948
10949void PS4cpu::Link::ConstructJob(Compilation &C, const JobAction &JA,
10950 const InputInfo &Output,
10951 const InputInfoList &Inputs,
10952 const ArgList &Args,
10953 const char *LinkingOutput) const {
10954 const toolchains::FreeBSD &ToolChain =
10955 static_cast<const toolchains::FreeBSD &>(getToolChain());
10956 const Driver &D = ToolChain.getDriver();
10957 bool PS4Linker;
10958 StringRef LinkerOptName;
10959 if (const Arg *A = Args.getLastArg(options::OPT_fuse_ld_EQ)) {
10960 LinkerOptName = A->getValue();
10961 if (LinkerOptName != "ps4" && LinkerOptName != "gold")
10962 D.Diag(diag::err_drv_unsupported_linker) << LinkerOptName;
10963 }
10964
10965 if (LinkerOptName == "gold")
10966 PS4Linker = false;
10967 else if (LinkerOptName == "ps4")
10968 PS4Linker = true;
10969 else
10970 PS4Linker = !Args.hasArg(options::OPT_shared);
10971
10972 if (PS4Linker)
10973 ConstructPS4LinkJob(*this, C, JA, Output, Inputs, Args, LinkingOutput);
10974 else
10975 ConstructGoldLinkJob(*this, C, JA, Output, Inputs, Args, LinkingOutput);
10976}
Justin Lebar21e5d4f2016-01-14 21:41:27 +000010977
10978void NVPTX::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
10979 const InputInfo &Output,
10980 const InputInfoList &Inputs,
10981 const ArgList &Args,
10982 const char *LinkingOutput) const {
10983 const auto &TC =
10984 static_cast<const toolchains::CudaToolChain &>(getToolChain());
Justin Lebarb2db4502016-01-23 21:28:08 +000010985 assert(TC.getTriple().isNVPTX() && "Wrong platform");
Justin Lebar21e5d4f2016-01-14 21:41:27 +000010986
10987 std::vector<std::string> gpu_archs =
10988 Args.getAllArgValues(options::OPT_march_EQ);
10989 assert(gpu_archs.size() == 1 && "Exactly one GPU Arch required for ptxas.");
10990 const std::string& gpu_arch = gpu_archs[0];
10991
Justin Lebar21e5d4f2016-01-14 21:41:27 +000010992 ArgStringList CmdArgs;
10993 CmdArgs.push_back(TC.getTriple().isArch64Bit() ? "-m64" : "-m32");
Justin Lebarb41f33c2016-04-19 02:27:11 +000010994 if (Args.hasFlag(options::OPT_cuda_noopt_device_debug,
10995 options::OPT_no_cuda_noopt_device_debug, false)) {
Artem Belevich0a0e54c2016-02-16 22:03:20 +000010996 // ptxas does not accept -g option if optimization is enabled, so
10997 // we ignore the compiler's -O* options if we want debug info.
10998 CmdArgs.push_back("-g");
10999 CmdArgs.push_back("--dont-merge-basicblocks");
11000 CmdArgs.push_back("--return-at-end");
11001 } else if (Arg *A = Args.getLastArg(options::OPT_O_Group)) {
11002 // Map the -O we received to -O{0,1,2,3}.
11003 //
11004 // TODO: Perhaps we should map host -O2 to ptxas -O3. -O3 is ptxas's
11005 // default, so it may correspond more closely to the spirit of clang -O2.
Justin Lebar21e5d4f2016-01-14 21:41:27 +000011006
Justin Lebar2836dcd2016-01-19 19:52:21 +000011007 // -O3 seems like the least-bad option when -Osomething is specified to
11008 // clang but it isn't handled below.
11009 StringRef OOpt = "3";
11010 if (A->getOption().matches(options::OPT_O4) ||
11011 A->getOption().matches(options::OPT_Ofast))
11012 OOpt = "3";
11013 else if (A->getOption().matches(options::OPT_O0))
11014 OOpt = "0";
11015 else if (A->getOption().matches(options::OPT_O)) {
11016 // -Os, -Oz, and -O(anything else) map to -O2, for lack of better options.
11017 OOpt = llvm::StringSwitch<const char *>(A->getValue())
11018 .Case("1", "1")
11019 .Case("2", "2")
11020 .Case("3", "3")
11021 .Case("s", "2")
11022 .Case("z", "2")
11023 .Default("2");
11024 }
11025 CmdArgs.push_back(Args.MakeArgString(llvm::Twine("-O") + OOpt));
11026 } else {
11027 // If no -O was passed, pass -O0 to ptxas -- no opt flag should correspond
11028 // to no optimizations, but ptxas's default is -O3.
11029 CmdArgs.push_back("-O0");
11030 }
Justin Lebar21e5d4f2016-01-14 21:41:27 +000011031
Justin Lebar21e5d4f2016-01-14 21:41:27 +000011032 CmdArgs.push_back("--gpu-name");
11033 CmdArgs.push_back(Args.MakeArgString(gpu_arch));
11034 CmdArgs.push_back("--output-file");
11035 CmdArgs.push_back(Args.MakeArgString(Output.getFilename()));
11036 for (const auto& II : Inputs)
11037 CmdArgs.push_back(Args.MakeArgString(II.getFilename()));
11038
11039 for (const auto& A : Args.getAllArgValues(options::OPT_Xcuda_ptxas))
11040 CmdArgs.push_back(Args.MakeArgString(A));
11041
11042 const char *Exec = Args.MakeArgString(TC.GetProgramPath("ptxas"));
11043 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
11044}
11045
11046// All inputs to this linker must be from CudaDeviceActions, as we need to look
11047// at the Inputs' Actions in order to figure out which GPU architecture they
11048// correspond to.
11049void NVPTX::Linker::ConstructJob(Compilation &C, const JobAction &JA,
11050 const InputInfo &Output,
11051 const InputInfoList &Inputs,
11052 const ArgList &Args,
11053 const char *LinkingOutput) const {
11054 const auto &TC =
11055 static_cast<const toolchains::CudaToolChain &>(getToolChain());
Justin Lebarb2db4502016-01-23 21:28:08 +000011056 assert(TC.getTriple().isNVPTX() && "Wrong platform");
Justin Lebar21e5d4f2016-01-14 21:41:27 +000011057
11058 ArgStringList CmdArgs;
11059 CmdArgs.push_back("--cuda");
11060 CmdArgs.push_back(TC.getTriple().isArch64Bit() ? "-64" : "-32");
11061 CmdArgs.push_back(Args.MakeArgString("--create"));
11062 CmdArgs.push_back(Args.MakeArgString(Output.getFilename()));
11063
11064 for (const auto& II : Inputs) {
11065 auto* A = cast<const CudaDeviceAction>(II.getAction());
11066 // We need to pass an Arch of the form "sm_XX" for cubin files and
11067 // "compute_XX" for ptx.
11068 const char *Arch = (II.getType() == types::TY_PP_Asm)
11069 ? A->getComputeArchName()
11070 : A->getGpuArchName();
11071 CmdArgs.push_back(Args.MakeArgString(llvm::Twine("--image=profile=") +
11072 Arch + ",file=" + II.getFilename()));
11073 }
11074
11075 for (const auto& A : Args.getAllArgValues(options::OPT_Xcuda_fatbinary))
11076 CmdArgs.push_back(Args.MakeArgString(A));
11077
11078 const char *Exec = Args.MakeArgString(TC.GetProgramPath("fatbinary"));
11079 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
11080}