blob: 92f41063e2d4fa67faa2116dd2ea2a012e1dab42 [file] [log] [blame]
Nick Lewyckye47c2452010-09-23 23:48:20 +00001//===--- Tools.cpp - Tools Implementations --------------------------------===//
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"
12#include "SanitizerArgs.h"
13#include "ToolChains.h"
14#include "clang/Basic/ObjCRuntime.h"
Daniel Dunbara2aedc62009-03-18 10:01:51 +000015#include "clang/Driver/Action.h"
Daniel Dunbar04c4c2c2009-03-18 07:06:02 +000016#include "clang/Driver/Arg.h"
Daniel Dunbara3246a02009-03-18 08:07:30 +000017#include "clang/Driver/ArgList.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000018#include "clang/Driver/Compilation.h"
Daniel Dunbar1a8a2e82009-10-29 02:39:57 +000019#include "clang/Driver/Driver.h"
20#include "clang/Driver/DriverDiagnostic.h"
Daniel Dunbar04c4c2c2009-03-18 07:06:02 +000021#include "clang/Driver/Job.h"
Daniel Dunbara3246a02009-03-18 08:07:30 +000022#include "clang/Driver/Option.h"
Daniel Dunbarda13faf2009-11-19 04:25:22 +000023#include "clang/Driver/Options.h"
Daniel Dunbara3246a02009-03-18 08:07:30 +000024#include "clang/Driver/ToolChain.h"
Daniel Dunbar04c4c2c2009-03-18 07:06:02 +000025#include "clang/Driver/Util.h"
Daniel Dunbar1c28f1e2009-09-09 22:32:48 +000026#include "llvm/ADT/SmallString.h"
Douglas Gregorf7b87cb2009-10-29 00:41:01 +000027#include "llvm/ADT/StringSwitch.h"
Daniel Dunbarb4a3e432009-09-09 22:32:34 +000028#include "llvm/ADT/Twine.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000029#include "llvm/Support/ErrorHandling.h"
Michael J. Spencerf6efe582011-01-10 02:34:13 +000030#include "llvm/Support/FileSystem.h"
Daniel Dunbarc1964212009-03-26 16:23:12 +000031#include "llvm/Support/Format.h"
Michael J. Spencer8aaf4992010-11-29 18:12:39 +000032#include "llvm/Support/Host.h"
33#include "llvm/Support/Process.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000034#include "llvm/Support/raw_ostream.h"
Daniel Dunbar04c4c2c2009-03-18 07:06:02 +000035
Daniel Dunbar1a093d22009-03-18 06:00:36 +000036using namespace clang::driver;
37using namespace clang::driver::tools;
Chris Lattner0e62c1c2011-07-23 10:55:15 +000038using namespace clang;
Daniel Dunbar1a093d22009-03-18 06:00:36 +000039
Daniel Dunbar64198ef2009-09-10 01:21:05 +000040/// CheckPreprocessingOptions - Perform some validation of preprocessing
41/// arguments that is shared with gcc.
42static void CheckPreprocessingOptions(const Driver &D, const ArgList &Args) {
43 if (Arg *A = Args.getLastArg(options::OPT_C, options::OPT_CC))
Joerg Sonnenbergerb86f5f42011-03-06 23:31:01 +000044 if (!Args.hasArg(options::OPT_E) && !D.CCCIsCPP)
Chris Lattner0e62c1c2011-07-23 10:55:15 +000045 D.Diag(diag::err_drv_argument_only_allowed_with)
Daniel Dunbar64198ef2009-09-10 01:21:05 +000046 << A->getAsString(Args) << "-E";
47}
48
Daniel Dunbar4eadb602009-09-10 01:21:12 +000049/// CheckCodeGenerationOptions - Perform some validation of code generation
50/// arguments that is shared with gcc.
51static void CheckCodeGenerationOptions(const Driver &D, const ArgList &Args) {
52 // In gcc, only ARM checks this, but it seems reasonable to check universally.
53 if (Args.hasArg(options::OPT_static))
54 if (const Arg *A = Args.getLastArg(options::OPT_dynamic,
55 options::OPT_mdynamic_no_pic))
Chris Lattner0e62c1c2011-07-23 10:55:15 +000056 D.Diag(diag::err_drv_argument_not_allowed_with)
Daniel Dunbar4eadb602009-09-10 01:21:12 +000057 << A->getAsString(Args) << "-static";
58}
59
Chris Lattnerbf2803f2010-03-29 17:55:58 +000060// Quote target names for inclusion in GNU Make dependency files.
61// Only the characters '$', '#', ' ', '\t' are quoted.
Chris Lattner0e62c1c2011-07-23 10:55:15 +000062static void QuoteTarget(StringRef Target,
63 SmallVectorImpl<char> &Res) {
Chris Lattnerbf2803f2010-03-29 17:55:58 +000064 for (unsigned i = 0, e = Target.size(); i != e; ++i) {
65 switch (Target[i]) {
66 case ' ':
67 case '\t':
68 // Escape the preceding backslashes
69 for (int j = i - 1; j >= 0 && Target[j] == '\\'; --j)
70 Res.push_back('\\');
71
72 // Escape the space/tab
73 Res.push_back('\\');
74 break;
75 case '$':
76 Res.push_back('$');
77 break;
78 case '#':
79 Res.push_back('\\');
80 break;
81 default:
82 break;
83 }
84
85 Res.push_back(Target[i]);
86 }
87}
88
Bill Wendlingc0938f32012-03-12 22:10:06 +000089static void addDirectoryList(const ArgList &Args,
Bill Wendling281ca292012-03-12 21:22:35 +000090 ArgStringList &CmdArgs,
91 const char *ArgName,
Bill Wendlingc0938f32012-03-12 22:10:06 +000092 const char *EnvVar) {
93 const char *DirList = ::getenv(EnvVar);
Chad Rosier616e8a52012-10-30 21:42:09 +000094 bool CombinedArg = false;
95
Bill Wendling281ca292012-03-12 21:22:35 +000096 if (!DirList)
97 return; // Nothing to do.
98
Chad Rosier616e8a52012-10-30 21:42:09 +000099 StringRef Name(ArgName);
100 if (Name.equals("-I") || Name.equals("-L"))
101 CombinedArg = true;
102
Bill Wendling281ca292012-03-12 21:22:35 +0000103 StringRef Dirs(DirList);
104 if (Dirs.empty()) // Empty string should not add '.'.
105 return;
106
107 StringRef::size_type Delim;
108 while ((Delim = Dirs.find(llvm::sys::PathSeparator)) != StringRef::npos) {
109 if (Delim == 0) { // Leading colon.
Chad Rosier616e8a52012-10-30 21:42:09 +0000110 if (CombinedArg) {
111 CmdArgs.push_back(Args.MakeArgString(std::string(ArgName) + "."));
112 } else {
113 CmdArgs.push_back(ArgName);
114 CmdArgs.push_back(".");
115 }
Bill Wendling281ca292012-03-12 21:22:35 +0000116 } else {
Chad Rosier616e8a52012-10-30 21:42:09 +0000117 if (CombinedArg) {
118 CmdArgs.push_back(Args.MakeArgString(std::string(ArgName) + Dirs.substr(0, Delim)));
119 } else {
120 CmdArgs.push_back(ArgName);
121 CmdArgs.push_back(Args.MakeArgString(Dirs.substr(0, Delim)));
122 }
Bill Wendling281ca292012-03-12 21:22:35 +0000123 }
Nico Weber89355782012-03-19 15:00:03 +0000124 Dirs = Dirs.substr(Delim + 1);
Bill Wendling281ca292012-03-12 21:22:35 +0000125 }
126
127 if (Dirs.empty()) { // Trailing colon.
Chad Rosier616e8a52012-10-30 21:42:09 +0000128 if (CombinedArg) {
129 CmdArgs.push_back(Args.MakeArgString(std::string(ArgName) + "."));
130 } else {
131 CmdArgs.push_back(ArgName);
132 CmdArgs.push_back(".");
133 }
Bill Wendling281ca292012-03-12 21:22:35 +0000134 } else { // Add the last path.
Chad Rosier616e8a52012-10-30 21:42:09 +0000135 if (CombinedArg) {
136 CmdArgs.push_back(Args.MakeArgString(std::string(ArgName) + Dirs));
137 } else {
138 CmdArgs.push_back(ArgName);
139 CmdArgs.push_back(Args.MakeArgString(Dirs));
140 }
Bill Wendling281ca292012-03-12 21:22:35 +0000141 }
142}
143
Daniel Dunbar54423b22010-09-17 00:24:54 +0000144static void AddLinkerInputs(const ToolChain &TC,
145 const InputInfoList &Inputs, const ArgList &Args,
146 ArgStringList &CmdArgs) {
147 const Driver &D = TC.getDriver();
148
Daniel Dunbar1094bb12011-02-19 05:33:51 +0000149 // Add extra linker input arguments which are not treated as inputs
150 // (constructed via -Xarch_).
151 Args.AddAllArgValues(CmdArgs, options::OPT_Zlinker_input);
152
Daniel Dunbar54423b22010-09-17 00:24:54 +0000153 for (InputInfoList::const_iterator
154 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
155 const InputInfo &II = *it;
156
157 if (!TC.HasNativeLLVMSupport()) {
158 // Don't try to pass LLVM inputs unless we have native support.
159 if (II.getType() == types::TY_LLVM_IR ||
160 II.getType() == types::TY_LTO_IR ||
161 II.getType() == types::TY_LLVM_BC ||
162 II.getType() == types::TY_LTO_BC)
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000163 D.Diag(diag::err_drv_no_linker_llvm_support)
Daniel Dunbar54423b22010-09-17 00:24:54 +0000164 << TC.getTripleString();
165 }
166
Daniel Dunbar2cc3f172010-09-17 00:45:02 +0000167 // Add filenames immediately.
168 if (II.isFilename()) {
Daniel Dunbar54423b22010-09-17 00:24:54 +0000169 CmdArgs.push_back(II.getFilename());
Daniel Dunbar2cc3f172010-09-17 00:45:02 +0000170 continue;
171 }
172
173 // Otherwise, this is a linker input argument.
174 const Arg &A = II.getInputArg();
175
176 // Handle reserved library options.
177 if (A.getOption().matches(options::OPT_Z_reserved_lib_stdcxx)) {
Daniel Dunbar3f7796f2010-09-17 01:20:05 +0000178 TC.AddCXXStdlibLibArgs(Args, CmdArgs);
Shantonu Senafeb03b2010-09-17 18:39:08 +0000179 } else if (A.getOption().matches(options::OPT_Z_reserved_lib_cckext)) {
180 TC.AddCCKextLibArgs(Args, CmdArgs);
Daniel Dunbar2cc3f172010-09-17 00:45:02 +0000181 } else
182 A.renderAsInput(Args, CmdArgs);
Daniel Dunbar54423b22010-09-17 00:24:54 +0000183 }
Bill Wendling281ca292012-03-12 21:22:35 +0000184
185 // LIBRARY_PATH - included following the user specified library paths.
Bill Wendlingc0938f32012-03-12 22:10:06 +0000186 addDirectoryList(Args, CmdArgs, "-L", "LIBRARY_PATH");
Daniel Dunbar54423b22010-09-17 00:24:54 +0000187}
188
John McCall31168b02011-06-15 23:02:42 +0000189/// \brief Determine whether Objective-C automated reference counting is
190/// enabled.
191static bool isObjCAutoRefCount(const ArgList &Args) {
192 return Args.hasFlag(options::OPT_fobjc_arc, options::OPT_fno_objc_arc, false);
193}
194
Ted Kremeneke65b0862012-03-06 20:05:56 +0000195/// \brief Determine whether we are linking the ObjC runtime.
196static bool isObjCRuntimeLinked(const ArgList &Args) {
Bob Wilson29536fc2012-08-07 19:58:00 +0000197 if (isObjCAutoRefCount(Args)) {
198 Args.ClaimAllArgs(options::OPT_fobjc_link_runtime);
Ted Kremeneke65b0862012-03-06 20:05:56 +0000199 return true;
Bob Wilson29536fc2012-08-07 19:58:00 +0000200 }
Ted Kremeneke65b0862012-03-06 20:05:56 +0000201 return Args.hasArg(options::OPT_fobjc_link_runtime);
202}
203
Rafael Espindola9d4a8cf2011-06-02 18:58:46 +0000204static void addProfileRT(const ToolChain &TC, const ArgList &Args,
Bill Wendling08760582011-06-27 19:15:03 +0000205 ArgStringList &CmdArgs,
206 llvm::Triple Triple) {
207 if (!(Args.hasArg(options::OPT_fprofile_arcs) ||
208 Args.hasArg(options::OPT_fprofile_generate) ||
209 Args.hasArg(options::OPT_fcreate_profile) ||
210 Args.hasArg(options::OPT_coverage)))
211 return;
212
213 // GCC links libgcov.a by adding -L<inst>/gcc/lib/gcc/<triple>/<ver> -lgcov to
214 // the link line. We cannot do the same thing because unlike gcov there is a
215 // libprofile_rt.so. We used to use the -l:libprofile_rt.a syntax, but that is
216 // not supported by old linkers.
Benjamin Kramerf5fbe432011-11-07 16:02:25 +0000217 std::string ProfileRT =
218 std::string(TC.getDriver().Dir) + "/../lib/libprofile_rt.a";
Bill Wendling08760582011-06-27 19:15:03 +0000219
Bill Wendling08760582011-06-27 19:15:03 +0000220 CmdArgs.push_back(Args.MakeArgString(ProfileRT));
Rafael Espindola9d4a8cf2011-06-02 18:58:46 +0000221}
222
Michael J. Spencer66e2b202012-10-19 22:37:06 +0000223static bool forwardToGCC(const Option &O) {
224 return !O.hasFlag(options::NoForward) &&
225 !O.hasFlag(options::DriverOption) &&
226 !O.hasFlag(options::LinkerInput);
227}
228
Peter Collingbourne9b515cb2011-11-06 00:40:05 +0000229void Clang::AddPreprocessingOptions(Compilation &C,
230 const Driver &D,
Douglas Gregor111af7d2009-04-18 00:34:01 +0000231 const ArgList &Args,
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000232 ArgStringList &CmdArgs,
233 const InputInfo &Output,
234 const InputInfoList &Inputs) const {
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000235 Arg *A;
Daniel Dunbar367dbb92009-06-08 21:48:20 +0000236
Daniel Dunbar64198ef2009-09-10 01:21:05 +0000237 CheckPreprocessingOptions(D, Args);
238
239 Args.AddLastArg(CmdArgs, options::OPT_C);
240 Args.AddLastArg(CmdArgs, options::OPT_CC);
Daniel Dunbar367dbb92009-06-08 21:48:20 +0000241
242 // Handle dependency file generation.
Daniel Dunbar86aed7d2010-12-08 21:33:40 +0000243 if ((A = Args.getLastArg(options::OPT_M, options::OPT_MM)) ||
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000244 (A = Args.getLastArg(options::OPT_MD)) ||
245 (A = Args.getLastArg(options::OPT_MMD))) {
246 // Determine the output location.
247 const char *DepFile;
Benjamin Kramer2715fce2012-09-26 19:01:49 +0000248 if (Arg *MF = Args.getLastArg(options::OPT_MF)) {
Richard Smithbd55daf2012-11-01 04:30:05 +0000249 DepFile = MF->getValue();
Peter Collingbourne119cfaa2011-11-21 00:01:05 +0000250 C.addFailureResultFile(DepFile);
Benjamin Kramer2715fce2012-09-26 19:01:49 +0000251 } else if (Output.getType() == types::TY_Dependencies) {
252 DepFile = Output.getFilename();
Daniel Dunbar0bfb21e2009-11-19 03:26:40 +0000253 } else if (A->getOption().matches(options::OPT_M) ||
254 A->getOption().matches(options::OPT_MM)) {
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000255 DepFile = "-";
256 } else {
Bob Wilsondecc03e2012-11-23 06:14:39 +0000257 DepFile = getDependencyFileName(Args, Inputs);
Peter Collingbourne119cfaa2011-11-21 00:01:05 +0000258 C.addFailureResultFile(DepFile);
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000259 }
260 CmdArgs.push_back("-dependency-file");
261 CmdArgs.push_back(DepFile);
262
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000263 // Add a default target if one wasn't specified.
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000264 if (!Args.hasArg(options::OPT_MT) && !Args.hasArg(options::OPT_MQ)) {
265 const char *DepTarget;
266
267 // If user provided -o, that is the dependency target, except
268 // when we are only generating a dependency file.
269 Arg *OutputOpt = Args.getLastArg(options::OPT_o);
270 if (OutputOpt && Output.getType() != types::TY_Dependencies) {
Richard Smithbd55daf2012-11-01 04:30:05 +0000271 DepTarget = OutputOpt->getValue();
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000272 } else {
273 // Otherwise derive from the base input.
274 //
275 // FIXME: This should use the computed output file location.
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +0000276 SmallString<128> P(Inputs[0].getBaseInput());
Michael J. Spencere1696752010-12-18 00:19:12 +0000277 llvm::sys::path::replace_extension(P, "o");
278 DepTarget = Args.MakeArgString(llvm::sys::path::filename(P));
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000279 }
280
281 CmdArgs.push_back("-MT");
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +0000282 SmallString<128> Quoted;
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000283 QuoteTarget(DepTarget, Quoted);
284 CmdArgs.push_back(Args.MakeArgString(Quoted));
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000285 }
286
Daniel Dunbar0bfb21e2009-11-19 03:26:40 +0000287 if (A->getOption().matches(options::OPT_M) ||
288 A->getOption().matches(options::OPT_MD))
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000289 CmdArgs.push_back("-sys-header-deps");
290 }
291
Peter Collingbourne77b0e7f22011-07-12 19:35:15 +0000292 if (Args.hasArg(options::OPT_MG)) {
293 if (!A || A->getOption().matches(options::OPT_MD) ||
294 A->getOption().matches(options::OPT_MMD))
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000295 D.Diag(diag::err_drv_mg_requires_m_or_mm);
Peter Collingbourne77b0e7f22011-07-12 19:35:15 +0000296 CmdArgs.push_back("-MG");
297 }
298
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000299 Args.AddLastArg(CmdArgs, options::OPT_MP);
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000300
301 // Convert all -MQ <target> args to -MT <quoted target>
302 for (arg_iterator it = Args.filtered_begin(options::OPT_MT,
303 options::OPT_MQ),
304 ie = Args.filtered_end(); it != ie; ++it) {
Daniel Dunbara442fd52010-06-11 22:00:13 +0000305 const Arg *A = *it;
306 A->claim();
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000307
Daniel Dunbara442fd52010-06-11 22:00:13 +0000308 if (A->getOption().matches(options::OPT_MQ)) {
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000309 CmdArgs.push_back("-MT");
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +0000310 SmallString<128> Quoted;
Richard Smithbd55daf2012-11-01 04:30:05 +0000311 QuoteTarget(A->getValue(), Quoted);
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000312 CmdArgs.push_back(Args.MakeArgString(Quoted));
313
314 // -MT flag - no change
315 } else {
Daniel Dunbara442fd52010-06-11 22:00:13 +0000316 A->render(Args, CmdArgs);
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000317 }
318 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000319
Douglas Gregor111af7d2009-04-18 00:34:01 +0000320 // Add -i* options, and automatically translate to
321 // -include-pch/-include-pth for transparent PCH support. It's
322 // wonky, but we include looking for .gch so we can support seamless
323 // replacement into a build system already set up to be generating
324 // .gch files.
Argyrios Kyrtzidis2f23b412010-09-30 16:53:47 +0000325 bool RenderedImplicitInclude = false;
Daniel Dunbar44b36ee2009-11-25 11:53:23 +0000326 for (arg_iterator it = Args.filtered_begin(options::OPT_clang_i_Group),
327 ie = Args.filtered_end(); it != ie; ++it) {
328 const Arg *A = it;
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000329
330 if (A->getOption().matches(options::OPT_include)) {
Argyrios Kyrtzidis2f23b412010-09-30 16:53:47 +0000331 bool IsFirstImplicitInclude = !RenderedImplicitInclude;
332 RenderedImplicitInclude = true;
333
Argyrios Kyrtzidis90bdfbb2010-08-11 23:27:58 +0000334 // Use PCH if the user requested it.
Daniel Dunbarcbc34b72009-10-15 20:02:44 +0000335 bool UsePCH = D.CCCUsePCH;
Daniel Dunbarcbc34b72009-10-15 20:02:44 +0000336
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000337 bool FoundPTH = false;
Douglas Gregor111af7d2009-04-18 00:34:01 +0000338 bool FoundPCH = false;
Richard Smithbd55daf2012-11-01 04:30:05 +0000339 llvm::sys::Path P(A->getValue());
Michael J. Spencerf6efe582011-01-10 02:34:13 +0000340 bool Exists;
Daniel Dunbarcbc34b72009-10-15 20:02:44 +0000341 if (UsePCH) {
Douglas Gregor111af7d2009-04-18 00:34:01 +0000342 P.appendSuffix("pch");
Michael J. Spencerf6efe582011-01-10 02:34:13 +0000343 if (!llvm::sys::fs::exists(P.str(), Exists) && Exists)
Douglas Gregor111af7d2009-04-18 00:34:01 +0000344 FoundPCH = true;
Mike Stump11289f42009-09-09 15:08:12 +0000345 else
Douglas Gregor111af7d2009-04-18 00:34:01 +0000346 P.eraseSuffix();
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000347 }
348
Douglas Gregor111af7d2009-04-18 00:34:01 +0000349 if (!FoundPCH) {
350 P.appendSuffix("pth");
Michael J. Spencerf6efe582011-01-10 02:34:13 +0000351 if (!llvm::sys::fs::exists(P.str(), Exists) && Exists)
Douglas Gregor111af7d2009-04-18 00:34:01 +0000352 FoundPTH = true;
353 else
354 P.eraseSuffix();
Mike Stump11289f42009-09-09 15:08:12 +0000355 }
356
Douglas Gregor111af7d2009-04-18 00:34:01 +0000357 if (!FoundPCH && !FoundPTH) {
358 P.appendSuffix("gch");
Michael J. Spencerf6efe582011-01-10 02:34:13 +0000359 if (!llvm::sys::fs::exists(P.str(), Exists) && Exists) {
Daniel Dunbarcbc34b72009-10-15 20:02:44 +0000360 FoundPCH = UsePCH;
361 FoundPTH = !UsePCH;
Douglas Gregor111af7d2009-04-18 00:34:01 +0000362 }
Mike Stump11289f42009-09-09 15:08:12 +0000363 else
Douglas Gregor111af7d2009-04-18 00:34:01 +0000364 P.eraseSuffix();
365 }
366
367 if (FoundPCH || FoundPTH) {
Argyrios Kyrtzidis2f23b412010-09-30 16:53:47 +0000368 if (IsFirstImplicitInclude) {
369 A->claim();
370 if (UsePCH)
371 CmdArgs.push_back("-include-pch");
372 else
373 CmdArgs.push_back("-include-pth");
374 CmdArgs.push_back(Args.MakeArgString(P.str()));
375 continue;
376 } else {
377 // Ignore the PCH if not first on command line and emit warning.
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000378 D.Diag(diag::warn_drv_pch_not_first_include)
Argyrios Kyrtzidis2f23b412010-09-30 16:53:47 +0000379 << P.str() << A->getAsString(Args);
380 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000381 }
382 }
383
384 // Not translated, render as usual.
385 A->claim();
386 A->render(Args, CmdArgs);
387 }
388
389 Args.AddAllArgs(CmdArgs, options::OPT_D, options::OPT_U);
Douglas Gregor9f93e382011-07-28 04:45:53 +0000390 Args.AddAllArgs(CmdArgs, options::OPT_I_Group, options::OPT_F,
391 options::OPT_index_header_map);
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000392
393 // Add -Wp, and -Xassembler if using the preprocessor.
394
395 // FIXME: There is a very unfortunate problem here, some troubled
396 // souls abuse -Wp, to pass preprocessor options in gcc syntax. To
397 // really support that we would have to parse and then translate
398 // those options. :(
399 Args.AddAllArgValues(CmdArgs, options::OPT_Wp_COMMA,
400 options::OPT_Xpreprocessor);
Daniel Dunbar38b62792009-10-29 01:53:44 +0000401
402 // -I- is a deprecated GCC feature, reject it.
403 if (Arg *A = Args.getLastArg(options::OPT_I_))
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000404 D.Diag(diag::err_drv_I_dash_not_supported) << A->getAsString(Args);
Chandler Carruth24e17e12010-10-20 07:00:47 +0000405
406 // If we have a --sysroot, and don't have an explicit -isysroot flag, add an
407 // -isysroot to the CC1 invocation.
Sebastian Pop980920a2012-04-16 04:16:43 +0000408 StringRef sysroot = C.getSysRoot();
409 if (sysroot != "") {
Chandler Carruth24e17e12010-10-20 07:00:47 +0000410 if (!Args.hasArg(options::OPT_isysroot)) {
411 CmdArgs.push_back("-isysroot");
Sebastian Pop980920a2012-04-16 04:16:43 +0000412 CmdArgs.push_back(C.getArgs().MakeArgString(sysroot));
Chandler Carruth24e17e12010-10-20 07:00:47 +0000413 }
414 }
Douglas Gregorf936f782011-09-14 20:28:46 +0000415
416 // If a module path was provided, pass it along. Otherwise, use a temporary
417 // directory.
418 if (Arg *A = Args.getLastArg(options::OPT_fmodule_cache_path)) {
Douglas Gregorf936f782011-09-14 20:28:46 +0000419 A->claim();
420 A->render(Args, CmdArgs);
421 } else {
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +0000422 SmallString<128> DefaultModuleCache;
Douglas Gregorf936f782011-09-14 20:28:46 +0000423 llvm::sys::path::system_temp_directory(/*erasedOnReboot=*/false,
424 DefaultModuleCache);
425 llvm::sys::path::append(DefaultModuleCache, "clang-module-cache");
426 CmdArgs.push_back("-fmodule-cache-path");
427 CmdArgs.push_back(Args.MakeArgString(DefaultModuleCache));
428 }
Douglas Gregor97eec242011-09-15 22:00:41 +0000429
Benjamin Kramer8404eb02011-09-22 21:41:16 +0000430 // Parse additional include paths from environment variables.
Chandler Carruth9802c142011-11-04 07:12:58 +0000431 // FIXME: We should probably sink the logic for handling these from the
432 // frontend into the driver. It will allow deleting 4 otherwise unused flags.
Benjamin Kramer8404eb02011-09-22 21:41:16 +0000433 // CPATH - included following the user specified includes (but prior to
434 // builtin and standard includes).
Bill Wendlingc0938f32012-03-12 22:10:06 +0000435 addDirectoryList(Args, CmdArgs, "-I", "CPATH");
Benjamin Kramer8404eb02011-09-22 21:41:16 +0000436 // C_INCLUDE_PATH - system includes enabled when compiling C.
Bill Wendlingc0938f32012-03-12 22:10:06 +0000437 addDirectoryList(Args, CmdArgs, "-c-isystem", "C_INCLUDE_PATH");
Benjamin Kramer8404eb02011-09-22 21:41:16 +0000438 // CPLUS_INCLUDE_PATH - system includes enabled when compiling C++.
Bill Wendlingc0938f32012-03-12 22:10:06 +0000439 addDirectoryList(Args, CmdArgs, "-cxx-isystem", "CPLUS_INCLUDE_PATH");
Benjamin Kramer8404eb02011-09-22 21:41:16 +0000440 // OBJC_INCLUDE_PATH - system includes enabled when compiling ObjC.
Bill Wendlingc0938f32012-03-12 22:10:06 +0000441 addDirectoryList(Args, CmdArgs, "-objc-isystem", "OBJC_INCLUDE_PATH");
Benjamin Kramer8404eb02011-09-22 21:41:16 +0000442 // OBJCPLUS_INCLUDE_PATH - system includes enabled when compiling ObjC++.
Bill Wendlingc0938f32012-03-12 22:10:06 +0000443 addDirectoryList(Args, CmdArgs, "-objcxx-isystem", "OBJCPLUS_INCLUDE_PATH");
Chandler Carruth6bfd84f2011-11-04 07:12:53 +0000444
Chandler Carruth6bfd84f2011-11-04 07:12:53 +0000445 // Add C++ include arguments, if needed.
Chandler Carruth4c81dfa2011-11-04 07:43:33 +0000446 if (types::isCXX(Inputs[0].getType()))
Chandler Carruth491db322011-11-04 07:34:47 +0000447 getToolChain().AddClangCXXStdlibIncludeArgs(Args, CmdArgs);
Chandler Carrutha796f532011-11-05 20:17:13 +0000448
449 // Add system include arguments.
450 getToolChain().AddClangSystemIncludeArgs(Args, CmdArgs);
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000451}
452
Daniel Dunbarf492c922009-09-10 22:59:51 +0000453/// getLLVMArchSuffixForARM - Get the LLVM arch name to use for a particular
Daniel Dunbarfb58b0a2009-09-10 06:49:20 +0000454/// CPU.
455//
456// FIXME: This is redundant with -mcpu, why does LLVM use this.
457// FIXME: tblgen this, or kill it!
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000458static const char *getLLVMArchSuffixForARM(StringRef CPU) {
Chad Rosier9ac84512011-10-07 17:48:56 +0000459 return llvm::StringSwitch<const char *>(CPU)
460 .Cases("arm7tdmi", "arm7tdmi-s", "arm710t", "v4t")
461 .Cases("arm720t", "arm9", "arm9tdmi", "v4t")
462 .Cases("arm920", "arm920t", "arm922t", "v4t")
463 .Cases("arm940t", "ep9312","v4t")
464 .Cases("arm10tdmi", "arm1020t", "v5")
465 .Cases("arm9e", "arm926ej-s", "arm946e-s", "v5e")
466 .Cases("arm966e-s", "arm968e-s", "arm10e", "v5e")
467 .Cases("arm1020e", "arm1022e", "xscale", "iwmmxt", "v5e")
468 .Cases("arm1136j-s", "arm1136jf-s", "arm1176jz-s", "v6")
469 .Cases("arm1176jzf-s", "mpcorenovfp", "mpcore", "v6")
470 .Cases("arm1156t2-s", "arm1156t2f-s", "v6t2")
Quentin Colombet2e9952e2012-11-29 23:15:27 +0000471 .Cases("cortex-a5", "cortex-a8", "cortex-a9", "cortex-a15", "v7")
Bob Wilson7f05ca32012-03-21 17:19:12 +0000472 .Case("cortex-m3", "v7m")
Jim Grosbach903e63f2012-03-29 19:53:34 +0000473 .Case("cortex-m4", "v7m")
Bob Wilson7f05ca32012-03-21 17:19:12 +0000474 .Case("cortex-m0", "v6m")
Bob Wilsond7cf1042012-09-29 23:52:50 +0000475 .Case("cortex-a9-mp", "v7f")
476 .Case("swift", "v7s")
Chad Rosier9ac84512011-10-07 17:48:56 +0000477 .Default("");
Daniel Dunbarfb58b0a2009-09-10 06:49:20 +0000478}
479
Benjamin Kramer09811c72012-06-26 22:20:06 +0000480/// getARMTargetCPU - Get the (LLVM) name of the ARM cpu we are targeting.
481//
482// FIXME: tblgen this.
483static std::string getARMTargetCPU(const ArgList &Args,
484 const llvm::Triple &Triple) {
485 // FIXME: Warn on inconsistent use of -mcpu and -march.
486
487 // If we have -mcpu=, use that.
488 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +0000489 StringRef MCPU = A->getValue();
Benjamin Kramer09811c72012-06-26 22:20:06 +0000490 // Handle -mcpu=native.
491 if (MCPU == "native")
492 return llvm::sys::getHostCPUName();
493 else
494 return MCPU;
495 }
496
497 StringRef MArch;
498 if (Arg *A = Args.getLastArg(options::OPT_march_EQ)) {
499 // Otherwise, if we have -march= choose the base CPU for that arch.
Richard Smithbd55daf2012-11-01 04:30:05 +0000500 MArch = A->getValue();
Benjamin Kramer09811c72012-06-26 22:20:06 +0000501 } else {
502 // Otherwise, use the Arch from the triple.
503 MArch = Triple.getArchName();
504 }
505
506 // Handle -march=native.
507 std::string NativeMArch;
508 if (MArch == "native") {
509 std::string CPU = llvm::sys::getHostCPUName();
510 if (CPU != "generic") {
511 // Translate the native cpu into the architecture. The switch below will
512 // then chose the minimum cpu for that arch.
513 NativeMArch = std::string("arm") + getLLVMArchSuffixForARM(CPU);
514 MArch = NativeMArch;
515 }
516 }
517
518 return llvm::StringSwitch<const char *>(MArch)
519 .Cases("armv2", "armv2a","arm2")
520 .Case("armv3", "arm6")
521 .Case("armv3m", "arm7m")
522 .Cases("armv4", "armv4t", "arm7tdmi")
523 .Cases("armv5", "armv5t", "arm10tdmi")
524 .Cases("armv5e", "armv5te", "arm1022e")
525 .Case("armv5tej", "arm926ej-s")
526 .Cases("armv6", "armv6k", "arm1136jf-s")
527 .Case("armv6j", "arm1136j-s")
528 .Cases("armv6z", "armv6zk", "arm1176jzf-s")
529 .Case("armv6t2", "arm1156t2-s")
530 .Cases("armv7", "armv7a", "armv7-a", "cortex-a8")
Bob Wilsond7cf1042012-09-29 23:52:50 +0000531 .Cases("armv7f", "armv7-f", "cortex-a9-mp")
532 .Cases("armv7s", "armv7-s", "swift")
Benjamin Kramer09811c72012-06-26 22:20:06 +0000533 .Cases("armv7r", "armv7-r", "cortex-r4")
534 .Cases("armv7m", "armv7-m", "cortex-m3")
535 .Case("ep9312", "ep9312")
536 .Case("iwmmxt", "iwmmxt")
537 .Case("xscale", "xscale")
538 .Cases("armv6m", "armv6-m", "cortex-m0")
539 // If all else failed, return the most base CPU LLVM supports.
540 .Default("arm7tdmi");
541}
542
Daniel Dunbard609b7b2009-11-17 06:37:03 +0000543// FIXME: Move to target hook.
544static bool isSignedCharDefault(const llvm::Triple &Triple) {
545 switch (Triple.getArch()) {
546 default:
547 return true;
548
Jim Grosbach7c2c6642011-05-24 15:40:46 +0000549 case llvm::Triple::arm:
Daniel Dunbard609b7b2009-11-17 06:37:03 +0000550 case llvm::Triple::ppc:
551 case llvm::Triple::ppc64:
Bob Wilson6524dd32011-10-14 05:03:44 +0000552 if (Triple.isOSDarwin())
Daniel Dunbard609b7b2009-11-17 06:37:03 +0000553 return true;
554 return false;
Daniel Dunbard609b7b2009-11-17 06:37:03 +0000555 }
556}
557
Chad Rosiercfbfc582012-04-04 20:51:35 +0000558// Handle -mfpu=.
559//
560// FIXME: Centralize feature selection, defaulting shouldn't be also in the
561// frontend target.
562static void addFPUArgs(const Driver &D, const Arg *A, const ArgList &Args,
563 ArgStringList &CmdArgs) {
Richard Smithbd55daf2012-11-01 04:30:05 +0000564 StringRef FPU = A->getValue();
Chad Rosiercfbfc582012-04-04 20:51:35 +0000565
566 // Set the target features based on the FPU.
567 if (FPU == "fpa" || FPU == "fpe2" || FPU == "fpe3" || FPU == "maverick") {
568 // Disable any default FPU support.
569 CmdArgs.push_back("-target-feature");
570 CmdArgs.push_back("-vfp2");
571 CmdArgs.push_back("-target-feature");
572 CmdArgs.push_back("-vfp3");
573 CmdArgs.push_back("-target-feature");
574 CmdArgs.push_back("-neon");
575 } else if (FPU == "vfp3-d16" || FPU == "vfpv3-d16") {
576 CmdArgs.push_back("-target-feature");
577 CmdArgs.push_back("+vfp3");
578 CmdArgs.push_back("-target-feature");
579 CmdArgs.push_back("+d16");
580 CmdArgs.push_back("-target-feature");
581 CmdArgs.push_back("-neon");
582 } else if (FPU == "vfp") {
583 CmdArgs.push_back("-target-feature");
584 CmdArgs.push_back("+vfp2");
585 CmdArgs.push_back("-target-feature");
586 CmdArgs.push_back("-neon");
587 } else if (FPU == "vfp3" || FPU == "vfpv3") {
588 CmdArgs.push_back("-target-feature");
589 CmdArgs.push_back("+vfp3");
590 CmdArgs.push_back("-target-feature");
591 CmdArgs.push_back("-neon");
592 } else if (FPU == "neon") {
593 CmdArgs.push_back("-target-feature");
594 CmdArgs.push_back("+neon");
595 } else
596 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
597}
598
Chad Rosier1f0e52e2012-04-04 20:39:32 +0000599// Handle -mfpmath=.
600static void addFPMathArgs(const Driver &D, const Arg *A, const ArgList &Args,
Chad Rosier45619cb2012-04-04 22:13:40 +0000601 ArgStringList &CmdArgs, StringRef CPU) {
Richard Smithbd55daf2012-11-01 04:30:05 +0000602 StringRef FPMath = A->getValue();
Chad Rosier1f0e52e2012-04-04 20:39:32 +0000603
604 // Set the target features based on the FPMath.
605 if (FPMath == "neon") {
606 CmdArgs.push_back("-target-feature");
607 CmdArgs.push_back("+neonfp");
Chad Rosier45619cb2012-04-04 22:13:40 +0000608
Silviu Baranga157f7c62012-09-13 15:06:00 +0000609 if (CPU != "cortex-a8" && CPU != "cortex-a9" && CPU != "cortex-a9-mp" &&
Quentin Colombet2e9952e2012-11-29 23:15:27 +0000610 CPU != "cortex-a15" && CPU != "cortex-a5")
Chad Rosier45619cb2012-04-04 22:13:40 +0000611 D.Diag(diag::err_drv_invalid_feature) << "-mfpmath=neon" << CPU;
612
Chad Rosier1f0e52e2012-04-04 20:39:32 +0000613 } else if (FPMath == "vfp" || FPMath == "vfp2" || FPMath == "vfp3" ||
614 FPMath == "vfp4") {
615 CmdArgs.push_back("-target-feature");
616 CmdArgs.push_back("-neonfp");
Chad Rosier45619cb2012-04-04 22:13:40 +0000617
618 // FIXME: Add warnings when disabling a feature not present for a given CPU.
Chad Rosier1f0e52e2012-04-04 20:39:32 +0000619 } else
620 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
621}
622
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000623// Select the float ABI as determined by -msoft-float, -mhard-float, and
624// -mfloat-abi=.
625static StringRef getARMFloatABI(const Driver &D,
626 const ArgList &Args,
627 const llvm::Triple &Triple) {
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000628 StringRef FloatABI;
Daniel Dunbar78485922009-09-10 23:00:09 +0000629 if (Arg *A = Args.getLastArg(options::OPT_msoft_float,
630 options::OPT_mhard_float,
631 options::OPT_mfloat_abi_EQ)) {
632 if (A->getOption().matches(options::OPT_msoft_float))
633 FloatABI = "soft";
634 else if (A->getOption().matches(options::OPT_mhard_float))
635 FloatABI = "hard";
636 else {
Richard Smithbd55daf2012-11-01 04:30:05 +0000637 FloatABI = A->getValue();
Daniel Dunbar78485922009-09-10 23:00:09 +0000638 if (FloatABI != "soft" && FloatABI != "softfp" && FloatABI != "hard") {
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000639 D.Diag(diag::err_drv_invalid_mfloat_abi)
Daniel Dunbar78485922009-09-10 23:00:09 +0000640 << A->getAsString(Args);
641 FloatABI = "soft";
642 }
643 }
644 }
645
646 // If unspecified, choose the default based on the platform.
647 if (FloatABI.empty()) {
Rafael Espindola0e1fb4f2010-06-28 17:18:09 +0000648 switch (Triple.getOS()) {
Bob Wilson6524dd32011-10-14 05:03:44 +0000649 case llvm::Triple::Darwin:
650 case llvm::Triple::MacOSX:
651 case llvm::Triple::IOS: {
Daniel Dunbar78485922009-09-10 23:00:09 +0000652 // Darwin defaults to "softfp" for v6 and v7.
653 //
654 // FIXME: Factor out an ARM class so we can cache the arch somewhere.
Benjamin Kramer09811c72012-06-26 22:20:06 +0000655 std::string ArchName =
Rafael Espindola0e1fb4f2010-06-28 17:18:09 +0000656 getLLVMArchSuffixForARM(getARMTargetCPU(Args, Triple));
Benjamin Kramer09811c72012-06-26 22:20:06 +0000657 if (StringRef(ArchName).startswith("v6") ||
658 StringRef(ArchName).startswith("v7"))
Daniel Dunbar78485922009-09-10 23:00:09 +0000659 FloatABI = "softfp";
660 else
661 FloatABI = "soft";
662 break;
663 }
664
665 default:
Bob Wilsond1447c42011-02-04 17:59:28 +0000666 switch(Triple.getEnvironment()) {
Jiangning Liu61b06cb2012-07-31 08:06:29 +0000667 case llvm::Triple::GNUEABIHF:
668 FloatABI = "hard";
669 break;
Bob Wilsond1447c42011-02-04 17:59:28 +0000670 case llvm::Triple::GNUEABI:
671 FloatABI = "softfp";
672 break;
673 case llvm::Triple::EABI:
674 // EABI is always AAPCS, and if it was not marked 'hard', it's softfp
675 FloatABI = "softfp";
676 break;
Logan Chienc6fd8202012-09-02 09:30:11 +0000677 case llvm::Triple::Android: {
Benjamin Kramer09811c72012-06-26 22:20:06 +0000678 std::string ArchName =
Chandler Carruthc89aa9d2012-01-10 19:47:42 +0000679 getLLVMArchSuffixForARM(getARMTargetCPU(Args, Triple));
Benjamin Kramer09811c72012-06-26 22:20:06 +0000680 if (StringRef(ArchName).startswith("v7"))
Chandler Carruthc89aa9d2012-01-10 19:47:42 +0000681 FloatABI = "softfp";
682 else
683 FloatABI = "soft";
684 break;
685 }
Bob Wilsond1447c42011-02-04 17:59:28 +0000686 default:
687 // Assume "soft", but warn the user we are guessing.
688 FloatABI = "soft";
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000689 D.Diag(diag::warn_drv_assuming_mfloat_abi_is) << "soft";
Bob Wilsond1447c42011-02-04 17:59:28 +0000690 break;
691 }
Daniel Dunbar78485922009-09-10 23:00:09 +0000692 }
693 }
694
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000695 return FloatABI;
696}
697
698
699void Clang::AddARMTargetArgs(const ArgList &Args,
700 ArgStringList &CmdArgs,
701 bool KernelOrKext) const {
702 const Driver &D = getToolChain().getDriver();
Daniel Dunbarbd847cc2012-10-15 22:23:53 +0000703 // Get the effective triple, which takes into account the deployment target.
704 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
705 llvm::Triple Triple(TripleStr);
Daniel Dunbar5f18f6e2012-10-22 18:30:51 +0000706 std::string CPUName = getARMTargetCPU(Args, Triple);
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000707
708 // Select the ABI to use.
709 //
710 // FIXME: Support -meabi.
711 const char *ABIName = 0;
712 if (Arg *A = Args.getLastArg(options::OPT_mabi_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +0000713 ABIName = A->getValue();
Daniel Dunbar5f18f6e2012-10-22 18:30:51 +0000714 } else if (Triple.isOSDarwin()) {
715 // The backend is hardwired to assume AAPCS for M-class processors, ensure
716 // the frontend matches that.
717 if (StringRef(CPUName).startswith("cortex-m")) {
718 ABIName = "aapcs";
719 } else {
720 ABIName = "apcs-gnu";
721 }
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000722 } else {
723 // Select the default based on the platform.
724 switch(Triple.getEnvironment()) {
Logan Chienc6fd8202012-09-02 09:30:11 +0000725 case llvm::Triple::Android:
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000726 case llvm::Triple::GNUEABI:
Jiangning Liu61b06cb2012-07-31 08:06:29 +0000727 case llvm::Triple::GNUEABIHF:
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000728 ABIName = "aapcs-linux";
729 break;
730 case llvm::Triple::EABI:
731 ABIName = "aapcs";
732 break;
733 default:
734 ABIName = "apcs-gnu";
735 }
736 }
737 CmdArgs.push_back("-target-abi");
738 CmdArgs.push_back(ABIName);
739
740 // Set the CPU based on -march= and -mcpu=.
741 CmdArgs.push_back("-target-cpu");
Daniel Dunbar5f18f6e2012-10-22 18:30:51 +0000742 CmdArgs.push_back(Args.MakeArgString(CPUName));
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000743
744 // Determine floating point ABI from the options & target defaults.
745 StringRef FloatABI = getARMFloatABI(D, Args, Triple);
Daniel Dunbar78485922009-09-10 23:00:09 +0000746 if (FloatABI == "soft") {
747 // Floating point operations and argument passing are soft.
748 //
749 // FIXME: This changes CPP defines, we need -target-soft-float.
Daniel Dunbara74f8ff2009-11-30 08:42:00 +0000750 CmdArgs.push_back("-msoft-float");
Daniel Dunbar6cc525b2009-12-08 19:49:51 +0000751 CmdArgs.push_back("-mfloat-abi");
752 CmdArgs.push_back("soft");
Daniel Dunbar78485922009-09-10 23:00:09 +0000753 } else if (FloatABI == "softfp") {
754 // Floating point operations are hard, but argument passing is soft.
Daniel Dunbar6cc525b2009-12-08 19:49:51 +0000755 CmdArgs.push_back("-mfloat-abi");
756 CmdArgs.push_back("soft");
Daniel Dunbar78485922009-09-10 23:00:09 +0000757 } else {
758 // Floating point operations and argument passing are hard.
759 assert(FloatABI == "hard" && "Invalid float abi!");
Daniel Dunbar6cc525b2009-12-08 19:49:51 +0000760 CmdArgs.push_back("-mfloat-abi");
761 CmdArgs.push_back("hard");
Daniel Dunbar78485922009-09-10 23:00:09 +0000762 }
Daniel Dunbar893d4752009-12-19 04:15:38 +0000763
764 // Set appropriate target features for floating point mode.
765 //
766 // FIXME: Note, this is a hack, the LLVM backend doesn't actually use these
767 // yet (it uses the -mfloat-abi and -msoft-float options above), and it is
768 // stripped out by the ARM target.
769
770 // Use software floating point operations?
771 if (FloatABI == "soft") {
772 CmdArgs.push_back("-target-feature");
773 CmdArgs.push_back("+soft-float");
774 }
775
776 // Use software floating point argument passing?
777 if (FloatABI != "hard") {
778 CmdArgs.push_back("-target-feature");
779 CmdArgs.push_back("+soft-float-abi");
780 }
Daniel Dunbar0def3d12009-12-21 23:28:17 +0000781
782 // Honor -mfpu=.
Chad Rosiercfbfc582012-04-04 20:51:35 +0000783 if (const Arg *A = Args.getLastArg(options::OPT_mfpu_EQ))
Chad Rosierd1717c12012-04-04 20:56:36 +0000784 addFPUArgs(D, A, Args, CmdArgs);
Daniel Dunbarb1db4b62011-03-17 00:07:34 +0000785
Chad Rosier1f0e52e2012-04-04 20:39:32 +0000786 // Honor -mfpmath=.
787 if (const Arg *A = Args.getLastArg(options::OPT_mfpmath_EQ))
Chad Rosier45619cb2012-04-04 22:13:40 +0000788 addFPMathArgs(D, A, Args, CmdArgs, getARMTargetCPU(Args, Triple));
Chad Rosier1f0e52e2012-04-04 20:39:32 +0000789
Daniel Dunbarb1db4b62011-03-17 00:07:34 +0000790 // Setting -msoft-float effectively disables NEON because of the GCC
791 // implementation, although the same isn't true of VFP or VFP3.
792 if (FloatABI == "soft") {
Daniel Dunbarc9388c12011-03-17 17:10:06 +0000793 CmdArgs.push_back("-target-feature");
794 CmdArgs.push_back("-neon");
795 }
796
797 // Kernel code has more strict alignment requirements.
798 if (KernelOrKext) {
Daniel Dunbarbd847cc2012-10-15 22:23:53 +0000799 if (Triple.getOS() != llvm::Triple::IOS || Triple.isOSVersionLT(6)) {
800 CmdArgs.push_back("-backend-option");
801 CmdArgs.push_back("-arm-long-calls");
802 }
Daniel Dunbarc9388c12011-03-17 17:10:06 +0000803
Daniel Dunbar12100e22011-03-22 16:48:17 +0000804 CmdArgs.push_back("-backend-option");
Daniel Dunbarc9388c12011-03-17 17:10:06 +0000805 CmdArgs.push_back("-arm-strict-align");
Daniel Dunbared904c82011-04-18 21:26:42 +0000806
807 // The kext linker doesn't know how to deal with movw/movt.
Daniel Dunbared904c82011-04-18 21:26:42 +0000808 CmdArgs.push_back("-backend-option");
809 CmdArgs.push_back("-arm-darwin-use-movt=0");
Daniel Dunbarb1db4b62011-03-17 00:07:34 +0000810 }
Chad Rosierba3df1d2011-08-26 00:26:29 +0000811
812 // Setting -mno-global-merge disables the codegen global merge pass. Setting
813 // -mglobal-merge has no effect as the pass is enabled by default.
814 if (Arg *A = Args.getLastArg(options::OPT_mglobal_merge,
815 options::OPT_mno_global_merge)) {
816 if (A->getOption().matches(options::OPT_mno_global_merge))
817 CmdArgs.push_back("-mno-global-merge");
818 }
Chad Rosierf1985d22012-05-16 20:40:09 +0000819
Chad Rosierc14ded72012-05-16 21:19:55 +0000820 if (Args.hasArg(options::OPT_mno_implicit_float))
Chad Rosierf1985d22012-05-16 20:40:09 +0000821 CmdArgs.push_back("-no-implicit-float");
Daniel Dunbar0f5c5422009-09-10 04:57:17 +0000822}
823
Simon Atanasyan2efe53e2012-09-21 20:19:32 +0000824// Translate MIPS CPU name alias option to CPU name.
825static StringRef getMipsCPUFromAlias(const Arg &A) {
826 if (A.getOption().matches(options::OPT_mips32))
827 return "mips32";
828 if (A.getOption().matches(options::OPT_mips32r2))
829 return "mips32r2";
830 if (A.getOption().matches(options::OPT_mips64))
831 return "mips64";
832 if (A.getOption().matches(options::OPT_mips64r2))
833 return "mips64r2";
834 llvm_unreachable("Unexpected option");
835 return "";
836}
837
Simon Atanasyan3b7589a2012-04-07 22:09:23 +0000838// Get CPU and ABI names. They are not independent
839// so we have to calculate them together.
840static void getMipsCPUAndABI(const ArgList &Args,
841 const ToolChain &TC,
842 StringRef &CPUName,
843 StringRef &ABIName) {
Simon Atanasyan464a7f72012-09-10 08:32:41 +0000844 const char *DefMips32CPU = "mips32";
845 const char *DefMips64CPU = "mips64";
Akira Hatanaka37fd9e92011-09-26 21:07:52 +0000846
Simon Atanasyan464a7f72012-09-10 08:32:41 +0000847 if (Arg *A = Args.getLastArg(options::OPT_march_EQ,
Simon Atanasyan2efe53e2012-09-21 20:19:32 +0000848 options::OPT_mcpu_EQ,
849 options::OPT_mips_CPUs_Group)) {
850 if (A->getOption().matches(options::OPT_mips_CPUs_Group))
851 CPUName = getMipsCPUFromAlias(*A);
852 else
Richard Smithbd55daf2012-11-01 04:30:05 +0000853 CPUName = A->getValue();
Simon Atanasyan2efe53e2012-09-21 20:19:32 +0000854 }
Simon Atanasyan464a7f72012-09-10 08:32:41 +0000855
Akira Hatanaka37fd9e92011-09-26 21:07:52 +0000856 if (Arg *A = Args.getLastArg(options::OPT_mabi_EQ))
Richard Smithbd55daf2012-11-01 04:30:05 +0000857 ABIName = A->getValue();
Simon Atanasyan464a7f72012-09-10 08:32:41 +0000858
859 // Setup default CPU and ABI names.
860 if (CPUName.empty() && ABIName.empty()) {
861 switch (TC.getTriple().getArch()) {
862 default:
863 llvm_unreachable("Unexpected triple arch name");
864 case llvm::Triple::mips:
865 case llvm::Triple::mipsel:
866 CPUName = DefMips32CPU;
867 break;
868 case llvm::Triple::mips64:
869 case llvm::Triple::mips64el:
870 CPUName = DefMips64CPU;
871 break;
872 }
873 }
874
875 if (!ABIName.empty()) {
876 // Deduce CPU name from ABI name.
877 CPUName = llvm::StringSwitch<const char *>(ABIName)
878 .Cases("o32", "eabi", DefMips32CPU)
879 .Cases("n32", "n64", DefMips64CPU)
880 .Default("");
881 }
882 else if (!CPUName.empty()) {
883 // Deduce ABI name from CPU name.
884 ABIName = llvm::StringSwitch<const char *>(CPUName)
885 .Cases("mips32", "mips32r2", "o32")
886 .Cases("mips64", "mips64r2", "n64")
887 .Default("");
888 }
889
890 // FIXME: Warn on inconsistent cpu and abi usage.
Simon Atanasyan3b7589a2012-04-07 22:09:23 +0000891}
892
Simon Atanasyan590ad8f2012-06-02 15:06:29 +0000893// Select the MIPS float ABI as determined by -msoft-float, -mhard-float,
894// and -mfloat-abi=.
895static StringRef getMipsFloatABI(const Driver &D, const ArgList &Args) {
Akira Hatanaka6976ec82012-03-23 23:07:09 +0000896 // Select the float ABI as determined by -msoft-float, -mhard-float,
897 // and -mfloat-abi=.
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000898 StringRef FloatABI;
Eric Christopher0b26a612010-03-02 02:41:08 +0000899 if (Arg *A = Args.getLastArg(options::OPT_msoft_float,
Akira Hatanaka6976ec82012-03-23 23:07:09 +0000900 options::OPT_mhard_float,
901 options::OPT_mfloat_abi_EQ)) {
Eric Christopher0b26a612010-03-02 02:41:08 +0000902 if (A->getOption().matches(options::OPT_msoft_float))
903 FloatABI = "soft";
904 else if (A->getOption().matches(options::OPT_mhard_float))
905 FloatABI = "hard";
Akira Hatanaka6976ec82012-03-23 23:07:09 +0000906 else {
Richard Smithbd55daf2012-11-01 04:30:05 +0000907 FloatABI = A->getValue();
Akira Hatanaka6976ec82012-03-23 23:07:09 +0000908 if (FloatABI != "soft" && FloatABI != "single" && FloatABI != "hard") {
Simon Atanasyan590ad8f2012-06-02 15:06:29 +0000909 D.Diag(diag::err_drv_invalid_mfloat_abi) << A->getAsString(Args);
Akira Hatanaka6976ec82012-03-23 23:07:09 +0000910 FloatABI = "hard";
911 }
912 }
Eric Christopher0b26a612010-03-02 02:41:08 +0000913 }
914
915 // If unspecified, choose the default based on the platform.
916 if (FloatABI.empty()) {
Akira Hatanaka6976ec82012-03-23 23:07:09 +0000917 // Assume "hard", because it's a default value used by gcc.
918 // When we start to recognize specific target MIPS processors,
919 // we will be able to select the default more correctly.
920 FloatABI = "hard";
Eric Christopher0b26a612010-03-02 02:41:08 +0000921 }
922
Simon Atanasyan590ad8f2012-06-02 15:06:29 +0000923 return FloatABI;
924}
925
Simon Atanasyan9b1932d2012-07-05 18:51:43 +0000926static void AddTargetFeature(const ArgList &Args,
927 ArgStringList &CmdArgs,
928 OptSpecifier OnOpt,
929 OptSpecifier OffOpt,
930 StringRef FeatureName) {
931 if (Arg *A = Args.getLastArg(OnOpt, OffOpt)) {
932 CmdArgs.push_back("-target-feature");
933 if (A->getOption().matches(OnOpt))
934 CmdArgs.push_back(Args.MakeArgString("+" + FeatureName));
935 else
936 CmdArgs.push_back(Args.MakeArgString("-" + FeatureName));
937 }
938}
939
Simon Atanasyan590ad8f2012-06-02 15:06:29 +0000940void Clang::AddMIPSTargetArgs(const ArgList &Args,
941 ArgStringList &CmdArgs) const {
942 const Driver &D = getToolChain().getDriver();
943 StringRef CPUName;
944 StringRef ABIName;
945 getMipsCPUAndABI(Args, getToolChain(), CPUName, ABIName);
946
947 CmdArgs.push_back("-target-cpu");
948 CmdArgs.push_back(CPUName.data());
949
950 CmdArgs.push_back("-target-abi");
951 CmdArgs.push_back(ABIName.data());
952
953 StringRef FloatABI = getMipsFloatABI(D, Args);
954
Eric Christopher0b26a612010-03-02 02:41:08 +0000955 if (FloatABI == "soft") {
956 // Floating point operations and argument passing are soft.
Eric Christopher0b26a612010-03-02 02:41:08 +0000957 CmdArgs.push_back("-msoft-float");
Akira Hatanaka6976ec82012-03-23 23:07:09 +0000958 CmdArgs.push_back("-mfloat-abi");
959 CmdArgs.push_back("soft");
960
961 // FIXME: Note, this is a hack. We need to pass the selected float
962 // mode to the MipsTargetInfoBase to define appropriate macros there.
963 // Now it is the only method.
964 CmdArgs.push_back("-target-feature");
965 CmdArgs.push_back("+soft-float");
966 }
967 else if (FloatABI == "single") {
968 // Restrict the use of hardware floating-point
969 // instructions to 32-bit operations.
970 CmdArgs.push_back("-target-feature");
971 CmdArgs.push_back("+single-float");
972 }
973 else {
974 // Floating point operations and argument passing are hard.
Eric Christopher0b26a612010-03-02 02:41:08 +0000975 assert(FloatABI == "hard" && "Invalid float abi!");
Akira Hatanaka6976ec82012-03-23 23:07:09 +0000976 CmdArgs.push_back("-mfloat-abi");
977 CmdArgs.push_back("hard");
Eric Christopher0b26a612010-03-02 02:41:08 +0000978 }
Simon Atanasyan6f23fa02012-07-05 14:19:39 +0000979
Simon Atanasyan9b1932d2012-07-05 18:51:43 +0000980 AddTargetFeature(Args, CmdArgs,
981 options::OPT_mips16, options::OPT_mno_mips16,
982 "mips16");
Simon Atanasyan9c6f1f72012-07-05 19:23:00 +0000983 AddTargetFeature(Args, CmdArgs,
984 options::OPT_mdsp, options::OPT_mno_dsp,
985 "dsp");
986 AddTargetFeature(Args, CmdArgs,
987 options::OPT_mdspr2, options::OPT_mno_dspr2,
988 "dspr2");
Simon Atanasyanec4b1c12012-08-27 20:55:56 +0000989
Simon Atanasyan2eaec512012-12-01 18:27:21 +0000990 if (Arg *A = Args.getLastArg(options::OPT_mxgot, options::OPT_mno_xgot)) {
991 if (A->getOption().matches(options::OPT_mxgot)) {
992 CmdArgs.push_back("-mllvm");
993 CmdArgs.push_back("-mxgot");
994 }
995 }
996
Simon Atanasyanec4b1c12012-08-27 20:55:56 +0000997 if (Arg *A = Args.getLastArg(options::OPT_G)) {
Richard Smithbd55daf2012-11-01 04:30:05 +0000998 StringRef v = A->getValue();
Simon Atanasyanec4b1c12012-08-27 20:55:56 +0000999 CmdArgs.push_back("-mllvm");
1000 CmdArgs.push_back(Args.MakeArgString("-mips-ssection-threshold=" + v));
1001 A->claim();
1002 }
Eric Christopher0b26a612010-03-02 02:41:08 +00001003}
1004
Hal Finkel8eb59282012-06-11 22:35:19 +00001005/// getPPCTargetCPU - Get the (LLVM) name of the PowerPC cpu we are targeting.
1006static std::string getPPCTargetCPU(const ArgList &Args) {
1007 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00001008 StringRef CPUName = A->getValue();
Hal Finkel8eb59282012-06-11 22:35:19 +00001009
1010 if (CPUName == "native") {
1011 std::string CPU = llvm::sys::getHostCPUName();
1012 if (!CPU.empty() && CPU != "generic")
1013 return CPU;
1014 else
1015 return "";
1016 }
1017
1018 return llvm::StringSwitch<const char *>(CPUName)
1019 .Case("common", "generic")
1020 .Case("440", "440")
1021 .Case("440fp", "440")
1022 .Case("450", "450")
1023 .Case("601", "601")
1024 .Case("602", "602")
1025 .Case("603", "603")
1026 .Case("603e", "603e")
1027 .Case("603ev", "603ev")
1028 .Case("604", "604")
1029 .Case("604e", "604e")
1030 .Case("620", "620")
1031 .Case("G3", "g3")
1032 .Case("7400", "7400")
1033 .Case("G4", "g4")
1034 .Case("7450", "7450")
1035 .Case("G4+", "g4+")
1036 .Case("750", "750")
1037 .Case("970", "970")
1038 .Case("G5", "g5")
1039 .Case("a2", "a2")
Hal Finkelf6d6cb02012-09-18 22:25:03 +00001040 .Case("e500mc", "e500mc")
1041 .Case("e5500", "e5500")
Hal Finkel8eb59282012-06-11 22:35:19 +00001042 .Case("power6", "pwr6")
1043 .Case("power7", "pwr7")
1044 .Case("powerpc", "ppc")
1045 .Case("powerpc64", "ppc64")
1046 .Default("");
1047 }
1048
1049 return "";
1050}
1051
1052void Clang::AddPPCTargetArgs(const ArgList &Args,
1053 ArgStringList &CmdArgs) const {
1054 std::string TargetCPUName = getPPCTargetCPU(Args);
1055
1056 // LLVM may default to generating code for the native CPU,
1057 // but, like gcc, we default to a more generic option for
1058 // each architecture. (except on Darwin)
1059 llvm::Triple Triple = getToolChain().getTriple();
1060 if (TargetCPUName.empty() && !Triple.isOSDarwin()) {
1061 if (Triple.getArch() == llvm::Triple::ppc64)
1062 TargetCPUName = "ppc64";
1063 else
1064 TargetCPUName = "ppc";
1065 }
1066
1067 if (!TargetCPUName.empty()) {
1068 CmdArgs.push_back("-target-cpu");
1069 CmdArgs.push_back(Args.MakeArgString(TargetCPUName.c_str()));
1070 }
1071}
1072
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001073void Clang::AddSparcTargetArgs(const ArgList &Args,
1074 ArgStringList &CmdArgs) const {
1075 const Driver &D = getToolChain().getDriver();
1076
1077 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ)) {
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001078 CmdArgs.push_back("-target-cpu");
Richard Smithbd55daf2012-11-01 04:30:05 +00001079 CmdArgs.push_back(A->getValue());
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001080 }
1081
1082 // Select the float ABI as determined by -msoft-float, -mhard-float, and
Chris Lattner0e62c1c2011-07-23 10:55:15 +00001083 StringRef FloatABI;
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001084 if (Arg *A = Args.getLastArg(options::OPT_msoft_float,
1085 options::OPT_mhard_float)) {
1086 if (A->getOption().matches(options::OPT_msoft_float))
1087 FloatABI = "soft";
1088 else if (A->getOption().matches(options::OPT_mhard_float))
1089 FloatABI = "hard";
1090 }
1091
1092 // If unspecified, choose the default based on the platform.
1093 if (FloatABI.empty()) {
1094 switch (getToolChain().getTriple().getOS()) {
1095 default:
1096 // Assume "soft", but warn the user we are guessing.
1097 FloatABI = "soft";
Chris Lattner0e62c1c2011-07-23 10:55:15 +00001098 D.Diag(diag::warn_drv_assuming_mfloat_abi_is) << "soft";
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001099 break;
1100 }
1101 }
1102
1103 if (FloatABI == "soft") {
1104 // Floating point operations and argument passing are soft.
1105 //
1106 // FIXME: This changes CPP defines, we need -target-soft-float.
1107 CmdArgs.push_back("-msoft-float");
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001108 CmdArgs.push_back("-target-feature");
1109 CmdArgs.push_back("+soft-float");
1110 } else {
1111 assert(FloatABI == "hard" && "Invalid float abi!");
1112 CmdArgs.push_back("-mhard-float");
1113 }
1114}
1115
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00001116void Clang::AddX86TargetArgs(const ArgList &Args,
1117 ArgStringList &CmdArgs) const {
Rafael Espindola7df35012012-11-02 20:41:30 +00001118 const bool isAndroid =
1119 getToolChain().getTriple().getEnvironment() == llvm::Triple::Android;
Daniel Dunbare2cf8f72009-09-10 22:59:57 +00001120 if (!Args.hasFlag(options::OPT_mred_zone,
1121 options::OPT_mno_red_zone,
1122 true) ||
1123 Args.hasArg(options::OPT_mkernel) ||
1124 Args.hasArg(options::OPT_fapple_kext))
Daniel Dunbar8bed86c2009-11-20 22:21:36 +00001125 CmdArgs.push_back("-disable-red-zone");
Daniel Dunbare2cf8f72009-09-10 22:59:57 +00001126
Daniel Dunbare2cf8f72009-09-10 22:59:57 +00001127 if (Args.hasFlag(options::OPT_msoft_float,
1128 options::OPT_mno_soft_float,
1129 false))
Daniel Dunbar8bed86c2009-11-20 22:21:36 +00001130 CmdArgs.push_back("-no-implicit-float");
Daniel Dunbare2cf8f72009-09-10 22:59:57 +00001131
Daniel Dunbare13ada62009-11-14 22:04:54 +00001132 const char *CPUName = 0;
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00001133 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00001134 if (StringRef(A->getValue()) == "native") {
Daniel Dunbare13ada62009-11-14 22:04:54 +00001135 // FIXME: Reject attempts to use -march=native unless the target matches
1136 // the host.
1137 //
1138 // FIXME: We should also incorporate the detected target features for use
1139 // with -native.
1140 std::string CPU = llvm::sys::getHostCPUName();
Bob Wilsone78227b2012-05-09 17:53:10 +00001141 if (!CPU.empty() && CPU != "generic")
Daniel Dunbare13ada62009-11-14 22:04:54 +00001142 CPUName = Args.MakeArgString(CPU);
1143 } else
Richard Smithbd55daf2012-11-01 04:30:05 +00001144 CPUName = A->getValue();
Daniel Dunbare13ada62009-11-14 22:04:54 +00001145 }
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00001146
Daniel Dunbare13ada62009-11-14 22:04:54 +00001147 // Select the default CPU if none was given (or detection failed).
1148 if (!CPUName) {
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00001149 // FIXME: Need target hooks.
Bob Wilson6524dd32011-10-14 05:03:44 +00001150 if (getToolChain().getTriple().isOSDarwin()) {
Daniel Dunbar116b3052011-05-31 15:58:55 +00001151 if (getToolChain().getArch() == llvm::Triple::x86_64)
Daniel Dunbare13ada62009-11-14 22:04:54 +00001152 CPUName = "core2";
Daniel Dunbar116b3052011-05-31 15:58:55 +00001153 else if (getToolChain().getArch() == llvm::Triple::x86)
Daniel Dunbare13ada62009-11-14 22:04:54 +00001154 CPUName = "yonah";
Chris Lattnerb986aba2010-04-11 19:29:39 +00001155 } else if (getToolChain().getOS().startswith("haiku")) {
Daniel Dunbar116b3052011-05-31 15:58:55 +00001156 if (getToolChain().getArch() == llvm::Triple::x86_64)
Chris Lattnerb986aba2010-04-11 19:29:39 +00001157 CPUName = "x86-64";
Daniel Dunbar116b3052011-05-31 15:58:55 +00001158 else if (getToolChain().getArch() == llvm::Triple::x86)
Chris Lattnerb986aba2010-04-11 19:29:39 +00001159 CPUName = "i586";
Daniel Dunbarea3813f2010-08-01 23:13:54 +00001160 } else if (getToolChain().getOS().startswith("openbsd")) {
Daniel Dunbar116b3052011-05-31 15:58:55 +00001161 if (getToolChain().getArch() == llvm::Triple::x86_64)
Daniel Dunbarea3813f2010-08-01 23:13:54 +00001162 CPUName = "x86-64";
Daniel Dunbar116b3052011-05-31 15:58:55 +00001163 else if (getToolChain().getArch() == llvm::Triple::x86)
Daniel Dunbarea3813f2010-08-01 23:13:54 +00001164 CPUName = "i486";
Eli Friedman9fa28852012-08-08 23:57:20 +00001165 } else if (getToolChain().getOS().startswith("bitrig")) {
1166 if (getToolChain().getArch() == llvm::Triple::x86_64)
1167 CPUName = "x86-64";
1168 else if (getToolChain().getArch() == llvm::Triple::x86)
1169 CPUName = "i686";
Roman Divacky432f10d2011-03-01 18:11:37 +00001170 } else if (getToolChain().getOS().startswith("freebsd")) {
Daniel Dunbar116b3052011-05-31 15:58:55 +00001171 if (getToolChain().getArch() == llvm::Triple::x86_64)
Roman Divacky432f10d2011-03-01 18:11:37 +00001172 CPUName = "x86-64";
Daniel Dunbar116b3052011-05-31 15:58:55 +00001173 else if (getToolChain().getArch() == llvm::Triple::x86)
Roman Divacky432f10d2011-03-01 18:11:37 +00001174 CPUName = "i486";
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00001175 } else if (getToolChain().getOS().startswith("netbsd")) {
Daniel Dunbar116b3052011-05-31 15:58:55 +00001176 if (getToolChain().getArch() == llvm::Triple::x86_64)
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00001177 CPUName = "x86-64";
Daniel Dunbar116b3052011-05-31 15:58:55 +00001178 else if (getToolChain().getArch() == llvm::Triple::x86)
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00001179 CPUName = "i486";
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00001180 } else {
Daniel Dunbar116b3052011-05-31 15:58:55 +00001181 if (getToolChain().getArch() == llvm::Triple::x86_64)
Daniel Dunbare13ada62009-11-14 22:04:54 +00001182 CPUName = "x86-64";
Daniel Dunbar116b3052011-05-31 15:58:55 +00001183 else if (getToolChain().getArch() == llvm::Triple::x86)
Rafael Espindola7df35012012-11-02 20:41:30 +00001184 // All x86 devices running Android have core2 as their common
1185 // denominator. This makes a better choice than pentium4.
1186 CPUName = isAndroid ? "core2" : "pentium4";
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00001187 }
1188 }
1189
Daniel Dunbare13ada62009-11-14 22:04:54 +00001190 if (CPUName) {
Daniel Dunbara7d02312009-12-18 06:30:12 +00001191 CmdArgs.push_back("-target-cpu");
Daniel Dunbare13ada62009-11-14 22:04:54 +00001192 CmdArgs.push_back(CPUName);
1193 }
1194
Eli Friedmanad811f02011-07-02 00:34:19 +00001195 // The required algorithm here is slightly strange: the options are applied
1196 // in order (so -mno-sse -msse2 disables SSE3), but any option that gets
1197 // directly overridden later is ignored (so "-mno-sse -msse2 -mno-sse2 -msse"
1198 // is equivalent to "-mno-sse2 -msse"). The -cc1 handling deals with the
1199 // former correctly, but not the latter; handle directly-overridden
1200 // attributes here.
1201 llvm::StringMap<unsigned> PrevFeature;
1202 std::vector<const char*> Features;
Daniel Dunbar44b36ee2009-11-25 11:53:23 +00001203 for (arg_iterator it = Args.filtered_begin(options::OPT_m_x86_Features_Group),
1204 ie = Args.filtered_end(); it != ie; ++it) {
Chris Lattner0e62c1c2011-07-23 10:55:15 +00001205 StringRef Name = (*it)->getOption().getName();
Daniel Dunbara442fd52010-06-11 22:00:13 +00001206 (*it)->claim();
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00001207
Daniel Dunbar44b36ee2009-11-25 11:53:23 +00001208 // Skip over "-m".
Michael J. Spencer929fccd2012-10-22 22:13:48 +00001209 assert(Name.startswith("m") && "Invalid feature name.");
1210 Name = Name.substr(1);
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00001211
Daniel Dunbar44b36ee2009-11-25 11:53:23 +00001212 bool IsNegative = Name.startswith("no-");
1213 if (IsNegative)
1214 Name = Name.substr(3);
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00001215
Eli Friedmanad811f02011-07-02 00:34:19 +00001216 unsigned& Prev = PrevFeature[Name];
1217 if (Prev)
1218 Features[Prev - 1] = 0;
1219 Prev = Features.size() + 1;
1220 Features.push_back(Args.MakeArgString((IsNegative ? "-" : "+") + Name));
1221 }
1222 for (unsigned i = 0; i < Features.size(); i++) {
1223 if (Features[i]) {
1224 CmdArgs.push_back("-target-feature");
1225 CmdArgs.push_back(Features[i]);
1226 }
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00001227 }
1228}
1229
Tony Linthicum76329bf2011-12-12 21:14:55 +00001230static Arg* getLastHexagonArchArg (const ArgList &Args)
1231{
1232 Arg * A = NULL;
1233
Sebastian Pop86500282012-01-13 20:37:10 +00001234 for (ArgList::const_iterator it = Args.begin(), ie = Args.end();
1235 it != ie; ++it) {
1236 if ((*it)->getOption().matches(options::OPT_march_EQ) ||
Tony Linthicum76329bf2011-12-12 21:14:55 +00001237 (*it)->getOption().matches(options::OPT_mcpu_EQ)) {
1238 A = *it;
1239 A->claim();
1240 }
Sebastian Pop86500282012-01-13 20:37:10 +00001241 else if ((*it)->getOption().matches(options::OPT_m_Joined)){
Richard Smithbd55daf2012-11-01 04:30:05 +00001242 StringRef Value = (*it)->getValue(0);
Sebastian Pop86500282012-01-13 20:37:10 +00001243 if (Value.startswith("v")) {
1244 A = *it;
1245 A->claim();
1246 }
1247 }
Tony Linthicum76329bf2011-12-12 21:14:55 +00001248 }
1249 return A;
1250}
1251
Sebastian Pop86500282012-01-13 20:37:10 +00001252static StringRef getHexagonTargetCPU(const ArgList &Args)
Tony Linthicum76329bf2011-12-12 21:14:55 +00001253{
1254 Arg *A;
1255 llvm::StringRef WhichHexagon;
1256
Sebastian Pop86500282012-01-13 20:37:10 +00001257 // Select the default CPU (v4) if none was given or detection failed.
Tony Linthicum76329bf2011-12-12 21:14:55 +00001258 if ((A = getLastHexagonArchArg (Args))) {
Richard Smithbd55daf2012-11-01 04:30:05 +00001259 WhichHexagon = A->getValue();
Sebastian Pop86500282012-01-13 20:37:10 +00001260 if (WhichHexagon == "")
1261 return "v4";
1262 else
1263 return WhichHexagon;
Tony Linthicum76329bf2011-12-12 21:14:55 +00001264 }
Sebastian Pop86500282012-01-13 20:37:10 +00001265 else
1266 return "v4";
Tony Linthicum76329bf2011-12-12 21:14:55 +00001267}
1268
1269void Clang::AddHexagonTargetArgs(const ArgList &Args,
1270 ArgStringList &CmdArgs) const {
1271 llvm::Triple Triple = getToolChain().getTriple();
1272
1273 CmdArgs.push_back("-target-cpu");
Sebastian Pop86500282012-01-13 20:37:10 +00001274 CmdArgs.push_back(Args.MakeArgString("hexagon" + getHexagonTargetCPU(Args)));
Tony Linthicum76329bf2011-12-12 21:14:55 +00001275 CmdArgs.push_back("-fno-signed-char");
1276 CmdArgs.push_back("-nobuiltininc");
1277
Sirish Pande11ebc4e2012-05-10 20:19:54 +00001278 if (Args.hasArg(options::OPT_mqdsp6_compat))
Tony Linthicum76329bf2011-12-12 21:14:55 +00001279 CmdArgs.push_back("-mqdsp6-compat");
1280
1281 if (Arg *A = Args.getLastArg(options::OPT_G,
1282 options::OPT_msmall_data_threshold_EQ)) {
1283 std::string SmallDataThreshold="-small-data-threshold=";
Richard Smithbd55daf2012-11-01 04:30:05 +00001284 SmallDataThreshold += A->getValue();
Tony Linthicum76329bf2011-12-12 21:14:55 +00001285 CmdArgs.push_back ("-mllvm");
1286 CmdArgs.push_back(Args.MakeArgString(SmallDataThreshold));
1287 A->claim();
1288 }
1289
Sirish Pande11ebc4e2012-05-10 20:19:54 +00001290 if (!Args.hasArg(options::OPT_fno_short_enums))
1291 CmdArgs.push_back("-fshort-enums");
1292 if (Args.getLastArg(options::OPT_mieee_rnd_near)) {
1293 CmdArgs.push_back ("-mllvm");
1294 CmdArgs.push_back ("-enable-hexagon-ieee-rnd-near");
1295 }
Tony Linthicum76329bf2011-12-12 21:14:55 +00001296 CmdArgs.push_back ("-mllvm");
1297 CmdArgs.push_back ("-machine-sink-split=0");
1298}
1299
Eric Christopher84fbdb42011-08-19 00:30:14 +00001300static bool
John McCall5fb5df92012-06-20 06:18:46 +00001301shouldUseExceptionTablesForObjCExceptions(const ObjCRuntime &runtime,
Anders Carlsson246ff3f2011-02-28 00:44:51 +00001302 const llvm::Triple &Triple) {
1303 // We use the zero-cost exception tables for Objective-C if the non-fragile
1304 // ABI is enabled or when compiling for x86_64 and ARM on Snow Leopard and
1305 // later.
John McCall5fb5df92012-06-20 06:18:46 +00001306 if (runtime.isNonFragile())
Anders Carlsson246ff3f2011-02-28 00:44:51 +00001307 return true;
1308
Bob Wilson6524dd32011-10-14 05:03:44 +00001309 if (!Triple.isOSDarwin())
Anders Carlsson246ff3f2011-02-28 00:44:51 +00001310 return false;
1311
Eric Christopherbf15d2b2011-07-02 00:20:22 +00001312 return (!Triple.isMacOSXVersionLT(10,5) &&
Anders Carlsson246ff3f2011-02-28 00:44:51 +00001313 (Triple.getArch() == llvm::Triple::x86_64 ||
Eric Christopher84fbdb42011-08-19 00:30:14 +00001314 Triple.getArch() == llvm::Triple::arm));
Anders Carlsson246ff3f2011-02-28 00:44:51 +00001315}
1316
Anders Carlssone96ab552011-02-28 02:27:16 +00001317/// addExceptionArgs - Adds exception related arguments to the driver command
1318/// arguments. There's a master flag, -fexceptions and also language specific
1319/// flags to enable/disable C++ and Objective-C exceptions.
1320/// This makes it possible to for example disable C++ exceptions but enable
1321/// Objective-C exceptions.
1322static void addExceptionArgs(const ArgList &Args, types::ID InputType,
1323 const llvm::Triple &Triple,
Fariborz Jahanianb2482212012-04-04 18:28:00 +00001324 bool KernelOrKext,
John McCall5fb5df92012-06-20 06:18:46 +00001325 const ObjCRuntime &objcRuntime,
Anders Carlssone96ab552011-02-28 02:27:16 +00001326 ArgStringList &CmdArgs) {
Chad Rosier4fab82c2012-03-26 22:04:46 +00001327 if (KernelOrKext) {
1328 // -mkernel and -fapple-kext imply no exceptions, so claim exception related
1329 // arguments now to avoid warnings about unused arguments.
1330 Args.ClaimAllArgs(options::OPT_fexceptions);
1331 Args.ClaimAllArgs(options::OPT_fno_exceptions);
1332 Args.ClaimAllArgs(options::OPT_fobjc_exceptions);
1333 Args.ClaimAllArgs(options::OPT_fno_objc_exceptions);
1334 Args.ClaimAllArgs(options::OPT_fcxx_exceptions);
1335 Args.ClaimAllArgs(options::OPT_fno_cxx_exceptions);
Anders Carlssone96ab552011-02-28 02:27:16 +00001336 return;
Chad Rosier4fab82c2012-03-26 22:04:46 +00001337 }
Anders Carlssone96ab552011-02-28 02:27:16 +00001338
1339 // Exceptions are enabled by default.
1340 bool ExceptionsEnabled = true;
1341
1342 // This keeps track of whether exceptions were explicitly turned on or off.
1343 bool DidHaveExplicitExceptionFlag = false;
1344
Rafael Espindola00a66572009-10-01 13:33:33 +00001345 if (Arg *A = Args.getLastArg(options::OPT_fexceptions,
1346 options::OPT_fno_exceptions)) {
1347 if (A->getOption().matches(options::OPT_fexceptions))
Anders Carlssone96ab552011-02-28 02:27:16 +00001348 ExceptionsEnabled = true;
Eric Christopher84fbdb42011-08-19 00:30:14 +00001349 else
Anders Carlssone96ab552011-02-28 02:27:16 +00001350 ExceptionsEnabled = false;
1351
1352 DidHaveExplicitExceptionFlag = true;
Rafael Espindola00a66572009-10-01 13:33:33 +00001353 }
Daniel Dunbar30a12b82010-09-14 23:12:31 +00001354
Anders Carlssone96ab552011-02-28 02:27:16 +00001355 bool ShouldUseExceptionTables = false;
Fariborz Jahaniane4b21ab2009-10-01 20:30:46 +00001356
Anders Carlssone96ab552011-02-28 02:27:16 +00001357 // Exception tables and cleanups can be enabled with -fexceptions even if the
1358 // language itself doesn't support exceptions.
1359 if (ExceptionsEnabled && DidHaveExplicitExceptionFlag)
1360 ShouldUseExceptionTables = true;
Daniel Dunbar30a12b82010-09-14 23:12:31 +00001361
Daniel Dunbarc44f8cf2011-03-17 23:28:31 +00001362 // Obj-C exceptions are enabled by default, regardless of -fexceptions. This
1363 // is not necessarily sensible, but follows GCC.
1364 if (types::isObjC(InputType) &&
Eric Christopher84fbdb42011-08-19 00:30:14 +00001365 Args.hasFlag(options::OPT_fobjc_exceptions,
Daniel Dunbarc44f8cf2011-03-17 23:28:31 +00001366 options::OPT_fno_objc_exceptions,
1367 true)) {
1368 CmdArgs.push_back("-fobjc-exceptions");
Anders Carlssone96ab552011-02-28 02:27:16 +00001369
Eric Christopher84fbdb42011-08-19 00:30:14 +00001370 ShouldUseExceptionTables |=
John McCall5fb5df92012-06-20 06:18:46 +00001371 shouldUseExceptionTablesForObjCExceptions(objcRuntime, Triple);
Anders Carlssone96ab552011-02-28 02:27:16 +00001372 }
1373
1374 if (types::isCXX(InputType)) {
1375 bool CXXExceptionsEnabled = ExceptionsEnabled;
1376
Eric Christopher84fbdb42011-08-19 00:30:14 +00001377 if (Arg *A = Args.getLastArg(options::OPT_fcxx_exceptions,
1378 options::OPT_fno_cxx_exceptions,
Anders Carlssone96ab552011-02-28 02:27:16 +00001379 options::OPT_fexceptions,
1380 options::OPT_fno_exceptions)) {
1381 if (A->getOption().matches(options::OPT_fcxx_exceptions))
1382 CXXExceptionsEnabled = true;
Chandler Carruth74f87112011-02-28 07:25:18 +00001383 else if (A->getOption().matches(options::OPT_fno_cxx_exceptions))
Anders Carlssone96ab552011-02-28 02:27:16 +00001384 CXXExceptionsEnabled = false;
1385 }
1386
1387 if (CXXExceptionsEnabled) {
1388 CmdArgs.push_back("-fcxx-exceptions");
1389
1390 ShouldUseExceptionTables = true;
1391 }
1392 }
1393
1394 if (ShouldUseExceptionTables)
1395 CmdArgs.push_back("-fexceptions");
Rafael Espindola00a66572009-10-01 13:33:33 +00001396}
1397
Rafael Espindola4cfa7972011-05-02 17:43:32 +00001398static bool ShouldDisableCFI(const ArgList &Args,
1399 const ToolChain &TC) {
Rafael Espindolac41db922012-03-08 14:39:55 +00001400 bool Default = true;
Bob Wilson6524dd32011-10-14 05:03:44 +00001401 if (TC.getTriple().isOSDarwin()) {
Rafael Espindolaf934f982011-05-17 16:26:17 +00001402 // The native darwin assembler doesn't support cfi directives, so
Rafael Espindola35ab91c2011-05-17 19:06:58 +00001403 // we disable them if we think the .s file will be passed to it.
Rafael Espindolac41db922012-03-08 14:39:55 +00001404 Default = Args.hasFlag(options::OPT_integrated_as,
1405 options::OPT_no_integrated_as,
1406 TC.IsIntegratedAssemblerDefault());
Rafael Espindolaf934f982011-05-17 16:26:17 +00001407 }
Rafael Espindolac41db922012-03-08 14:39:55 +00001408 return !Args.hasFlag(options::OPT_fdwarf2_cfi_asm,
1409 options::OPT_fno_dwarf2_cfi_asm,
1410 Default);
Rafael Espindola4cfa7972011-05-02 17:43:32 +00001411}
1412
Nick Lewycky1d617ac2011-10-17 23:05:52 +00001413static bool ShouldDisableDwarfDirectory(const ArgList &Args,
1414 const ToolChain &TC) {
1415 bool IsIADefault = TC.IsIntegratedAssemblerDefault();
1416 bool UseIntegratedAs = Args.hasFlag(options::OPT_integrated_as,
1417 options::OPT_no_integrated_as,
1418 IsIADefault);
1419 bool UseDwarfDirectory = Args.hasFlag(options::OPT_fdwarf_directory_asm,
1420 options::OPT_fno_dwarf_directory_asm,
1421 UseIntegratedAs);
1422 return !UseDwarfDirectory;
1423}
1424
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00001425/// \brief Check whether the given input tree contains any compilation actions.
1426static bool ContainsCompileAction(const Action *A) {
Chris Lattner0e62c1c2011-07-23 10:55:15 +00001427 if (isa<CompileJobAction>(A))
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00001428 return true;
1429
1430 for (Action::const_iterator it = A->begin(), ie = A->end(); it != ie; ++it)
1431 if (ContainsCompileAction(*it))
1432 return true;
1433
1434 return false;
1435}
1436
1437/// \brief Check if -relax-all should be passed to the internal assembler.
1438/// This is done by default when compiling non-assembler source with -O0.
1439static bool UseRelaxAll(Compilation &C, const ArgList &Args) {
1440 bool RelaxDefault = true;
1441
1442 if (Arg *A = Args.getLastArg(options::OPT_O_Group))
1443 RelaxDefault = A->getOption().matches(options::OPT_O0);
1444
1445 if (RelaxDefault) {
1446 RelaxDefault = false;
1447 for (ActionList::const_iterator it = C.getActions().begin(),
1448 ie = C.getActions().end(); it != ie; ++it) {
1449 if (ContainsCompileAction(*it)) {
1450 RelaxDefault = true;
1451 break;
1452 }
1453 }
1454 }
1455
1456 return Args.hasFlag(options::OPT_mrelax_all, options::OPT_mno_relax_all,
1457 RelaxDefault);
1458}
1459
Alexey Samsonov627b10f2012-11-06 15:09:03 +00001460SanitizerArgs::SanitizerArgs(const Driver &D, const ArgList &Args) {
1461 Kind = 0;
Richard Smith52be6192012-11-05 22:04:41 +00001462
Richard Smith52be6192012-11-05 22:04:41 +00001463 for (ArgList::const_iterator I = Args.begin(), E = Args.end(); I != E; ++I) {
Alexey Samsonov53f7e122012-11-28 17:34:24 +00001464 unsigned Add, Remove;
1465 if (!parse(D, Args, *I, Add, Remove, true))
Richard Smith52be6192012-11-05 22:04:41 +00001466 continue;
Richard Smith52be6192012-11-05 22:04:41 +00001467 (*I)->claim();
Alexey Samsonov627b10f2012-11-06 15:09:03 +00001468 Kind |= Add;
1469 Kind &= ~Remove;
Richard Smith52be6192012-11-05 22:04:41 +00001470 }
1471
1472 // Only one runtime library can be used at once.
Alexey Samsonov627b10f2012-11-06 15:09:03 +00001473 bool NeedsAsan = needsAsanRt();
1474 bool NeedsTsan = needsTsanRt();
Richard Smith06d87f12012-12-01 01:02:45 +00001475 if (NeedsAsan && NeedsTsan)
Richard Smith52be6192012-11-05 22:04:41 +00001476 D.Diag(diag::err_drv_argument_not_allowed_with)
Richard Smith06d87f12012-12-01 01:02:45 +00001477 << lastArgumentForKind(D, Args, NeedsAsanRt)
1478 << lastArgumentForKind(D, Args, NeedsTsanRt);
Alexey Samsonov0e96bec2012-11-29 22:36:21 +00001479
1480 // If -fsanitize contains extra features of ASan, it should also
1481 // explicitly contain -fsanitize=address.
1482 if (NeedsAsan && ((Kind & Address) == 0))
1483 D.Diag(diag::err_drv_argument_only_allowed_with)
1484 << lastArgumentForKind(D, Args, NeedsAsanRt)
1485 << "-fsanitize=address";
Alexey Samsonov9ab73622012-12-03 19:12:58 +00001486
1487 // Parse -f(no-)sanitize-blacklist options.
1488 if (Arg *BLArg = Args.getLastArg(options::OPT_fsanitize_blacklist,
1489 options::OPT_fno_sanitize_blacklist)) {
1490 if (BLArg->getOption().matches(options::OPT_fsanitize_blacklist)) {
1491 std::string BLPath = BLArg->getValue();
1492 bool BLExists = false;
1493 if (!llvm::sys::fs::exists(BLPath, BLExists) && BLExists)
1494 BlacklistFile = BLPath;
1495 else
1496 D.Diag(diag::err_drv_no_such_file) << BLPath;
1497 }
1498 }
Richard Smith52be6192012-11-05 22:04:41 +00001499}
1500
Kostya Serebryany7bca6c22011-11-30 01:39:16 +00001501/// If AddressSanitizer is enabled, add appropriate linker flags (Linux).
1502/// This needs to be called before we add the C run-time (malloc, etc).
1503static void addAsanRTLinux(const ToolChain &TC, const ArgList &Args,
Kostya Serebryany0b692ce2011-12-06 19:18:44 +00001504 ArgStringList &CmdArgs) {
Logan Chienc6fd8202012-09-02 09:30:11 +00001505 if(TC.getTriple().getEnvironment() == llvm::Triple::Android) {
Evgeniy Stepanov77866712012-04-25 08:59:22 +00001506 if (!Args.hasArg(options::OPT_shared)) {
Evgeniy Stepanovea155f02012-06-04 11:15:05 +00001507 if (!Args.hasArg(options::OPT_pie))
1508 TC.getDriver().Diag(diag::err_drv_asan_android_requires_pie);
Evgeniy Stepanov77866712012-04-25 08:59:22 +00001509 }
Daniel Dunbar3ca41d42011-12-07 23:22:17 +00001510
Evgeniy Stepanovcac6aaa2012-09-12 09:09:08 +00001511 SmallString<128> LibAsan(TC.getDriver().ResourceDir);
1512 llvm::sys::path::append(LibAsan, "lib", "linux",
1513 (Twine("libclang_rt.asan-") +
1514 TC.getArchName() + "-android.so"));
Matt Beaumont-Gay35439df2012-12-04 21:18:26 +00001515 CmdArgs.insert(CmdArgs.begin(), Args.MakeArgString(LibAsan));
Evgeniy Stepanov77866712012-04-25 08:59:22 +00001516 } else {
1517 if (!Args.hasArg(options::OPT_shared)) {
1518 // LibAsan is "libclang_rt.asan-<ArchName>.a" in the Linux library
1519 // resource directory.
1520 SmallString<128> LibAsan(TC.getDriver().ResourceDir);
1521 llvm::sys::path::append(LibAsan, "lib", "linux",
1522 (Twine("libclang_rt.asan-") +
1523 TC.getArchName() + ".a"));
Matt Beaumont-Gay35439df2012-12-04 21:18:26 +00001524 // The ASan runtime needs to come before -lstdc++ (or -lc++, libstdc++.a,
1525 // etc.) so that the linker picks ASan's versions of the global 'operator
1526 // new' and 'operator delete' symbols. We take the extreme (but simple)
1527 // strategy of inserting it at the front of the link command.
1528 CmdArgs.insert(CmdArgs.begin(), Args.MakeArgString(LibAsan));
Evgeniy Stepanov77866712012-04-25 08:59:22 +00001529 CmdArgs.push_back("-lpthread");
1530 CmdArgs.push_back("-ldl");
1531 CmdArgs.push_back("-export-dynamic");
1532 }
1533 }
Kostya Serebryany7bca6c22011-11-30 01:39:16 +00001534}
1535
Kostya Serebryany66e8fab2012-05-16 06:36:00 +00001536/// If ThreadSanitizer is enabled, add appropriate linker flags (Linux).
1537/// This needs to be called before we add the C run-time (malloc, etc).
1538static void addTsanRTLinux(const ToolChain &TC, const ArgList &Args,
1539 ArgStringList &CmdArgs) {
Kostya Serebryany66e8fab2012-05-16 06:36:00 +00001540 if (!Args.hasArg(options::OPT_shared)) {
Evgeniy Stepanovaea92e52012-12-03 13:20:43 +00001541 if (!Args.hasArg(options::OPT_pie))
1542 TC.getDriver().Diag(diag::err_drv_sanitizer_requires_pie) <<
1543 /* Thread */ 0;
Kostya Serebryany66e8fab2012-05-16 06:36:00 +00001544 // LibTsan is "libclang_rt.tsan-<ArchName>.a" in the Linux library
1545 // resource directory.
1546 SmallString<128> LibTsan(TC.getDriver().ResourceDir);
1547 llvm::sys::path::append(LibTsan, "lib", "linux",
1548 (Twine("libclang_rt.tsan-") +
1549 TC.getArchName() + ".a"));
1550 CmdArgs.push_back(Args.MakeArgString(LibTsan));
1551 CmdArgs.push_back("-lpthread");
1552 CmdArgs.push_back("-ldl");
1553 CmdArgs.push_back("-export-dynamic");
1554 }
1555}
1556
Evgeniy Stepanovaea92e52012-12-03 13:20:43 +00001557/// If MemorySanitizer is enabled, add appropriate linker flags (Linux).
1558/// This needs to be called before we add the C run-time (malloc, etc).
1559static void addMsanRTLinux(const ToolChain &TC, const ArgList &Args,
1560 ArgStringList &CmdArgs) {
1561 if (!Args.hasArg(options::OPT_shared)) {
1562 if (!Args.hasArg(options::OPT_pie))
1563 TC.getDriver().Diag(diag::err_drv_sanitizer_requires_pie) <<
1564 /* Memory */ 1;
1565 // LibMsan is "libclang_rt.msan-<ArchName>.a" in the Linux library
1566 // resource directory.
1567 SmallString<128> LibMsan(TC.getDriver().ResourceDir);
1568 llvm::sys::path::append(LibMsan, "lib", "linux",
1569 (Twine("libclang_rt.msan-") +
1570 TC.getArchName() + ".a"));
1571 CmdArgs.push_back(Args.MakeArgString(LibMsan));
1572 CmdArgs.push_back("-lpthread");
1573 CmdArgs.push_back("-ldl");
1574 CmdArgs.push_back("-export-dynamic");
1575 }
1576}
1577
Richard Smithe30752c2012-10-09 19:52:38 +00001578/// If UndefinedBehaviorSanitizer is enabled, add appropriate linker flags
1579/// (Linux).
1580static void addUbsanRTLinux(const ToolChain &TC, const ArgList &Args,
1581 ArgStringList &CmdArgs) {
Richard Smithe30752c2012-10-09 19:52:38 +00001582 if (!Args.hasArg(options::OPT_shared)) {
1583 // LibUbsan is "libclang_rt.ubsan-<ArchName>.a" in the Linux library
1584 // resource directory.
1585 SmallString<128> LibUbsan(TC.getDriver().ResourceDir);
1586 llvm::sys::path::append(LibUbsan, "lib", "linux",
1587 (Twine("libclang_rt.ubsan-") +
1588 TC.getArchName() + ".a"));
1589 CmdArgs.push_back(Args.MakeArgString(LibUbsan));
Richard Smith437abed2012-11-02 20:32:19 +00001590 CmdArgs.push_back("-lpthread");
Richard Smith06d87f12012-12-01 01:02:45 +00001591 CmdArgs.push_back("-export-dynamic");
Richard Smithe30752c2012-10-09 19:52:38 +00001592 }
1593}
1594
Rafael Espindola224dd632011-12-14 21:02:23 +00001595static bool shouldUseFramePointer(const ArgList &Args,
1596 const llvm::Triple &Triple) {
1597 if (Arg *A = Args.getLastArg(options::OPT_fno_omit_frame_pointer,
1598 options::OPT_fomit_frame_pointer))
1599 return A->getOption().matches(options::OPT_fno_omit_frame_pointer);
1600
Rafael Espindola00b29182011-12-14 21:50:24 +00001601 // Don't use a frame pointer on linux x86 and x86_64 if optimizing.
Rafael Espindola224dd632011-12-14 21:02:23 +00001602 if ((Triple.getArch() == llvm::Triple::x86_64 ||
1603 Triple.getArch() == llvm::Triple::x86) &&
1604 Triple.getOS() == llvm::Triple::Linux) {
1605 if (Arg *A = Args.getLastArg(options::OPT_O_Group))
1606 if (!A->getOption().matches(options::OPT_O0))
1607 return false;
1608 }
1609
1610 return true;
1611}
1612
Daniel Dunbar1a093d22009-03-18 06:00:36 +00001613void Clang::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar04c4c2c2009-03-18 07:06:02 +00001614 const InputInfo &Output,
Daniel Dunbar0450e6d2009-03-18 06:07:59 +00001615 const InputInfoList &Inputs,
Daniel Dunbara2aedc62009-03-18 10:01:51 +00001616 const ArgList &Args,
Daniel Dunbar1a093d22009-03-18 06:00:36 +00001617 const char *LinkingOutput) const {
Daniel Dunbare46b52a2010-03-20 04:52:14 +00001618 bool KernelOrKext = Args.hasArg(options::OPT_mkernel,
1619 options::OPT_fapple_kext);
Daniel Dunbar083edf72009-12-21 18:54:17 +00001620 const Driver &D = getToolChain().getDriver();
Daniel Dunbara3246a02009-03-18 08:07:30 +00001621 ArgStringList CmdArgs;
1622
Daniel Dunbare521a892009-03-31 20:53:55 +00001623 assert(Inputs.size() == 1 && "Unable to handle multiple inputs.");
1624
Daniel Dunbar6c536aa2009-12-11 23:00:49 +00001625 // Invoke ourselves in -cc1 mode.
1626 //
1627 // FIXME: Implement custom jobs for internal actions.
1628 CmdArgs.push_back("-cc1");
1629
Daniel Dunbar624c21b2009-10-30 18:12:20 +00001630 // Add the "effective" target triple.
Daniel Dunbard640be22009-03-31 17:35:15 +00001631 CmdArgs.push_back("-triple");
Daniel Dunbar82eb4ce2010-08-23 22:35:37 +00001632 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
Daniel Dunbar624c21b2009-10-30 18:12:20 +00001633 CmdArgs.push_back(Args.MakeArgString(TripleStr));
Daniel Dunbarfb58b0a2009-09-10 06:49:20 +00001634
Daniel Dunbar624c21b2009-10-30 18:12:20 +00001635 // Select the appropriate action.
John McCall5fb5df92012-06-20 06:18:46 +00001636 RewriteKind rewriteKind = RK_None;
Fariborz Jahanian7ebeede2012-04-04 18:50:28 +00001637
Daniel Dunbara2aedc62009-03-18 10:01:51 +00001638 if (isa<AnalyzeJobAction>(JA)) {
1639 assert(JA.getType() == types::TY_Plist && "Invalid output type.");
1640 CmdArgs.push_back("-analyze");
Ted Kremenekf7639e12012-03-06 20:06:33 +00001641 } else if (isa<MigrateJobAction>(JA)) {
1642 CmdArgs.push_back("-migrate");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00001643 } else if (isa<PreprocessJobAction>(JA)) {
Daniel Dunbard67a3222009-03-30 06:36:42 +00001644 if (Output.getType() == types::TY_Dependencies)
1645 CmdArgs.push_back("-Eonly");
1646 else
1647 CmdArgs.push_back("-E");
Daniel Dunbarc4343942010-02-03 03:07:56 +00001648 } else if (isa<AssembleJobAction>(JA)) {
1649 CmdArgs.push_back("-emit-obj");
Daniel Dunbar06e2cc32010-05-27 06:18:05 +00001650
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00001651 if (UseRelaxAll(C, Args))
Daniel Dunbar06e2cc32010-05-27 06:18:05 +00001652 CmdArgs.push_back("-mrelax-all");
Daniel Dunbarfe6c97b2010-08-24 16:47:49 +00001653
Daniel Dunbar2b4de142010-10-18 22:36:15 +00001654 // When using an integrated assembler, translate -Wa, and -Xassembler
1655 // options.
1656 for (arg_iterator it = Args.filtered_begin(options::OPT_Wa_COMMA,
1657 options::OPT_Xassembler),
1658 ie = Args.filtered_end(); it != ie; ++it) {
1659 const Arg *A = *it;
1660 A->claim();
1661
1662 for (unsigned i = 0, e = A->getNumValues(); i != e; ++i) {
Richard Smithbd55daf2012-11-01 04:30:05 +00001663 StringRef Value = A->getValue(i);
Daniel Dunbar2b4de142010-10-18 22:36:15 +00001664
1665 if (Value == "-force_cpusubtype_ALL") {
1666 // Do nothing, this is the default and we don't support anything else.
Daniel Dunbara78e5892010-10-28 20:36:23 +00001667 } else if (Value == "-L") {
Daniel Dunbar67919b22011-03-28 22:49:28 +00001668 CmdArgs.push_back("-msave-temp-labels");
Joerg Sonnenberger3028e462011-05-19 20:46:39 +00001669 } else if (Value == "--fatal-warnings") {
Joerg Sonnenbergerb487d2d2011-05-19 18:42:29 +00001670 CmdArgs.push_back("-mllvm");
1671 CmdArgs.push_back("-fatal-assembler-warnings");
Nick Lewyckyca6b90d2011-06-21 00:14:18 +00001672 } else if (Value == "--noexecstack") {
1673 CmdArgs.push_back("-mnoexecstack");
Daniel Dunbar2b4de142010-10-18 22:36:15 +00001674 } else {
Chris Lattner0e62c1c2011-07-23 10:55:15 +00001675 D.Diag(diag::err_drv_unsupported_option_argument)
Daniel Dunbar2b4de142010-10-18 22:36:15 +00001676 << A->getOption().getName() << Value;
1677 }
1678 }
1679 }
Daniel Dunbar7c874332010-11-19 16:23:35 +00001680
1681 // Also ignore explicit -force_cpusubtype_ALL option.
1682 (void) Args.hasArg(options::OPT_force__cpusubtype__ALL);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00001683 } else if (isa<PrecompileJobAction>(JA)) {
Argyrios Kyrtzidis90bdfbb2010-08-11 23:27:58 +00001684 // Use PCH if the user requested it.
Daniel Dunbarcbc34b72009-10-15 20:02:44 +00001685 bool UsePCH = D.CCCUsePCH;
Daniel Dunbarcbc34b72009-10-15 20:02:44 +00001686
Aaron Ballman1f10cc52012-07-31 01:21:00 +00001687 if (JA.getType() == types::TY_Nothing)
1688 CmdArgs.push_back("-fsyntax-only");
1689 else if (UsePCH)
Douglas Gregor111af7d2009-04-18 00:34:01 +00001690 CmdArgs.push_back("-emit-pch");
1691 else
1692 CmdArgs.push_back("-emit-pth");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00001693 } else {
1694 assert(isa<CompileJobAction>(JA) && "Invalid action for clang tool.");
Daniel Dunbard067f7f2009-04-08 23:54:23 +00001695
Daniel Dunbara2aedc62009-03-18 10:01:51 +00001696 if (JA.getType() == types::TY_Nothing) {
1697 CmdArgs.push_back("-fsyntax-only");
Daniel Dunbar24e52992010-06-07 23:28:45 +00001698 } else if (JA.getType() == types::TY_LLVM_IR ||
1699 JA.getType() == types::TY_LTO_IR) {
Daniel Dunbara2aedc62009-03-18 10:01:51 +00001700 CmdArgs.push_back("-emit-llvm");
Daniel Dunbar24e52992010-06-07 23:28:45 +00001701 } else if (JA.getType() == types::TY_LLVM_BC ||
1702 JA.getType() == types::TY_LTO_BC) {
Daniel Dunbara2aedc62009-03-18 10:01:51 +00001703 CmdArgs.push_back("-emit-llvm-bc");
1704 } else if (JA.getType() == types::TY_PP_Asm) {
Daniel Dunbard112f102009-09-17 00:47:53 +00001705 CmdArgs.push_back("-S");
Daniel Dunbar6cdf83c2009-09-01 16:57:46 +00001706 } else if (JA.getType() == types::TY_AST) {
1707 CmdArgs.push_back("-emit-pch");
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00001708 } else if (JA.getType() == types::TY_RewrittenObjC) {
1709 CmdArgs.push_back("-rewrite-objc");
John McCall5fb5df92012-06-20 06:18:46 +00001710 rewriteKind = RK_NonFragile;
Fariborz Jahanian73223bb2012-04-02 15:59:19 +00001711 } else if (JA.getType() == types::TY_RewrittenLegacyObjC) {
1712 CmdArgs.push_back("-rewrite-objc");
John McCall5fb5df92012-06-20 06:18:46 +00001713 rewriteKind = RK_Fragile;
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00001714 } else {
1715 assert(JA.getType() == types::TY_PP_Asm &&
1716 "Unexpected output type!");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00001717 }
Daniel Dunbara3246a02009-03-18 08:07:30 +00001718 }
1719
Daniel Dunbara2aedc62009-03-18 10:01:51 +00001720 // The make clang go fast button.
1721 CmdArgs.push_back("-disable-free");
1722
John McCallbb79b5f2010-02-13 03:50:24 +00001723 // Disable the verification pass in -asserts builds.
1724#ifdef NDEBUG
1725 CmdArgs.push_back("-disable-llvm-verifier");
1726#endif
1727
Daniel Dunbar3b358a32009-04-08 05:11:16 +00001728 // Set the main file name, so that debug info works even with
1729 // -save-temps.
1730 CmdArgs.push_back("-main-file-name");
Bob Wilsondecc03e2012-11-23 06:14:39 +00001731 CmdArgs.push_back(getBaseInputName(Args, Inputs));
Daniel Dunbar3b358a32009-04-08 05:11:16 +00001732
Daniel Dunbar17ddaa62009-04-08 18:03:55 +00001733 // Some flags which affect the language (via preprocessor
Bob Wilsondecc03e2012-11-23 06:14:39 +00001734 // defines).
Daniel Dunbar17ddaa62009-04-08 18:03:55 +00001735 if (Args.hasArg(options::OPT_static))
1736 CmdArgs.push_back("-static-define");
1737
Daniel Dunbara2aedc62009-03-18 10:01:51 +00001738 if (isa<AnalyzeJobAction>(JA)) {
Ted Kremenek05e6f5b2009-09-25 05:55:59 +00001739 // Enable region store model by default.
1740 CmdArgs.push_back("-analyzer-store=region");
1741
Ted Kremenek7bea9a12009-12-07 22:26:14 +00001742 // Treat blocks as analysis entry points.
1743 CmdArgs.push_back("-analyzer-opt-analyze-nested-blocks");
1744
Ted Kremenek49c79792011-03-24 00:28:47 +00001745 CmdArgs.push_back("-analyzer-eagerly-assume");
1746
Daniel Dunbara2aedc62009-03-18 10:01:51 +00001747 // Add default argument set.
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00001748 if (!Args.hasArg(options::OPT__analyzer_no_default_checks)) {
Argyrios Kyrtzidisa6d04d52011-02-15 07:42:33 +00001749 CmdArgs.push_back("-analyzer-checker=core");
Ted Kremenek49c79792011-03-24 00:28:47 +00001750
Argyrios Kyrtzidisa6d04d52011-02-15 07:42:33 +00001751 if (getToolChain().getTriple().getOS() != llvm::Triple::Win32)
1752 CmdArgs.push_back("-analyzer-checker=unix");
Ted Kremenek49c79792011-03-24 00:28:47 +00001753
Argyrios Kyrtzidisa6d04d52011-02-15 07:42:33 +00001754 if (getToolChain().getTriple().getVendor() == llvm::Triple::Apple)
Ted Kremenek49c79792011-03-24 00:28:47 +00001755 CmdArgs.push_back("-analyzer-checker=osx");
Ted Kremenekb9ff6b22012-01-20 06:00:17 +00001756
1757 CmdArgs.push_back("-analyzer-checker=deadcode");
Ted Kremenek37e96522012-01-26 02:27:38 +00001758
1759 // Enable the following experimental checkers for testing.
Ted Kremenek37e96522012-01-26 02:27:38 +00001760 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.UncheckedReturn");
1761 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.getpw");
1762 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.gets");
1763 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.mktemp");
1764 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.mkstemp");
1765 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.vfork");
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00001766 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00001767
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00001768 // Set the output format. The default is plist, for (lame) historical
1769 // reasons.
1770 CmdArgs.push_back("-analyzer-output");
1771 if (Arg *A = Args.getLastArg(options::OPT__analyzer_output))
Richard Smithbd55daf2012-11-01 04:30:05 +00001772 CmdArgs.push_back(A->getValue());
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00001773 else
1774 CmdArgs.push_back("plist");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00001775
Ted Kremenekfe449a22010-03-22 22:32:05 +00001776 // Disable the presentation of standard compiler warnings when
1777 // using --analyze. We only want to show static analyzer diagnostics
1778 // or frontend errors.
1779 CmdArgs.push_back("-w");
1780
Daniel Dunbara2aedc62009-03-18 10:01:51 +00001781 // Add -Xanalyzer arguments when running as analyzer.
1782 Args.AddAllArgValues(CmdArgs, options::OPT_Xanalyzer);
Mike Stump11289f42009-09-09 15:08:12 +00001783 }
1784
Daniel Dunbar4eadb602009-09-10 01:21:12 +00001785 CheckCodeGenerationOptions(D, Args);
1786
Chandler Carruth76a943b2012-11-19 03:52:03 +00001787 // For the PIC and PIE flag options, this logic is different from the legacy
1788 // logic in very old versions of GCC, as that logic was just a bug no one had
1789 // ever fixed. This logic is both more rational and consistent with GCC's new
1790 // logic now that the bugs are fixed. The last argument relating to either
1791 // PIC or PIE wins, and no other argument is used. If the last argument is
1792 // any flavor of the '-fno-...' arguments, both PIC and PIE are disabled. Any
1793 // PIE option implicitly enables PIC at the same level.
1794 bool PIE = false;
1795 bool PIC = getToolChain().isPICDefault();
1796 bool IsPICLevelTwo = PIC;
1797 if (Arg *A = Args.getLastArg(options::OPT_fPIC, options::OPT_fno_PIC,
1798 options::OPT_fpic, options::OPT_fno_pic,
1799 options::OPT_fPIE, options::OPT_fno_PIE,
1800 options::OPT_fpie, options::OPT_fno_pie)) {
1801 Option O = A->getOption();
1802 if (O.matches(options::OPT_fPIC) || O.matches(options::OPT_fpic) ||
1803 O.matches(options::OPT_fPIE) || O.matches(options::OPT_fpie)) {
1804 PIE = O.matches(options::OPT_fPIE) || O.matches(options::OPT_fpie);
1805 PIC = PIE || O.matches(options::OPT_fPIC) || O.matches(options::OPT_fpic);
1806 IsPICLevelTwo = O.matches(options::OPT_fPIE) ||
1807 O.matches(options::OPT_fPIC);
1808 } else {
1809 PIE = PIC = false;
1810 }
Benjamin Kramer76db2902012-11-13 15:32:35 +00001811 }
Chandler Carruth76a943b2012-11-19 03:52:03 +00001812 // Check whether the tool chain trumps the PIC-ness decision. If the PIC-ness
1813 // is forced, then neither PIC nor PIE flags will have no effect.
1814 if (getToolChain().isPICDefaultForced()) {
1815 PIE = false;
1816 PIC = getToolChain().isPICDefault();
1817 IsPICLevelTwo = PIC;
Chandler Carruthc0c04552012-04-08 16:40:35 +00001818 }
Chandler Carruth76a943b2012-11-19 03:52:03 +00001819
1820 // Inroduce a Darwin-specific hack. If the default is PIC but the flags
1821 // specified while enabling PIC enabled level 1 PIC, just force it back to
1822 // level 2 PIC instead. This matches the behavior of Darwin GCC (based on my
1823 // informal testing).
1824 if (PIC && getToolChain().getTriple().isOSDarwin())
1825 IsPICLevelTwo |= getToolChain().isPICDefault();
1826
Chandler Carruthc0c04552012-04-08 16:40:35 +00001827 // Note that these flags are trump-cards. Regardless of the order w.r.t. the
1828 // PIC or PIE options above, if these show up, PIC is disabled.
Daniel Dunbarbd847cc2012-10-15 22:23:53 +00001829 llvm::Triple Triple(TripleStr);
1830 if ((Args.hasArg(options::OPT_mkernel) ||
1831 Args.hasArg(options::OPT_fapple_kext)) &&
1832 (Triple.getOS() != llvm::Triple::IOS ||
1833 Triple.isOSVersionLT(6)))
Chandler Carruth76a943b2012-11-19 03:52:03 +00001834 PIC = PIE = false;
Chandler Carruthc0c04552012-04-08 16:40:35 +00001835 if (Args.hasArg(options::OPT_static))
Chandler Carruth76a943b2012-11-19 03:52:03 +00001836 PIC = PIE = false;
Chandler Carruthc0c04552012-04-08 16:40:35 +00001837
Chandler Carruth76a943b2012-11-19 03:52:03 +00001838 if (Arg *A = Args.getLastArg(options::OPT_mdynamic_no_pic)) {
1839 // This is a very special mode. It trumps the other modes, almost no one
1840 // uses it, and it isn't even valid on any OS but Darwin.
1841 if (!getToolChain().getTriple().isOSDarwin())
1842 D.Diag(diag::err_drv_unsupported_opt_for_target)
1843 << A->getSpelling() << getToolChain().getTriple().str();
1844
1845 // FIXME: Warn when this flag trumps some other PIC or PIE flag.
1846
Daniel Dunbara1b02a22009-11-29 07:18:39 +00001847 CmdArgs.push_back("-mrelocation-model");
Chandler Carruth76a943b2012-11-19 03:52:03 +00001848 CmdArgs.push_back("dynamic-no-pic");
Daniel Dunbar44e71222009-04-29 18:32:25 +00001849
Chandler Carruth76a943b2012-11-19 03:52:03 +00001850 // Only a forced PIC mode can cause the actual compile to have PIC defines
1851 // etc., no flags are sufficient. This behavior was selected to closely
1852 // match that of llvm-gcc and Apple GCC before that.
1853 if (getToolChain().isPICDefault() && getToolChain().isPICDefaultForced()) {
1854 CmdArgs.push_back("-pic-level");
1855 CmdArgs.push_back("2");
1856 }
1857 } else {
1858 // Currently, LLVM only knows about PIC vs. static; the PIE differences are
1859 // handled in Clang's IRGen by the -pie-level flag.
1860 CmdArgs.push_back("-mrelocation-model");
1861 CmdArgs.push_back(PIC ? "pic" : "static");
1862
1863 if (PIC) {
1864 CmdArgs.push_back("-pic-level");
1865 CmdArgs.push_back(IsPICLevelTwo ? "2" : "1");
1866 if (PIE) {
1867 CmdArgs.push_back("-pie-level");
1868 CmdArgs.push_back(IsPICLevelTwo ? "2" : "1");
1869 }
1870 }
Daniel Dunbar44e71222009-04-29 18:32:25 +00001871 }
Chandler Carruthc0c04552012-04-08 16:40:35 +00001872
Tanya Lattnerf9d41df2009-11-04 01:18:09 +00001873 if (!Args.hasFlag(options::OPT_fmerge_all_constants,
1874 options::OPT_fno_merge_all_constants))
Chris Lattner9242b332011-04-08 18:06:54 +00001875 CmdArgs.push_back("-fno-merge-all-constants");
Daniel Dunbar306945d2009-09-16 06:17:29 +00001876
Daniel Dunbara1b02a22009-11-29 07:18:39 +00001877 // LLVM Code Generator Options.
1878
Daniel Dunbar0bb03312011-02-09 17:54:19 +00001879 if (Arg *A = Args.getLastArg(options::OPT_mregparm_EQ)) {
1880 CmdArgs.push_back("-mregparm");
Richard Smithbd55daf2012-11-01 04:30:05 +00001881 CmdArgs.push_back(A->getValue());
Daniel Dunbar0bb03312011-02-09 17:54:19 +00001882 }
1883
Roman Divacky65b88cd2011-03-01 17:40:53 +00001884 if (Args.hasFlag(options::OPT_mrtd, options::OPT_mno_rtd, false))
1885 CmdArgs.push_back("-mrtd");
1886
Rafael Espindola224dd632011-12-14 21:02:23 +00001887 if (shouldUseFramePointer(Args, getToolChain().getTriple()))
Daniel Dunbara1b02a22009-11-29 07:18:39 +00001888 CmdArgs.push_back("-mdisable-fp-elim");
1889 if (!Args.hasFlag(options::OPT_fzero_initialized_in_bss,
1890 options::OPT_fno_zero_initialized_in_bss))
1891 CmdArgs.push_back("-mno-zero-initialized-in-bss");
Daniel Dunbar7aa71f92011-02-04 02:20:39 +00001892 if (!Args.hasFlag(options::OPT_fstrict_aliasing,
1893 options::OPT_fno_strict_aliasing,
1894 getToolChain().IsStrictAliasingDefault()))
Dan Gohman10169b92010-10-14 22:36:56 +00001895 CmdArgs.push_back("-relaxed-aliasing");
Chandler Carruth8b4140d2012-03-27 23:58:37 +00001896 if (Args.hasFlag(options::OPT_fstrict_enums, options::OPT_fno_strict_enums,
1897 false))
1898 CmdArgs.push_back("-fstrict-enums");
Nick Lewycky1c8c4362012-01-23 08:29:12 +00001899 if (!Args.hasFlag(options::OPT_foptimize_sibling_calls,
1900 options::OPT_fno_optimize_sibling_calls))
1901 CmdArgs.push_back("-mdisable-tail-calls");
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00001902
Chandler Carruth306bd2c2012-01-02 14:19:45 +00001903 // Handle various floating point optimization flags, mapping them to the
1904 // appropriate LLVM code generation flags. The pattern for all of these is to
1905 // default off the codegen optimizations, and if any flag enables them and no
1906 // flag disables them after the flag enabling them, enable the codegen
1907 // optimization. This is complicated by several "umbrella" flags.
1908 if (Arg *A = Args.getLastArg(options::OPT_ffast_math,
Chad Rosierc30eb1c2012-09-25 22:03:25 +00001909 options::OPT_fno_fast_math,
Chandler Carruth306bd2c2012-01-02 14:19:45 +00001910 options::OPT_ffinite_math_only,
1911 options::OPT_fno_finite_math_only,
1912 options::OPT_fhonor_infinities,
1913 options::OPT_fno_honor_infinities))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00001914 if (A->getOption().getID() != options::OPT_fno_fast_math &&
1915 A->getOption().getID() != options::OPT_fno_finite_math_only &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00001916 A->getOption().getID() != options::OPT_fhonor_infinities)
1917 CmdArgs.push_back("-menable-no-infs");
1918 if (Arg *A = Args.getLastArg(options::OPT_ffast_math,
Chad Rosierc30eb1c2012-09-25 22:03:25 +00001919 options::OPT_fno_fast_math,
Chandler Carruth306bd2c2012-01-02 14:19:45 +00001920 options::OPT_ffinite_math_only,
1921 options::OPT_fno_finite_math_only,
1922 options::OPT_fhonor_nans,
1923 options::OPT_fno_honor_nans))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00001924 if (A->getOption().getID() != options::OPT_fno_fast_math &&
1925 A->getOption().getID() != options::OPT_fno_finite_math_only &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00001926 A->getOption().getID() != options::OPT_fhonor_nans)
1927 CmdArgs.push_back("-menable-no-nans");
1928
Benjamin Kramerc242ef22012-05-02 14:55:48 +00001929 // -fmath-errno is the default on some platforms, e.g. BSD-derived OSes.
1930 bool MathErrno = getToolChain().IsMathErrnoDefault();
Chandler Carruth306bd2c2012-01-02 14:19:45 +00001931 if (Arg *A = Args.getLastArg(options::OPT_ffast_math,
Chad Rosierc30eb1c2012-09-25 22:03:25 +00001932 options::OPT_fno_fast_math,
Chandler Carruth306bd2c2012-01-02 14:19:45 +00001933 options::OPT_fmath_errno,
Chandler Carruth3634c662012-04-26 02:10:51 +00001934 options::OPT_fno_math_errno))
1935 MathErrno = A->getOption().getID() == options::OPT_fmath_errno;
1936 if (MathErrno)
1937 CmdArgs.push_back("-fmath-errno");
Chandler Carruth306bd2c2012-01-02 14:19:45 +00001938
1939 // There are several flags which require disabling very specific
1940 // optimizations. Any of these being disabled forces us to turn off the
1941 // entire set of LLVM optimizations, so collect them through all the flag
1942 // madness.
1943 bool AssociativeMath = false;
1944 if (Arg *A = Args.getLastArg(options::OPT_ffast_math,
Chad Rosierc30eb1c2012-09-25 22:03:25 +00001945 options::OPT_fno_fast_math,
Chandler Carruth306bd2c2012-01-02 14:19:45 +00001946 options::OPT_funsafe_math_optimizations,
1947 options::OPT_fno_unsafe_math_optimizations,
1948 options::OPT_fassociative_math,
1949 options::OPT_fno_associative_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00001950 if (A->getOption().getID() != options::OPT_fno_fast_math &&
1951 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00001952 A->getOption().getID() != options::OPT_fno_associative_math)
1953 AssociativeMath = true;
1954 bool ReciprocalMath = false;
1955 if (Arg *A = Args.getLastArg(options::OPT_ffast_math,
Chad Rosierc30eb1c2012-09-25 22:03:25 +00001956 options::OPT_fno_fast_math,
Chandler Carruth306bd2c2012-01-02 14:19:45 +00001957 options::OPT_funsafe_math_optimizations,
1958 options::OPT_fno_unsafe_math_optimizations,
1959 options::OPT_freciprocal_math,
1960 options::OPT_fno_reciprocal_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00001961 if (A->getOption().getID() != options::OPT_fno_fast_math &&
1962 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00001963 A->getOption().getID() != options::OPT_fno_reciprocal_math)
1964 ReciprocalMath = true;
1965 bool SignedZeros = true;
1966 if (Arg *A = Args.getLastArg(options::OPT_ffast_math,
Chad Rosierc30eb1c2012-09-25 22:03:25 +00001967 options::OPT_fno_fast_math,
Chandler Carruth306bd2c2012-01-02 14:19:45 +00001968 options::OPT_funsafe_math_optimizations,
1969 options::OPT_fno_unsafe_math_optimizations,
1970 options::OPT_fsigned_zeros,
1971 options::OPT_fno_signed_zeros))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00001972 if (A->getOption().getID() != options::OPT_fno_fast_math &&
1973 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00001974 A->getOption().getID() != options::OPT_fsigned_zeros)
1975 SignedZeros = false;
1976 bool TrappingMath = true;
1977 if (Arg *A = Args.getLastArg(options::OPT_ffast_math,
Chad Rosierc30eb1c2012-09-25 22:03:25 +00001978 options::OPT_fno_fast_math,
Chandler Carruth306bd2c2012-01-02 14:19:45 +00001979 options::OPT_funsafe_math_optimizations,
1980 options::OPT_fno_unsafe_math_optimizations,
1981 options::OPT_ftrapping_math,
1982 options::OPT_fno_trapping_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00001983 if (A->getOption().getID() != options::OPT_fno_fast_math &&
1984 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00001985 A->getOption().getID() != options::OPT_ftrapping_math)
1986 TrappingMath = false;
1987 if (!MathErrno && AssociativeMath && ReciprocalMath && !SignedZeros &&
1988 !TrappingMath)
1989 CmdArgs.push_back("-menable-unsafe-fp-math");
1990
Lang Hamesaa53b932012-07-06 00:59:19 +00001991
1992 // Validate and pass through -fp-contract option.
1993 if (Arg *A = Args.getLastArg(options::OPT_ffast_math,
Chad Rosierc30eb1c2012-09-25 22:03:25 +00001994 options::OPT_fno_fast_math,
Lang Hamesaa53b932012-07-06 00:59:19 +00001995 options::OPT_ffp_contract)) {
1996 if (A->getOption().getID() == options::OPT_ffp_contract) {
Richard Smithbd55daf2012-11-01 04:30:05 +00001997 StringRef Val = A->getValue();
Lang Hamesaa53b932012-07-06 00:59:19 +00001998 if (Val == "fast" || Val == "on" || Val == "off") {
1999 CmdArgs.push_back(Args.MakeArgString("-ffp-contract=" + Val));
2000 } else {
2001 D.Diag(diag::err_drv_unsupported_option_argument)
2002 << A->getOption().getName() << Val;
2003 }
Chad Rosierc30eb1c2012-09-25 22:03:25 +00002004 } else if (A->getOption().getID() == options::OPT_ffast_math) {
Lang Hamesaa53b932012-07-06 00:59:19 +00002005 // If fast-math is set then set the fp-contract mode to fast.
2006 CmdArgs.push_back(Args.MakeArgString("-ffp-contract=fast"));
2007 }
2008 }
2009
Bob Wilson6a039162012-07-19 03:52:53 +00002010 // We separately look for the '-ffast-math' and '-ffinite-math-only' flags,
2011 // and if we find them, tell the frontend to provide the appropriate
2012 // preprocessor macros. This is distinct from enabling any optimizations as
2013 // these options induce language changes which must survive serialization
2014 // and deserialization, etc.
Chad Rosierc30eb1c2012-09-25 22:03:25 +00002015 if (Arg *A = Args.getLastArg(options::OPT_ffast_math, options::OPT_fno_fast_math))
2016 if (A->getOption().matches(options::OPT_ffast_math))
2017 CmdArgs.push_back("-ffast-math");
2018 if (Arg *A = Args.getLastArg(options::OPT_ffinite_math_only, options::OPT_fno_fast_math))
2019 if (A->getOption().matches(options::OPT_ffinite_math_only))
2020 CmdArgs.push_back("-ffinite-math-only");
Chandler Carruth306bd2c2012-01-02 14:19:45 +00002021
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00002022 // Decide whether to use verbose asm. Verbose assembly is the default on
2023 // toolchains which have the integrated assembler on by default.
2024 bool IsVerboseAsmDefault = getToolChain().IsIntegratedAssemblerDefault();
2025 if (Args.hasFlag(options::OPT_fverbose_asm, options::OPT_fno_verbose_asm,
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00002026 IsVerboseAsmDefault) ||
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00002027 Args.hasArg(options::OPT_dA))
Daniel Dunbara1b02a22009-11-29 07:18:39 +00002028 CmdArgs.push_back("-masm-verbose");
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00002029
Daniel Dunbara1b02a22009-11-29 07:18:39 +00002030 if (Args.hasArg(options::OPT_fdebug_pass_structure)) {
2031 CmdArgs.push_back("-mdebug-pass");
2032 CmdArgs.push_back("Structure");
2033 }
2034 if (Args.hasArg(options::OPT_fdebug_pass_arguments)) {
2035 CmdArgs.push_back("-mdebug-pass");
2036 CmdArgs.push_back("Arguments");
2037 }
2038
John McCall8517abc2010-02-19 02:45:38 +00002039 // Enable -mconstructor-aliases except on darwin, where we have to
2040 // work around a linker bug; see <rdar://problem/7651567>.
Bob Wilson6524dd32011-10-14 05:03:44 +00002041 if (!getToolChain().getTriple().isOSDarwin())
John McCall8517abc2010-02-19 02:45:38 +00002042 CmdArgs.push_back("-mconstructor-aliases");
NAKAMURA Takumi029d74b2011-02-17 08:50:50 +00002043
John McCall7ef5cb32011-03-18 02:56:14 +00002044 // Darwin's kernel doesn't support guard variables; just die if we
2045 // try to use them.
Bob Wilson6524dd32011-10-14 05:03:44 +00002046 if (KernelOrKext && getToolChain().getTriple().isOSDarwin())
John McCall7ef5cb32011-03-18 02:56:14 +00002047 CmdArgs.push_back("-fforbid-guard-variables");
2048
Douglas Gregordbe39272011-02-01 15:15:22 +00002049 if (Args.hasArg(options::OPT_mms_bitfields)) {
2050 CmdArgs.push_back("-mms-bitfields");
2051 }
John McCall8517abc2010-02-19 02:45:38 +00002052
Daniel Dunbar306945d2009-09-16 06:17:29 +00002053 // This is a coarse approximation of what llvm-gcc actually does, both
2054 // -fasynchronous-unwind-tables and -fnon-call-exceptions interact in more
2055 // complicated ways.
2056 bool AsynchronousUnwindTables =
2057 Args.hasFlag(options::OPT_fasynchronous_unwind_tables,
2058 options::OPT_fno_asynchronous_unwind_tables,
2059 getToolChain().IsUnwindTablesDefault() &&
Daniel Dunbare46b52a2010-03-20 04:52:14 +00002060 !KernelOrKext);
Daniel Dunbar306945d2009-09-16 06:17:29 +00002061 if (Args.hasFlag(options::OPT_funwind_tables, options::OPT_fno_unwind_tables,
2062 AsynchronousUnwindTables))
Daniel Dunbara1b02a22009-11-29 07:18:39 +00002063 CmdArgs.push_back("-munwind-tables");
2064
Chandler Carruth05fb5852012-11-21 23:40:23 +00002065 getToolChain().addClangTargetOptions(Args, CmdArgs);
Rafael Espindola66aa0452012-06-19 01:26:10 +00002066
Daniel Dunbara1b02a22009-11-29 07:18:39 +00002067 if (Arg *A = Args.getLastArg(options::OPT_flimited_precision_EQ)) {
2068 CmdArgs.push_back("-mlimit-float-precision");
Richard Smithbd55daf2012-11-01 04:30:05 +00002069 CmdArgs.push_back(A->getValue());
Daniel Dunbara1b02a22009-11-29 07:18:39 +00002070 }
Daniel Dunbar44e71222009-04-29 18:32:25 +00002071
Daniel Dunbar4dbaaa62009-05-06 03:16:41 +00002072 // FIXME: Handle -mtune=.
2073 (void) Args.hasArg(options::OPT_mtune_EQ);
Daniel Dunbar44e71222009-04-29 18:32:25 +00002074
Benjamin Kramercf4371a2009-08-05 14:30:52 +00002075 if (Arg *A = Args.getLastArg(options::OPT_mcmodel_EQ)) {
Daniel Dunbara1b02a22009-11-29 07:18:39 +00002076 CmdArgs.push_back("-mcode-model");
Richard Smithbd55daf2012-11-01 04:30:05 +00002077 CmdArgs.push_back(A->getValue());
Benjamin Kramercf4371a2009-08-05 14:30:52 +00002078 }
2079
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00002080 // Add target specific cpu and features flags.
2081 switch(getToolChain().getTriple().getArch()) {
2082 default:
2083 break;
Daniel Dunbar4dbaaa62009-05-06 03:16:41 +00002084
Daniel Dunbar0f5c5422009-09-10 04:57:17 +00002085 case llvm::Triple::arm:
2086 case llvm::Triple::thumb:
Daniel Dunbarc9388c12011-03-17 17:10:06 +00002087 AddARMTargetArgs(Args, CmdArgs, KernelOrKext);
Daniel Dunbar0f5c5422009-09-10 04:57:17 +00002088 break;
2089
Eric Christopher0b26a612010-03-02 02:41:08 +00002090 case llvm::Triple::mips:
2091 case llvm::Triple::mipsel:
Akira Hatanaka94ab5542011-09-21 02:13:07 +00002092 case llvm::Triple::mips64:
2093 case llvm::Triple::mips64el:
Eric Christopher0b26a612010-03-02 02:41:08 +00002094 AddMIPSTargetArgs(Args, CmdArgs);
2095 break;
2096
Hal Finkel8eb59282012-06-11 22:35:19 +00002097 case llvm::Triple::ppc:
2098 case llvm::Triple::ppc64:
2099 AddPPCTargetArgs(Args, CmdArgs);
2100 break;
2101
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00002102 case llvm::Triple::sparc:
2103 AddSparcTargetArgs(Args, CmdArgs);
2104 break;
2105
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00002106 case llvm::Triple::x86:
2107 case llvm::Triple::x86_64:
2108 AddX86TargetArgs(Args, CmdArgs);
2109 break;
Tony Linthicum76329bf2011-12-12 21:14:55 +00002110
2111 case llvm::Triple::hexagon:
2112 AddHexagonTargetArgs(Args, CmdArgs);
2113 break;
Daniel Dunbar44e71222009-04-29 18:32:25 +00002114 }
2115
Tony Linthicum76329bf2011-12-12 21:14:55 +00002116
2117
Daniel Dunbar976a2f52010-08-11 23:07:47 +00002118 // Pass the linker version in use.
2119 if (Arg *A = Args.getLastArg(options::OPT_mlinker_version_EQ)) {
2120 CmdArgs.push_back("-target-linker-version");
Richard Smithbd55daf2012-11-01 04:30:05 +00002121 CmdArgs.push_back(A->getValue());
Daniel Dunbar976a2f52010-08-11 23:07:47 +00002122 }
2123
Nick Lewycky75033772011-02-02 06:43:03 +00002124 // -mno-omit-leaf-frame-pointer is the default on Darwin.
Daniel Dunbarbb7ac522010-07-01 01:31:45 +00002125 if (Args.hasFlag(options::OPT_momit_leaf_frame_pointer,
Nick Lewycky75033772011-02-02 06:43:03 +00002126 options::OPT_mno_omit_leaf_frame_pointer,
Bob Wilson6524dd32011-10-14 05:03:44 +00002127 !getToolChain().getTriple().isOSDarwin()))
Daniel Dunbarbb7ac522010-07-01 01:31:45 +00002128 CmdArgs.push_back("-momit-leaf-frame-pointer");
2129
Daniel Dunbarfcc49a82010-05-12 18:19:58 +00002130 // Explicitly error on some things we know we don't support and can't just
2131 // ignore.
2132 types::ID InputType = Inputs[0].getType();
Daniel Dunbar4ed214a2010-09-24 19:39:37 +00002133 if (!Args.hasArg(options::OPT_fallow_unsupported)) {
2134 Arg *Unsupported;
Daniel Dunbar4ed214a2010-09-24 19:39:37 +00002135 if (types::isCXX(InputType) &&
Bob Wilson6524dd32011-10-14 05:03:44 +00002136 getToolChain().getTriple().isOSDarwin() &&
Daniel Dunbar4ed214a2010-09-24 19:39:37 +00002137 getToolChain().getTriple().getArch() == llvm::Triple::x86) {
Bob Wilson0d45f582011-08-13 23:48:55 +00002138 if ((Unsupported = Args.getLastArg(options::OPT_fapple_kext)) ||
2139 (Unsupported = Args.getLastArg(options::OPT_mkernel)))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00002140 D.Diag(diag::err_drv_clang_unsupported_opt_cxx_darwin_i386)
Daniel Dunbar4ed214a2010-09-24 19:39:37 +00002141 << Unsupported->getOption().getName();
2142 }
Daniel Dunbarfcc49a82010-05-12 18:19:58 +00002143 }
2144
Daniel Dunbara2aedc62009-03-18 10:01:51 +00002145 Args.AddAllArgs(CmdArgs, options::OPT_v);
Daniel Dunbard4352752010-08-24 22:44:13 +00002146 Args.AddLastArg(CmdArgs, options::OPT_H);
Chad Rosierbe10f982011-08-02 17:58:04 +00002147 if (D.CCPrintHeaders && !D.CCGenDiagnostics) {
Daniel Dunbarac540b32011-02-02 21:11:35 +00002148 CmdArgs.push_back("-header-include-file");
2149 CmdArgs.push_back(D.CCPrintHeadersFilename ?
2150 D.CCPrintHeadersFilename : "-");
2151 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00002152 Args.AddLastArg(CmdArgs, options::OPT_P);
Mike Stump11289f42009-09-09 15:08:12 +00002153 Args.AddLastArg(CmdArgs, options::OPT_print_ivar_layout);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00002154
Chad Rosierbe10f982011-08-02 17:58:04 +00002155 if (D.CCLogDiagnostics && !D.CCGenDiagnostics) {
Daniel Dunbar529c03b2011-04-07 18:01:20 +00002156 CmdArgs.push_back("-diagnostic-log-file");
2157 CmdArgs.push_back(D.CCLogDiagnosticsFilename ?
2158 D.CCLogDiagnosticsFilename : "-");
2159 }
2160
Alexey Samsonovdda3a7f2012-05-29 08:10:34 +00002161 // Use the last option from "-g" group. "-gline-tables-only" is
2162 // preserved, all other debug options are substituted with "-g".
Rafael Espindola08a692a2010-03-07 04:46:18 +00002163 Args.ClaimAllArgs(options::OPT_g_Group);
Alexey Samsonovdda3a7f2012-05-29 08:10:34 +00002164 if (Arg *A = Args.getLastArg(options::OPT_g_Group)) {
2165 if (A->getOption().matches(options::OPT_gline_tables_only)) {
2166 CmdArgs.push_back("-gline-tables-only");
Alexey Samsonovf50a9ff2012-06-21 08:22:39 +00002167 } else if (!A->getOption().matches(options::OPT_g0) &&
2168 !A->getOption().matches(options::OPT_ggdb0)) {
Chad Rosier8fe3b112011-11-07 19:52:29 +00002169 CmdArgs.push_back("-g");
Chad Rosierc2bf3382011-11-04 19:28:44 +00002170 }
Alexey Samsonovdda3a7f2012-05-29 08:10:34 +00002171 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00002172
Alexey Samsonovf50a9ff2012-06-21 08:22:39 +00002173 // We ignore flags -gstrict-dwarf and -grecord-gcc-switches for now.
2174 Args.ClaimAllArgs(options::OPT_g_flags_Group);
Eric Christophera2f7eb72012-10-18 21:52:18 +00002175 if (Args.hasArg(options::OPT_gcolumn_info))
2176 CmdArgs.push_back("-dwarf-column-info");
Alexey Samsonovf50a9ff2012-06-21 08:22:39 +00002177
Rafael Espindola66bfb2752010-05-06 21:06:04 +00002178 Args.AddAllArgs(CmdArgs, options::OPT_ffunction_sections);
2179 Args.AddAllArgs(CmdArgs, options::OPT_fdata_sections);
2180
Chris Lattner3c77a352010-06-22 00:03:40 +00002181 Args.AddAllArgs(CmdArgs, options::OPT_finstrument_functions);
2182
Nick Lewycky207bce32011-04-21 23:44:07 +00002183 if (Args.hasArg(options::OPT_ftest_coverage) ||
2184 Args.hasArg(options::OPT_coverage))
2185 CmdArgs.push_back("-femit-coverage-notes");
2186 if (Args.hasArg(options::OPT_fprofile_arcs) ||
2187 Args.hasArg(options::OPT_coverage))
2188 CmdArgs.push_back("-femit-coverage-data");
2189
Nick Lewycky480cb992011-05-04 20:46:58 +00002190 if (C.getArgs().hasArg(options::OPT_c) ||
2191 C.getArgs().hasArg(options::OPT_S)) {
2192 if (Output.isFilename()) {
Nick Lewycky85c011d2011-05-05 00:08:20 +00002193 CmdArgs.push_back("-coverage-file");
Bill Wendling8c0b4bc2012-08-30 00:43:41 +00002194 SmallString<128> absFilename(Output.getFilename());
2195 llvm::sys::fs::make_absolute(absFilename);
2196 CmdArgs.push_back(Args.MakeArgString(absFilename));
Nick Lewycky480cb992011-05-04 20:46:58 +00002197 }
2198 }
2199
Daniel Dunbarb25bfde2011-10-11 18:20:10 +00002200 // Pass options for controlling the default header search paths.
2201 if (Args.hasArg(options::OPT_nostdinc)) {
2202 CmdArgs.push_back("-nostdsysteminc");
2203 CmdArgs.push_back("-nobuiltininc");
2204 } else {
Daniel Dunbar0f41eee2011-10-11 18:20:16 +00002205 if (Args.hasArg(options::OPT_nostdlibinc))
2206 CmdArgs.push_back("-nostdsysteminc");
Daniel Dunbarb25bfde2011-10-11 18:20:10 +00002207 Args.AddLastArg(CmdArgs, options::OPT_nostdincxx);
2208 Args.AddLastArg(CmdArgs, options::OPT_nobuiltininc);
2209 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00002210
Daniel Dunbar34e0b8c2009-12-15 01:02:52 +00002211 // Pass the path to compiler resource files.
Daniel Dunbar34e0b8c2009-12-15 01:02:52 +00002212 CmdArgs.push_back("-resource-dir");
Daniel Dunbar3f3e2cd2010-01-20 02:35:16 +00002213 CmdArgs.push_back(D.ResourceDir.c_str());
Daniel Dunbar9dc82a22009-04-07 21:42:00 +00002214
Argyrios Kyrtzidis71731d62010-11-03 22:45:23 +00002215 Args.AddLastArg(CmdArgs, options::OPT_working_directory);
2216
Ted Kremenekf7639e12012-03-06 20:06:33 +00002217 bool ARCMTEnabled = false;
John McCalld70fb982011-06-15 23:25:17 +00002218 if (!Args.hasArg(options::OPT_fno_objc_arc)) {
Argyrios Kyrtzidisc44b93d2011-07-07 04:00:39 +00002219 if (const Arg *A = Args.getLastArg(options::OPT_ccc_arcmt_check,
Argyrios Kyrtzidis7fbd97f2011-07-09 20:00:58 +00002220 options::OPT_ccc_arcmt_modify,
2221 options::OPT_ccc_arcmt_migrate)) {
Ted Kremenekf7639e12012-03-06 20:06:33 +00002222 ARCMTEnabled = true;
John McCalld70fb982011-06-15 23:25:17 +00002223 switch (A->getOption().getID()) {
2224 default:
2225 llvm_unreachable("missed a case");
Argyrios Kyrtzidisc44b93d2011-07-07 04:00:39 +00002226 case options::OPT_ccc_arcmt_check:
John McCalld70fb982011-06-15 23:25:17 +00002227 CmdArgs.push_back("-arcmt-check");
2228 break;
Argyrios Kyrtzidisc44b93d2011-07-07 04:00:39 +00002229 case options::OPT_ccc_arcmt_modify:
John McCalld70fb982011-06-15 23:25:17 +00002230 CmdArgs.push_back("-arcmt-modify");
2231 break;
Argyrios Kyrtzidis7fbd97f2011-07-09 20:00:58 +00002232 case options::OPT_ccc_arcmt_migrate:
2233 CmdArgs.push_back("-arcmt-migrate");
Ted Kremenekf7639e12012-03-06 20:06:33 +00002234 CmdArgs.push_back("-mt-migrate-directory");
Richard Smithbd55daf2012-11-01 04:30:05 +00002235 CmdArgs.push_back(A->getValue());
Argyrios Kyrtzidisd5713632011-07-19 17:20:03 +00002236
2237 Args.AddLastArg(CmdArgs, options::OPT_arcmt_migrate_report_output);
2238 Args.AddLastArg(CmdArgs, options::OPT_arcmt_migrate_emit_arc_errors);
Argyrios Kyrtzidis7fbd97f2011-07-09 20:00:58 +00002239 break;
John McCalld70fb982011-06-15 23:25:17 +00002240 }
2241 }
2242 }
Eric Christopher84fbdb42011-08-19 00:30:14 +00002243
Ted Kremenekf7639e12012-03-06 20:06:33 +00002244 if (const Arg *A = Args.getLastArg(options::OPT_ccc_objcmt_migrate)) {
2245 if (ARCMTEnabled) {
2246 D.Diag(diag::err_drv_argument_not_allowed_with)
2247 << A->getAsString(Args) << "-ccc-arcmt-migrate";
2248 }
2249 CmdArgs.push_back("-mt-migrate-directory");
Richard Smithbd55daf2012-11-01 04:30:05 +00002250 CmdArgs.push_back(A->getValue());
Ted Kremenekf7639e12012-03-06 20:06:33 +00002251
2252 if (!Args.hasArg(options::OPT_objcmt_migrate_literals,
2253 options::OPT_objcmt_migrate_subscripting)) {
2254 // None specified, means enable them all.
2255 CmdArgs.push_back("-objcmt-migrate-literals");
2256 CmdArgs.push_back("-objcmt-migrate-subscripting");
2257 } else {
2258 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_literals);
2259 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_subscripting);
2260 }
2261 }
2262
Daniel Dunbard067f7f2009-04-08 23:54:23 +00002263 // Add preprocessing options like -I, -D, etc. if we are using the
2264 // preprocessor.
2265 //
2266 // FIXME: Support -fpreprocessed
Daniel Dunbard067f7f2009-04-08 23:54:23 +00002267 if (types::getPreprocessedType(InputType) != types::TY_INVALID)
Peter Collingbourne9b515cb2011-11-06 00:40:05 +00002268 AddPreprocessingOptions(C, D, Args, CmdArgs, Output, Inputs);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00002269
Rafael Espindolaa7431922011-07-21 23:40:37 +00002270 // Don't warn about "clang -c -DPIC -fPIC test.i" because libtool.m4 assumes
2271 // that "The compiler can only warn and ignore the option if not recognized".
2272 // When building with ccache, it will pass -D options to clang even on
2273 // preprocessed inputs and configure concludes that -fPIC is not supported.
2274 Args.ClaimAllArgs(options::OPT_D);
2275
Daniel Dunbar58f78332009-09-17 06:53:36 +00002276 // Manually translate -O to -O2 and -O4 to -O3; let clang reject
Daniel Dunbar13864952009-03-24 20:17:30 +00002277 // others.
2278 if (Arg *A = Args.getLastArg(options::OPT_O_Group)) {
Daniel Dunbar0bfb21e2009-11-19 03:26:40 +00002279 if (A->getOption().matches(options::OPT_O4))
Daniel Dunbar13864952009-03-24 20:17:30 +00002280 CmdArgs.push_back("-O3");
Daniel Dunbar9296f632010-05-27 06:51:08 +00002281 else if (A->getOption().matches(options::OPT_O) &&
Richard Smithbd55daf2012-11-01 04:30:05 +00002282 A->getValue()[0] == '\0')
Daniel Dunbar58f78332009-09-17 06:53:36 +00002283 CmdArgs.push_back("-O2");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00002284 else
Daniel Dunbar7ef5ed62009-03-18 23:39:35 +00002285 A->render(Args, CmdArgs);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00002286 }
2287
Daniel Dunbar945577c2009-10-29 02:24:45 +00002288 Args.AddAllArgs(CmdArgs, options::OPT_W_Group);
Ted Kremenekb22ea2a2012-07-07 05:53:30 +00002289 if (Args.hasFlag(options::OPT_pedantic, options::OPT_no_pedantic, false))
2290 CmdArgs.push_back("-pedantic");
Daniel Dunbar945577c2009-10-29 02:24:45 +00002291 Args.AddLastArg(CmdArgs, options::OPT_pedantic_errors);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00002292 Args.AddLastArg(CmdArgs, options::OPT_w);
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00002293
2294 // Handle -{std, ansi, trigraphs} -- take the last of -{std, ansi}
2295 // (-ansi is equivalent to -std=c89).
2296 //
2297 // If a std is supplied, only add -trigraphs if it follows the
2298 // option.
2299 if (Arg *Std = Args.getLastArg(options::OPT_std_EQ, options::OPT_ansi)) {
2300 if (Std->getOption().matches(options::OPT_ansi))
Nuno Lopes275225d2009-10-16 14:28:06 +00002301 if (types::isCXX(InputType))
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00002302 CmdArgs.push_back("-std=c++98");
Nuno Lopes275225d2009-10-16 14:28:06 +00002303 else
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00002304 CmdArgs.push_back("-std=c89");
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00002305 else
2306 Std->render(Args, CmdArgs);
2307
Daniel Dunbar3f1a1ff2010-06-14 21:23:08 +00002308 if (Arg *A = Args.getLastArg(options::OPT_std_EQ, options::OPT_ansi,
2309 options::OPT_trigraphs))
2310 if (A != Std)
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00002311 A->render(Args, CmdArgs);
Daniel Dunbar72a60902009-04-26 01:10:38 +00002312 } else {
2313 // Honor -std-default.
Daniel Dunbar12998192010-01-29 21:03:02 +00002314 //
2315 // FIXME: Clang doesn't correctly handle -std= when the input language
2316 // doesn't match. For the time being just ignore this for C++ inputs;
2317 // eventually we want to do all the standard defaulting here instead of
2318 // splitting it between the driver and clang -cc1.
2319 if (!types::isCXX(InputType))
Nico Weber723b4f02012-08-30 02:08:31 +00002320 Args.AddAllArgsTranslated(CmdArgs, options::OPT_std_default_EQ,
2321 "-std=", /*Joined=*/true);
2322 else if (getToolChain().getTriple().getOS() == llvm::Triple::Win32)
2323 CmdArgs.push_back("-std=c++11");
2324
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00002325 Args.AddLastArg(CmdArgs, options::OPT_trigraphs);
Daniel Dunbar72a60902009-04-26 01:10:38 +00002326 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00002327
Chandler Carruthb009b142011-04-23 06:30:43 +00002328 // Map the bizarre '-Wwrite-strings' flag to a more sensible
2329 // '-fconst-strings'; this better indicates its actual behavior.
2330 if (Args.hasFlag(options::OPT_Wwrite_strings, options::OPT_Wno_write_strings,
2331 false)) {
2332 // For perfect compatibility with GCC, we do this even in the presence of
2333 // '-w'. This flag names something other than a warning for GCC.
2334 CmdArgs.push_back("-fconst-strings");
2335 }
2336
Chandler Carruth61fbf622011-04-23 09:27:53 +00002337 // GCC provides a macro definition '__DEPRECATED' when -Wdeprecated is active
Chandler Carruth30483fb2011-04-23 19:48:40 +00002338 // during C++ compilation, which it is by default. GCC keeps this define even
2339 // in the presence of '-w', match this behavior bug-for-bug.
2340 if (types::isCXX(InputType) &&
2341 Args.hasFlag(options::OPT_Wdeprecated, options::OPT_Wno_deprecated,
2342 true)) {
2343 CmdArgs.push_back("-fdeprecated-macro");
Chandler Carruth61fbf622011-04-23 09:27:53 +00002344 }
2345
Chandler Carruthe0391482010-05-22 02:21:53 +00002346 // Translate GCC's misnamer '-fasm' arguments to '-fgnu-keywords'.
2347 if (Arg *Asm = Args.getLastArg(options::OPT_fasm, options::OPT_fno_asm)) {
2348 if (Asm->getOption().matches(options::OPT_fasm))
2349 CmdArgs.push_back("-fgnu-keywords");
2350 else
2351 CmdArgs.push_back("-fno-gnu-keywords");
2352 }
2353
Rafael Espindola4cfa7972011-05-02 17:43:32 +00002354 if (ShouldDisableCFI(Args, getToolChain()))
2355 CmdArgs.push_back("-fno-dwarf2-cfi-asm");
Rafael Espindolae2641872011-04-30 18:35:43 +00002356
Nick Lewycky1d617ac2011-10-17 23:05:52 +00002357 if (ShouldDisableDwarfDirectory(Args, getToolChain()))
2358 CmdArgs.push_back("-fno-dwarf-directory-asm");
2359
Nick Lewyckyba743b72011-10-21 02:32:14 +00002360 if (const char *pwd = ::getenv("PWD")) {
2361 // GCC also verifies that stat(pwd) and stat(".") have the same inode
2362 // number. Not doing those because stats are slow, but we could.
NAKAMURA Takumib5e6fa22011-10-22 10:25:25 +00002363 if (llvm::sys::path::is_absolute(pwd)) {
Nick Lewyckyba743b72011-10-21 02:32:14 +00002364 std::string CompDir = pwd;
2365 CmdArgs.push_back("-fdebug-compilation-dir");
2366 CmdArgs.push_back(Args.MakeArgString(CompDir));
2367 }
2368 }
2369
Richard Smith9a568822011-11-21 19:36:32 +00002370 if (Arg *A = Args.getLastArg(options::OPT_ftemplate_depth_,
2371 options::OPT_ftemplate_depth_EQ)) {
Daniel Dunbara2aedc62009-03-18 10:01:51 +00002372 CmdArgs.push_back("-ftemplate-depth");
Richard Smithbd55daf2012-11-01 04:30:05 +00002373 CmdArgs.push_back(A->getValue());
Daniel Dunbara2aedc62009-03-18 10:01:51 +00002374 }
2375
Richard Smith9a568822011-11-21 19:36:32 +00002376 if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_depth_EQ)) {
2377 CmdArgs.push_back("-fconstexpr-depth");
Richard Smithbd55daf2012-11-01 04:30:05 +00002378 CmdArgs.push_back(A->getValue());
Richard Smith9a568822011-11-21 19:36:32 +00002379 }
2380
Argyrios Kyrtzidisef6c8da2010-11-18 00:20:36 +00002381 if (Arg *A = Args.getLastArg(options::OPT_Wlarge_by_value_copy_EQ,
2382 options::OPT_Wlarge_by_value_copy_def)) {
Jean-Daniel Dupas73d801c2012-05-04 08:08:37 +00002383 if (A->getNumValues()) {
Richard Smithbd55daf2012-11-01 04:30:05 +00002384 StringRef bytes = A->getValue();
Jean-Daniel Dupas73d801c2012-05-04 08:08:37 +00002385 CmdArgs.push_back(Args.MakeArgString("-Wlarge-by-value-copy=" + bytes));
2386 } else
2387 CmdArgs.push_back("-Wlarge-by-value-copy=64"); // default value
Argyrios Kyrtzidisaf84ec02010-11-17 23:11:54 +00002388 }
2389
Nuno Lopes3d6311d2012-05-08 22:10:46 +00002390
Michael J. Spencer929fccd2012-10-22 22:13:48 +00002391 if (Args.hasArg(options::OPT_relocatable_pch))
Daniel Dunbar8bed86c2009-11-20 22:21:36 +00002392 CmdArgs.push_back("-relocatable-pch");
Mike Stump11289f42009-09-09 15:08:12 +00002393
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00002394 if (Arg *A = Args.getLastArg(options::OPT_fconstant_string_class_EQ)) {
2395 CmdArgs.push_back("-fconstant-string-class");
Richard Smithbd55daf2012-11-01 04:30:05 +00002396 CmdArgs.push_back(A->getValue());
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00002397 }
David Chisnall5778fce2009-08-31 16:41:57 +00002398
Chris Lattnere23003d2010-01-09 21:54:33 +00002399 if (Arg *A = Args.getLastArg(options::OPT_ftabstop_EQ)) {
2400 CmdArgs.push_back("-ftabstop");
Richard Smithbd55daf2012-11-01 04:30:05 +00002401 CmdArgs.push_back(A->getValue());
Chris Lattnere23003d2010-01-09 21:54:33 +00002402 }
2403
Chris Lattnerb35583d2010-04-07 20:49:23 +00002404 CmdArgs.push_back("-ferror-limit");
2405 if (Arg *A = Args.getLastArg(options::OPT_ferror_limit_EQ))
Richard Smithbd55daf2012-11-01 04:30:05 +00002406 CmdArgs.push_back(A->getValue());
Chris Lattnerb35583d2010-04-07 20:49:23 +00002407 else
2408 CmdArgs.push_back("19");
Douglas Gregorffed1cb2010-04-20 07:18:24 +00002409
Chandler Carrutha77a7272010-05-06 04:55:18 +00002410 if (Arg *A = Args.getLastArg(options::OPT_fmacro_backtrace_limit_EQ)) {
2411 CmdArgs.push_back("-fmacro-backtrace-limit");
Richard Smithbd55daf2012-11-01 04:30:05 +00002412 CmdArgs.push_back(A->getValue());
Chandler Carrutha77a7272010-05-06 04:55:18 +00002413 }
2414
2415 if (Arg *A = Args.getLastArg(options::OPT_ftemplate_backtrace_limit_EQ)) {
2416 CmdArgs.push_back("-ftemplate-backtrace-limit");
Richard Smithbd55daf2012-11-01 04:30:05 +00002417 CmdArgs.push_back(A->getValue());
Chandler Carrutha77a7272010-05-06 04:55:18 +00002418 }
2419
Richard Smithf6f003a2011-12-16 19:06:07 +00002420 if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_backtrace_limit_EQ)) {
2421 CmdArgs.push_back("-fconstexpr-backtrace-limit");
Richard Smithbd55daf2012-11-01 04:30:05 +00002422 CmdArgs.push_back(A->getValue());
Richard Smithf6f003a2011-12-16 19:06:07 +00002423 }
2424
Daniel Dunbar2c978472009-11-04 06:24:47 +00002425 // Pass -fmessage-length=.
Daniel Dunbar84bb7932009-11-30 08:40:54 +00002426 CmdArgs.push_back("-fmessage-length");
Daniel Dunbar2c978472009-11-04 06:24:47 +00002427 if (Arg *A = Args.getLastArg(options::OPT_fmessage_length_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00002428 CmdArgs.push_back(A->getValue());
Daniel Dunbar2c978472009-11-04 06:24:47 +00002429 } else {
2430 // If -fmessage-length=N was not specified, determine whether this is a
2431 // terminal and, if so, implicitly define -fmessage-length appropriately.
2432 unsigned N = llvm::sys::Process::StandardErrColumns();
Chris Lattner0e62c1c2011-07-23 10:55:15 +00002433 CmdArgs.push_back(Args.MakeArgString(Twine(N)));
Daniel Dunbar2c978472009-11-04 06:24:47 +00002434 }
2435
Daniel Dunbare357d562009-12-03 18:42:11 +00002436 if (const Arg *A = Args.getLastArg(options::OPT_fvisibility_EQ)) {
2437 CmdArgs.push_back("-fvisibility");
Richard Smithbd55daf2012-11-01 04:30:05 +00002438 CmdArgs.push_back(A->getValue());
Daniel Dunbare357d562009-12-03 18:42:11 +00002439 }
2440
Douglas Gregor08329632010-06-15 17:05:35 +00002441 Args.AddLastArg(CmdArgs, options::OPT_fvisibility_inlines_hidden);
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00002442
Hans Wennborgf60f6af2012-06-28 08:01:44 +00002443 Args.AddLastArg(CmdArgs, options::OPT_ftlsmodel_EQ);
2444
Daniel Dunbare46b52a2010-03-20 04:52:14 +00002445 // -fhosted is default.
Chad Rosier4fab82c2012-03-26 22:04:46 +00002446 if (Args.hasFlag(options::OPT_ffreestanding, options::OPT_fhosted, false) ||
2447 KernelOrKext)
Daniel Dunbare46b52a2010-03-20 04:52:14 +00002448 CmdArgs.push_back("-ffreestanding");
2449
Daniel Dunbare357d562009-12-03 18:42:11 +00002450 // Forward -f (flag) options which we can pass directly.
Daniel Dunbar3a148f22009-04-07 21:51:40 +00002451 Args.AddLastArg(CmdArgs, options::OPT_femit_all_decls);
Daniel Dunbar3a148f22009-04-07 21:51:40 +00002452 Args.AddLastArg(CmdArgs, options::OPT_fheinous_gnu_extensions);
Devang Patel91bbb552010-09-30 19:05:55 +00002453 Args.AddLastArg(CmdArgs, options::OPT_flimit_debug_info);
Devang Patel384dfa42011-11-04 20:05:58 +00002454 Args.AddLastArg(CmdArgs, options::OPT_fno_limit_debug_info);
Eric Christopher86050822011-10-25 07:13:06 +00002455 Args.AddLastArg(CmdArgs, options::OPT_fno_operator_names);
Anton Yartsev9b6b2e52011-12-23 20:23:19 +00002456 Args.AddLastArg(CmdArgs, options::OPT_faltivec);
Richard Trieu91844232012-06-26 18:18:47 +00002457 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_show_template_tree);
2458 Args.AddLastArg(CmdArgs, options::OPT_fno_elide_type);
Chad Rosier864dfe12012-03-13 23:45:51 +00002459
Alexey Samsonov627b10f2012-11-06 15:09:03 +00002460 SanitizerArgs Sanitize(D, Args);
Richard Smith52be6192012-11-05 22:04:41 +00002461 Sanitize.addArgs(Args, CmdArgs);
2462
Chad Rosier864dfe12012-03-13 23:45:51 +00002463 // Report and error for -faltivec on anything other then PowerPC.
2464 if (const Arg *A = Args.getLastArg(options::OPT_faltivec))
2465 if (!(getToolChain().getTriple().getArch() == llvm::Triple::ppc ||
2466 getToolChain().getTriple().getArch() == llvm::Triple::ppc64))
2467 D.Diag(diag::err_drv_argument_only_allowed_with)
2468 << A->getAsString(Args) << "ppc/ppc64";
2469
Daniel Dunbar733b0f82011-03-01 18:49:30 +00002470 if (getToolChain().SupportsProfiling())
2471 Args.AddLastArg(CmdArgs, options::OPT_pg);
Daniel Dunbar35621a92010-03-16 16:57:46 +00002472
2473 // -flax-vector-conversions is default.
2474 if (!Args.hasFlag(options::OPT_flax_vector_conversions,
2475 options::OPT_fno_lax_vector_conversions))
2476 CmdArgs.push_back("-fno-lax-vector-conversions");
2477
Fariborz Jahaniana4cfff82011-01-07 01:05:02 +00002478 if (Args.getLastArg(options::OPT_fapple_kext))
2479 CmdArgs.push_back("-fapple-kext");
2480
David Blaikie690f21e2012-06-14 18:55:27 +00002481 if (Args.hasFlag(options::OPT_frewrite_includes,
2482 options::OPT_fno_rewrite_includes, false))
2483 CmdArgs.push_back("-frewrite-includes");
2484
Fariborz Jahaniana4404f22009-05-22 20:17:16 +00002485 Args.AddLastArg(CmdArgs, options::OPT_fobjc_sender_dependent_dispatch);
Chris Lattner69686412009-04-21 05:34:31 +00002486 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_print_source_range_info);
Douglas Gregoreec975c2010-08-19 20:24:43 +00002487 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_parseable_fixits);
Daniel Dunbar3a148f22009-04-07 21:51:40 +00002488 Args.AddLastArg(CmdArgs, options::OPT_ftime_report);
2489 Args.AddLastArg(CmdArgs, options::OPT_ftrapv);
David Chisnalldd84ef12010-09-17 18:29:54 +00002490
2491 if (Arg *A = Args.getLastArg(options::OPT_ftrapv_handler_EQ)) {
2492 CmdArgs.push_back("-ftrapv-handler");
Richard Smithbd55daf2012-11-01 04:30:05 +00002493 CmdArgs.push_back(A->getValue());
David Chisnalldd84ef12010-09-17 18:29:54 +00002494 }
2495
Bob Wilson14adb362012-02-03 06:27:22 +00002496 Args.AddLastArg(CmdArgs, options::OPT_ftrap_function_EQ);
Evan Cheng04c94292011-04-08 21:37:45 +00002497
Chandler Carruth6e501032011-03-27 00:04:55 +00002498 // -fno-strict-overflow implies -fwrapv if it isn't disabled, but
2499 // -fstrict-overflow won't turn off an explicitly enabled -fwrapv.
2500 if (Arg *A = Args.getLastArg(options::OPT_fwrapv,
2501 options::OPT_fno_wrapv)) {
2502 if (A->getOption().matches(options::OPT_fwrapv))
2503 CmdArgs.push_back("-fwrapv");
2504 } else if (Arg *A = Args.getLastArg(options::OPT_fstrict_overflow,
2505 options::OPT_fno_strict_overflow)) {
2506 if (A->getOption().matches(options::OPT_fno_strict_overflow))
2507 CmdArgs.push_back("-fwrapv");
2508 }
Daniel Dunbar3a148f22009-04-07 21:51:40 +00002509 Args.AddLastArg(CmdArgs, options::OPT_fwritable_strings);
Eric Christopherf387dbd2010-08-07 23:08:14 +00002510 Args.AddLastArg(CmdArgs, options::OPT_funroll_loops);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00002511
Daniel Dunbara77eaeb2009-09-03 04:54:28 +00002512 Args.AddLastArg(CmdArgs, options::OPT_pthread);
2513
Mahesha S6a682be42012-10-27 07:47:56 +00002514
Daniel Dunbar4930e332009-11-17 08:07:36 +00002515 // -stack-protector=0 is default.
2516 unsigned StackProtectorLevel = 0;
Bill Wendlingd63bbad2009-06-28 07:36:13 +00002517 if (Arg *A = Args.getLastArg(options::OPT_fno_stack_protector,
2518 options::OPT_fstack_protector_all,
2519 options::OPT_fstack_protector)) {
Daniel Dunbar4930e332009-11-17 08:07:36 +00002520 if (A->getOption().matches(options::OPT_fstack_protector))
2521 StackProtectorLevel = 1;
2522 else if (A->getOption().matches(options::OPT_fstack_protector_all))
2523 StackProtectorLevel = 2;
Nico Weberdd473632011-08-23 07:38:27 +00002524 } else {
2525 StackProtectorLevel =
2526 getToolChain().GetDefaultStackProtectorLevel(KernelOrKext);
2527 }
Daniel Dunbar4930e332009-11-17 08:07:36 +00002528 if (StackProtectorLevel) {
2529 CmdArgs.push_back("-stack-protector");
Chris Lattner0e62c1c2011-07-23 10:55:15 +00002530 CmdArgs.push_back(Args.MakeArgString(Twine(StackProtectorLevel)));
Joerg Sonnenberger85e2bbc2012-09-12 13:51:14 +00002531 }
Chad Rosierdb3da832012-08-21 16:16:06 +00002532
Joerg Sonnenberger85e2bbc2012-09-12 13:51:14 +00002533 // --param ssp-buffer-size=
2534 for (arg_iterator it = Args.filtered_begin(options::OPT__param),
2535 ie = Args.filtered_end(); it != ie; ++it) {
Richard Smithbd55daf2012-11-01 04:30:05 +00002536 StringRef Str((*it)->getValue());
Joerg Sonnenberger85e2bbc2012-09-12 13:51:14 +00002537 if (Str.startswith("ssp-buffer-size=")) {
2538 if (StackProtectorLevel) {
Chad Rosierdb3da832012-08-21 16:16:06 +00002539 CmdArgs.push_back("-stack-protector-buffer-size");
2540 // FIXME: Verify the argument is a valid integer.
2541 CmdArgs.push_back(Args.MakeArgString(Str.drop_front(16)));
Chad Rosierdb3da832012-08-21 16:16:06 +00002542 }
Joerg Sonnenberger85e2bbc2012-09-12 13:51:14 +00002543 (*it)->claim();
Chad Rosierdb3da832012-08-21 16:16:06 +00002544 }
Bill Wendlingd63bbad2009-06-28 07:36:13 +00002545 }
2546
Nick Lewyckyf4d3f7a2011-12-06 03:33:03 +00002547 // Translate -mstackrealign
2548 if (Args.hasFlag(options::OPT_mstackrealign, options::OPT_mno_stackrealign,
2549 false)) {
2550 CmdArgs.push_back("-backend-option");
2551 CmdArgs.push_back("-force-align-stack");
2552 }
2553 if (!Args.hasFlag(options::OPT_mno_stackrealign, options::OPT_mstackrealign,
2554 false)) {
2555 CmdArgs.push_back(Args.MakeArgString("-mstackrealign"));
2556 }
2557
Joerg Sonnenbergerdb66ed02011-12-05 23:05:23 +00002558 if (Args.hasArg(options::OPT_mstack_alignment)) {
2559 StringRef alignment = Args.getLastArgValue(options::OPT_mstack_alignment);
2560 CmdArgs.push_back(Args.MakeArgString("-mstack-alignment=" + alignment));
Eric Christopherd5c45f62011-05-02 21:18:22 +00002561 }
Chad Rosier9ae53f82012-11-29 00:42:06 +00002562 // -mkernel implies -mstrict-align; don't add the redundant option.
2563 if (Args.hasArg(options::OPT_mstrict_align) && !KernelOrKext) {
Chad Rosierd87e4f72012-11-09 18:27:01 +00002564 CmdArgs.push_back("-backend-option");
2565 CmdArgs.push_back("-arm-strict-align");
Chad Rosier60027022012-11-09 17:29:19 +00002566 }
Eric Christopher84fbdb42011-08-19 00:30:14 +00002567
Daniel Dunbard18049a2009-04-07 21:16:11 +00002568 // Forward -f options with positive and negative forms; we translate
2569 // these by hand.
2570
Fariborz Jahaniana4cfff82011-01-07 01:05:02 +00002571 if (Args.hasArg(options::OPT_mkernel)) {
Daniel Dunbar80f787c2011-02-04 17:24:47 +00002572 if (!Args.hasArg(options::OPT_fapple_kext) && types::isCXX(InputType))
Fariborz Jahaniana4cfff82011-01-07 01:05:02 +00002573 CmdArgs.push_back("-fapple-kext");
2574 if (!Args.hasArg(options::OPT_fbuiltin))
2575 CmdArgs.push_back("-fno-builtin");
Chad Rosierf27e1c42012-03-26 21:29:17 +00002576 Args.ClaimAllArgs(options::OPT_fno_builtin);
Fariborz Jahaniana4cfff82011-01-07 01:05:02 +00002577 }
Daniel Dunbar4930e332009-11-17 08:07:36 +00002578 // -fbuiltin is default.
Fariborz Jahaniana4cfff82011-01-07 01:05:02 +00002579 else if (!Args.hasFlag(options::OPT_fbuiltin, options::OPT_fno_builtin))
Daniel Dunbar484afa22009-11-19 04:55:23 +00002580 CmdArgs.push_back("-fno-builtin");
Daniel Dunbard18049a2009-04-07 21:16:11 +00002581
Nuno Lopes13c88c72009-12-16 16:59:22 +00002582 if (!Args.hasFlag(options::OPT_fassume_sane_operator_new,
2583 options::OPT_fno_assume_sane_operator_new))
2584 CmdArgs.push_back("-fno-assume-sane-operator-new");
2585
Daniel Dunbar4930e332009-11-17 08:07:36 +00002586 // -fblocks=0 is default.
2587 if (Args.hasFlag(options::OPT_fblocks, options::OPT_fno_blocks,
David Chisnallda209912011-02-28 17:11:43 +00002588 getToolChain().IsBlocksDefault()) ||
2589 (Args.hasArg(options::OPT_fgnu_runtime) &&
2590 Args.hasArg(options::OPT_fobjc_nonfragile_abi) &&
2591 !Args.hasArg(options::OPT_fno_blocks))) {
Daniel Dunbar4930e332009-11-17 08:07:36 +00002592 CmdArgs.push_back("-fblocks");
John McCall7959fee2011-09-09 20:41:01 +00002593
2594 if (!Args.hasArg(options::OPT_fgnu_runtime) &&
2595 !getToolChain().hasBlocksRuntime())
2596 CmdArgs.push_back("-fblocks-runtime-optional");
David Chisnall950a9512009-11-17 19:33:30 +00002597 }
Daniel Dunbard18049a2009-04-07 21:16:11 +00002598
Douglas Gregor226173a2012-01-18 15:19:58 +00002599 // -fmodules enables modules (off by default). However, for C++/Objective-C++,
2600 // users must also pass -fcxx-modules. The latter flag will disappear once the
2601 // modules implementation is solid for C++/Objective-C++ programs as well.
2602 if (Args.hasFlag(options::OPT_fmodules, options::OPT_fno_modules, false)) {
2603 bool AllowedInCXX = Args.hasFlag(options::OPT_fcxx_modules,
2604 options::OPT_fno_cxx_modules,
2605 false);
2606 if (AllowedInCXX || !types::isCXX(InputType))
2607 CmdArgs.push_back("-fmodules");
2608 }
Douglas Gregor787869b2012-01-03 17:13:05 +00002609
John McCalldfea9982010-04-09 19:12:06 +00002610 // -faccess-control is default.
John McCall3155f572010-04-09 19:03:51 +00002611 if (Args.hasFlag(options::OPT_fno_access_control,
2612 options::OPT_faccess_control,
John McCalldfea9982010-04-09 19:12:06 +00002613 false))
John McCall3155f572010-04-09 19:03:51 +00002614 CmdArgs.push_back("-fno-access-control");
John McCall59bb1d42010-03-17 01:32:13 +00002615
Anders Carlssond470fef2010-11-21 00:09:52 +00002616 // -felide-constructors is the default.
2617 if (Args.hasFlag(options::OPT_fno_elide_constructors,
2618 options::OPT_felide_constructors,
2619 false))
2620 CmdArgs.push_back("-fno-elide-constructors");
2621
Daniel Dunbar0730e4f2009-11-17 07:06:20 +00002622 // -frtti is default.
Chad Rosier4fab82c2012-03-26 22:04:46 +00002623 if (!Args.hasFlag(options::OPT_frtti, options::OPT_fno_rtti) ||
Richard Smith52be6192012-11-05 22:04:41 +00002624 KernelOrKext) {
Daniel Dunbar484afa22009-11-19 04:55:23 +00002625 CmdArgs.push_back("-fno-rtti");
Mike Stump183c3d22009-07-31 23:15:31 +00002626
Richard Smith52be6192012-11-05 22:04:41 +00002627 // -fno-rtti cannot usefully be combined with -fsanitize=vptr.
Alexey Samsonov627b10f2012-11-06 15:09:03 +00002628 if (Sanitize.sanitizesVptr()) {
NAKAMURA Takumiab060362012-11-06 22:02:00 +00002629 std::string NoRttiArg =
Richard Smith52be6192012-11-05 22:04:41 +00002630 Args.getLastArg(options::OPT_mkernel,
2631 options::OPT_fapple_kext,
Richard Smithaa716572012-11-06 01:12:02 +00002632 options::OPT_fno_rtti)->getAsString(Args);
Richard Smith52be6192012-11-05 22:04:41 +00002633 D.Diag(diag::err_drv_argument_not_allowed_with)
2634 << "-fsanitize=vptr" << NoRttiArg;
2635 }
2636 }
2637
Tony Linthicum76329bf2011-12-12 21:14:55 +00002638 // -fshort-enums=0 is default for all architectures except Hexagon.
Argyrios Kyrtzidis74825bc2010-10-08 00:25:19 +00002639 if (Args.hasFlag(options::OPT_fshort_enums,
Tony Linthicum76329bf2011-12-12 21:14:55 +00002640 options::OPT_fno_short_enums,
2641 getToolChain().getTriple().getArch() ==
2642 llvm::Triple::hexagon))
Argyrios Kyrtzidis74825bc2010-10-08 00:25:19 +00002643 CmdArgs.push_back("-fshort-enums");
2644
Daniel Dunbard609b7b2009-11-17 06:37:03 +00002645 // -fsigned-char is default.
Daniel Dunbar5bdd2992009-11-25 10:14:30 +00002646 if (!Args.hasFlag(options::OPT_fsigned_char, options::OPT_funsigned_char,
Daniel Dunbard609b7b2009-11-17 06:37:03 +00002647 isSignedCharDefault(getToolChain().getTriple())))
Daniel Dunbar5fe08662009-11-29 02:39:08 +00002648 CmdArgs.push_back("-fno-signed-char");
Eli Friedman327f0b52009-06-05 07:21:14 +00002649
Anders Carlssonfcd764a2010-02-06 23:23:06 +00002650 // -fthreadsafe-static is default.
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00002651 if (!Args.hasFlag(options::OPT_fthreadsafe_statics,
Anders Carlssonfcd764a2010-02-06 23:23:06 +00002652 options::OPT_fno_threadsafe_statics))
2653 CmdArgs.push_back("-fno-threadsafe-statics");
2654
Daniel Dunbarfe06df42010-03-20 04:15:41 +00002655 // -fuse-cxa-atexit is default.
Chad Rosier4fab82c2012-03-26 22:04:46 +00002656 if (!Args.hasFlag(options::OPT_fuse_cxa_atexit,
2657 options::OPT_fno_use_cxa_atexit,
2658 getToolChain().getTriple().getOS() != llvm::Triple::Cygwin &&
Tony Linthicum76329bf2011-12-12 21:14:55 +00002659 getToolChain().getTriple().getOS() != llvm::Triple::MinGW32 &&
Chad Rosier4fab82c2012-03-26 22:04:46 +00002660 getToolChain().getTriple().getArch() != llvm::Triple::hexagon) ||
2661 KernelOrKext)
Daniel Dunbarfe06df42010-03-20 04:15:41 +00002662 CmdArgs.push_back("-fno-use-cxa-atexit");
2663
Daniel Dunbar0730e4f2009-11-17 07:06:20 +00002664 // -fms-extensions=0 is default.
Daniel Dunbar5bdd2992009-11-25 10:14:30 +00002665 if (Args.hasFlag(options::OPT_fms_extensions, options::OPT_fno_ms_extensions,
Daniel Dunbar0730e4f2009-11-17 07:06:20 +00002666 getToolChain().getTriple().getOS() == llvm::Triple::Win32))
2667 CmdArgs.push_back("-fms-extensions");
2668
Chad Rosiered943242012-07-20 21:20:33 +00002669 // -fms-inline-asm.
Chad Rosierd3957e52012-07-20 23:12:26 +00002670 if (Args.hasArg(options::OPT_fenable_experimental_ms_inline_asm))
2671 CmdArgs.push_back("-fenable-experimental-ms-inline-asm");
Chad Rosiered943242012-07-20 21:20:33 +00002672
Francois Pichet1b4f1632011-09-17 04:32:15 +00002673 // -fms-compatibility=0 is default.
Douglas Gregor2b4907e2011-10-24 15:49:38 +00002674 if (Args.hasFlag(options::OPT_fms_compatibility,
2675 options::OPT_fno_ms_compatibility,
2676 (getToolChain().getTriple().getOS() == llvm::Triple::Win32 &&
2677 Args.hasFlag(options::OPT_fms_extensions,
2678 options::OPT_fno_ms_extensions,
2679 true))))
Francois Pichet1b4f1632011-09-17 04:32:15 +00002680 CmdArgs.push_back("-fms-compatibility");
2681
Michael J. Spencer4992ca4b2010-10-21 05:21:48 +00002682 // -fmsc-version=1300 is default.
2683 if (Args.hasFlag(options::OPT_fms_extensions, options::OPT_fno_ms_extensions,
2684 getToolChain().getTriple().getOS() == llvm::Triple::Win32) ||
2685 Args.hasArg(options::OPT_fmsc_version)) {
Chris Lattner0e62c1c2011-07-23 10:55:15 +00002686 StringRef msc_ver = Args.getLastArgValue(options::OPT_fmsc_version);
Michael J. Spencer4992ca4b2010-10-21 05:21:48 +00002687 if (msc_ver.empty())
2688 CmdArgs.push_back("-fmsc-version=1300");
2689 else
2690 CmdArgs.push_back(Args.MakeArgString("-fmsc-version=" + msc_ver));
2691 }
2692
2693
Dawn Perchik68bb1b42010-09-02 23:59:25 +00002694 // -fborland-extensions=0 is default.
2695 if (Args.hasFlag(options::OPT_fborland_extensions,
2696 options::OPT_fno_borland_extensions, false))
2697 CmdArgs.push_back("-fborland-extensions");
2698
Francois Pichet02744872011-09-01 16:38:08 +00002699 // -fno-delayed-template-parsing is default, except for Windows where MSVC STL
2700 // needs it.
Francois Pichet1c229c02011-04-22 22:18:13 +00002701 if (Args.hasFlag(options::OPT_fdelayed_template_parsing,
2702 options::OPT_fno_delayed_template_parsing,
Francois Pichet02744872011-09-01 16:38:08 +00002703 getToolChain().getTriple().getOS() == llvm::Triple::Win32))
Francois Pichet35bc5de2011-08-26 00:22:34 +00002704 CmdArgs.push_back("-fdelayed-template-parsing");
Francois Pichet1c229c02011-04-22 22:18:13 +00002705
Chandler Carruthe03aa552010-04-17 20:17:31 +00002706 // -fgnu-keywords default varies depending on language; only pass if
2707 // specified.
2708 if (Arg *A = Args.getLastArg(options::OPT_fgnu_keywords,
Daniel Dunbardb059592010-04-24 17:56:39 +00002709 options::OPT_fno_gnu_keywords))
2710 A->render(Args, CmdArgs);
Chandler Carruthe03aa552010-04-17 20:17:31 +00002711
Rafael Espindola922a6242011-06-02 17:30:53 +00002712 if (Args.hasFlag(options::OPT_fgnu89_inline,
2713 options::OPT_fno_gnu89_inline,
2714 false))
Rafael Espindolafb2af642011-06-02 16:13:27 +00002715 CmdArgs.push_back("-fgnu89-inline");
2716
Chad Rosier9c76d242012-03-15 22:31:42 +00002717 if (Args.hasArg(options::OPT_fno_inline))
2718 CmdArgs.push_back("-fno-inline");
2719
Chad Rosier64d6be92012-03-06 21:17:19 +00002720 if (Args.hasArg(options::OPT_fno_inline_functions))
2721 CmdArgs.push_back("-fno-inline-functions");
Chad Rosier80603182012-03-06 18:49:20 +00002722
John McCall5fb5df92012-06-20 06:18:46 +00002723 ObjCRuntime objcRuntime = AddObjCRuntimeArgs(Args, CmdArgs, rewriteKind);
John McCall24fc0de2011-07-06 00:26:06 +00002724
John McCall5fb5df92012-06-20 06:18:46 +00002725 // -fobjc-dispatch-method is only relevant with the nonfragile-abi, and
2726 // legacy is the default.
2727 if (objcRuntime.isNonFragile()) {
David Chisnall3154e682011-09-30 13:32:35 +00002728 if (!Args.hasFlag(options::OPT_fobjc_legacy_dispatch,
2729 options::OPT_fno_objc_legacy_dispatch,
David Chisnallda225352012-07-04 11:52:24 +00002730 objcRuntime.isLegacyDispatchDefaultForArch(
2731 getToolChain().getTriple().getArch()))) {
David Chisnall3154e682011-09-30 13:32:35 +00002732 if (getToolChain().UseObjCMixedDispatch())
2733 CmdArgs.push_back("-fobjc-dispatch-method=mixed");
2734 else
2735 CmdArgs.push_back("-fobjc-dispatch-method=non-legacy");
2736 }
2737 }
2738
Nico Weber97bd94b2012-03-09 21:19:44 +00002739 // -fobjc-default-synthesize-properties=1 is default. This only has an effect
2740 // if the nonfragile objc abi is used.
Fariborz Jahanian05684072012-04-09 18:58:55 +00002741 if (getToolChain().IsObjCDefaultSynthPropertiesDefault()) {
David Chisnall3154e682011-09-30 13:32:35 +00002742 CmdArgs.push_back("-fobjc-default-synthesize-properties");
2743 }
2744
Fariborz Jahanian0e3043b2012-11-15 19:02:45 +00002745 // -fencode-extended-block-signature=1 is default.
2746 if (getToolChain().IsEncodeExtendedBlockSignatureDefault()) {
2747 CmdArgs.push_back("-fencode-extended-block-signature");
2748 }
2749
John McCall24fc0de2011-07-06 00:26:06 +00002750 // Allow -fno-objc-arr to trump -fobjc-arr/-fobjc-arc.
2751 // NOTE: This logic is duplicated in ToolChains.cpp.
2752 bool ARC = isObjCAutoRefCount(Args);
2753 if (ARC) {
John McCall3deb1ad2012-08-21 02:47:43 +00002754 getToolChain().CheckObjCARC();
Argyrios Kyrtzidis3dbeb552012-02-29 03:43:52 +00002755
John McCall24fc0de2011-07-06 00:26:06 +00002756 CmdArgs.push_back("-fobjc-arc");
2757
Chandler Carruth491db322011-11-04 07:34:47 +00002758 // FIXME: It seems like this entire block, and several around it should be
2759 // wrapped in isObjC, but for now we just use it here as this is where it
2760 // was being used previously.
2761 if (types::isCXX(InputType) && types::isObjC(InputType)) {
2762 if (getToolChain().GetCXXStdlibType(Args) == ToolChain::CST_Libcxx)
2763 CmdArgs.push_back("-fobjc-arc-cxxlib=libc++");
2764 else
2765 CmdArgs.push_back("-fobjc-arc-cxxlib=libstdc++");
2766 }
2767
John McCall24fc0de2011-07-06 00:26:06 +00002768 // Allow the user to enable full exceptions code emission.
2769 // We define off for Objective-CC, on for Objective-C++.
2770 if (Args.hasFlag(options::OPT_fobjc_arc_exceptions,
2771 options::OPT_fno_objc_arc_exceptions,
2772 /*default*/ types::isCXX(InputType)))
2773 CmdArgs.push_back("-fobjc-arc-exceptions");
2774 }
2775
2776 // -fobjc-infer-related-result-type is the default, except in the Objective-C
2777 // rewriter.
John McCall5fb5df92012-06-20 06:18:46 +00002778 if (rewriteKind != RK_None)
John McCall24fc0de2011-07-06 00:26:06 +00002779 CmdArgs.push_back("-fno-objc-infer-related-result-type");
Eric Christopher84fbdb42011-08-19 00:30:14 +00002780
John McCall24fc0de2011-07-06 00:26:06 +00002781 // Handle -fobjc-gc and -fobjc-gc-only. They are exclusive, and -fobjc-gc-only
2782 // takes precedence.
2783 const Arg *GCArg = Args.getLastArg(options::OPT_fobjc_gc_only);
2784 if (!GCArg)
2785 GCArg = Args.getLastArg(options::OPT_fobjc_gc);
2786 if (GCArg) {
2787 if (ARC) {
Chris Lattner0e62c1c2011-07-23 10:55:15 +00002788 D.Diag(diag::err_drv_objc_gc_arr)
John McCall24fc0de2011-07-06 00:26:06 +00002789 << GCArg->getAsString(Args);
2790 } else if (getToolChain().SupportsObjCGC()) {
2791 GCArg->render(Args, CmdArgs);
2792 } else {
2793 // FIXME: We should move this to a hard error.
Chris Lattner0e62c1c2011-07-23 10:55:15 +00002794 D.Diag(diag::warn_drv_objc_gc_unsupported)
John McCall24fc0de2011-07-06 00:26:06 +00002795 << GCArg->getAsString(Args);
2796 }
2797 }
2798
John McCallb5f652e2011-06-22 00:53:57 +00002799 // Add exception args.
2800 addExceptionArgs(Args, InputType, getToolChain().getTriple(),
John McCall5fb5df92012-06-20 06:18:46 +00002801 KernelOrKext, objcRuntime, CmdArgs);
John McCallb5f652e2011-06-22 00:53:57 +00002802
2803 if (getToolChain().UseSjLjExceptions())
2804 CmdArgs.push_back("-fsjlj-exceptions");
2805
2806 // C++ "sane" operator new.
Daniel Dunbar2e3f2c82010-02-01 21:07:25 +00002807 if (!Args.hasFlag(options::OPT_fassume_sane_operator_new,
2808 options::OPT_fno_assume_sane_operator_new))
2809 CmdArgs.push_back("-fno-assume-sane-operator-new");
2810
Daniel Dunbar34d7a992010-04-27 15:34:57 +00002811 // -fconstant-cfstrings is default, and may be subject to argument translation
2812 // on Darwin.
2813 if (!Args.hasFlag(options::OPT_fconstant_cfstrings,
2814 options::OPT_fno_constant_cfstrings) ||
2815 !Args.hasFlag(options::OPT_mconstant_cfstrings,
2816 options::OPT_mno_constant_cfstrings))
2817 CmdArgs.push_back("-fno-constant-cfstrings");
2818
John Thompsoned4e2952009-11-05 20:14:16 +00002819 // -fshort-wchar default varies depending on platform; only
2820 // pass if specified.
Daniel Dunbar2cb4e7a2010-04-27 15:35:03 +00002821 if (Arg *A = Args.getLastArg(options::OPT_fshort_wchar))
2822 A->render(Args, CmdArgs);
John Thompsoned4e2952009-11-05 20:14:16 +00002823
Daniel Dunbar1a8a2e82009-10-29 02:39:57 +00002824 // -fno-pascal-strings is default, only pass non-default. If the tool chain
2825 // happened to translate to -mpascal-strings, we want to back translate here.
Daniel Dunbard4510f22009-04-07 23:51:44 +00002826 //
2827 // FIXME: This is gross; that translation should be pulled from the
2828 // tool chain.
Daniel Dunbard067f7f2009-04-08 23:54:23 +00002829 if (Args.hasFlag(options::OPT_fpascal_strings,
Daniel Dunbard4510f22009-04-07 23:51:44 +00002830 options::OPT_fno_pascal_strings,
2831 false) ||
2832 Args.hasFlag(options::OPT_mpascal_strings,
2833 options::OPT_mno_pascal_strings,
2834 false))
Daniel Dunbard18049a2009-04-07 21:16:11 +00002835 CmdArgs.push_back("-fpascal-strings");
NAKAMURA Takumi029d74b2011-02-17 08:50:50 +00002836
Daniel Dunbar096ed292011-10-05 21:04:55 +00002837 // Honor -fpack-struct= and -fpack-struct, if given. Note that
2838 // -fno-pack-struct doesn't apply to -fpack-struct=.
2839 if (Arg *A = Args.getLastArg(options::OPT_fpack_struct_EQ)) {
James Molloycebf75e2012-05-02 07:56:14 +00002840 std::string PackStructStr = "-fpack-struct=";
Richard Smithbd55daf2012-11-01 04:30:05 +00002841 PackStructStr += A->getValue();
James Molloycebf75e2012-05-02 07:56:14 +00002842 CmdArgs.push_back(Args.MakeArgString(PackStructStr));
Daniel Dunbar096ed292011-10-05 21:04:55 +00002843 } else if (Args.hasFlag(options::OPT_fpack_struct,
2844 options::OPT_fno_pack_struct, false)) {
James Molloycebf75e2012-05-02 07:56:14 +00002845 CmdArgs.push_back("-fpack-struct=1");
Daniel Dunbar096ed292011-10-05 21:04:55 +00002846 }
2847
Fariborz Jahaniana4cfff82011-01-07 01:05:02 +00002848 if (Args.hasArg(options::OPT_mkernel) ||
2849 Args.hasArg(options::OPT_fapple_kext)) {
2850 if (!Args.hasArg(options::OPT_fcommon))
2851 CmdArgs.push_back("-fno-common");
Chad Rosierd9d80e02012-03-26 21:35:40 +00002852 Args.ClaimAllArgs(options::OPT_fno_common);
Fariborz Jahaniana4cfff82011-01-07 01:05:02 +00002853 }
Daniel Dunbar096ed292011-10-05 21:04:55 +00002854
Daniel Dunbard18049a2009-04-07 21:16:11 +00002855 // -fcommon is default, only pass non-default.
Fariborz Jahaniana4cfff82011-01-07 01:05:02 +00002856 else if (!Args.hasFlag(options::OPT_fcommon, options::OPT_fno_common))
Daniel Dunbard18049a2009-04-07 21:16:11 +00002857 CmdArgs.push_back("-fno-common");
2858
Daniel Dunbar2edd9232009-04-15 02:37:43 +00002859 // -fsigned-bitfields is default, and clang doesn't yet support
Daniel Dunbar6358d682010-10-15 22:30:42 +00002860 // -funsigned-bitfields.
Mike Stump11289f42009-09-09 15:08:12 +00002861 if (!Args.hasFlag(options::OPT_fsigned_bitfields,
Daniel Dunbar2edd9232009-04-15 02:37:43 +00002862 options::OPT_funsigned_bitfields))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00002863 D.Diag(diag::warn_drv_clang_unsupported)
Daniel Dunbar2edd9232009-04-15 02:37:43 +00002864 << Args.getLastArg(options::OPT_funsigned_bitfields)->getAsString(Args);
2865
Daniel Dunbar6358d682010-10-15 22:30:42 +00002866 // -fsigned-bitfields is default, and clang doesn't support -fno-for-scope.
2867 if (!Args.hasFlag(options::OPT_ffor_scope,
2868 options::OPT_fno_for_scope))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00002869 D.Diag(diag::err_drv_clang_unsupported)
Daniel Dunbar6358d682010-10-15 22:30:42 +00002870 << Args.getLastArg(options::OPT_fno_for_scope)->getAsString(Args);
2871
Jeffrey Yasskin460aa542010-06-08 04:56:20 +00002872 // -fcaret-diagnostics is default.
2873 if (!Args.hasFlag(options::OPT_fcaret_diagnostics,
2874 options::OPT_fno_caret_diagnostics, true))
2875 CmdArgs.push_back("-fno-caret-diagnostics");
2876
Daniel Dunbar8281bde2009-04-19 21:09:34 +00002877 // -fdiagnostics-fixit-info is default, only pass non-default.
Mike Stump11289f42009-09-09 15:08:12 +00002878 if (!Args.hasFlag(options::OPT_fdiagnostics_fixit_info,
Daniel Dunbar8281bde2009-04-19 21:09:34 +00002879 options::OPT_fno_diagnostics_fixit_info))
2880 CmdArgs.push_back("-fno-diagnostics-fixit-info");
Eric Christopher84fbdb42011-08-19 00:30:14 +00002881
Daniel Dunbar092f0cc2009-04-16 06:32:38 +00002882 // Enable -fdiagnostics-show-option by default.
Mike Stump11289f42009-09-09 15:08:12 +00002883 if (Args.hasFlag(options::OPT_fdiagnostics_show_option,
Daniel Dunbar092f0cc2009-04-16 06:32:38 +00002884 options::OPT_fno_diagnostics_show_option))
2885 CmdArgs.push_back("-fdiagnostics-show-option");
Daniel Dunbar5ec95022009-11-04 06:24:57 +00002886
Chris Lattnerbf6fac82010-05-04 21:55:25 +00002887 if (const Arg *A =
2888 Args.getLastArg(options::OPT_fdiagnostics_show_category_EQ)) {
2889 CmdArgs.push_back("-fdiagnostics-show-category");
Richard Smithbd55daf2012-11-01 04:30:05 +00002890 CmdArgs.push_back(A->getValue());
Chris Lattnerbf6fac82010-05-04 21:55:25 +00002891 }
Daniel Dunbarfe6c97b2010-08-24 16:47:49 +00002892
Douglas Gregor643c9222011-05-21 17:07:29 +00002893 if (const Arg *A =
2894 Args.getLastArg(options::OPT_fdiagnostics_format_EQ)) {
2895 CmdArgs.push_back("-fdiagnostics-format");
Richard Smithbd55daf2012-11-01 04:30:05 +00002896 CmdArgs.push_back(A->getValue());
Douglas Gregor643c9222011-05-21 17:07:29 +00002897 }
2898
Chandler Carruthb6766f02011-03-27 01:50:55 +00002899 if (Arg *A = Args.getLastArg(
2900 options::OPT_fdiagnostics_show_note_include_stack,
2901 options::OPT_fno_diagnostics_show_note_include_stack)) {
2902 if (A->getOption().matches(
2903 options::OPT_fdiagnostics_show_note_include_stack))
2904 CmdArgs.push_back("-fdiagnostics-show-note-include-stack");
2905 else
2906 CmdArgs.push_back("-fno-diagnostics-show-note-include-stack");
2907 }
2908
Daniel Dunbar5ec95022009-11-04 06:24:57 +00002909 // Color diagnostics are the default, unless the terminal doesn't support
2910 // them.
2911 if (Args.hasFlag(options::OPT_fcolor_diagnostics,
Argyrios Kyrtzidis4f920162010-09-23 12:56:06 +00002912 options::OPT_fno_color_diagnostics,
2913 llvm::sys::Process::StandardErrHasColors()))
Daniel Dunbar5ec95022009-11-04 06:24:57 +00002914 CmdArgs.push_back("-fcolor-diagnostics");
2915
Daniel Dunbardb097022009-06-08 21:13:54 +00002916 if (!Args.hasFlag(options::OPT_fshow_source_location,
2917 options::OPT_fno_show_source_location))
2918 CmdArgs.push_back("-fno-show-source-location");
Daniel Dunbar092f0cc2009-04-16 06:32:38 +00002919
Douglas Gregor643c9222011-05-21 17:07:29 +00002920 if (!Args.hasFlag(options::OPT_fshow_column,
2921 options::OPT_fno_show_column,
2922 true))
2923 CmdArgs.push_back("-fno-show-column");
2924
Douglas Gregor8ed0c0b2010-07-09 17:35:33 +00002925 if (!Args.hasFlag(options::OPT_fspell_checking,
2926 options::OPT_fno_spell_checking))
2927 CmdArgs.push_back("-fno-spell-checking");
Daniel Dunbarfe6c97b2010-08-24 16:47:49 +00002928
Daniel Dunbar473f8a62010-10-18 22:49:46 +00002929
Daniel Dunbar3ada2b72010-11-02 19:42:04 +00002930 // Silently ignore -fasm-blocks for now.
2931 (void) Args.hasFlag(options::OPT_fasm_blocks, options::OPT_fno_asm_blocks,
2932 false);
Daniel Dunbar473f8a62010-10-18 22:49:46 +00002933
Jeffrey Yasskin2b99c6f2010-06-11 05:57:47 +00002934 if (Arg *A = Args.getLastArg(options::OPT_fshow_overloads_EQ))
2935 A->render(Args, CmdArgs);
2936
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00002937 // -fdollars-in-identifiers default varies depending on platform and
2938 // language; only pass if specified.
Mike Stump11289f42009-09-09 15:08:12 +00002939 if (Arg *A = Args.getLastArg(options::OPT_fdollars_in_identifiers,
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00002940 options::OPT_fno_dollars_in_identifiers)) {
2941 if (A->getOption().matches(options::OPT_fdollars_in_identifiers))
Daniel Dunbar15cef0e2009-12-16 20:10:18 +00002942 CmdArgs.push_back("-fdollars-in-identifiers");
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00002943 else
Daniel Dunbar15cef0e2009-12-16 20:10:18 +00002944 CmdArgs.push_back("-fno-dollars-in-identifiers");
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00002945 }
2946
Daniel Dunbaradeeb052009-05-22 19:02:20 +00002947 // -funit-at-a-time is default, and we don't support -fno-unit-at-a-time for
2948 // practical purposes.
Mike Stump11289f42009-09-09 15:08:12 +00002949 if (Arg *A = Args.getLastArg(options::OPT_funit_at_a_time,
Daniel Dunbaradeeb052009-05-22 19:02:20 +00002950 options::OPT_fno_unit_at_a_time)) {
2951 if (A->getOption().matches(options::OPT_fno_unit_at_a_time))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00002952 D.Diag(diag::warn_drv_clang_unsupported) << A->getAsString(Args);
Daniel Dunbaradeeb052009-05-22 19:02:20 +00002953 }
Eli Friedmanbb0d9a52009-07-14 21:58:17 +00002954
Eli Friedman055c9702011-11-02 01:53:16 +00002955 if (Args.hasFlag(options::OPT_fapple_pragma_pack,
2956 options::OPT_fno_apple_pragma_pack, false))
2957 CmdArgs.push_back("-fapple-pragma-pack");
2958
Daniel Dunbar2ffe0292009-09-10 03:37:02 +00002959 // Default to -fno-builtin-str{cat,cpy} on Darwin for ARM.
Daniel Dunbar4fa08112009-09-10 04:57:27 +00002960 //
Daniel Dunbar6c536aa2009-12-11 23:00:49 +00002961 // FIXME: This is disabled until clang -cc1 supports -fno-builtin-foo. PR4941.
Daniel Dunbar4fa08112009-09-10 04:57:27 +00002962#if 0
Bob Wilson6524dd32011-10-14 05:03:44 +00002963 if (getToolChain().getTriple().isOSDarwin() &&
Daniel Dunbar2ffe0292009-09-10 03:37:02 +00002964 (getToolChain().getTriple().getArch() == llvm::Triple::arm ||
2965 getToolChain().getTriple().getArch() == llvm::Triple::thumb)) {
2966 if (!Args.hasArg(options::OPT_fbuiltin_strcat))
2967 CmdArgs.push_back("-fno-builtin-strcat");
2968 if (!Args.hasArg(options::OPT_fbuiltin_strcpy))
2969 CmdArgs.push_back("-fno-builtin-strcpy");
2970 }
Daniel Dunbar4fa08112009-09-10 04:57:27 +00002971#endif
Daniel Dunbar2ffe0292009-09-10 03:37:02 +00002972
Daniel Dunbar8c3d7352011-03-18 21:23:40 +00002973 // Only allow -traditional or -traditional-cpp outside in preprocessing modes.
Mike Stump11289f42009-09-09 15:08:12 +00002974 if (Arg *A = Args.getLastArg(options::OPT_traditional,
Daniel Dunbar8c3d7352011-03-18 21:23:40 +00002975 options::OPT_traditional_cpp)) {
2976 if (isa<PreprocessJobAction>(JA))
2977 CmdArgs.push_back("-traditional-cpp");
Eric Christopher84fbdb42011-08-19 00:30:14 +00002978 else
Chris Lattner0e62c1c2011-07-23 10:55:15 +00002979 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
Daniel Dunbar8c3d7352011-03-18 21:23:40 +00002980 }
Eli Friedmanbb0d9a52009-07-14 21:58:17 +00002981
Daniel Dunbara2aedc62009-03-18 10:01:51 +00002982 Args.AddLastArg(CmdArgs, options::OPT_dM);
Chris Lattnercac63f32009-04-12 01:56:53 +00002983 Args.AddLastArg(CmdArgs, options::OPT_dD);
Ted Kremeneke73d9ed2011-11-11 00:07:43 +00002984
2985 // Handle serialized diagnostics.
2986 if (Arg *A = Args.getLastArg(options::OPT__serialize_diags)) {
2987 CmdArgs.push_back("-serialize-diagnostic-file");
Richard Smithbd55daf2012-11-01 04:30:05 +00002988 CmdArgs.push_back(Args.MakeArgString(A->getValue()));
Ted Kremeneke73d9ed2011-11-11 00:07:43 +00002989 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00002990
Ted Kremenekb47e6bc2012-09-13 06:41:18 +00002991 if (Args.hasArg(options::OPT_fretain_comments_from_system_headers))
2992 CmdArgs.push_back("-fretain-comments-from-system-headers");
2993
Daniel Dunbar76fa8402010-04-15 06:09:03 +00002994 // Forward -Xclang arguments to -cc1, and -mllvm arguments to the LLVM option
2995 // parser.
Daniel Dunbara2aedc62009-03-18 10:01:51 +00002996 Args.AddAllArgValues(CmdArgs, options::OPT_Xclang);
Daniel Dunbar76fa8402010-04-15 06:09:03 +00002997 for (arg_iterator it = Args.filtered_begin(options::OPT_mllvm),
2998 ie = Args.filtered_end(); it != ie; ++it) {
Daniel Dunbara442fd52010-06-11 22:00:13 +00002999 (*it)->claim();
Daniel Dunbar88534f42010-04-17 06:10:00 +00003000
Daniel Dunbar76fa8402010-04-15 06:09:03 +00003001 // We translate this by hand to the -cc1 argument, since nightly test uses
3002 // it and developers have been trained to spell it with -mllvm.
Richard Smithbd55daf2012-11-01 04:30:05 +00003003 if (StringRef((*it)->getValue(0)) == "-disable-llvm-optzns")
Daniel Dunbar76fa8402010-04-15 06:09:03 +00003004 CmdArgs.push_back("-disable-llvm-optzns");
3005 else
Daniel Dunbara442fd52010-06-11 22:00:13 +00003006 (*it)->render(Args, CmdArgs);
Daniel Dunbar76fa8402010-04-15 06:09:03 +00003007 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003008
Daniel Dunbard67a3222009-03-30 06:36:42 +00003009 if (Output.getType() == types::TY_Dependencies) {
3010 // Handled with other dependency code.
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00003011 } else if (Output.isFilename()) {
Daniel Dunbara3246a02009-03-18 08:07:30 +00003012 CmdArgs.push_back("-o");
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00003013 CmdArgs.push_back(Output.getFilename());
3014 } else {
3015 assert(Output.isNothing() && "Invalid output.");
Daniel Dunbara3246a02009-03-18 08:07:30 +00003016 }
3017
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003018 for (InputInfoList::const_iterator
3019 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
3020 const InputInfo &II = *it;
3021 CmdArgs.push_back("-x");
Fariborz Jahanian659bc4a2012-09-28 19:05:17 +00003022 if (Args.hasArg(options::OPT_rewrite_objc))
3023 CmdArgs.push_back(types::getTypeName(types::TY_PP_ObjCXX));
3024 else
3025 CmdArgs.push_back(types::getTypeName(II.getType()));
Daniel Dunbarb440f562010-08-02 02:38:21 +00003026 if (II.isFilename())
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00003027 CmdArgs.push_back(II.getFilename());
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003028 else
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00003029 II.getInputArg().renderAsInput(Args, CmdArgs);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003030 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00003031
Chris Lattnere9d7d782009-11-03 19:50:27 +00003032 Args.AddAllArgs(CmdArgs, options::OPT_undef);
3033
Daniel Dunbarb31b76f2010-07-18 21:16:15 +00003034 const char *Exec = getToolChain().getDriver().getClangProgramPath();
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00003035
3036 // Optionally embed the -cc1 level arguments into the debug info, for build
3037 // analysis.
3038 if (getToolChain().UseDwarfDebugFlags()) {
Daniel Dunbar7f3d9502010-06-04 18:47:06 +00003039 ArgStringList OriginalArgs;
3040 for (ArgList::const_iterator it = Args.begin(),
3041 ie = Args.end(); it != ie; ++it)
3042 (*it)->render(Args, OriginalArgs);
Daniel Dunbarfe6c97b2010-08-24 16:47:49 +00003043
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +00003044 SmallString<256> Flags;
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00003045 Flags += Exec;
Daniel Dunbar7f3d9502010-06-04 18:47:06 +00003046 for (unsigned i = 0, e = OriginalArgs.size(); i != e; ++i) {
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00003047 Flags += " ";
Daniel Dunbar7f3d9502010-06-04 18:47:06 +00003048 Flags += OriginalArgs[i];
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00003049 }
3050 CmdArgs.push_back("-dwarf-debug-flags");
3051 CmdArgs.push_back(Args.MakeArgString(Flags.str()));
3052 }
3053
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00003054 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbar17731772009-03-23 19:03:36 +00003055
Roman Divacky178e01602011-02-10 16:52:03 +00003056 if (Arg *A = Args.getLastArg(options::OPT_pg))
3057 if (Args.hasArg(options::OPT_fomit_frame_pointer))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00003058 D.Diag(diag::err_drv_argument_not_allowed_with)
Roman Divacky178e01602011-02-10 16:52:03 +00003059 << "-fomit-frame-pointer" << A->getAsString(Args);
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00003060
Daniel Dunbarc2a71892009-04-03 20:51:31 +00003061 // Claim some arguments which clang supports automatically.
3062
Daniel Dunbar3e0cac62010-04-15 06:18:42 +00003063 // -fpch-preprocess is used with gcc to add a special marker in the output to
3064 // include the PCH file. Clang's PTH solution is completely transparent, so we
3065 // do not need to deal with it at all.
Daniel Dunbarc2a71892009-04-03 20:51:31 +00003066 Args.ClaimAllArgs(options::OPT_fpch_preprocess);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00003067
Daniel Dunbar17731772009-03-23 19:03:36 +00003068 // Claim some arguments which clang doesn't support, but we don't
3069 // care to warn the user about.
Daniel Dunbar44b36ee2009-11-25 11:53:23 +00003070 Args.ClaimAllArgs(options::OPT_clang_ignored_f_Group);
3071 Args.ClaimAllArgs(options::OPT_clang_ignored_m_Group);
Rafael Espindola22f603032011-02-28 23:29:45 +00003072
Rafael Espindolad95a8122011-03-01 05:25:27 +00003073 // Disable warnings for clang -E -use-gold-plugin -emit-llvm foo.c
Rafael Espindola22f603032011-02-28 23:29:45 +00003074 Args.ClaimAllArgs(options::OPT_use_gold_plugin);
Rafael Espindolad95a8122011-03-01 05:25:27 +00003075 Args.ClaimAllArgs(options::OPT_emit_llvm);
Daniel Dunbar1a093d22009-03-18 06:00:36 +00003076}
3077
Jim Grosbach576452b2012-02-10 20:37:10 +00003078void ClangAs::AddARMTargetArgs(const ArgList &Args,
3079 ArgStringList &CmdArgs) const {
3080 const Driver &D = getToolChain().getDriver();
3081 llvm::Triple Triple = getToolChain().getTriple();
3082
3083 // Set the CPU based on -march= and -mcpu=.
3084 CmdArgs.push_back("-target-cpu");
Benjamin Kramer09811c72012-06-26 22:20:06 +00003085 CmdArgs.push_back(Args.MakeArgString(getARMTargetCPU(Args, Triple)));
Jim Grosbach576452b2012-02-10 20:37:10 +00003086
3087 // Honor -mfpu=.
Chad Rosiercfbfc582012-04-04 20:51:35 +00003088 if (const Arg *A = Args.getLastArg(options::OPT_mfpu_EQ))
Chad Rosierd1717c12012-04-04 20:56:36 +00003089 addFPUArgs(D, A, Args, CmdArgs);
Chad Rosier1f0e52e2012-04-04 20:39:32 +00003090
3091 // Honor -mfpmath=.
3092 if (const Arg *A = Args.getLastArg(options::OPT_mfpmath_EQ))
Chad Rosier45619cb2012-04-04 22:13:40 +00003093 addFPMathArgs(D, A, Args, CmdArgs, getARMTargetCPU(Args, Triple));
Jim Grosbach576452b2012-02-10 20:37:10 +00003094}
3095
John McCall5fb5df92012-06-20 06:18:46 +00003096/// Add options related to the Objective-C runtime/ABI.
3097///
3098/// Returns true if the runtime is non-fragile.
3099ObjCRuntime Clang::AddObjCRuntimeArgs(const ArgList &args,
3100 ArgStringList &cmdArgs,
3101 RewriteKind rewriteKind) const {
3102 // Look for the controlling runtime option.
3103 Arg *runtimeArg = args.getLastArg(options::OPT_fnext_runtime,
3104 options::OPT_fgnu_runtime,
3105 options::OPT_fobjc_runtime_EQ);
3106
3107 // Just forward -fobjc-runtime= to the frontend. This supercedes
3108 // options about fragility.
3109 if (runtimeArg &&
3110 runtimeArg->getOption().matches(options::OPT_fobjc_runtime_EQ)) {
3111 ObjCRuntime runtime;
Richard Smithbd55daf2012-11-01 04:30:05 +00003112 StringRef value = runtimeArg->getValue();
John McCall5fb5df92012-06-20 06:18:46 +00003113 if (runtime.tryParse(value)) {
3114 getToolChain().getDriver().Diag(diag::err_drv_unknown_objc_runtime)
3115 << value;
3116 }
3117
3118 runtimeArg->render(args, cmdArgs);
3119 return runtime;
3120 }
3121
3122 // Otherwise, we'll need the ABI "version". Version numbers are
3123 // slightly confusing for historical reasons:
3124 // 1 - Traditional "fragile" ABI
3125 // 2 - Non-fragile ABI, version 1
3126 // 3 - Non-fragile ABI, version 2
3127 unsigned objcABIVersion = 1;
3128 // If -fobjc-abi-version= is present, use that to set the version.
3129 if (Arg *abiArg = args.getLastArg(options::OPT_fobjc_abi_version_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00003130 StringRef value = abiArg->getValue();
John McCall5fb5df92012-06-20 06:18:46 +00003131 if (value == "1")
3132 objcABIVersion = 1;
3133 else if (value == "2")
3134 objcABIVersion = 2;
3135 else if (value == "3")
3136 objcABIVersion = 3;
3137 else
3138 getToolChain().getDriver().Diag(diag::err_drv_clang_unsupported)
3139 << value;
3140 } else {
3141 // Otherwise, determine if we are using the non-fragile ABI.
3142 bool nonFragileABIIsDefault =
3143 (rewriteKind == RK_NonFragile ||
3144 (rewriteKind == RK_None &&
3145 getToolChain().IsObjCNonFragileABIDefault()));
3146 if (args.hasFlag(options::OPT_fobjc_nonfragile_abi,
3147 options::OPT_fno_objc_nonfragile_abi,
3148 nonFragileABIIsDefault)) {
3149 // Determine the non-fragile ABI version to use.
3150#ifdef DISABLE_DEFAULT_NONFRAGILEABI_TWO
3151 unsigned nonFragileABIVersion = 1;
3152#else
3153 unsigned nonFragileABIVersion = 2;
3154#endif
3155
3156 if (Arg *abiArg = args.getLastArg(
3157 options::OPT_fobjc_nonfragile_abi_version_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00003158 StringRef value = abiArg->getValue();
John McCall5fb5df92012-06-20 06:18:46 +00003159 if (value == "1")
3160 nonFragileABIVersion = 1;
3161 else if (value == "2")
3162 nonFragileABIVersion = 2;
3163 else
3164 getToolChain().getDriver().Diag(diag::err_drv_clang_unsupported)
3165 << value;
3166 }
3167
3168 objcABIVersion = 1 + nonFragileABIVersion;
3169 } else {
3170 objcABIVersion = 1;
3171 }
3172 }
3173
3174 // We don't actually care about the ABI version other than whether
3175 // it's non-fragile.
3176 bool isNonFragile = objcABIVersion != 1;
3177
3178 // If we have no runtime argument, ask the toolchain for its default runtime.
3179 // However, the rewriter only really supports the Mac runtime, so assume that.
3180 ObjCRuntime runtime;
3181 if (!runtimeArg) {
3182 switch (rewriteKind) {
3183 case RK_None:
3184 runtime = getToolChain().getDefaultObjCRuntime(isNonFragile);
3185 break;
3186 case RK_Fragile:
3187 runtime = ObjCRuntime(ObjCRuntime::FragileMacOSX, VersionTuple());
3188 break;
3189 case RK_NonFragile:
3190 runtime = ObjCRuntime(ObjCRuntime::MacOSX, VersionTuple());
3191 break;
3192 }
3193
3194 // -fnext-runtime
3195 } else if (runtimeArg->getOption().matches(options::OPT_fnext_runtime)) {
3196 // On Darwin, make this use the default behavior for the toolchain.
3197 if (getToolChain().getTriple().isOSDarwin()) {
3198 runtime = getToolChain().getDefaultObjCRuntime(isNonFragile);
3199
3200 // Otherwise, build for a generic macosx port.
3201 } else {
3202 runtime = ObjCRuntime(ObjCRuntime::MacOSX, VersionTuple());
3203 }
3204
3205 // -fgnu-runtime
3206 } else {
3207 assert(runtimeArg->getOption().matches(options::OPT_fgnu_runtime));
David Chisnall314896c2012-07-04 10:37:03 +00003208 // Legacy behaviour is to target the gnustep runtime if we are i
3209 // non-fragile mode or the GCC runtime in fragile mode.
3210 if (isNonFragile)
David Chisnalla5f59412012-10-16 15:11:55 +00003211 runtime = ObjCRuntime(ObjCRuntime::GNUstep, VersionTuple(1,6));
David Chisnall314896c2012-07-04 10:37:03 +00003212 else
3213 runtime = ObjCRuntime(ObjCRuntime::GCC, VersionTuple());
John McCall5fb5df92012-06-20 06:18:46 +00003214 }
3215
3216 cmdArgs.push_back(args.MakeArgString(
3217 "-fobjc-runtime=" + runtime.getAsString()));
3218 return runtime;
3219}
3220
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00003221void ClangAs::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00003222 const InputInfo &Output,
3223 const InputInfoList &Inputs,
3224 const ArgList &Args,
3225 const char *LinkingOutput) const {
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00003226 ArgStringList CmdArgs;
3227
3228 assert(Inputs.size() == 1 && "Unexpected number of inputs.");
3229 const InputInfo &Input = Inputs[0];
3230
Rafael Espindolacfaadda2010-11-17 22:13:25 +00003231 // Don't warn about "clang -w -c foo.s"
3232 Args.ClaimAllArgs(options::OPT_w);
Rafael Espindolad95a8122011-03-01 05:25:27 +00003233 // and "clang -emit-llvm -c foo.s"
3234 Args.ClaimAllArgs(options::OPT_emit_llvm);
3235 // and "clang -use-gold-plugin -c foo.s"
3236 Args.ClaimAllArgs(options::OPT_use_gold_plugin);
Rafael Espindolacfaadda2010-11-17 22:13:25 +00003237
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00003238 // Invoke ourselves in -cc1as mode.
3239 //
3240 // FIXME: Implement custom jobs for internal actions.
3241 CmdArgs.push_back("-cc1as");
3242
3243 // Add the "effective" target triple.
3244 CmdArgs.push_back("-triple");
Chad Rosierd3a0f952011-09-20 20:44:06 +00003245 std::string TripleStr =
3246 getToolChain().ComputeEffectiveClangTriple(Args, Input.getType());
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00003247 CmdArgs.push_back(Args.MakeArgString(TripleStr));
3248
3249 // Set the output mode, we currently only expect to be used as a real
3250 // assembler.
3251 CmdArgs.push_back("-filetype");
3252 CmdArgs.push_back("obj");
3253
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00003254 if (UseRelaxAll(C, Args))
Daniel Dunbar99ca8b72010-05-28 16:43:21 +00003255 CmdArgs.push_back("-relax-all");
Daniel Dunbar06e2cc32010-05-27 06:18:05 +00003256
Jim Grosbach576452b2012-02-10 20:37:10 +00003257 // Add target specific cpu and features flags.
3258 switch(getToolChain().getTriple().getArch()) {
3259 default:
3260 break;
3261
3262 case llvm::Triple::arm:
3263 case llvm::Triple::thumb:
3264 AddARMTargetArgs(Args, CmdArgs);
3265 break;
3266 }
3267
Daniel Dunbar1d733e22011-03-17 17:37:29 +00003268 // Ignore explicit -force_cpusubtype_ALL option.
3269 (void) Args.hasArg(options::OPT_force__cpusubtype__ALL);
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00003270
Eric Christopherfc3ee562012-01-10 00:38:01 +00003271 // Determine the original source input.
3272 const Action *SourceAction = &JA;
3273 while (SourceAction->getKind() != Action::InputClass) {
3274 assert(!SourceAction->getInputs().empty() && "unexpected root action!");
3275 SourceAction = SourceAction->getInputs()[0];
3276 }
3277
3278 // Forward -g, assuming we are dealing with an actual assembly file.
3279 if (SourceAction->getType() == types::TY_Asm ||
3280 SourceAction->getType() == types::TY_PP_Asm) {
3281 Args.ClaimAllArgs(options::OPT_g_Group);
3282 if (Arg *A = Args.getLastArg(options::OPT_g_Group))
3283 if (!A->getOption().matches(options::OPT_g0))
3284 CmdArgs.push_back("-g");
3285 }
Kevin Enderby292dc082011-12-22 19:31:58 +00003286
3287 // Optionally embed the -cc1as level arguments into the debug info, for build
3288 // analysis.
3289 if (getToolChain().UseDwarfDebugFlags()) {
3290 ArgStringList OriginalArgs;
3291 for (ArgList::const_iterator it = Args.begin(),
3292 ie = Args.end(); it != ie; ++it)
3293 (*it)->render(Args, OriginalArgs);
3294
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +00003295 SmallString<256> Flags;
Kevin Enderby292dc082011-12-22 19:31:58 +00003296 const char *Exec = getToolChain().getDriver().getClangProgramPath();
3297 Flags += Exec;
3298 for (unsigned i = 0, e = OriginalArgs.size(); i != e; ++i) {
3299 Flags += " ";
3300 Flags += OriginalArgs[i];
3301 }
3302 CmdArgs.push_back("-dwarf-debug-flags");
3303 CmdArgs.push_back(Args.MakeArgString(Flags.str()));
3304 }
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00003305
3306 // FIXME: Add -static support, once we have it.
3307
3308 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
3309 options::OPT_Xassembler);
Daniel Dunbar252e8f92011-04-29 17:53:18 +00003310 Args.AddAllArgs(CmdArgs, options::OPT_mllvm);
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00003311
3312 assert(Output.isFilename() && "Unexpected lipo output.");
3313 CmdArgs.push_back("-o");
3314 CmdArgs.push_back(Output.getFilename());
3315
Daniel Dunbarb440f562010-08-02 02:38:21 +00003316 assert(Input.isFilename() && "Invalid input.");
3317 CmdArgs.push_back(Input.getFilename());
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00003318
Daniel Dunbarb31b76f2010-07-18 21:16:15 +00003319 const char *Exec = getToolChain().getDriver().getClangProgramPath();
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00003320 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00003321}
3322
Daniel Dunbara3246a02009-03-18 08:07:30 +00003323void gcc::Common::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbara3246a02009-03-18 08:07:30 +00003324 const InputInfo &Output,
3325 const InputInfoList &Inputs,
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003326 const ArgList &Args,
Daniel Dunbara3246a02009-03-18 08:07:30 +00003327 const char *LinkingOutput) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00003328 const Driver &D = getToolChain().getDriver();
Daniel Dunbara3246a02009-03-18 08:07:30 +00003329 ArgStringList CmdArgs;
Daniel Dunbar1a093d22009-03-18 06:00:36 +00003330
Daniel Dunbard067f7f2009-04-08 23:54:23 +00003331 for (ArgList::const_iterator
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003332 it = Args.begin(), ie = Args.end(); it != ie; ++it) {
Daniel Dunbara3246a02009-03-18 08:07:30 +00003333 Arg *A = *it;
Michael J. Spencer66e2b202012-10-19 22:37:06 +00003334 if (forwardToGCC(A->getOption())) {
Daniel Dunbar939c1212010-08-03 16:14:14 +00003335 // Don't forward any -g arguments to assembly steps.
3336 if (isa<AssembleJobAction>(JA) &&
3337 A->getOption().matches(options::OPT_g_Group))
3338 continue;
3339
Daniel Dunbar2da02722009-03-19 07:55:12 +00003340 // It is unfortunate that we have to claim here, as this means
3341 // we will basically never report anything interesting for
Daniel Dunbar5716d872009-05-02 21:41:52 +00003342 // platforms using a generic gcc, even if we are just using gcc
3343 // to get to the assembler.
Daniel Dunbar2da02722009-03-19 07:55:12 +00003344 A->claim();
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003345 A->render(Args, CmdArgs);
Daniel Dunbar2da02722009-03-19 07:55:12 +00003346 }
Daniel Dunbara3246a02009-03-18 08:07:30 +00003347 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00003348
Daniel Dunbar4e295052010-01-25 22:35:08 +00003349 RenderExtraToolArgs(JA, CmdArgs);
Daniel Dunbara3246a02009-03-18 08:07:30 +00003350
3351 // If using a driver driver, force the arch.
Rafael Espindola35ca7d92012-10-07 04:44:33 +00003352 llvm::Triple::ArchType Arch = getToolChain().getArch();
Bob Wilson6524dd32011-10-14 05:03:44 +00003353 if (getToolChain().getTriple().isOSDarwin()) {
Daniel Dunbara3246a02009-03-18 08:07:30 +00003354 CmdArgs.push_back("-arch");
Daniel Dunbar0a05d932009-04-01 20:33:11 +00003355
3356 // FIXME: Remove these special cases.
Rafael Espindola35ca7d92012-10-07 04:44:33 +00003357 if (Arch == llvm::Triple::ppc)
Daniel Dunbar5bbebfe2009-05-22 02:21:04 +00003358 CmdArgs.push_back("ppc");
Rafael Espindola35ca7d92012-10-07 04:44:33 +00003359 else if (Arch == llvm::Triple::ppc64)
Daniel Dunbar5bbebfe2009-05-22 02:21:04 +00003360 CmdArgs.push_back("ppc64");
3361 else
Rafael Espindola35ca7d92012-10-07 04:44:33 +00003362 CmdArgs.push_back(Args.MakeArgString(getToolChain().getArchName()));
Daniel Dunbara3246a02009-03-18 08:07:30 +00003363 }
3364
Daniel Dunbar5716d872009-05-02 21:41:52 +00003365 // Try to force gcc to match the tool chain we want, if we recognize
3366 // the arch.
Daniel Dunbar5bbebfe2009-05-22 02:21:04 +00003367 //
3368 // FIXME: The triple class should directly provide the information we want
3369 // here.
Rafael Espindola35ca7d92012-10-07 04:44:33 +00003370 if (Arch == llvm::Triple::x86 || Arch == llvm::Triple::ppc)
Daniel Dunbar5716d872009-05-02 21:41:52 +00003371 CmdArgs.push_back("-m32");
Rafael Espindola35ca7d92012-10-07 04:44:33 +00003372 else if (Arch == llvm::Triple::x86_64 || Arch == llvm::Triple::x86_64)
Daniel Dunbar5716d872009-05-02 21:41:52 +00003373 CmdArgs.push_back("-m64");
3374
Daniel Dunbarb440f562010-08-02 02:38:21 +00003375 if (Output.isFilename()) {
Daniel Dunbara3246a02009-03-18 08:07:30 +00003376 CmdArgs.push_back("-o");
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00003377 CmdArgs.push_back(Output.getFilename());
3378 } else {
3379 assert(Output.isNothing() && "Unexpected output");
Daniel Dunbara3246a02009-03-18 08:07:30 +00003380 CmdArgs.push_back("-fsyntax-only");
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00003381 }
Daniel Dunbara3246a02009-03-18 08:07:30 +00003382
Tony Linthicum76329bf2011-12-12 21:14:55 +00003383 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
3384 options::OPT_Xassembler);
Daniel Dunbara3246a02009-03-18 08:07:30 +00003385
3386 // Only pass -x if gcc will understand it; otherwise hope gcc
3387 // understands the suffix correctly. The main use case this would go
3388 // wrong in is for linker inputs if they happened to have an odd
3389 // suffix; really the only way to get this to happen is a command
3390 // like '-x foobar a.c' which will treat a.c like a linker input.
3391 //
3392 // FIXME: For the linker case specifically, can we safely convert
3393 // inputs into '-Wl,' options?
3394 for (InputInfoList::const_iterator
3395 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
3396 const InputInfo &II = *it;
Daniel Dunbare3e263f2009-05-02 20:14:53 +00003397
Daniel Dunbar6cdf83c2009-09-01 16:57:46 +00003398 // Don't try to pass LLVM or AST inputs to a generic gcc.
Daniel Dunbar24e52992010-06-07 23:28:45 +00003399 if (II.getType() == types::TY_LLVM_IR || II.getType() == types::TY_LTO_IR ||
3400 II.getType() == types::TY_LLVM_BC || II.getType() == types::TY_LTO_BC)
Chris Lattner0e62c1c2011-07-23 10:55:15 +00003401 D.Diag(diag::err_drv_no_linker_llvm_support)
Daniel Dunbar1c28f1e2009-09-09 22:32:48 +00003402 << getToolChain().getTripleString();
Daniel Dunbar6cdf83c2009-09-01 16:57:46 +00003403 else if (II.getType() == types::TY_AST)
Chris Lattner0e62c1c2011-07-23 10:55:15 +00003404 D.Diag(diag::err_drv_no_ast_support)
Daniel Dunbar1c28f1e2009-09-09 22:32:48 +00003405 << getToolChain().getTripleString();
Daniel Dunbare3e263f2009-05-02 20:14:53 +00003406
Daniel Dunbara3246a02009-03-18 08:07:30 +00003407 if (types::canTypeBeUserSpecified(II.getType())) {
3408 CmdArgs.push_back("-x");
3409 CmdArgs.push_back(types::getTypeName(II.getType()));
3410 }
3411
Daniel Dunbarb440f562010-08-02 02:38:21 +00003412 if (II.isFilename())
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00003413 CmdArgs.push_back(II.getFilename());
Daniel Dunbarf2476752010-09-25 18:10:05 +00003414 else {
3415 const Arg &A = II.getInputArg();
3416
3417 // Reverse translate some rewritten options.
3418 if (A.getOption().matches(options::OPT_Z_reserved_lib_stdcxx)) {
3419 CmdArgs.push_back("-lstdc++");
3420 continue;
3421 }
3422
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00003423 // Don't render as input, we need gcc to do the translations.
Daniel Dunbarf2476752010-09-25 18:10:05 +00003424 A.render(Args, CmdArgs);
3425 }
Daniel Dunbara3246a02009-03-18 08:07:30 +00003426 }
3427
Dylan Noblesmith70e73a32011-04-09 13:31:59 +00003428 const std::string customGCCName = D.getCCCGenericGCCName();
3429 const char *GCCName;
3430 if (!customGCCName.empty())
3431 GCCName = customGCCName.c_str();
3432 else if (D.CCCIsCXX) {
Dylan Noblesmith70e73a32011-04-09 13:31:59 +00003433 GCCName = "g++";
Dylan Noblesmith70e73a32011-04-09 13:31:59 +00003434 } else
3435 GCCName = "gcc";
3436
Daniel Dunbard067f7f2009-04-08 23:54:23 +00003437 const char *Exec =
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00003438 Args.MakeArgString(getToolChain().GetProgramPath(GCCName));
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00003439 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbar1a093d22009-03-18 06:00:36 +00003440}
3441
Daniel Dunbar4e295052010-01-25 22:35:08 +00003442void gcc::Preprocess::RenderExtraToolArgs(const JobAction &JA,
3443 ArgStringList &CmdArgs) const {
Daniel Dunbara3246a02009-03-18 08:07:30 +00003444 CmdArgs.push_back("-E");
Daniel Dunbar1a093d22009-03-18 06:00:36 +00003445}
3446
Daniel Dunbar4e295052010-01-25 22:35:08 +00003447void gcc::Precompile::RenderExtraToolArgs(const JobAction &JA,
3448 ArgStringList &CmdArgs) const {
Daniel Dunbara3246a02009-03-18 08:07:30 +00003449 // The type is good enough.
Daniel Dunbar1a093d22009-03-18 06:00:36 +00003450}
3451
Daniel Dunbar4e295052010-01-25 22:35:08 +00003452void gcc::Compile::RenderExtraToolArgs(const JobAction &JA,
3453 ArgStringList &CmdArgs) const {
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00003454 const Driver &D = getToolChain().getDriver();
3455
Daniel Dunbar4e295052010-01-25 22:35:08 +00003456 // If -flto, etc. are present then make sure not to force assembly output.
Daniel Dunbar24e52992010-06-07 23:28:45 +00003457 if (JA.getType() == types::TY_LLVM_IR || JA.getType() == types::TY_LTO_IR ||
3458 JA.getType() == types::TY_LLVM_BC || JA.getType() == types::TY_LTO_BC)
Daniel Dunbar4e295052010-01-25 22:35:08 +00003459 CmdArgs.push_back("-c");
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00003460 else {
3461 if (JA.getType() != types::TY_PP_Asm)
Chris Lattner0e62c1c2011-07-23 10:55:15 +00003462 D.Diag(diag::err_drv_invalid_gcc_output_type)
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00003463 << getTypeName(JA.getType());
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00003464
Daniel Dunbar4e295052010-01-25 22:35:08 +00003465 CmdArgs.push_back("-S");
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00003466 }
Daniel Dunbar1a093d22009-03-18 06:00:36 +00003467}
3468
Daniel Dunbar4e295052010-01-25 22:35:08 +00003469void gcc::Assemble::RenderExtraToolArgs(const JobAction &JA,
3470 ArgStringList &CmdArgs) const {
Daniel Dunbara3246a02009-03-18 08:07:30 +00003471 CmdArgs.push_back("-c");
Daniel Dunbar1a093d22009-03-18 06:00:36 +00003472}
Daniel Dunbara3246a02009-03-18 08:07:30 +00003473
Daniel Dunbar4e295052010-01-25 22:35:08 +00003474void gcc::Link::RenderExtraToolArgs(const JobAction &JA,
3475 ArgStringList &CmdArgs) const {
Daniel Dunbara3246a02009-03-18 08:07:30 +00003476 // The types are (hopefully) good enough.
3477}
3478
Tony Linthicum76329bf2011-12-12 21:14:55 +00003479// Hexagon tools start.
3480void hexagon::Assemble::RenderExtraToolArgs(const JobAction &JA,
3481 ArgStringList &CmdArgs) const {
3482
3483}
3484void hexagon::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
3485 const InputInfo &Output,
3486 const InputInfoList &Inputs,
3487 const ArgList &Args,
3488 const char *LinkingOutput) const {
3489
3490 const Driver &D = getToolChain().getDriver();
3491 ArgStringList CmdArgs;
3492
3493 std::string MarchString = "-march=";
3494 MarchString += getHexagonTargetCPU(Args);
3495 CmdArgs.push_back(Args.MakeArgString(MarchString));
3496
3497 RenderExtraToolArgs(JA, CmdArgs);
3498
3499 if (Output.isFilename()) {
3500 CmdArgs.push_back("-o");
3501 CmdArgs.push_back(Output.getFilename());
3502 } else {
3503 assert(Output.isNothing() && "Unexpected output");
3504 CmdArgs.push_back("-fsyntax-only");
3505 }
3506
3507
3508 // Only pass -x if gcc will understand it; otherwise hope gcc
3509 // understands the suffix correctly. The main use case this would go
3510 // wrong in is for linker inputs if they happened to have an odd
3511 // suffix; really the only way to get this to happen is a command
3512 // like '-x foobar a.c' which will treat a.c like a linker input.
3513 //
3514 // FIXME: For the linker case specifically, can we safely convert
3515 // inputs into '-Wl,' options?
3516 for (InputInfoList::const_iterator
3517 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
3518 const InputInfo &II = *it;
3519
3520 // Don't try to pass LLVM or AST inputs to a generic gcc.
3521 if (II.getType() == types::TY_LLVM_IR || II.getType() == types::TY_LTO_IR ||
3522 II.getType() == types::TY_LLVM_BC || II.getType() == types::TY_LTO_BC)
3523 D.Diag(clang::diag::err_drv_no_linker_llvm_support)
3524 << getToolChain().getTripleString();
3525 else if (II.getType() == types::TY_AST)
3526 D.Diag(clang::diag::err_drv_no_ast_support)
3527 << getToolChain().getTripleString();
3528
3529 if (II.isFilename())
3530 CmdArgs.push_back(II.getFilename());
3531 else
3532 // Don't render as input, we need gcc to do the translations. FIXME: Pranav: What is this ?
3533 II.getInputArg().render(Args, CmdArgs);
3534 }
3535
3536 const char *GCCName = "hexagon-as";
3537 const char *Exec =
3538 Args.MakeArgString(getToolChain().GetProgramPath(GCCName));
3539 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
3540
3541}
3542void hexagon::Link::RenderExtraToolArgs(const JobAction &JA,
3543 ArgStringList &CmdArgs) const {
3544 // The types are (hopefully) good enough.
3545}
3546
3547void hexagon::Link::ConstructJob(Compilation &C, const JobAction &JA,
3548 const InputInfo &Output,
3549 const InputInfoList &Inputs,
3550 const ArgList &Args,
3551 const char *LinkingOutput) const {
3552
3553 const Driver &D = getToolChain().getDriver();
3554 ArgStringList CmdArgs;
3555
3556 for (ArgList::const_iterator
3557 it = Args.begin(), ie = Args.end(); it != ie; ++it) {
3558 Arg *A = *it;
Michael J. Spencer66e2b202012-10-19 22:37:06 +00003559 if (forwardToGCC(A->getOption())) {
Tony Linthicum76329bf2011-12-12 21:14:55 +00003560 // Don't forward any -g arguments to assembly steps.
3561 if (isa<AssembleJobAction>(JA) &&
3562 A->getOption().matches(options::OPT_g_Group))
3563 continue;
3564
3565 // It is unfortunate that we have to claim here, as this means
3566 // we will basically never report anything interesting for
3567 // platforms using a generic gcc, even if we are just using gcc
3568 // to get to the assembler.
3569 A->claim();
3570 A->render(Args, CmdArgs);
3571 }
3572 }
3573
3574 RenderExtraToolArgs(JA, CmdArgs);
3575
3576 // Add Arch Information
3577 Arg *A;
Sebastian Pop86500282012-01-13 20:37:10 +00003578 if ((A = getLastHexagonArchArg(Args))) {
3579 if (A->getOption().matches(options::OPT_m_Joined))
3580 A->render(Args, CmdArgs);
Tony Linthicum76329bf2011-12-12 21:14:55 +00003581 else
Sebastian Pop86500282012-01-13 20:37:10 +00003582 CmdArgs.push_back (Args.MakeArgString("-m" + getHexagonTargetCPU(Args)));
Tony Linthicum76329bf2011-12-12 21:14:55 +00003583 }
Sebastian Pop86500282012-01-13 20:37:10 +00003584 else {
3585 CmdArgs.push_back (Args.MakeArgString("-m" + getHexagonTargetCPU(Args)));
3586 }
3587
Tony Linthicum76329bf2011-12-12 21:14:55 +00003588 CmdArgs.push_back("-mqdsp6-compat");
3589
3590 const char *GCCName;
3591 if (C.getDriver().CCCIsCXX)
3592 GCCName = "hexagon-g++";
3593 else
3594 GCCName = "hexagon-gcc";
3595 const char *Exec =
3596 Args.MakeArgString(getToolChain().GetProgramPath(GCCName));
3597
3598 if (Output.isFilename()) {
3599 CmdArgs.push_back("-o");
3600 CmdArgs.push_back(Output.getFilename());
3601 }
3602
3603 for (InputInfoList::const_iterator
3604 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
3605 const InputInfo &II = *it;
3606
3607 // Don't try to pass LLVM or AST inputs to a generic gcc.
3608 if (II.getType() == types::TY_LLVM_IR || II.getType() == types::TY_LTO_IR ||
3609 II.getType() == types::TY_LLVM_BC || II.getType() == types::TY_LTO_BC)
3610 D.Diag(clang::diag::err_drv_no_linker_llvm_support)
3611 << getToolChain().getTripleString();
3612 else if (II.getType() == types::TY_AST)
3613 D.Diag(clang::diag::err_drv_no_ast_support)
3614 << getToolChain().getTripleString();
3615
3616 if (II.isFilename())
3617 CmdArgs.push_back(II.getFilename());
3618 else
3619 // Don't render as input, we need gcc to do the translations. FIXME: Pranav: What is this ?
3620 II.getInputArg().render(Args, CmdArgs);
3621 }
3622 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
3623
3624}
3625// Hexagon tools end.
3626
Rafael Espindoladcbf6982012-10-31 18:51:07 +00003627llvm::Triple::ArchType darwin::getArchTypeForDarwinArchName(StringRef Str) {
3628 // See arch(3) and llvm-gcc's driver-driver.c. We don't implement support for
3629 // archs which Darwin doesn't use.
3630
3631 // The matching this routine does is fairly pointless, since it is neither the
3632 // complete architecture list, nor a reasonable subset. The problem is that
3633 // historically the driver driver accepts this and also ties its -march=
3634 // handling to the architecture name, so we need to be careful before removing
3635 // support for it.
3636
3637 // This code must be kept in sync with Clang's Darwin specific argument
3638 // translation.
3639
3640 return llvm::StringSwitch<llvm::Triple::ArchType>(Str)
3641 .Cases("ppc", "ppc601", "ppc603", "ppc604", "ppc604e", llvm::Triple::ppc)
3642 .Cases("ppc750", "ppc7400", "ppc7450", "ppc970", llvm::Triple::ppc)
3643 .Case("ppc64", llvm::Triple::ppc64)
3644 .Cases("i386", "i486", "i486SX", "i586", "i686", llvm::Triple::x86)
3645 .Cases("pentium", "pentpro", "pentIIm3", "pentIIm5", "pentium4",
3646 llvm::Triple::x86)
3647 .Case("x86_64", llvm::Triple::x86_64)
3648 // This is derived from the driver driver.
3649 .Cases("arm", "armv4t", "armv5", "armv6", llvm::Triple::arm)
3650 .Cases("armv7", "armv7f", "armv7k", "armv7s", "xscale", llvm::Triple::arm)
3651 .Case("r600", llvm::Triple::r600)
3652 .Case("nvptx", llvm::Triple::nvptx)
3653 .Case("nvptx64", llvm::Triple::nvptx64)
3654 .Case("amdil", llvm::Triple::amdil)
3655 .Case("spir", llvm::Triple::spir)
3656 .Default(llvm::Triple::UnknownArch);
3657}
Tony Linthicum76329bf2011-12-12 21:14:55 +00003658
Bob Wilsondecc03e2012-11-23 06:14:39 +00003659const char *Clang::getBaseInputName(const ArgList &Args,
3660 const InputInfoList &Inputs) {
Michael J. Spencere1696752010-12-18 00:19:12 +00003661 return Args.MakeArgString(
3662 llvm::sys::path::filename(Inputs[0].getBaseInput()));
Daniel Dunbarafec1f52009-03-29 18:40:18 +00003663}
3664
Bob Wilsondecc03e2012-11-23 06:14:39 +00003665const char *Clang::getBaseInputStem(const ArgList &Args,
3666 const InputInfoList &Inputs) {
Daniel Dunbarafec1f52009-03-29 18:40:18 +00003667 const char *Str = getBaseInputName(Args, Inputs);
3668
Chris Lattner906bb902011-01-16 08:14:11 +00003669 if (const char *End = strrchr(Str, '.'))
Daniel Dunbar1c28f1e2009-09-09 22:32:48 +00003670 return Args.MakeArgString(std::string(Str, End));
Daniel Dunbarafec1f52009-03-29 18:40:18 +00003671
3672 return Str;
3673}
3674
Bob Wilsondecc03e2012-11-23 06:14:39 +00003675const char *Clang::getDependencyFileName(const ArgList &Args,
3676 const InputInfoList &Inputs) {
Daniel Dunbarafec1f52009-03-29 18:40:18 +00003677 // FIXME: Think about this more.
3678 std::string Res;
3679
3680 if (Arg *OutputOpt = Args.getLastArg(options::OPT_o)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00003681 std::string Str(OutputOpt->getValue());
Daniel Dunbarafec1f52009-03-29 18:40:18 +00003682 Res = Str.substr(0, Str.rfind('.'));
Chad Rosier6fdf38b2011-08-17 23:08:45 +00003683 } else {
Bob Wilsondecc03e2012-11-23 06:14:39 +00003684 Res = getBaseInputStem(Args, Inputs);
Chad Rosier6fdf38b2011-08-17 23:08:45 +00003685 }
Daniel Dunbar1c28f1e2009-09-09 22:32:48 +00003686 return Args.MakeArgString(Res + ".d");
Daniel Dunbarafec1f52009-03-29 18:40:18 +00003687}
3688
Daniel Dunbarbe220842009-03-20 16:06:39 +00003689void darwin::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00003690 const InputInfo &Output,
Daniel Dunbard067f7f2009-04-08 23:54:23 +00003691 const InputInfoList &Inputs,
3692 const ArgList &Args,
Daniel Dunbarbe220842009-03-20 16:06:39 +00003693 const char *LinkingOutput) const {
3694 ArgStringList CmdArgs;
3695
3696 assert(Inputs.size() == 1 && "Unexpected number of inputs.");
3697 const InputInfo &Input = Inputs[0];
3698
Daniel Dunbardc8355e2011-04-12 23:59:20 +00003699 // Determine the original source input.
3700 const Action *SourceAction = &JA;
3701 while (SourceAction->getKind() != Action::InputClass) {
3702 assert(!SourceAction->getInputs().empty() && "unexpected root action!");
3703 SourceAction = SourceAction->getInputs()[0];
3704 }
3705
3706 // Forward -g, assuming we are dealing with an actual assembly file.
Eric Christopher84fbdb42011-08-19 00:30:14 +00003707 if (SourceAction->getType() == types::TY_Asm ||
Daniel Dunbardc8355e2011-04-12 23:59:20 +00003708 SourceAction->getType() == types::TY_PP_Asm) {
Daniel Dunbar5c9c1182009-04-01 00:27:44 +00003709 if (Args.hasArg(options::OPT_gstabs))
3710 CmdArgs.push_back("--gstabs");
3711 else if (Args.hasArg(options::OPT_g_Group))
Bob Wilson126c4912011-11-02 05:10:45 +00003712 CmdArgs.push_back("-g");
Daniel Dunbar5c9c1182009-04-01 00:27:44 +00003713 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00003714
Daniel Dunbarbe220842009-03-20 16:06:39 +00003715 // Derived from asm spec.
Daniel Dunbar3571dd92009-09-09 18:36:27 +00003716 AddDarwinArch(Args, CmdArgs);
Daniel Dunbarbe220842009-03-20 16:06:39 +00003717
Daniel Dunbar6d484762010-07-22 01:47:22 +00003718 // Use -force_cpusubtype_ALL on x86 by default.
3719 if (getToolChain().getTriple().getArch() == llvm::Triple::x86 ||
3720 getToolChain().getTriple().getArch() == llvm::Triple::x86_64 ||
Daniel Dunbar3571dd92009-09-09 18:36:27 +00003721 Args.hasArg(options::OPT_force__cpusubtype__ALL))
3722 CmdArgs.push_back("-force_cpusubtype_ALL");
3723
Daniel Dunbara6b4a3d2009-08-24 22:26:16 +00003724 if (getToolChain().getTriple().getArch() != llvm::Triple::x86_64 &&
Daniel Dunbarbd847cc2012-10-15 22:23:53 +00003725 (((Args.hasArg(options::OPT_mkernel) ||
3726 Args.hasArg(options::OPT_fapple_kext)) &&
3727 (!getDarwinToolChain().isTargetIPhoneOS() ||
3728 getDarwinToolChain().isIPhoneOSVersionLT(6, 0))) ||
3729 Args.hasArg(options::OPT_static)))
Daniel Dunbard067f7f2009-04-08 23:54:23 +00003730 CmdArgs.push_back("-static");
3731
Daniel Dunbarbe220842009-03-20 16:06:39 +00003732 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
3733 options::OPT_Xassembler);
3734
3735 assert(Output.isFilename() && "Unexpected lipo output.");
3736 CmdArgs.push_back("-o");
3737 CmdArgs.push_back(Output.getFilename());
3738
Daniel Dunbarb440f562010-08-02 02:38:21 +00003739 assert(Input.isFilename() && "Invalid input.");
3740 CmdArgs.push_back(Input.getFilename());
Daniel Dunbarbe220842009-03-20 16:06:39 +00003741
3742 // asm_final spec is empty.
3743
Daniel Dunbard067f7f2009-04-08 23:54:23 +00003744 const char *Exec =
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00003745 Args.MakeArgString(getToolChain().GetProgramPath("as"));
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00003746 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbarbe220842009-03-20 16:06:39 +00003747}
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00003748
David Blaikie68e081d2011-12-20 02:48:34 +00003749void darwin::DarwinTool::anchor() {}
3750
Daniel Dunbare9ded432009-09-09 18:36:20 +00003751void darwin::DarwinTool::AddDarwinArch(const ArgList &Args,
3752 ArgStringList &CmdArgs) const {
Chris Lattner0e62c1c2011-07-23 10:55:15 +00003753 StringRef ArchName = getDarwinToolChain().getDarwinArchName(Args);
Daniel Dunbardcc3b652010-01-22 02:04:58 +00003754
Daniel Dunbarc1964212009-03-26 16:23:12 +00003755 // Derived from darwin_arch spec.
3756 CmdArgs.push_back("-arch");
Daniel Dunbardcc3b652010-01-22 02:04:58 +00003757 CmdArgs.push_back(Args.MakeArgString(ArchName));
Daniel Dunbar91dbfd62009-09-04 18:35:31 +00003758
Daniel Dunbardcc3b652010-01-22 02:04:58 +00003759 // FIXME: Is this needed anymore?
3760 if (ArchName == "arm")
Daniel Dunbar91dbfd62009-09-04 18:35:31 +00003761 CmdArgs.push_back("-force_cpusubtype_ALL");
Daniel Dunbarc1964212009-03-26 16:23:12 +00003762}
3763
Bill Wendling3b2000f2012-10-02 18:02:50 +00003764bool darwin::Link::NeedsTempPath(const InputInfoList &Inputs) const {
3765 // We only need to generate a temp path for LTO if we aren't compiling object
3766 // files. When compiling source files, we run 'dsymutil' after linking. We
3767 // don't run 'dsymutil' when compiling object files.
3768 for (InputInfoList::const_iterator
3769 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it)
3770 if (it->getType() != types::TY_Object)
3771 return true;
3772
3773 return false;
3774}
3775
Daniel Dunbarccbc4522010-09-09 21:51:05 +00003776void darwin::Link::AddLinkArgs(Compilation &C,
3777 const ArgList &Args,
Bill Wendling3b2000f2012-10-02 18:02:50 +00003778 ArgStringList &CmdArgs,
3779 const InputInfoList &Inputs) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00003780 const Driver &D = getToolChain().getDriver();
Daniel Dunbarc44d3132011-04-28 21:23:41 +00003781 const toolchains::Darwin &DarwinTC = getDarwinToolChain();
Daniel Dunbarc1964212009-03-26 16:23:12 +00003782
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00003783 unsigned Version[3] = { 0, 0, 0 };
3784 if (Arg *A = Args.getLastArg(options::OPT_mlinker_version_EQ)) {
3785 bool HadExtra;
Richard Smithbd55daf2012-11-01 04:30:05 +00003786 if (!Driver::GetReleaseVersion(A->getValue(), Version[0],
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00003787 Version[1], Version[2], HadExtra) ||
3788 HadExtra)
Chris Lattner0e62c1c2011-07-23 10:55:15 +00003789 D.Diag(diag::err_drv_invalid_version_number)
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00003790 << A->getAsString(Args);
3791 }
3792
3793 // Newer linkers support -demangle, pass it if supported and not disabled by
3794 // the user.
Daniel Dunbarecb41cb2012-01-04 21:45:27 +00003795 if (Version[0] >= 100 && !Args.hasArg(options::OPT_Z_Xlinker__no_demangle)) {
Daniel Dunbar1eaf5c62010-09-07 17:07:49 +00003796 // Don't pass -demangle to ld_classic.
3797 //
3798 // FIXME: This is a temporary workaround, ld should be handling this.
3799 bool UsesLdClassic = (getToolChain().getArch() == llvm::Triple::x86 &&
3800 Args.hasArg(options::OPT_static));
Daniel Dunbar3d7e0e22010-09-07 17:50:41 +00003801 if (getToolChain().getArch() == llvm::Triple::x86) {
3802 for (arg_iterator it = Args.filtered_begin(options::OPT_Xlinker,
3803 options::OPT_Wl_COMMA),
3804 ie = Args.filtered_end(); it != ie; ++it) {
3805 const Arg *A = *it;
3806 for (unsigned i = 0, e = A->getNumValues(); i != e; ++i)
Richard Smithbd55daf2012-11-01 04:30:05 +00003807 if (StringRef(A->getValue(i)) == "-kext")
Daniel Dunbar3d7e0e22010-09-07 17:50:41 +00003808 UsesLdClassic = true;
3809 }
3810 }
Daniel Dunbar1eaf5c62010-09-07 17:07:49 +00003811 if (!UsesLdClassic)
3812 CmdArgs.push_back("-demangle");
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00003813 }
3814
Bill Wendling313b6bf2012-11-16 23:03:00 +00003815 // If we are using LTO, then automatically create a temporary file path for
3816 // the linker to use, so that it's lifetime will extend past a possible
3817 // dsymutil step.
3818 if (Version[0] >= 116 && D.IsUsingLTO(Args) && NeedsTempPath(Inputs)) {
3819 const char *TmpPath = C.getArgs().MakeArgString(
3820 D.GetTemporaryPath("cc", types::getTypeTempSuffix(types::TY_Object)));
3821 C.addTempFile(TmpPath);
3822 CmdArgs.push_back("-object_path_lto");
3823 CmdArgs.push_back(TmpPath);
Daniel Dunbaref889c72011-06-21 20:55:11 +00003824 }
3825
Daniel Dunbarc1964212009-03-26 16:23:12 +00003826 // Derived from the "link" spec.
3827 Args.AddAllArgs(CmdArgs, options::OPT_static);
3828 if (!Args.hasArg(options::OPT_static))
3829 CmdArgs.push_back("-dynamic");
3830 if (Args.hasArg(options::OPT_fgnu_runtime)) {
3831 // FIXME: gcc replaces -lobjc in forward args with -lobjc-gnu
3832 // here. How do we wish to handle such things?
3833 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00003834
Daniel Dunbarc1964212009-03-26 16:23:12 +00003835 if (!Args.hasArg(options::OPT_dynamiclib)) {
Daniel Dunbara48823f2010-01-22 02:04:52 +00003836 AddDarwinArch(Args, CmdArgs);
Daniel Dunbara48823f2010-01-22 02:04:52 +00003837 // FIXME: Why do this only on this path?
Daniel Dunbar93d7acf2010-01-22 03:37:33 +00003838 Args.AddLastArg(CmdArgs, options::OPT_force__cpusubtype__ALL);
Daniel Dunbarc1964212009-03-26 16:23:12 +00003839
3840 Args.AddLastArg(CmdArgs, options::OPT_bundle);
3841 Args.AddAllArgs(CmdArgs, options::OPT_bundle__loader);
3842 Args.AddAllArgs(CmdArgs, options::OPT_client__name);
3843
3844 Arg *A;
3845 if ((A = Args.getLastArg(options::OPT_compatibility__version)) ||
3846 (A = Args.getLastArg(options::OPT_current__version)) ||
3847 (A = Args.getLastArg(options::OPT_install__name)))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00003848 D.Diag(diag::err_drv_argument_only_allowed_with)
Daniel Dunbarc1964212009-03-26 16:23:12 +00003849 << A->getAsString(Args) << "-dynamiclib";
3850
3851 Args.AddLastArg(CmdArgs, options::OPT_force__flat__namespace);
3852 Args.AddLastArg(CmdArgs, options::OPT_keep__private__externs);
3853 Args.AddLastArg(CmdArgs, options::OPT_private__bundle);
3854 } else {
3855 CmdArgs.push_back("-dylib");
3856
3857 Arg *A;
3858 if ((A = Args.getLastArg(options::OPT_bundle)) ||
3859 (A = Args.getLastArg(options::OPT_bundle__loader)) ||
3860 (A = Args.getLastArg(options::OPT_client__name)) ||
3861 (A = Args.getLastArg(options::OPT_force__flat__namespace)) ||
3862 (A = Args.getLastArg(options::OPT_keep__private__externs)) ||
3863 (A = Args.getLastArg(options::OPT_private__bundle)))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00003864 D.Diag(diag::err_drv_argument_not_allowed_with)
Daniel Dunbarc1964212009-03-26 16:23:12 +00003865 << A->getAsString(Args) << "-dynamiclib";
Daniel Dunbard067f7f2009-04-08 23:54:23 +00003866
Daniel Dunbarc1964212009-03-26 16:23:12 +00003867 Args.AddAllArgsTranslated(CmdArgs, options::OPT_compatibility__version,
3868 "-dylib_compatibility_version");
3869 Args.AddAllArgsTranslated(CmdArgs, options::OPT_current__version,
3870 "-dylib_current_version");
3871
Daniel Dunbara48823f2010-01-22 02:04:52 +00003872 AddDarwinArch(Args, CmdArgs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00003873
3874 Args.AddAllArgsTranslated(CmdArgs, options::OPT_install__name,
3875 "-dylib_install_name");
3876 }
3877
3878 Args.AddLastArg(CmdArgs, options::OPT_all__load);
3879 Args.AddAllArgs(CmdArgs, options::OPT_allowable__client);
3880 Args.AddLastArg(CmdArgs, options::OPT_bind__at__load);
Daniel Dunbarc44d3132011-04-28 21:23:41 +00003881 if (DarwinTC.isTargetIPhoneOS())
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00003882 Args.AddLastArg(CmdArgs, options::OPT_arch__errors__fatal);
Daniel Dunbarc1964212009-03-26 16:23:12 +00003883 Args.AddLastArg(CmdArgs, options::OPT_dead__strip);
3884 Args.AddLastArg(CmdArgs, options::OPT_no__dead__strip__inits__and__terms);
3885 Args.AddAllArgs(CmdArgs, options::OPT_dylib__file);
3886 Args.AddLastArg(CmdArgs, options::OPT_dynamic);
3887 Args.AddAllArgs(CmdArgs, options::OPT_exported__symbols__list);
3888 Args.AddLastArg(CmdArgs, options::OPT_flat__namespace);
Daniel Dunbar044a3902011-06-28 20:16:02 +00003889 Args.AddAllArgs(CmdArgs, options::OPT_force__load);
Daniel Dunbarc1964212009-03-26 16:23:12 +00003890 Args.AddAllArgs(CmdArgs, options::OPT_headerpad__max__install__names);
3891 Args.AddAllArgs(CmdArgs, options::OPT_image__base);
3892 Args.AddAllArgs(CmdArgs, options::OPT_init);
3893
Daniel Dunbarc44d3132011-04-28 21:23:41 +00003894 // Add the deployment target.
Benjamin Kramerddefa6d2012-03-10 20:55:36 +00003895 VersionTuple TargetVersion = DarwinTC.getTargetVersion();
Daniel Dunbar72ceb922011-04-30 04:22:58 +00003896
3897 // If we had an explicit -mios-simulator-version-min argument, honor that,
3898 // otherwise use the traditional deployment targets. We can't just check the
3899 // is-sim attribute because existing code follows this path, and the linker
3900 // may not handle the argument.
3901 //
3902 // FIXME: We may be able to remove this, once we can verify no one depends on
3903 // it.
3904 if (Args.hasArg(options::OPT_mios_simulator_version_min_EQ))
3905 CmdArgs.push_back("-ios_simulator_version_min");
3906 else if (DarwinTC.isTargetIPhoneOS())
3907 CmdArgs.push_back("-iphoneos_version_min");
3908 else
3909 CmdArgs.push_back("-macosx_version_min");
Benjamin Kramerddefa6d2012-03-10 20:55:36 +00003910 CmdArgs.push_back(Args.MakeArgString(TargetVersion.getAsString()));
Daniel Dunbarc44d3132011-04-28 21:23:41 +00003911
Daniel Dunbarc1964212009-03-26 16:23:12 +00003912 Args.AddLastArg(CmdArgs, options::OPT_nomultidefs);
3913 Args.AddLastArg(CmdArgs, options::OPT_multi__module);
3914 Args.AddLastArg(CmdArgs, options::OPT_single__module);
3915 Args.AddAllArgs(CmdArgs, options::OPT_multiply__defined);
3916 Args.AddAllArgs(CmdArgs, options::OPT_multiply__defined__unused);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00003917
Daniel Dunbaraf68a882010-07-13 23:31:40 +00003918 if (const Arg *A = Args.getLastArg(options::OPT_fpie, options::OPT_fPIE,
3919 options::OPT_fno_pie,
3920 options::OPT_fno_PIE)) {
3921 if (A->getOption().matches(options::OPT_fpie) ||
3922 A->getOption().matches(options::OPT_fPIE))
3923 CmdArgs.push_back("-pie");
3924 else
3925 CmdArgs.push_back("-no_pie");
3926 }
Daniel Dunbarc1964212009-03-26 16:23:12 +00003927
3928 Args.AddLastArg(CmdArgs, options::OPT_prebind);
3929 Args.AddLastArg(CmdArgs, options::OPT_noprebind);
3930 Args.AddLastArg(CmdArgs, options::OPT_nofixprebinding);
3931 Args.AddLastArg(CmdArgs, options::OPT_prebind__all__twolevel__modules);
3932 Args.AddLastArg(CmdArgs, options::OPT_read__only__relocs);
3933 Args.AddAllArgs(CmdArgs, options::OPT_sectcreate);
3934 Args.AddAllArgs(CmdArgs, options::OPT_sectorder);
3935 Args.AddAllArgs(CmdArgs, options::OPT_seg1addr);
3936 Args.AddAllArgs(CmdArgs, options::OPT_segprot);
3937 Args.AddAllArgs(CmdArgs, options::OPT_segaddr);
3938 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__only__addr);
3939 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__write__addr);
3940 Args.AddAllArgs(CmdArgs, options::OPT_seg__addr__table);
3941 Args.AddAllArgs(CmdArgs, options::OPT_seg__addr__table__filename);
3942 Args.AddAllArgs(CmdArgs, options::OPT_sub__library);
3943 Args.AddAllArgs(CmdArgs, options::OPT_sub__umbrella);
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00003944
Daniel Dunbar84384642011-05-02 21:03:47 +00003945 // Give --sysroot= preference, over the Apple specific behavior to also use
3946 // --isysroot as the syslibroot.
Sebastian Pop980920a2012-04-16 04:16:43 +00003947 StringRef sysroot = C.getSysRoot();
3948 if (sysroot != "") {
Daniel Dunbar84384642011-05-02 21:03:47 +00003949 CmdArgs.push_back("-syslibroot");
Sebastian Pop980920a2012-04-16 04:16:43 +00003950 CmdArgs.push_back(C.getArgs().MakeArgString(sysroot));
Daniel Dunbar84384642011-05-02 21:03:47 +00003951 } else if (const Arg *A = Args.getLastArg(options::OPT_isysroot)) {
3952 CmdArgs.push_back("-syslibroot");
Richard Smithbd55daf2012-11-01 04:30:05 +00003953 CmdArgs.push_back(A->getValue());
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00003954 }
3955
Daniel Dunbarc1964212009-03-26 16:23:12 +00003956 Args.AddLastArg(CmdArgs, options::OPT_twolevel__namespace);
3957 Args.AddLastArg(CmdArgs, options::OPT_twolevel__namespace__hints);
3958 Args.AddAllArgs(CmdArgs, options::OPT_umbrella);
3959 Args.AddAllArgs(CmdArgs, options::OPT_undefined);
3960 Args.AddAllArgs(CmdArgs, options::OPT_unexported__symbols__list);
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00003961 Args.AddAllArgs(CmdArgs, options::OPT_weak__reference__mismatches);
Daniel Dunbarc1964212009-03-26 16:23:12 +00003962 Args.AddLastArg(CmdArgs, options::OPT_X_Flag);
3963 Args.AddAllArgs(CmdArgs, options::OPT_y);
3964 Args.AddLastArg(CmdArgs, options::OPT_w);
3965 Args.AddAllArgs(CmdArgs, options::OPT_pagezero__size);
3966 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__);
3967 Args.AddLastArg(CmdArgs, options::OPT_seglinkedit);
3968 Args.AddLastArg(CmdArgs, options::OPT_noseglinkedit);
3969 Args.AddAllArgs(CmdArgs, options::OPT_sectalign);
3970 Args.AddAllArgs(CmdArgs, options::OPT_sectobjectsymbols);
3971 Args.AddAllArgs(CmdArgs, options::OPT_segcreate);
3972 Args.AddLastArg(CmdArgs, options::OPT_whyload);
3973 Args.AddLastArg(CmdArgs, options::OPT_whatsloaded);
3974 Args.AddAllArgs(CmdArgs, options::OPT_dylinker__install__name);
3975 Args.AddLastArg(CmdArgs, options::OPT_dylinker);
3976 Args.AddLastArg(CmdArgs, options::OPT_Mach);
3977}
3978
3979void darwin::Link::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00003980 const InputInfo &Output,
Daniel Dunbard067f7f2009-04-08 23:54:23 +00003981 const InputInfoList &Inputs,
3982 const ArgList &Args,
Daniel Dunbarc1964212009-03-26 16:23:12 +00003983 const char *LinkingOutput) const {
3984 assert(Output.getType() == types::TY_Image && "Invalid linker output type.");
Daniel Dunbarc09988d2009-09-08 16:39:16 +00003985
Daniel Dunbarc1964212009-03-26 16:23:12 +00003986 // The logic here is derived from gcc's behavior; most of which
3987 // comes from specs (starting with link_command). Consult gcc for
3988 // more information.
Daniel Dunbarc1964212009-03-26 16:23:12 +00003989 ArgStringList CmdArgs;
3990
Argyrios Kyrtzidis741fab12011-10-07 22:58:08 +00003991 /// Hack(tm) to ignore linking errors when we are doing ARC migration.
3992 if (Args.hasArg(options::OPT_ccc_arcmt_check,
3993 options::OPT_ccc_arcmt_migrate)) {
3994 for (ArgList::const_iterator I = Args.begin(), E = Args.end(); I != E; ++I)
3995 (*I)->claim();
3996 const char *Exec =
3997 Args.MakeArgString(getToolChain().GetProgramPath("touch"));
3998 CmdArgs.push_back(Output.getFilename());
3999 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
4000 return;
4001 }
4002
Daniel Dunbarc1964212009-03-26 16:23:12 +00004003 // I'm not sure why this particular decomposition exists in gcc, but
4004 // we follow suite for ease of comparison.
Bill Wendling3b2000f2012-10-02 18:02:50 +00004005 AddLinkArgs(C, Args, CmdArgs, Inputs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00004006
Daniel Dunbarc1964212009-03-26 16:23:12 +00004007 Args.AddAllArgs(CmdArgs, options::OPT_d_Flag);
4008 Args.AddAllArgs(CmdArgs, options::OPT_s);
4009 Args.AddAllArgs(CmdArgs, options::OPT_t);
4010 Args.AddAllArgs(CmdArgs, options::OPT_Z_Flag);
4011 Args.AddAllArgs(CmdArgs, options::OPT_u_Group);
Daniel Dunbarc1964212009-03-26 16:23:12 +00004012 Args.AddLastArg(CmdArgs, options::OPT_e);
4013 Args.AddAllArgs(CmdArgs, options::OPT_m_Separate);
4014 Args.AddAllArgs(CmdArgs, options::OPT_r);
4015
Daniel Dunbar767bbab2010-10-18 22:08:36 +00004016 // Forward -ObjC when either -ObjC or -ObjC++ is used, to force loading
4017 // members of static archive libraries which implement Objective-C classes or
4018 // categories.
4019 if (Args.hasArg(options::OPT_ObjC) || Args.hasArg(options::OPT_ObjCXX))
4020 CmdArgs.push_back("-ObjC");
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00004021
Daniel Dunbarc1964212009-03-26 16:23:12 +00004022 CmdArgs.push_back("-o");
4023 CmdArgs.push_back(Output.getFilename());
4024
Chad Rosier06fd3c62012-05-16 23:45:12 +00004025 if (!Args.hasArg(options::OPT_nostdlib) &&
Daniel Dunbarc1964212009-03-26 16:23:12 +00004026 !Args.hasArg(options::OPT_nostartfiles)) {
4027 // Derived from startfile spec.
4028 if (Args.hasArg(options::OPT_dynamiclib)) {
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004029 // Derived from darwin_dylib1 spec.
Daniel Dunbar16d97092011-04-01 21:02:42 +00004030 if (getDarwinToolChain().isTargetIOSSimulator()) {
4031 // The simulator doesn't have a versioned crt1 file.
4032 CmdArgs.push_back("-ldylib1.o");
4033 } else if (getDarwinToolChain().isTargetIPhoneOS()) {
Daniel Dunbar83608032010-01-27 00:56:56 +00004034 if (getDarwinToolChain().isIPhoneOSVersionLT(3, 1))
4035 CmdArgs.push_back("-ldylib1.o");
4036 } else {
Daniel Dunbar6d23b2f2010-01-27 00:57:03 +00004037 if (getDarwinToolChain().isMacosxVersionLT(10, 5))
Daniel Dunbar83608032010-01-27 00:56:56 +00004038 CmdArgs.push_back("-ldylib1.o");
Daniel Dunbar6d23b2f2010-01-27 00:57:03 +00004039 else if (getDarwinToolChain().isMacosxVersionLT(10, 6))
Daniel Dunbar83608032010-01-27 00:56:56 +00004040 CmdArgs.push_back("-ldylib1.10.5.o");
4041 }
Daniel Dunbarc1964212009-03-26 16:23:12 +00004042 } else {
4043 if (Args.hasArg(options::OPT_bundle)) {
Daniel Dunbarae8bca02009-04-01 03:17:40 +00004044 if (!Args.hasArg(options::OPT_static)) {
4045 // Derived from darwin_bundle1 spec.
Daniel Dunbar16d97092011-04-01 21:02:42 +00004046 if (getDarwinToolChain().isTargetIOSSimulator()) {
4047 // The simulator doesn't have a versioned crt1 file.
4048 CmdArgs.push_back("-lbundle1.o");
4049 } else if (getDarwinToolChain().isTargetIPhoneOS()) {
Daniel Dunbar83608032010-01-27 00:56:56 +00004050 if (getDarwinToolChain().isIPhoneOSVersionLT(3, 1))
4051 CmdArgs.push_back("-lbundle1.o");
4052 } else {
Daniel Dunbar6d23b2f2010-01-27 00:57:03 +00004053 if (getDarwinToolChain().isMacosxVersionLT(10, 6))
Daniel Dunbar83608032010-01-27 00:56:56 +00004054 CmdArgs.push_back("-lbundle1.o");
4055 }
Daniel Dunbarae8bca02009-04-01 03:17:40 +00004056 }
Daniel Dunbarc1964212009-03-26 16:23:12 +00004057 } else {
Daniel Dunbar733b0f82011-03-01 18:49:30 +00004058 if (Args.hasArg(options::OPT_pg) &&
4059 getToolChain().SupportsProfiling()) {
Daniel Dunbarc1964212009-03-26 16:23:12 +00004060 if (Args.hasArg(options::OPT_static) ||
4061 Args.hasArg(options::OPT_object) ||
4062 Args.hasArg(options::OPT_preload)) {
4063 CmdArgs.push_back("-lgcrt0.o");
4064 } else {
4065 CmdArgs.push_back("-lgcrt1.o");
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004066
Daniel Dunbarc1964212009-03-26 16:23:12 +00004067 // darwin_crt2 spec is empty.
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004068 }
Bob Wilsonef285b42012-07-04 00:18:41 +00004069 // By default on OS X 10.8 and later, we don't link with a crt1.o
4070 // file and the linker knows to use _main as the entry point. But,
4071 // when compiling with -pg, we need to link with the gcrt1.o file,
4072 // so pass the -no_new_main option to tell the linker to use the
4073 // "start" symbol as the entry point.
Bob Wilson1e148fe2012-07-03 20:42:10 +00004074 if (getDarwinToolChain().isTargetMacOS() &&
4075 !getDarwinToolChain().isMacosxVersionLT(10, 8))
4076 CmdArgs.push_back("-no_new_main");
Daniel Dunbarc1964212009-03-26 16:23:12 +00004077 } else {
4078 if (Args.hasArg(options::OPT_static) ||
4079 Args.hasArg(options::OPT_object) ||
4080 Args.hasArg(options::OPT_preload)) {
4081 CmdArgs.push_back("-lcrt0.o");
4082 } else {
4083 // Derived from darwin_crt1 spec.
Daniel Dunbarebc34df2011-03-31 17:12:33 +00004084 if (getDarwinToolChain().isTargetIOSSimulator()) {
4085 // The simulator doesn't have a versioned crt1 file.
4086 CmdArgs.push_back("-lcrt1.o");
4087 } else if (getDarwinToolChain().isTargetIPhoneOS()) {
Daniel Dunbar83608032010-01-27 00:56:56 +00004088 if (getDarwinToolChain().isIPhoneOSVersionLT(3, 1))
4089 CmdArgs.push_back("-lcrt1.o");
Daniel Dunbarbd847cc2012-10-15 22:23:53 +00004090 else if (getDarwinToolChain().isIPhoneOSVersionLT(6, 0))
Daniel Dunbar83608032010-01-27 00:56:56 +00004091 CmdArgs.push_back("-lcrt1.3.1.o");
Daniel Dunbar6d23b2f2010-01-27 00:57:03 +00004092 } else {
4093 if (getDarwinToolChain().isMacosxVersionLT(10, 5))
4094 CmdArgs.push_back("-lcrt1.o");
4095 else if (getDarwinToolChain().isMacosxVersionLT(10, 6))
4096 CmdArgs.push_back("-lcrt1.10.5.o");
Ted Kremeneke65b0862012-03-06 20:05:56 +00004097 else if (getDarwinToolChain().isMacosxVersionLT(10, 8))
Daniel Dunbar6d23b2f2010-01-27 00:57:03 +00004098 CmdArgs.push_back("-lcrt1.10.6.o");
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004099
Daniel Dunbar6d23b2f2010-01-27 00:57:03 +00004100 // darwin_crt2 spec is empty.
4101 }
Daniel Dunbarc1964212009-03-26 16:23:12 +00004102 }
4103 }
4104 }
4105 }
4106
Daniel Dunbar6d23b2f2010-01-27 00:57:03 +00004107 if (!getDarwinToolChain().isTargetIPhoneOS() &&
4108 Args.hasArg(options::OPT_shared_libgcc) &&
4109 getDarwinToolChain().isMacosxVersionLT(10, 5)) {
Daniel Dunbar1c28f1e2009-09-09 22:32:48 +00004110 const char *Str =
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00004111 Args.MakeArgString(getToolChain().GetFilePath("crt3.o"));
Daniel Dunbar1c28f1e2009-09-09 22:32:48 +00004112 CmdArgs.push_back(Str);
Daniel Dunbarc1964212009-03-26 16:23:12 +00004113 }
4114 }
4115
4116 Args.AddAllArgs(CmdArgs, options::OPT_L);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004117
Alexey Samsonov627b10f2012-11-06 15:09:03 +00004118 SanitizerArgs Sanitize(getToolChain().getDriver(), Args);
Alexey Samsonovcc429802012-11-16 12:53:14 +00004119 // If we're building a dynamic lib with -fsanitize=address, or
4120 // -fsanitize=undefined, unresolved symbols may appear. Mark all
4121 // of them as dynamic_lookup. Linking executables is handled in
4122 // lib/Driver/ToolChains.cpp.
4123 if (Sanitize.needsAsanRt() || Sanitize.needsUbsanRt()) {
Kostya Serebryany0b692ce2011-12-06 19:18:44 +00004124 if (Args.hasArg(options::OPT_dynamiclib) ||
4125 Args.hasArg(options::OPT_bundle)) {
4126 CmdArgs.push_back("-undefined");
4127 CmdArgs.push_back("dynamic_lookup");
4128 }
4129 }
4130
Daniel Dunbarc1964212009-03-26 16:23:12 +00004131 if (Args.hasArg(options::OPT_fopenmp))
4132 // This is more complicated in gcc...
4133 CmdArgs.push_back("-lgomp");
4134
Douglas Gregor9295df02012-05-15 21:00:27 +00004135 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
4136
Bob Wilson16d93952012-05-15 18:57:39 +00004137 if (isObjCRuntimeLinked(Args) &&
4138 !Args.hasArg(options::OPT_nostdlib) &&
4139 !Args.hasArg(options::OPT_nodefaultlibs)) {
Ted Kremeneke65b0862012-03-06 20:05:56 +00004140 // Avoid linking compatibility stubs on i386 mac.
4141 if (!getDarwinToolChain().isTargetMacOS() ||
Rafael Espindola35ca7d92012-10-07 04:44:33 +00004142 getDarwinToolChain().getArch() != llvm::Triple::x86) {
Ted Kremeneke65b0862012-03-06 20:05:56 +00004143 // If we don't have ARC or subscripting runtime support, link in the
4144 // runtime stubs. We have to do this *before* adding any of the normal
4145 // linker inputs so that its initializer gets run first.
John McCall5fb5df92012-06-20 06:18:46 +00004146 ObjCRuntime runtime =
4147 getDarwinToolChain().getDefaultObjCRuntime(/*nonfragile*/ true);
Ted Kremeneke65b0862012-03-06 20:05:56 +00004148 // We use arclite library for both ARC and subscripting support.
John McCall3deb1ad2012-08-21 02:47:43 +00004149 if ((!runtime.hasNativeARC() && isObjCAutoRefCount(Args)) ||
John McCall5fb5df92012-06-20 06:18:46 +00004150 !runtime.hasSubscripting())
Ted Kremeneke65b0862012-03-06 20:05:56 +00004151 getDarwinToolChain().AddLinkARCArgs(Args, CmdArgs);
Ted Kremeneke65b0862012-03-06 20:05:56 +00004152 }
Bob Wilson7dda0cd2012-04-21 00:21:42 +00004153 CmdArgs.push_back("-framework");
4154 CmdArgs.push_back("Foundation");
Ted Kremeneke65b0862012-03-06 20:05:56 +00004155 // Link libobj.
4156 CmdArgs.push_back("-lobjc");
John McCall24fc0de2011-07-06 00:26:06 +00004157 }
John McCall31168b02011-06-15 23:02:42 +00004158
Daniel Dunbarc1964212009-03-26 16:23:12 +00004159 if (LinkingOutput) {
4160 CmdArgs.push_back("-arch_multiple");
4161 CmdArgs.push_back("-final_output");
4162 CmdArgs.push_back(LinkingOutput);
4163 }
4164
Daniel Dunbarc1964212009-03-26 16:23:12 +00004165 if (Args.hasArg(options::OPT_fnested_functions))
4166 CmdArgs.push_back("-allow_stack_execute");
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004167
Daniel Dunbarc1964212009-03-26 16:23:12 +00004168 if (!Args.hasArg(options::OPT_nostdlib) &&
4169 !Args.hasArg(options::OPT_nodefaultlibs)) {
Daniel Dunbar083edf72009-12-21 18:54:17 +00004170 if (getToolChain().getDriver().CCCIsCXX)
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00004171 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Daniel Dunbarad0f62b2009-04-08 06:06:21 +00004172
Daniel Dunbarc1964212009-03-26 16:23:12 +00004173 // link_ssp spec is empty.
4174
Daniel Dunbar26d482a2009-09-18 08:15:03 +00004175 // Let the tool chain choose which runtime library to link.
4176 getDarwinToolChain().AddLinkRuntimeLibArgs(Args, CmdArgs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00004177 }
4178
Chad Rosier06fd3c62012-05-16 23:45:12 +00004179 if (!Args.hasArg(options::OPT_nostdlib) &&
Daniel Dunbarc1964212009-03-26 16:23:12 +00004180 !Args.hasArg(options::OPT_nostartfiles)) {
4181 // endfile_spec is empty.
4182 }
4183
4184 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
4185 Args.AddAllArgs(CmdArgs, options::OPT_F);
4186
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004187 const char *Exec =
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00004188 Args.MakeArgString(getToolChain().GetProgramPath("ld"));
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00004189 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbarc1964212009-03-26 16:23:12 +00004190}
4191
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00004192void darwin::Lipo::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00004193 const InputInfo &Output,
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004194 const InputInfoList &Inputs,
4195 const ArgList &Args,
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00004196 const char *LinkingOutput) const {
4197 ArgStringList CmdArgs;
4198
4199 CmdArgs.push_back("-create");
4200 assert(Output.isFilename() && "Unexpected lipo output.");
Daniel Dunbar06686ab2009-03-24 00:24:37 +00004201
4202 CmdArgs.push_back("-output");
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00004203 CmdArgs.push_back(Output.getFilename());
Daniel Dunbar06686ab2009-03-24 00:24:37 +00004204
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00004205 for (InputInfoList::const_iterator
4206 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
4207 const InputInfo &II = *it;
4208 assert(II.isFilename() && "Unexpected lipo input.");
4209 CmdArgs.push_back(II.getFilename());
4210 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004211 const char *Exec =
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00004212 Args.MakeArgString(getToolChain().GetProgramPath("lipo"));
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00004213 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00004214}
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00004215
Daniel Dunbar88299622010-06-04 18:28:36 +00004216void darwin::Dsymutil::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00004217 const InputInfo &Output,
Daniel Dunbar88299622010-06-04 18:28:36 +00004218 const InputInfoList &Inputs,
4219 const ArgList &Args,
4220 const char *LinkingOutput) const {
4221 ArgStringList CmdArgs;
4222
Daniel Dunbareb86b042011-05-09 17:23:16 +00004223 CmdArgs.push_back("-o");
4224 CmdArgs.push_back(Output.getFilename());
4225
Daniel Dunbar88299622010-06-04 18:28:36 +00004226 assert(Inputs.size() == 1 && "Unable to handle multiple inputs.");
4227 const InputInfo &Input = Inputs[0];
4228 assert(Input.isFilename() && "Unexpected dsymutil input.");
4229 CmdArgs.push_back(Input.getFilename());
4230
Daniel Dunbar88299622010-06-04 18:28:36 +00004231 const char *Exec =
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00004232 Args.MakeArgString(getToolChain().GetProgramPath("dsymutil"));
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00004233 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbar88299622010-06-04 18:28:36 +00004234}
4235
Eric Christopher551ef452011-08-23 17:56:55 +00004236void darwin::VerifyDebug::ConstructJob(Compilation &C, const JobAction &JA,
4237 const InputInfo &Output,
4238 const InputInfoList &Inputs,
4239 const ArgList &Args,
4240 const char *LinkingOutput) const {
4241 ArgStringList CmdArgs;
4242 CmdArgs.push_back("--verify");
Eric Christopher36222212012-02-06 19:13:09 +00004243 CmdArgs.push_back("--debug-info");
4244 CmdArgs.push_back("--eh-frame");
Eric Christopher65c05fa2012-02-06 19:43:51 +00004245 CmdArgs.push_back("--quiet");
Eric Christopher551ef452011-08-23 17:56:55 +00004246
4247 assert(Inputs.size() == 1 && "Unable to handle multiple inputs.");
4248 const InputInfo &Input = Inputs[0];
4249 assert(Input.isFilename() && "Unexpected verify input");
4250
4251 // Grabbing the output of the earlier dsymutil run.
4252 CmdArgs.push_back(Input.getFilename());
4253
4254 const char *Exec =
4255 Args.MakeArgString(getToolChain().GetProgramPath("dwarfdump"));
4256 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
4257}
4258
David Chisnallf571cde2012-02-15 13:39:01 +00004259void solaris::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
4260 const InputInfo &Output,
4261 const InputInfoList &Inputs,
4262 const ArgList &Args,
4263 const char *LinkingOutput) const {
4264 ArgStringList CmdArgs;
4265
4266 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
4267 options::OPT_Xassembler);
4268
4269 CmdArgs.push_back("-o");
4270 CmdArgs.push_back(Output.getFilename());
4271
4272 for (InputInfoList::const_iterator
4273 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
4274 const InputInfo &II = *it;
4275 CmdArgs.push_back(II.getFilename());
4276 }
4277
4278 const char *Exec =
4279 Args.MakeArgString(getToolChain().GetProgramPath("as"));
4280 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
4281}
4282
4283
4284void solaris::Link::ConstructJob(Compilation &C, const JobAction &JA,
4285 const InputInfo &Output,
4286 const InputInfoList &Inputs,
4287 const ArgList &Args,
4288 const char *LinkingOutput) const {
4289 // FIXME: Find a real GCC, don't hard-code versions here
4290 std::string GCCLibPath = "/usr/gcc/4.5/lib/gcc/";
4291 const llvm::Triple &T = getToolChain().getTriple();
4292 std::string LibPath = "/usr/lib/";
4293 llvm::Triple::ArchType Arch = T.getArch();
4294 switch (Arch) {
4295 case llvm::Triple::x86:
4296 GCCLibPath += ("i386-" + T.getVendorName() + "-" +
4297 T.getOSName()).str() + "/4.5.2/";
4298 break;
4299 case llvm::Triple::x86_64:
4300 GCCLibPath += ("i386-" + T.getVendorName() + "-" +
4301 T.getOSName()).str();
4302 GCCLibPath += "/4.5.2/amd64/";
4303 LibPath += "amd64/";
4304 break;
4305 default:
4306 assert(0 && "Unsupported architecture");
4307 }
4308
4309 ArgStringList CmdArgs;
4310
David Chisnall272a0712012-02-29 15:06:12 +00004311 // Demangle C++ names in errors
4312 CmdArgs.push_back("-C");
4313
David Chisnallf571cde2012-02-15 13:39:01 +00004314 if ((!Args.hasArg(options::OPT_nostdlib)) &&
4315 (!Args.hasArg(options::OPT_shared))) {
4316 CmdArgs.push_back("-e");
4317 CmdArgs.push_back("_start");
4318 }
4319
4320 if (Args.hasArg(options::OPT_static)) {
4321 CmdArgs.push_back("-Bstatic");
4322 CmdArgs.push_back("-dn");
4323 } else {
4324 CmdArgs.push_back("-Bdynamic");
4325 if (Args.hasArg(options::OPT_shared)) {
4326 CmdArgs.push_back("-shared");
4327 } else {
4328 CmdArgs.push_back("--dynamic-linker");
4329 CmdArgs.push_back(Args.MakeArgString(LibPath + "ld.so.1"));
4330 }
4331 }
4332
4333 if (Output.isFilename()) {
4334 CmdArgs.push_back("-o");
4335 CmdArgs.push_back(Output.getFilename());
4336 } else {
4337 assert(Output.isNothing() && "Invalid output.");
4338 }
4339
4340 if (!Args.hasArg(options::OPT_nostdlib) &&
4341 !Args.hasArg(options::OPT_nostartfiles)) {
4342 if (!Args.hasArg(options::OPT_shared)) {
4343 CmdArgs.push_back(Args.MakeArgString(LibPath + "crt1.o"));
4344 CmdArgs.push_back(Args.MakeArgString(LibPath + "crti.o"));
David Chisnall0c52c0f2012-02-28 17:10:04 +00004345 CmdArgs.push_back(Args.MakeArgString(LibPath + "values-Xa.o"));
David Chisnallf571cde2012-02-15 13:39:01 +00004346 CmdArgs.push_back(Args.MakeArgString(GCCLibPath + "crtbegin.o"));
4347 } else {
4348 CmdArgs.push_back(Args.MakeArgString(LibPath + "crti.o"));
David Chisnall0c52c0f2012-02-28 17:10:04 +00004349 CmdArgs.push_back(Args.MakeArgString(LibPath + "values-Xa.o"));
4350 CmdArgs.push_back(Args.MakeArgString(GCCLibPath + "crtbegin.o"));
David Chisnallf571cde2012-02-15 13:39:01 +00004351 }
David Chisnallddc4c9d2012-03-13 14:14:54 +00004352 if (getToolChain().getDriver().CCCIsCXX)
4353 CmdArgs.push_back(Args.MakeArgString(LibPath + "cxa_finalize.o"));
David Chisnallf571cde2012-02-15 13:39:01 +00004354 }
4355
4356 CmdArgs.push_back(Args.MakeArgString("-L" + GCCLibPath));
4357
4358 Args.AddAllArgs(CmdArgs, options::OPT_L);
4359 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
4360 Args.AddAllArgs(CmdArgs, options::OPT_e);
David Chisnall0c52c0f2012-02-28 17:10:04 +00004361 Args.AddAllArgs(CmdArgs, options::OPT_r);
David Chisnallf571cde2012-02-15 13:39:01 +00004362
4363 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
4364
4365 if (!Args.hasArg(options::OPT_nostdlib) &&
4366 !Args.hasArg(options::OPT_nodefaultlibs)) {
David Chisnall3d127c72012-04-10 11:49:50 +00004367 if (getToolChain().getDriver().CCCIsCXX)
4368 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
David Chisnall1026fb02012-02-15 18:24:31 +00004369 CmdArgs.push_back("-lgcc_s");
David Chisnall0c52c0f2012-02-28 17:10:04 +00004370 if (!Args.hasArg(options::OPT_shared)) {
4371 CmdArgs.push_back("-lgcc");
David Chisnallf571cde2012-02-15 13:39:01 +00004372 CmdArgs.push_back("-lc");
David Chisnallc73fb892012-02-28 20:06:45 +00004373 CmdArgs.push_back("-lm");
David Chisnall0c52c0f2012-02-28 17:10:04 +00004374 }
David Chisnallf571cde2012-02-15 13:39:01 +00004375 }
4376
4377 if (!Args.hasArg(options::OPT_nostdlib) &&
4378 !Args.hasArg(options::OPT_nostartfiles)) {
David Chisnall0c52c0f2012-02-28 17:10:04 +00004379 CmdArgs.push_back(Args.MakeArgString(GCCLibPath + "crtend.o"));
David Chisnallf571cde2012-02-15 13:39:01 +00004380 }
David Chisnall96de9932012-02-16 16:00:47 +00004381 CmdArgs.push_back(Args.MakeArgString(LibPath + "crtn.o"));
David Chisnallf571cde2012-02-15 13:39:01 +00004382
4383 addProfileRT(getToolChain(), Args, CmdArgs, getToolChain().getTriple());
4384
4385 const char *Exec =
4386 Args.MakeArgString(getToolChain().GetProgramPath("ld"));
4387 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
4388}
4389
Edward O'Callaghan856e4ff2009-08-22 01:06:46 +00004390void auroraux::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00004391 const InputInfo &Output,
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004392 const InputInfoList &Inputs,
4393 const ArgList &Args,
4394 const char *LinkingOutput) const {
Edward O'Callaghan856e4ff2009-08-22 01:06:46 +00004395 ArgStringList CmdArgs;
4396
4397 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
4398 options::OPT_Xassembler);
4399
4400 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00004401 CmdArgs.push_back(Output.getFilename());
Edward O'Callaghan856e4ff2009-08-22 01:06:46 +00004402
4403 for (InputInfoList::const_iterator
4404 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
4405 const InputInfo &II = *it;
Daniel Dunbarb440f562010-08-02 02:38:21 +00004406 CmdArgs.push_back(II.getFilename());
Edward O'Callaghan856e4ff2009-08-22 01:06:46 +00004407 }
4408
4409 const char *Exec =
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00004410 Args.MakeArgString(getToolChain().GetProgramPath("gas"));
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00004411 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Edward O'Callaghan856e4ff2009-08-22 01:06:46 +00004412}
4413
4414void auroraux::Link::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00004415 const InputInfo &Output,
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004416 const InputInfoList &Inputs,
4417 const ArgList &Args,
4418 const char *LinkingOutput) const {
Edward O'Callaghan856e4ff2009-08-22 01:06:46 +00004419 ArgStringList CmdArgs;
4420
4421 if ((!Args.hasArg(options::OPT_nostdlib)) &&
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004422 (!Args.hasArg(options::OPT_shared))) {
Edward O'Callaghan856e4ff2009-08-22 01:06:46 +00004423 CmdArgs.push_back("-e");
Edward O'Callaghand8712d92009-10-15 07:44:07 +00004424 CmdArgs.push_back("_start");
Edward O'Callaghan856e4ff2009-08-22 01:06:46 +00004425 }
4426
4427 if (Args.hasArg(options::OPT_static)) {
4428 CmdArgs.push_back("-Bstatic");
Edward O'Callaghand8712d92009-10-15 07:44:07 +00004429 CmdArgs.push_back("-dn");
Edward O'Callaghan856e4ff2009-08-22 01:06:46 +00004430 } else {
Edward O'Callaghand8712d92009-10-15 07:44:07 +00004431// CmdArgs.push_back("--eh-frame-hdr");
Edward O'Callaghan856e4ff2009-08-22 01:06:46 +00004432 CmdArgs.push_back("-Bdynamic");
4433 if (Args.hasArg(options::OPT_shared)) {
4434 CmdArgs.push_back("-shared");
4435 } else {
Edward O'Callaghan7d3c2752009-10-16 19:44:18 +00004436 CmdArgs.push_back("--dynamic-linker");
Edward O'Callaghan856e4ff2009-08-22 01:06:46 +00004437 CmdArgs.push_back("/lib/ld.so.1"); // 64Bit Path /lib/amd64/ld.so.1
4438 }
4439 }
4440
Daniel Dunbarb440f562010-08-02 02:38:21 +00004441 if (Output.isFilename()) {
Edward O'Callaghan856e4ff2009-08-22 01:06:46 +00004442 CmdArgs.push_back("-o");
4443 CmdArgs.push_back(Output.getFilename());
4444 } else {
4445 assert(Output.isNothing() && "Invalid output.");
4446 }
4447
4448 if (!Args.hasArg(options::OPT_nostdlib) &&
4449 !Args.hasArg(options::OPT_nostartfiles)) {
4450 if (!Args.hasArg(options::OPT_shared)) {
Chris Lattner3e2ee142010-07-07 16:01:42 +00004451 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00004452 getToolChain().GetFilePath("crt1.o")));
Chris Lattner3e2ee142010-07-07 16:01:42 +00004453 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00004454 getToolChain().GetFilePath("crti.o")));
Chris Lattner3e2ee142010-07-07 16:01:42 +00004455 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00004456 getToolChain().GetFilePath("crtbegin.o")));
Edward O'Callaghan856e4ff2009-08-22 01:06:46 +00004457 } else {
Chris Lattner3e2ee142010-07-07 16:01:42 +00004458 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00004459 getToolChain().GetFilePath("crti.o")));
Edward O'Callaghan856e4ff2009-08-22 01:06:46 +00004460 }
Chris Lattner3e2ee142010-07-07 16:01:42 +00004461 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00004462 getToolChain().GetFilePath("crtn.o")));
Edward O'Callaghan856e4ff2009-08-22 01:06:46 +00004463 }
4464
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004465 CmdArgs.push_back(Args.MakeArgString("-L/opt/gcc4/lib/gcc/"
4466 + getToolChain().getTripleString()
Daniel Dunbarb0b18612009-10-29 02:24:37 +00004467 + "/4.2.4"));
Edward O'Callaghan856e4ff2009-08-22 01:06:46 +00004468
4469 Args.AddAllArgs(CmdArgs, options::OPT_L);
4470 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
4471 Args.AddAllArgs(CmdArgs, options::OPT_e);
4472
Daniel Dunbar54423b22010-09-17 00:24:54 +00004473 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Edward O'Callaghan856e4ff2009-08-22 01:06:46 +00004474
4475 if (!Args.hasArg(options::OPT_nostdlib) &&
4476 !Args.hasArg(options::OPT_nodefaultlibs)) {
4477 // FIXME: For some reason GCC passes -lgcc before adding
4478 // the default system libraries. Just mimic this for now.
4479 CmdArgs.push_back("-lgcc");
4480
4481 if (Args.hasArg(options::OPT_pthread))
4482 CmdArgs.push_back("-pthread");
4483 if (!Args.hasArg(options::OPT_shared))
4484 CmdArgs.push_back("-lc");
4485 CmdArgs.push_back("-lgcc");
4486 }
4487
4488 if (!Args.hasArg(options::OPT_nostdlib) &&
4489 !Args.hasArg(options::OPT_nostartfiles)) {
4490 if (!Args.hasArg(options::OPT_shared))
Chris Lattner3e2ee142010-07-07 16:01:42 +00004491 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00004492 getToolChain().GetFilePath("crtend.o")));
Edward O'Callaghan856e4ff2009-08-22 01:06:46 +00004493 }
4494
Bill Wendling08760582011-06-27 19:15:03 +00004495 addProfileRT(getToolChain(), Args, CmdArgs, getToolChain().getTriple());
Nick Lewycky82fe5f42011-05-24 21:54:59 +00004496
Edward O'Callaghan856e4ff2009-08-22 01:06:46 +00004497 const char *Exec =
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00004498 Args.MakeArgString(getToolChain().GetProgramPath("ld"));
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00004499 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Edward O'Callaghan856e4ff2009-08-22 01:06:46 +00004500}
4501
Daniel Dunbar10de9e62009-06-29 20:52:51 +00004502void openbsd::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00004503 const InputInfo &Output,
Daniel Dunbar10de9e62009-06-29 20:52:51 +00004504 const InputInfoList &Inputs,
4505 const ArgList &Args,
Mike Stump11289f42009-09-09 15:08:12 +00004506 const char *LinkingOutput) const {
Daniel Dunbar10de9e62009-06-29 20:52:51 +00004507 ArgStringList CmdArgs;
4508
4509 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
4510 options::OPT_Xassembler);
4511
4512 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00004513 CmdArgs.push_back(Output.getFilename());
Daniel Dunbar10de9e62009-06-29 20:52:51 +00004514
4515 for (InputInfoList::const_iterator
4516 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
4517 const InputInfo &II = *it;
Daniel Dunbarb440f562010-08-02 02:38:21 +00004518 CmdArgs.push_back(II.getFilename());
Daniel Dunbar10de9e62009-06-29 20:52:51 +00004519 }
4520
4521 const char *Exec =
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00004522 Args.MakeArgString(getToolChain().GetProgramPath("as"));
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00004523 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00004524}
4525
4526void openbsd::Link::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00004527 const InputInfo &Output,
Daniel Dunbar10de9e62009-06-29 20:52:51 +00004528 const InputInfoList &Inputs,
4529 const ArgList &Args,
4530 const char *LinkingOutput) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00004531 const Driver &D = getToolChain().getDriver();
Daniel Dunbar10de9e62009-06-29 20:52:51 +00004532 ArgStringList CmdArgs;
4533
Daniel Dunbara8888ac2009-08-03 01:28:59 +00004534 if ((!Args.hasArg(options::OPT_nostdlib)) &&
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004535 (!Args.hasArg(options::OPT_shared))) {
Daniel Dunbara8888ac2009-08-03 01:28:59 +00004536 CmdArgs.push_back("-e");
4537 CmdArgs.push_back("__start");
4538 }
4539
Daniel Dunbar10de9e62009-06-29 20:52:51 +00004540 if (Args.hasArg(options::OPT_static)) {
4541 CmdArgs.push_back("-Bstatic");
4542 } else {
Rafael Espindola7ba97af2010-11-11 02:17:51 +00004543 if (Args.hasArg(options::OPT_rdynamic))
4544 CmdArgs.push_back("-export-dynamic");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00004545 CmdArgs.push_back("--eh-frame-hdr");
Daniel Dunbara8888ac2009-08-03 01:28:59 +00004546 CmdArgs.push_back("-Bdynamic");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00004547 if (Args.hasArg(options::OPT_shared)) {
Daniel Dunbara8888ac2009-08-03 01:28:59 +00004548 CmdArgs.push_back("-shared");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00004549 } else {
4550 CmdArgs.push_back("-dynamic-linker");
4551 CmdArgs.push_back("/usr/libexec/ld.so");
4552 }
4553 }
4554
Daniel Dunbarb440f562010-08-02 02:38:21 +00004555 if (Output.isFilename()) {
Daniel Dunbar10de9e62009-06-29 20:52:51 +00004556 CmdArgs.push_back("-o");
4557 CmdArgs.push_back(Output.getFilename());
4558 } else {
4559 assert(Output.isNothing() && "Invalid output.");
4560 }
4561
4562 if (!Args.hasArg(options::OPT_nostdlib) &&
4563 !Args.hasArg(options::OPT_nostartfiles)) {
4564 if (!Args.hasArg(options::OPT_shared)) {
Eli Friedman3715d1f2011-12-15 02:15:56 +00004565 if (Args.hasArg(options::OPT_pg))
4566 CmdArgs.push_back(Args.MakeArgString(
4567 getToolChain().GetFilePath("gcrt0.o")));
4568 else
4569 CmdArgs.push_back(Args.MakeArgString(
4570 getToolChain().GetFilePath("crt0.o")));
Chris Lattner3e2ee142010-07-07 16:01:42 +00004571 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00004572 getToolChain().GetFilePath("crtbegin.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00004573 } else {
Chris Lattner3e2ee142010-07-07 16:01:42 +00004574 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00004575 getToolChain().GetFilePath("crtbeginS.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00004576 }
4577 }
4578
Edward O'Callaghan5c521462009-10-28 15:13:08 +00004579 std::string Triple = getToolChain().getTripleString();
4580 if (Triple.substr(0, 6) == "x86_64")
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004581 Triple.replace(0, 6, "amd64");
Daniel Dunbarb0b18612009-10-29 02:24:37 +00004582 CmdArgs.push_back(Args.MakeArgString("-L/usr/lib/gcc-lib/" + Triple +
Daniel Dunbarea3813f2010-08-01 23:13:54 +00004583 "/4.2.1"));
Daniel Dunbara8888ac2009-08-03 01:28:59 +00004584
Daniel Dunbar10de9e62009-06-29 20:52:51 +00004585 Args.AddAllArgs(CmdArgs, options::OPT_L);
4586 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
4587 Args.AddAllArgs(CmdArgs, options::OPT_e);
4588
Daniel Dunbar54423b22010-09-17 00:24:54 +00004589 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Daniel Dunbar10de9e62009-06-29 20:52:51 +00004590
4591 if (!Args.hasArg(options::OPT_nostdlib) &&
4592 !Args.hasArg(options::OPT_nodefaultlibs)) {
Daniel Dunbarea3813f2010-08-01 23:13:54 +00004593 if (D.CCCIsCXX) {
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00004594 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Eli Friedman3715d1f2011-12-15 02:15:56 +00004595 if (Args.hasArg(options::OPT_pg))
4596 CmdArgs.push_back("-lm_p");
4597 else
4598 CmdArgs.push_back("-lm");
Daniel Dunbarea3813f2010-08-01 23:13:54 +00004599 }
4600
Daniel Dunbara8888ac2009-08-03 01:28:59 +00004601 // FIXME: For some reason GCC passes -lgcc before adding
4602 // the default system libraries. Just mimic this for now.
4603 CmdArgs.push_back("-lgcc");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00004604
Eric Christopher17674ec2012-09-13 06:32:34 +00004605 if (Args.hasArg(options::OPT_pthread)) {
4606 if (!Args.hasArg(options::OPT_shared) &&
4607 Args.hasArg(options::OPT_pg))
4608 CmdArgs.push_back("-lpthread_p");
4609 else
4610 CmdArgs.push_back("-lpthread");
4611 }
4612
Chandler Carruth45661652011-12-17 22:32:42 +00004613 if (!Args.hasArg(options::OPT_shared)) {
Eric Christopher17674ec2012-09-13 06:32:34 +00004614 if (Args.hasArg(options::OPT_pg))
Eli Friedman3715d1f2011-12-15 02:15:56 +00004615 CmdArgs.push_back("-lc_p");
4616 else
4617 CmdArgs.push_back("-lc");
Chandler Carruth45661652011-12-17 22:32:42 +00004618 }
Eric Christopher17674ec2012-09-13 06:32:34 +00004619
Daniel Dunbara8888ac2009-08-03 01:28:59 +00004620 CmdArgs.push_back("-lgcc");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00004621 }
4622
4623 if (!Args.hasArg(options::OPT_nostdlib) &&
4624 !Args.hasArg(options::OPT_nostartfiles)) {
4625 if (!Args.hasArg(options::OPT_shared))
Chris Lattner3e2ee142010-07-07 16:01:42 +00004626 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00004627 getToolChain().GetFilePath("crtend.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00004628 else
Chris Lattner3e2ee142010-07-07 16:01:42 +00004629 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00004630 getToolChain().GetFilePath("crtendS.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00004631 }
4632
4633 const char *Exec =
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00004634 Args.MakeArgString(getToolChain().GetProgramPath("ld"));
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00004635 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00004636}
Ed Schoutene33194b2009-04-02 19:13:12 +00004637
Eli Friedman9fa28852012-08-08 23:57:20 +00004638void bitrig::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
4639 const InputInfo &Output,
4640 const InputInfoList &Inputs,
4641 const ArgList &Args,
4642 const char *LinkingOutput) const {
4643 ArgStringList CmdArgs;
4644
4645 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
4646 options::OPT_Xassembler);
4647
4648 CmdArgs.push_back("-o");
4649 CmdArgs.push_back(Output.getFilename());
4650
4651 for (InputInfoList::const_iterator
4652 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
4653 const InputInfo &II = *it;
4654 CmdArgs.push_back(II.getFilename());
4655 }
4656
4657 const char *Exec =
4658 Args.MakeArgString(getToolChain().GetProgramPath("as"));
4659 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
4660}
4661
4662void bitrig::Link::ConstructJob(Compilation &C, const JobAction &JA,
4663 const InputInfo &Output,
4664 const InputInfoList &Inputs,
4665 const ArgList &Args,
4666 const char *LinkingOutput) const {
4667 const Driver &D = getToolChain().getDriver();
4668 ArgStringList CmdArgs;
4669
4670 if ((!Args.hasArg(options::OPT_nostdlib)) &&
4671 (!Args.hasArg(options::OPT_shared))) {
4672 CmdArgs.push_back("-e");
4673 CmdArgs.push_back("__start");
4674 }
4675
4676 if (Args.hasArg(options::OPT_static)) {
4677 CmdArgs.push_back("-Bstatic");
4678 } else {
4679 if (Args.hasArg(options::OPT_rdynamic))
4680 CmdArgs.push_back("-export-dynamic");
4681 CmdArgs.push_back("--eh-frame-hdr");
4682 CmdArgs.push_back("-Bdynamic");
4683 if (Args.hasArg(options::OPT_shared)) {
4684 CmdArgs.push_back("-shared");
4685 } else {
4686 CmdArgs.push_back("-dynamic-linker");
4687 CmdArgs.push_back("/usr/libexec/ld.so");
4688 }
4689 }
4690
4691 if (Output.isFilename()) {
4692 CmdArgs.push_back("-o");
4693 CmdArgs.push_back(Output.getFilename());
4694 } else {
4695 assert(Output.isNothing() && "Invalid output.");
4696 }
4697
4698 if (!Args.hasArg(options::OPT_nostdlib) &&
4699 !Args.hasArg(options::OPT_nostartfiles)) {
4700 if (!Args.hasArg(options::OPT_shared)) {
4701 if (Args.hasArg(options::OPT_pg))
4702 CmdArgs.push_back(Args.MakeArgString(
4703 getToolChain().GetFilePath("gcrt0.o")));
4704 else
4705 CmdArgs.push_back(Args.MakeArgString(
4706 getToolChain().GetFilePath("crt0.o")));
4707 CmdArgs.push_back(Args.MakeArgString(
4708 getToolChain().GetFilePath("crtbegin.o")));
4709 } else {
4710 CmdArgs.push_back(Args.MakeArgString(
4711 getToolChain().GetFilePath("crtbeginS.o")));
4712 }
4713 }
4714
4715 Args.AddAllArgs(CmdArgs, options::OPT_L);
4716 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
4717 Args.AddAllArgs(CmdArgs, options::OPT_e);
4718
4719 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
4720
4721 if (!Args.hasArg(options::OPT_nostdlib) &&
4722 !Args.hasArg(options::OPT_nodefaultlibs)) {
4723 if (D.CCCIsCXX) {
4724 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
4725 if (Args.hasArg(options::OPT_pg))
4726 CmdArgs.push_back("-lm_p");
4727 else
4728 CmdArgs.push_back("-lm");
4729 }
4730
Rafael Espindola1ad26f02012-10-23 17:07:31 +00004731 if (Args.hasArg(options::OPT_pthread)) {
4732 if (!Args.hasArg(options::OPT_shared) &&
4733 Args.hasArg(options::OPT_pg))
4734 CmdArgs.push_back("-lpthread_p");
4735 else
4736 CmdArgs.push_back("-lpthread");
4737 }
4738
Eli Friedman9fa28852012-08-08 23:57:20 +00004739 if (!Args.hasArg(options::OPT_shared)) {
4740 if (Args.hasArg(options::OPT_pg))
4741 CmdArgs.push_back("-lc_p");
4742 else
4743 CmdArgs.push_back("-lc");
4744 }
4745
4746 std::string myarch = "-lclang_rt.";
4747 const llvm::Triple &T = getToolChain().getTriple();
4748 llvm::Triple::ArchType Arch = T.getArch();
4749 switch (Arch) {
4750 case llvm::Triple::arm:
4751 myarch += ("arm");
4752 break;
4753 case llvm::Triple::x86:
4754 myarch += ("i386");
4755 break;
4756 case llvm::Triple::x86_64:
4757 myarch += ("amd64");
4758 break;
4759 default:
4760 assert(0 && "Unsupported architecture");
4761 }
4762 CmdArgs.push_back(Args.MakeArgString(myarch));
4763 }
4764
4765 if (!Args.hasArg(options::OPT_nostdlib) &&
4766 !Args.hasArg(options::OPT_nostartfiles)) {
4767 if (!Args.hasArg(options::OPT_shared))
4768 CmdArgs.push_back(Args.MakeArgString(
4769 getToolChain().GetFilePath("crtend.o")));
4770 else
4771 CmdArgs.push_back(Args.MakeArgString(
4772 getToolChain().GetFilePath("crtendS.o")));
4773 }
Eli Friedman5bb2ba02012-08-09 22:42:04 +00004774
4775 const char *Exec =
4776 Args.MakeArgString(getToolChain().GetProgramPath("ld"));
4777 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Eli Friedman9fa28852012-08-08 23:57:20 +00004778}
4779
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00004780void freebsd::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00004781 const InputInfo &Output,
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004782 const InputInfoList &Inputs,
4783 const ArgList &Args,
Mike Stump11289f42009-09-09 15:08:12 +00004784 const char *LinkingOutput) const {
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00004785 ArgStringList CmdArgs;
4786
Daniel Dunbard854c8d2009-04-01 19:36:32 +00004787 // When building 32-bit code on FreeBSD/amd64, we have to explicitly
4788 // instruct as in the base system to assemble 32-bit code.
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00004789 if (getToolChain().getArch() == llvm::Triple::x86)
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00004790 CmdArgs.push_back("--32");
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00004791 else if (getToolChain().getArch() == llvm::Triple::ppc)
Roman Divacky00859c22011-06-04 07:37:31 +00004792 CmdArgs.push_back("-a32");
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00004793 else if (getToolChain().getArch() == llvm::Triple::mips ||
4794 getToolChain().getArch() == llvm::Triple::mipsel ||
4795 getToolChain().getArch() == llvm::Triple::mips64 ||
4796 getToolChain().getArch() == llvm::Triple::mips64el) {
4797 StringRef CPUName;
4798 StringRef ABIName;
4799 getMipsCPUAndABI(Args, getToolChain(), CPUName, ABIName);
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00004800
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00004801 CmdArgs.push_back("-march");
4802 CmdArgs.push_back(CPUName.data());
4803
4804 // Convert ABI name to the GNU tools acceptable variant.
4805 if (ABIName == "o32")
4806 ABIName = "32";
4807 else if (ABIName == "n64")
4808 ABIName = "64";
4809
4810 CmdArgs.push_back("-mabi");
4811 CmdArgs.push_back(ABIName.data());
4812
4813 if (getToolChain().getArch() == llvm::Triple::mips ||
4814 getToolChain().getArch() == llvm::Triple::mips64)
4815 CmdArgs.push_back("-EB");
4816 else
4817 CmdArgs.push_back("-EL");
4818
4819 Arg *LastPICArg = Args.getLastArg(options::OPT_fPIC, options::OPT_fno_PIC,
4820 options::OPT_fpic, options::OPT_fno_pic,
4821 options::OPT_fPIE, options::OPT_fno_PIE,
4822 options::OPT_fpie, options::OPT_fno_pie);
4823 if (LastPICArg &&
4824 (LastPICArg->getOption().matches(options::OPT_fPIC) ||
4825 LastPICArg->getOption().matches(options::OPT_fpic) ||
4826 LastPICArg->getOption().matches(options::OPT_fPIE) ||
4827 LastPICArg->getOption().matches(options::OPT_fpie))) {
4828 CmdArgs.push_back("-KPIC");
4829 }
4830 }
Eric Christopher0b26a612010-03-02 02:41:08 +00004831
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00004832 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
4833 options::OPT_Xassembler);
4834
4835 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00004836 CmdArgs.push_back(Output.getFilename());
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00004837
4838 for (InputInfoList::const_iterator
4839 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
4840 const InputInfo &II = *it;
Daniel Dunbarb440f562010-08-02 02:38:21 +00004841 CmdArgs.push_back(II.getFilename());
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00004842 }
4843
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004844 const char *Exec =
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00004845 Args.MakeArgString(getToolChain().GetProgramPath("as"));
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00004846 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00004847}
Daniel Dunbard854c8d2009-04-01 19:36:32 +00004848
4849void freebsd::Link::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00004850 const InputInfo &Output,
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004851 const InputInfoList &Inputs,
4852 const ArgList &Args,
Daniel Dunbare3e263f2009-05-02 20:14:53 +00004853 const char *LinkingOutput) const {
Roman Divackyafe2f232012-08-28 15:09:03 +00004854 const toolchains::FreeBSD& ToolChain =
4855 static_cast<const toolchains::FreeBSD&>(getToolChain());
4856 const Driver &D = ToolChain.getDriver();
Daniel Dunbard854c8d2009-04-01 19:36:32 +00004857 ArgStringList CmdArgs;
David Chisnall5f99f482012-07-29 15:24:44 +00004858
4859 // Silence warning for "clang -g foo.o -o foo"
4860 Args.ClaimAllArgs(options::OPT_g_Group);
4861 // and "clang -emit-llvm foo.o -o foo"
4862 Args.ClaimAllArgs(options::OPT_emit_llvm);
4863 // and for "clang -w foo.o -o foo". Other warning options are already
4864 // handled somewhere else.
4865 Args.ClaimAllArgs(options::OPT_w);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00004866
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00004867 if (!D.SysRoot.empty())
4868 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
4869
Roman Divackyafe2f232012-08-28 15:09:03 +00004870 if (Args.hasArg(options::OPT_pie))
4871 CmdArgs.push_back("-pie");
4872
Daniel Dunbard854c8d2009-04-01 19:36:32 +00004873 if (Args.hasArg(options::OPT_static)) {
4874 CmdArgs.push_back("-Bstatic");
4875 } else {
Rafael Espindola7ba97af2010-11-11 02:17:51 +00004876 if (Args.hasArg(options::OPT_rdynamic))
4877 CmdArgs.push_back("-export-dynamic");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00004878 CmdArgs.push_back("--eh-frame-hdr");
4879 if (Args.hasArg(options::OPT_shared)) {
4880 CmdArgs.push_back("-Bshareable");
4881 } else {
4882 CmdArgs.push_back("-dynamic-linker");
4883 CmdArgs.push_back("/libexec/ld-elf.so.1");
4884 }
Roman Divackyafe2f232012-08-28 15:09:03 +00004885 if (ToolChain.getTriple().getOSMajorVersion() >= 9) {
4886 llvm::Triple::ArchType Arch = ToolChain.getArch();
David Chisnall5f99f482012-07-29 15:24:44 +00004887 if (Arch == llvm::Triple::arm || Arch == llvm::Triple::sparc ||
4888 Arch == llvm::Triple::x86 || Arch == llvm::Triple::x86_64) {
4889 CmdArgs.push_back("--hash-style=both");
4890 }
4891 }
4892 CmdArgs.push_back("--enable-new-dtags");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00004893 }
4894
4895 // When building 32-bit code on FreeBSD/amd64, we have to explicitly
4896 // instruct ld in the base system to link 32-bit code.
Rafael Espindola35ca7d92012-10-07 04:44:33 +00004897 if (ToolChain.getArch() == llvm::Triple::x86) {
Daniel Dunbard854c8d2009-04-01 19:36:32 +00004898 CmdArgs.push_back("-m");
4899 CmdArgs.push_back("elf_i386_fbsd");
4900 }
4901
Rafael Espindola35ca7d92012-10-07 04:44:33 +00004902 if (ToolChain.getArch() == llvm::Triple::ppc) {
Roman Divacky5e300b82011-06-04 07:40:24 +00004903 CmdArgs.push_back("-m");
Roman Divackyd150ad32011-11-21 16:50:32 +00004904 CmdArgs.push_back("elf32ppc_fbsd");
Roman Divacky5e300b82011-06-04 07:40:24 +00004905 }
4906
Daniel Dunbarb440f562010-08-02 02:38:21 +00004907 if (Output.isFilename()) {
Daniel Dunbard854c8d2009-04-01 19:36:32 +00004908 CmdArgs.push_back("-o");
4909 CmdArgs.push_back(Output.getFilename());
4910 } else {
4911 assert(Output.isNothing() && "Invalid output.");
4912 }
4913
4914 if (!Args.hasArg(options::OPT_nostdlib) &&
4915 !Args.hasArg(options::OPT_nostartfiles)) {
Roman Divackyafe2f232012-08-28 15:09:03 +00004916 const char *crt1 = NULL;
Daniel Dunbard854c8d2009-04-01 19:36:32 +00004917 if (!Args.hasArg(options::OPT_shared)) {
Roman Divacky66f22762011-02-10 16:59:40 +00004918 if (Args.hasArg(options::OPT_pg))
Roman Divackyafe2f232012-08-28 15:09:03 +00004919 crt1 = "gcrt1.o";
4920 else if (Args.hasArg(options::OPT_pie))
4921 crt1 = "Scrt1.o";
4922 else
4923 crt1 = "crt1.o";
Daniel Dunbard854c8d2009-04-01 19:36:32 +00004924 }
Roman Divackyafe2f232012-08-28 15:09:03 +00004925 if (crt1)
4926 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crt1)));
4927
4928 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
4929
4930 const char *crtbegin = NULL;
4931 if (Args.hasArg(options::OPT_static))
4932 crtbegin = "crtbeginT.o";
4933 else if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_pie))
4934 crtbegin = "crtbeginS.o";
4935 else
4936 crtbegin = "crtbegin.o";
4937
4938 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtbegin)));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00004939 }
4940
4941 Args.AddAllArgs(CmdArgs, options::OPT_L);
Roman Divackyafe2f232012-08-28 15:09:03 +00004942 const ToolChain::path_list Paths = ToolChain.getFilePaths();
Roman Divackyee8188a2011-03-01 17:53:14 +00004943 for (ToolChain::path_list::const_iterator i = Paths.begin(), e = Paths.end();
4944 i != e; ++i)
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004945 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + *i));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00004946 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
4947 Args.AddAllArgs(CmdArgs, options::OPT_e);
David Chisnall589a4942010-08-15 22:58:12 +00004948 Args.AddAllArgs(CmdArgs, options::OPT_s);
4949 Args.AddAllArgs(CmdArgs, options::OPT_t);
4950 Args.AddAllArgs(CmdArgs, options::OPT_Z_Flag);
4951 Args.AddAllArgs(CmdArgs, options::OPT_r);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00004952
Roman Divackyafe2f232012-08-28 15:09:03 +00004953 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00004954
4955 if (!Args.hasArg(options::OPT_nostdlib) &&
4956 !Args.hasArg(options::OPT_nodefaultlibs)) {
Daniel Dunbar4b8ef282010-02-17 08:07:51 +00004957 if (D.CCCIsCXX) {
Roman Divackyafe2f232012-08-28 15:09:03 +00004958 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
Roman Divacky66f22762011-02-10 16:59:40 +00004959 if (Args.hasArg(options::OPT_pg))
4960 CmdArgs.push_back("-lm_p");
4961 else
4962 CmdArgs.push_back("-lm");
Daniel Dunbar4b8ef282010-02-17 08:07:51 +00004963 }
Daniel Dunbard854c8d2009-04-01 19:36:32 +00004964 // FIXME: For some reason GCC passes -lgcc and -lgcc_s before adding
4965 // the default system libraries. Just mimic this for now.
Roman Divacky66f22762011-02-10 16:59:40 +00004966 if (Args.hasArg(options::OPT_pg))
4967 CmdArgs.push_back("-lgcc_p");
4968 else
4969 CmdArgs.push_back("-lgcc");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00004970 if (Args.hasArg(options::OPT_static)) {
4971 CmdArgs.push_back("-lgcc_eh");
Roman Divacky66f22762011-02-10 16:59:40 +00004972 } else if (Args.hasArg(options::OPT_pg)) {
4973 CmdArgs.push_back("-lgcc_eh_p");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00004974 } else {
4975 CmdArgs.push_back("--as-needed");
4976 CmdArgs.push_back("-lgcc_s");
4977 CmdArgs.push_back("--no-as-needed");
4978 }
4979
Matt Beaumont-Gay1fe49152011-02-10 20:35:01 +00004980 if (Args.hasArg(options::OPT_pthread)) {
Roman Divacky66f22762011-02-10 16:59:40 +00004981 if (Args.hasArg(options::OPT_pg))
4982 CmdArgs.push_back("-lpthread_p");
4983 else
4984 CmdArgs.push_back("-lpthread");
Matt Beaumont-Gay1fe49152011-02-10 20:35:01 +00004985 }
Daniel Dunbard854c8d2009-04-01 19:36:32 +00004986
Roman Divacky66f22762011-02-10 16:59:40 +00004987 if (Args.hasArg(options::OPT_pg)) {
4988 if (Args.hasArg(options::OPT_shared))
4989 CmdArgs.push_back("-lc");
4990 else
4991 CmdArgs.push_back("-lc_p");
4992 CmdArgs.push_back("-lgcc_p");
4993 } else {
4994 CmdArgs.push_back("-lc");
4995 CmdArgs.push_back("-lgcc");
4996 }
4997
Daniel Dunbard854c8d2009-04-01 19:36:32 +00004998 if (Args.hasArg(options::OPT_static)) {
4999 CmdArgs.push_back("-lgcc_eh");
Roman Divacky66f22762011-02-10 16:59:40 +00005000 } else if (Args.hasArg(options::OPT_pg)) {
5001 CmdArgs.push_back("-lgcc_eh_p");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00005002 } else {
5003 CmdArgs.push_back("--as-needed");
5004 CmdArgs.push_back("-lgcc_s");
5005 CmdArgs.push_back("--no-as-needed");
5006 }
5007 }
5008
5009 if (!Args.hasArg(options::OPT_nostdlib) &&
5010 !Args.hasArg(options::OPT_nostartfiles)) {
Roman Divackya3c50242012-09-07 13:36:21 +00005011 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_pie))
Roman Divackyafe2f232012-08-28 15:09:03 +00005012 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtendS.o")));
Roman Divackya3c50242012-09-07 13:36:21 +00005013 else
5014 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtend.o")));
Roman Divackyafe2f232012-08-28 15:09:03 +00005015 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00005016 }
5017
Roman Divackyafe2f232012-08-28 15:09:03 +00005018 addProfileRT(ToolChain, Args, CmdArgs, ToolChain.getTriple());
Nick Lewycky82fe5f42011-05-24 21:54:59 +00005019
Daniel Dunbard067f7f2009-04-08 23:54:23 +00005020 const char *Exec =
Roman Divackyafe2f232012-08-28 15:09:03 +00005021 Args.MakeArgString(ToolChain.GetProgramPath("ld"));
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00005022 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00005023}
Daniel Dunbarcc912342009-05-02 18:28:39 +00005024
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00005025void netbsd::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
5026 const InputInfo &Output,
5027 const InputInfoList &Inputs,
5028 const ArgList &Args,
5029 const char *LinkingOutput) const {
5030 ArgStringList CmdArgs;
5031
5032 // When building 32-bit code on NetBSD/amd64, we have to explicitly
5033 // instruct as in the base system to assemble 32-bit code.
Joerg Sonnenbergerd64c60e2012-01-26 22:27:52 +00005034 if (getToolChain().getArch() == llvm::Triple::x86)
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00005035 CmdArgs.push_back("--32");
5036
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00005037 // Set byte order explicitly
Rafael Espindola35ca7d92012-10-07 04:44:33 +00005038 if (getToolChain().getArch() == llvm::Triple::mips)
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00005039 CmdArgs.push_back("-EB");
Rafael Espindola35ca7d92012-10-07 04:44:33 +00005040 else if (getToolChain().getArch() == llvm::Triple::mipsel)
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00005041 CmdArgs.push_back("-EL");
5042
5043 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
5044 options::OPT_Xassembler);
5045
5046 CmdArgs.push_back("-o");
5047 CmdArgs.push_back(Output.getFilename());
5048
5049 for (InputInfoList::const_iterator
5050 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
5051 const InputInfo &II = *it;
5052 CmdArgs.push_back(II.getFilename());
5053 }
5054
David Chisnallddbd68f2011-09-27 22:03:18 +00005055 const char *Exec = Args.MakeArgString((getToolChain().GetProgramPath("as")));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00005056 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
5057}
5058
5059void netbsd::Link::ConstructJob(Compilation &C, const JobAction &JA,
5060 const InputInfo &Output,
5061 const InputInfoList &Inputs,
5062 const ArgList &Args,
5063 const char *LinkingOutput) const {
5064 const Driver &D = getToolChain().getDriver();
5065 ArgStringList CmdArgs;
5066
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00005067 if (!D.SysRoot.empty())
5068 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
5069
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00005070 if (Args.hasArg(options::OPT_static)) {
5071 CmdArgs.push_back("-Bstatic");
5072 } else {
5073 if (Args.hasArg(options::OPT_rdynamic))
5074 CmdArgs.push_back("-export-dynamic");
5075 CmdArgs.push_back("--eh-frame-hdr");
5076 if (Args.hasArg(options::OPT_shared)) {
5077 CmdArgs.push_back("-Bshareable");
5078 } else {
5079 CmdArgs.push_back("-dynamic-linker");
5080 CmdArgs.push_back("/libexec/ld.elf_so");
5081 }
5082 }
5083
5084 // When building 32-bit code on NetBSD/amd64, we have to explicitly
5085 // instruct ld in the base system to link 32-bit code.
Joerg Sonnenbergerd64c60e2012-01-26 22:27:52 +00005086 if (getToolChain().getArch() == llvm::Triple::x86) {
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00005087 CmdArgs.push_back("-m");
5088 CmdArgs.push_back("elf_i386");
5089 }
5090
5091 if (Output.isFilename()) {
5092 CmdArgs.push_back("-o");
5093 CmdArgs.push_back(Output.getFilename());
5094 } else {
5095 assert(Output.isNothing() && "Invalid output.");
5096 }
5097
5098 if (!Args.hasArg(options::OPT_nostdlib) &&
5099 !Args.hasArg(options::OPT_nostartfiles)) {
5100 if (!Args.hasArg(options::OPT_shared)) {
5101 CmdArgs.push_back(Args.MakeArgString(
5102 getToolChain().GetFilePath("crt0.o")));
5103 CmdArgs.push_back(Args.MakeArgString(
5104 getToolChain().GetFilePath("crti.o")));
5105 CmdArgs.push_back(Args.MakeArgString(
5106 getToolChain().GetFilePath("crtbegin.o")));
5107 } else {
5108 CmdArgs.push_back(Args.MakeArgString(
5109 getToolChain().GetFilePath("crti.o")));
5110 CmdArgs.push_back(Args.MakeArgString(
5111 getToolChain().GetFilePath("crtbeginS.o")));
5112 }
5113 }
5114
5115 Args.AddAllArgs(CmdArgs, options::OPT_L);
5116 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
5117 Args.AddAllArgs(CmdArgs, options::OPT_e);
5118 Args.AddAllArgs(CmdArgs, options::OPT_s);
5119 Args.AddAllArgs(CmdArgs, options::OPT_t);
5120 Args.AddAllArgs(CmdArgs, options::OPT_Z_Flag);
5121 Args.AddAllArgs(CmdArgs, options::OPT_r);
5122
5123 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
5124
5125 if (!Args.hasArg(options::OPT_nostdlib) &&
5126 !Args.hasArg(options::OPT_nodefaultlibs)) {
5127 if (D.CCCIsCXX) {
5128 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
5129 CmdArgs.push_back("-lm");
5130 }
5131 // FIXME: For some reason GCC passes -lgcc and -lgcc_s before adding
5132 // the default system libraries. Just mimic this for now.
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00005133 if (Args.hasArg(options::OPT_static)) {
5134 CmdArgs.push_back("-lgcc_eh");
5135 } else {
5136 CmdArgs.push_back("--as-needed");
5137 CmdArgs.push_back("-lgcc_s");
5138 CmdArgs.push_back("--no-as-needed");
5139 }
Joerg Sonnenberger87717772011-06-07 23:39:17 +00005140 CmdArgs.push_back("-lgcc");
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00005141
5142 if (Args.hasArg(options::OPT_pthread))
5143 CmdArgs.push_back("-lpthread");
5144 CmdArgs.push_back("-lc");
5145
5146 CmdArgs.push_back("-lgcc");
5147 if (Args.hasArg(options::OPT_static)) {
5148 CmdArgs.push_back("-lgcc_eh");
5149 } else {
5150 CmdArgs.push_back("--as-needed");
5151 CmdArgs.push_back("-lgcc_s");
5152 CmdArgs.push_back("--no-as-needed");
5153 }
5154 }
5155
5156 if (!Args.hasArg(options::OPT_nostdlib) &&
5157 !Args.hasArg(options::OPT_nostartfiles)) {
5158 if (!Args.hasArg(options::OPT_shared))
5159 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath(
5160 "crtend.o")));
5161 else
5162 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath(
5163 "crtendS.o")));
5164 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath(
5165 "crtn.o")));
5166 }
5167
Bill Wendling08760582011-06-27 19:15:03 +00005168 addProfileRT(getToolChain(), Args, CmdArgs, getToolChain().getTriple());
Nick Lewycky82fe5f42011-05-24 21:54:59 +00005169
David Chisnallddbd68f2011-09-27 22:03:18 +00005170 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("ld"));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00005171 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
5172}
5173
Rafael Espindola92b00932010-08-10 00:25:48 +00005174void linuxtools::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
5175 const InputInfo &Output,
5176 const InputInfoList &Inputs,
5177 const ArgList &Args,
5178 const char *LinkingOutput) const {
5179 ArgStringList CmdArgs;
5180
5181 // Add --32/--64 to make sure we get the format we want.
5182 // This is incomplete
5183 if (getToolChain().getArch() == llvm::Triple::x86) {
5184 CmdArgs.push_back("--32");
5185 } else if (getToolChain().getArch() == llvm::Triple::x86_64) {
5186 CmdArgs.push_back("--64");
Eli Friedman4a4932c2011-11-28 23:46:52 +00005187 } else if (getToolChain().getArch() == llvm::Triple::ppc) {
5188 CmdArgs.push_back("-a32");
5189 CmdArgs.push_back("-mppc");
5190 CmdArgs.push_back("-many");
5191 } else if (getToolChain().getArch() == llvm::Triple::ppc64) {
5192 CmdArgs.push_back("-a64");
5193 CmdArgs.push_back("-mppc64");
5194 CmdArgs.push_back("-many");
Rafael Espindola92b00932010-08-10 00:25:48 +00005195 } else if (getToolChain().getArch() == llvm::Triple::arm) {
Chris Lattner0e62c1c2011-07-23 10:55:15 +00005196 StringRef MArch = getToolChain().getArchName();
Rafael Espindola92b00932010-08-10 00:25:48 +00005197 if (MArch == "armv7" || MArch == "armv7a" || MArch == "armv7-a")
5198 CmdArgs.push_back("-mfpu=neon");
Evgeniy Stepanoved943f62012-04-20 09:03:40 +00005199
5200 StringRef ARMFloatABI = getARMFloatABI(getToolChain().getDriver(), Args,
5201 getToolChain().getTriple());
5202 CmdArgs.push_back(Args.MakeArgString("-mfloat-abi=" + ARMFloatABI));
Evgeniy Stepanov582911a2012-04-24 09:05:31 +00005203
5204 Args.AddLastArg(CmdArgs, options::OPT_march_EQ);
5205 Args.AddLastArg(CmdArgs, options::OPT_mcpu_EQ);
5206 Args.AddLastArg(CmdArgs, options::OPT_mfpu_EQ);
Akira Hatanaka5e9dde32011-11-30 19:31:38 +00005207 } else if (getToolChain().getArch() == llvm::Triple::mips ||
5208 getToolChain().getArch() == llvm::Triple::mipsel ||
5209 getToolChain().getArch() == llvm::Triple::mips64 ||
5210 getToolChain().getArch() == llvm::Triple::mips64el) {
Simon Atanasyan571d7bd2012-04-07 22:31:29 +00005211 StringRef CPUName;
5212 StringRef ABIName;
5213 getMipsCPUAndABI(Args, getToolChain(), CPUName, ABIName);
Akira Hatanaka5e9dde32011-11-30 19:31:38 +00005214
Simon Atanasyan571d7bd2012-04-07 22:31:29 +00005215 CmdArgs.push_back("-march");
5216 CmdArgs.push_back(CPUName.data());
5217
5218 // Convert ABI name to the GNU tools acceptable variant.
5219 if (ABIName == "o32")
5220 ABIName = "32";
5221 else if (ABIName == "n64")
5222 ABIName = "64";
5223
5224 CmdArgs.push_back("-mabi");
5225 CmdArgs.push_back(ABIName.data());
Simon Atanasyan2390aa12012-04-06 19:15:24 +00005226
5227 if (getToolChain().getArch() == llvm::Triple::mips ||
5228 getToolChain().getArch() == llvm::Triple::mips64)
5229 CmdArgs.push_back("-EB");
5230 else
5231 CmdArgs.push_back("-EL");
Simon Atanasyan217dc2d2012-05-29 19:07:33 +00005232
5233 Arg *LastPICArg = Args.getLastArg(options::OPT_fPIC, options::OPT_fno_PIC,
5234 options::OPT_fpic, options::OPT_fno_pic,
5235 options::OPT_fPIE, options::OPT_fno_PIE,
5236 options::OPT_fpie, options::OPT_fno_pie);
5237 if (LastPICArg &&
5238 (LastPICArg->getOption().matches(options::OPT_fPIC) ||
5239 LastPICArg->getOption().matches(options::OPT_fpic) ||
5240 LastPICArg->getOption().matches(options::OPT_fPIE) ||
5241 LastPICArg->getOption().matches(options::OPT_fpie))) {
5242 CmdArgs.push_back("-KPIC");
5243 }
Rafael Espindola92b00932010-08-10 00:25:48 +00005244 }
5245
5246 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
5247 options::OPT_Xassembler);
5248
5249 CmdArgs.push_back("-o");
5250 CmdArgs.push_back(Output.getFilename());
5251
5252 for (InputInfoList::const_iterator
5253 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
5254 const InputInfo &II = *it;
5255 CmdArgs.push_back(II.getFilename());
5256 }
5257
5258 const char *Exec =
5259 Args.MakeArgString(getToolChain().GetProgramPath("as"));
5260 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
5261}
5262
Evgeniy Stepanov77866712012-04-25 08:59:22 +00005263static void AddLibgcc(llvm::Triple Triple, const Driver &D,
5264 ArgStringList &CmdArgs, const ArgList &Args) {
Logan Chienc6fd8202012-09-02 09:30:11 +00005265 bool isAndroid = Triple.getEnvironment() == llvm::Triple::Android;
Logan Chien3d3373c2012-11-19 12:04:11 +00005266 bool StaticLibgcc = Args.hasArg(options::OPT_static) ||
5267 Args.hasArg(options::OPT_static_libgcc);
Rafael Espindolacc354322011-10-17 21:39:04 +00005268 if (!D.CCCIsCXX)
5269 CmdArgs.push_back("-lgcc");
5270
Logan Chien3d3373c2012-11-19 12:04:11 +00005271 if (StaticLibgcc || isAndroid) {
Rafael Espindolacc354322011-10-17 21:39:04 +00005272 if (D.CCCIsCXX)
5273 CmdArgs.push_back("-lgcc");
5274 } else {
5275 if (!D.CCCIsCXX)
5276 CmdArgs.push_back("--as-needed");
5277 CmdArgs.push_back("-lgcc_s");
5278 if (!D.CCCIsCXX)
5279 CmdArgs.push_back("--no-as-needed");
5280 }
5281
Evgeniy Stepanov77866712012-04-25 08:59:22 +00005282 if (StaticLibgcc && !isAndroid)
Rafael Espindolacc354322011-10-17 21:39:04 +00005283 CmdArgs.push_back("-lgcc_eh");
5284 else if (!Args.hasArg(options::OPT_shared) && D.CCCIsCXX)
5285 CmdArgs.push_back("-lgcc");
Logan Chien3d3373c2012-11-19 12:04:11 +00005286
5287 // According to Android ABI, we have to link with libdl if we are
5288 // linking with non-static libgcc.
5289 //
5290 // NOTE: This fixes a link error on Android MIPS as well. The non-static
5291 // libgcc for MIPS relies on _Unwind_Find_FDE and dl_iterate_phdr from libdl.
5292 if (isAndroid && !StaticLibgcc)
5293 CmdArgs.push_back("-ldl");
Rafael Espindolacc354322011-10-17 21:39:04 +00005294}
5295
Simon Atanasyan2d1b1ad2012-10-21 11:44:57 +00005296static bool hasMipsN32ABIArg(const ArgList &Args) {
5297 Arg *A = Args.getLastArg(options::OPT_mabi_EQ);
Richard Smithbd55daf2012-11-01 04:30:05 +00005298 return A && (A->getValue() == StringRef("n32"));
Simon Atanasyan2d1b1ad2012-10-21 11:44:57 +00005299}
5300
Rafael Espindolac8f008f2010-11-07 20:14:31 +00005301void linuxtools::Link::ConstructJob(Compilation &C, const JobAction &JA,
5302 const InputInfo &Output,
5303 const InputInfoList &Inputs,
5304 const ArgList &Args,
5305 const char *LinkingOutput) const {
5306 const toolchains::Linux& ToolChain =
5307 static_cast<const toolchains::Linux&>(getToolChain());
5308 const Driver &D = ToolChain.getDriver();
Rafael Espindola7df35012012-11-02 20:41:30 +00005309 const bool isAndroid =
5310 ToolChain.getTriple().getEnvironment() == llvm::Triple::Android;
Evgeniy Stepanov77866712012-04-25 08:59:22 +00005311
Rafael Espindolac8f008f2010-11-07 20:14:31 +00005312 ArgStringList CmdArgs;
5313
Rafael Espindolad1002f62010-11-15 18:28:16 +00005314 // Silence warning for "clang -g foo.o -o foo"
5315 Args.ClaimAllArgs(options::OPT_g_Group);
Rafael Espindolad95a8122011-03-01 05:25:27 +00005316 // and "clang -emit-llvm foo.o -o foo"
5317 Args.ClaimAllArgs(options::OPT_emit_llvm);
David Chisnall5f99f482012-07-29 15:24:44 +00005318 // and for "clang -w foo.o -o foo". Other warning options are already
Rafael Espindolaf92614c2010-11-17 20:37:10 +00005319 // handled somewhere else.
5320 Args.ClaimAllArgs(options::OPT_w);
Rafael Espindolad1002f62010-11-15 18:28:16 +00005321
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00005322 if (!D.SysRoot.empty())
5323 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00005324
Rafael Espindolad47ac232010-11-17 22:26:15 +00005325 if (Args.hasArg(options::OPT_pie))
5326 CmdArgs.push_back("-pie");
5327
Rafael Espindola1c76c592010-11-07 22:57:16 +00005328 if (Args.hasArg(options::OPT_rdynamic))
5329 CmdArgs.push_back("-export-dynamic");
5330
Rafael Espindola34d77dc2010-11-11 19:34:42 +00005331 if (Args.hasArg(options::OPT_s))
5332 CmdArgs.push_back("-s");
5333
Rafael Espindolac8f008f2010-11-07 20:14:31 +00005334 for (std::vector<std::string>::const_iterator i = ToolChain.ExtraOpts.begin(),
5335 e = ToolChain.ExtraOpts.end();
5336 i != e; ++i)
5337 CmdArgs.push_back(i->c_str());
5338
5339 if (!Args.hasArg(options::OPT_static)) {
5340 CmdArgs.push_back("--eh-frame-hdr");
5341 }
5342
5343 CmdArgs.push_back("-m");
5344 if (ToolChain.getArch() == llvm::Triple::x86)
5345 CmdArgs.push_back("elf_i386");
Eric Christopher84fbdb42011-08-19 00:30:14 +00005346 else if (ToolChain.getArch() == llvm::Triple::arm
Douglas Gregord9bb1522011-03-06 19:11:49 +00005347 || ToolChain.getArch() == llvm::Triple::thumb)
Rafael Espindolac8f008f2010-11-07 20:14:31 +00005348 CmdArgs.push_back("armelf_linux_eabi");
Ted Kremenek43d47cc2011-04-05 22:04:27 +00005349 else if (ToolChain.getArch() == llvm::Triple::ppc)
5350 CmdArgs.push_back("elf32ppclinux");
5351 else if (ToolChain.getArch() == llvm::Triple::ppc64)
5352 CmdArgs.push_back("elf64ppc");
Eli Friedman27b8c4f2011-11-08 19:43:37 +00005353 else if (ToolChain.getArch() == llvm::Triple::mips)
5354 CmdArgs.push_back("elf32btsmip");
5355 else if (ToolChain.getArch() == llvm::Triple::mipsel)
5356 CmdArgs.push_back("elf32ltsmip");
Simon Atanasyan2d1b1ad2012-10-21 11:44:57 +00005357 else if (ToolChain.getArch() == llvm::Triple::mips64) {
5358 if (hasMipsN32ABIArg(Args))
5359 CmdArgs.push_back("elf32btsmipn32");
5360 else
5361 CmdArgs.push_back("elf64btsmip");
5362 }
5363 else if (ToolChain.getArch() == llvm::Triple::mips64el) {
5364 if (hasMipsN32ABIArg(Args))
5365 CmdArgs.push_back("elf32ltsmipn32");
5366 else
5367 CmdArgs.push_back("elf64ltsmip");
5368 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00005369 else
5370 CmdArgs.push_back("elf_x86_64");
5371
5372 if (Args.hasArg(options::OPT_static)) {
Douglas Gregord9bb1522011-03-06 19:11:49 +00005373 if (ToolChain.getArch() == llvm::Triple::arm
5374 || ToolChain.getArch() == llvm::Triple::thumb)
Rafael Espindolac8f008f2010-11-07 20:14:31 +00005375 CmdArgs.push_back("-Bstatic");
5376 else
5377 CmdArgs.push_back("-static");
5378 } else if (Args.hasArg(options::OPT_shared)) {
5379 CmdArgs.push_back("-shared");
Rafael Espindola7df35012012-11-02 20:41:30 +00005380 if (isAndroid) {
Evgeniy Stepanov77866712012-04-25 08:59:22 +00005381 CmdArgs.push_back("-Bsymbolic");
5382 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00005383 }
5384
5385 if (ToolChain.getArch() == llvm::Triple::arm ||
Douglas Gregord9bb1522011-03-06 19:11:49 +00005386 ToolChain.getArch() == llvm::Triple::thumb ||
Rafael Espindolac8f008f2010-11-07 20:14:31 +00005387 (!Args.hasArg(options::OPT_static) &&
5388 !Args.hasArg(options::OPT_shared))) {
5389 CmdArgs.push_back("-dynamic-linker");
Evgeniy Stepanov77866712012-04-25 08:59:22 +00005390 if (isAndroid)
5391 CmdArgs.push_back("/system/bin/linker");
5392 else if (ToolChain.getArch() == llvm::Triple::x86)
Rafael Espindolac8f008f2010-11-07 20:14:31 +00005393 CmdArgs.push_back("/lib/ld-linux.so.2");
Douglas Gregord9bb1522011-03-06 19:11:49 +00005394 else if (ToolChain.getArch() == llvm::Triple::arm ||
Jiangning Liueabbf922012-07-30 11:05:56 +00005395 ToolChain.getArch() == llvm::Triple::thumb) {
5396 if (ToolChain.getTriple().getEnvironment() == llvm::Triple::GNUEABIHF)
5397 CmdArgs.push_back("/lib/ld-linux-armhf.so.3");
5398 else
5399 CmdArgs.push_back("/lib/ld-linux.so.3");
5400 }
Eli Friedman27b8c4f2011-11-08 19:43:37 +00005401 else if (ToolChain.getArch() == llvm::Triple::mips ||
5402 ToolChain.getArch() == llvm::Triple::mipsel)
5403 CmdArgs.push_back("/lib/ld.so.1");
Simon Atanasyan1e1e2e22012-04-06 20:14:27 +00005404 else if (ToolChain.getArch() == llvm::Triple::mips64 ||
Simon Atanasyan2d1b1ad2012-10-21 11:44:57 +00005405 ToolChain.getArch() == llvm::Triple::mips64el) {
5406 if (hasMipsN32ABIArg(Args))
5407 CmdArgs.push_back("/lib32/ld.so.1");
5408 else
5409 CmdArgs.push_back("/lib64/ld.so.1");
5410 }
Ted Kremenek43d47cc2011-04-05 22:04:27 +00005411 else if (ToolChain.getArch() == llvm::Triple::ppc)
Chris Lattner20b90d02011-04-11 21:15:37 +00005412 CmdArgs.push_back("/lib/ld.so.1");
Ted Kremenek43d47cc2011-04-05 22:04:27 +00005413 else if (ToolChain.getArch() == llvm::Triple::ppc64)
Chris Lattner20b90d02011-04-11 21:15:37 +00005414 CmdArgs.push_back("/lib64/ld64.so.1");
Rafael Espindolac8f008f2010-11-07 20:14:31 +00005415 else
5416 CmdArgs.push_back("/lib64/ld-linux-x86-64.so.2");
5417 }
5418
5419 CmdArgs.push_back("-o");
5420 CmdArgs.push_back(Output.getFilename());
5421
Rafael Espindola81937ec2010-12-01 01:52:43 +00005422 if (!Args.hasArg(options::OPT_nostdlib) &&
5423 !Args.hasArg(options::OPT_nostartfiles)) {
Evgeniy Stepanov77866712012-04-25 08:59:22 +00005424 if (!isAndroid) {
5425 const char *crt1 = NULL;
5426 if (!Args.hasArg(options::OPT_shared)){
5427 if (Args.hasArg(options::OPT_pie))
5428 crt1 = "Scrt1.o";
5429 else
5430 crt1 = "crt1.o";
5431 }
5432 if (crt1)
5433 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crt1)));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00005434
Evgeniy Stepanov77866712012-04-25 08:59:22 +00005435 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
5436 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00005437
Rafael Espindola9aa60e92010-11-12 03:00:39 +00005438 const char *crtbegin;
5439 if (Args.hasArg(options::OPT_static))
Evgeniy Stepanov77866712012-04-25 08:59:22 +00005440 crtbegin = isAndroid ? "crtbegin_static.o" : "crtbeginT.o";
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00005441 else if (Args.hasArg(options::OPT_shared))
Evgeniy Stepanov77866712012-04-25 08:59:22 +00005442 crtbegin = isAndroid ? "crtbegin_so.o" : "crtbeginS.o";
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00005443 else if (Args.hasArg(options::OPT_pie))
5444 crtbegin = isAndroid ? "crtbegin_dynamic.o" : "crtbeginS.o";
Rafael Espindola9aa60e92010-11-12 03:00:39 +00005445 else
Evgeniy Stepanov77866712012-04-25 08:59:22 +00005446 crtbegin = isAndroid ? "crtbegin_dynamic.o" : "crtbegin.o";
Rafael Espindola9aa60e92010-11-12 03:00:39 +00005447 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtbegin)));
Benjamin Kramer058666a2012-10-04 19:42:20 +00005448
5449 // Add crtfastmath.o if available and fast math is enabled.
5450 ToolChain.AddFastMathRuntimeIfAvailable(Args, CmdArgs);
Rafael Espindola9aa60e92010-11-12 03:00:39 +00005451 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00005452
5453 Args.AddAllArgs(CmdArgs, options::OPT_L);
5454
5455 const ToolChain::path_list Paths = ToolChain.getFilePaths();
5456
Roman Divackyee8188a2011-03-01 17:53:14 +00005457 for (ToolChain::path_list::const_iterator i = Paths.begin(), e = Paths.end();
5458 i != e; ++i)
Chris Lattner0e62c1c2011-07-23 10:55:15 +00005459 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + *i));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00005460
Rafael Espindola9446d762012-04-09 23:53:34 +00005461 // Tell the linker to load the plugin. This has to come before AddLinkerInputs
5462 // as gold requires -plugin to come before any -plugin-opt that -Wl might
5463 // forward.
5464 if (D.IsUsingLTO(Args) || Args.hasArg(options::OPT_use_gold_plugin)) {
5465 CmdArgs.push_back("-plugin");
5466 std::string Plugin = ToolChain.getDriver().Dir + "/../lib/LLVMgold.so";
5467 CmdArgs.push_back(Args.MakeArgString(Plugin));
5468 }
5469
Nick Lewycky2fe6aab2012-08-17 03:39:16 +00005470 if (Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
5471 CmdArgs.push_back("--no-demangle");
5472
Rafael Espindolac8f008f2010-11-07 20:14:31 +00005473 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
5474
Alexey Samsonov627b10f2012-11-06 15:09:03 +00005475 SanitizerArgs Sanitize(D, Args);
Richard Smith52be6192012-11-05 22:04:41 +00005476
Eric Christopher04997782012-11-29 18:51:05 +00005477 // Call these before we add the C++ ABI library.
Richard Smith52be6192012-11-05 22:04:41 +00005478 if (Sanitize.needsUbsanRt())
5479 addUbsanRTLinux(getToolChain(), Args, CmdArgs);
Eric Christopher04997782012-11-29 18:51:05 +00005480 if (Sanitize.needsAsanRt())
5481 addAsanRTLinux(getToolChain(), Args, CmdArgs);
5482 if (Sanitize.needsTsanRt())
5483 addTsanRTLinux(getToolChain(), Args, CmdArgs);
Evgeniy Stepanovaea92e52012-12-03 13:20:43 +00005484 if (Sanitize.needsMsanRt())
5485 addMsanRTLinux(getToolChain(), Args, CmdArgs);
Richard Smith4d3110a2012-10-25 02:14:12 +00005486
Chandler Carruth94a32012012-05-14 18:31:18 +00005487 if (D.CCCIsCXX &&
5488 !Args.hasArg(options::OPT_nostdlib) &&
5489 !Args.hasArg(options::OPT_nodefaultlibs)) {
Rafael Espindola70b8d762011-10-17 22:14:51 +00005490 bool OnlyLibstdcxxStatic = Args.hasArg(options::OPT_static_libstdcxx) &&
5491 !Args.hasArg(options::OPT_static);
5492 if (OnlyLibstdcxxStatic)
5493 CmdArgs.push_back("-Bstatic");
Rafael Espindolac8f008f2010-11-07 20:14:31 +00005494 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
Rafael Espindola70b8d762011-10-17 22:14:51 +00005495 if (OnlyLibstdcxxStatic)
5496 CmdArgs.push_back("-Bdynamic");
Rafael Espindolac8f008f2010-11-07 20:14:31 +00005497 CmdArgs.push_back("-lm");
5498 }
5499
Rafael Espindola9aa60e92010-11-12 03:00:39 +00005500 if (!Args.hasArg(options::OPT_nostdlib)) {
Chandler Carruth94a32012012-05-14 18:31:18 +00005501 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
5502 if (Args.hasArg(options::OPT_static))
5503 CmdArgs.push_back("--start-group");
Nick Lewycky97864da2011-06-04 06:27:06 +00005504
Evgeniy Stepanov77866712012-04-25 08:59:22 +00005505 AddLibgcc(ToolChain.getTriple(), D, CmdArgs, Args);
Rafael Espindola9aa60e92010-11-12 03:00:39 +00005506
Chandler Carruth94a32012012-05-14 18:31:18 +00005507 if (Args.hasArg(options::OPT_pthread) ||
5508 Args.hasArg(options::OPT_pthreads))
5509 CmdArgs.push_back("-lpthread");
5510
5511 CmdArgs.push_back("-lc");
5512
5513 if (Args.hasArg(options::OPT_static))
5514 CmdArgs.push_back("--end-group");
5515 else
5516 AddLibgcc(ToolChain.getTriple(), D, CmdArgs, Args);
5517 }
Rafael Espindolad47ac232010-11-17 22:26:15 +00005518
Rafael Espindola81937ec2010-12-01 01:52:43 +00005519 if (!Args.hasArg(options::OPT_nostartfiles)) {
5520 const char *crtend;
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00005521 if (Args.hasArg(options::OPT_shared))
Evgeniy Stepanov77866712012-04-25 08:59:22 +00005522 crtend = isAndroid ? "crtend_so.o" : "crtendS.o";
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00005523 else if (Args.hasArg(options::OPT_pie))
5524 crtend = isAndroid ? "crtend_android.o" : "crtendS.o";
Rafael Espindola81937ec2010-12-01 01:52:43 +00005525 else
Evgeniy Stepanov77866712012-04-25 08:59:22 +00005526 crtend = isAndroid ? "crtend_android.o" : "crtend.o";
Rafael Espindola9aa60e92010-11-12 03:00:39 +00005527
Rafael Espindola81937ec2010-12-01 01:52:43 +00005528 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtend)));
Evgeniy Stepanov77866712012-04-25 08:59:22 +00005529 if (!isAndroid)
5530 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
Rafael Espindola81937ec2010-12-01 01:52:43 +00005531 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00005532 }
5533
Bill Wendling08760582011-06-27 19:15:03 +00005534 addProfileRT(getToolChain(), Args, CmdArgs, getToolChain().getTriple());
Nick Lewycky82fe5f42011-05-24 21:54:59 +00005535
Rafael Espindolac8f008f2010-11-07 20:14:31 +00005536 C.addCommand(new Command(JA, *this, ToolChain.Linker.c_str(), CmdArgs));
5537}
Rafael Espindola92b00932010-08-10 00:25:48 +00005538
Chris Lattner3e2ee142010-07-07 16:01:42 +00005539void minix::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00005540 const InputInfo &Output,
5541 const InputInfoList &Inputs,
5542 const ArgList &Args,
5543 const char *LinkingOutput) const {
Chris Lattner3e2ee142010-07-07 16:01:42 +00005544 ArgStringList CmdArgs;
5545
5546 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
5547 options::OPT_Xassembler);
5548
5549 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00005550 CmdArgs.push_back(Output.getFilename());
Chris Lattner3e2ee142010-07-07 16:01:42 +00005551
5552 for (InputInfoList::const_iterator
5553 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
5554 const InputInfo &II = *it;
Daniel Dunbarb440f562010-08-02 02:38:21 +00005555 CmdArgs.push_back(II.getFilename());
Chris Lattner3e2ee142010-07-07 16:01:42 +00005556 }
5557
5558 const char *Exec =
Eli Friedman83de5132011-12-08 23:54:21 +00005559 Args.MakeArgString(getToolChain().GetProgramPath("as"));
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00005560 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Chris Lattner3e2ee142010-07-07 16:01:42 +00005561}
5562
5563void minix::Link::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00005564 const InputInfo &Output,
5565 const InputInfoList &Inputs,
5566 const ArgList &Args,
5567 const char *LinkingOutput) const {
Chris Lattner3e2ee142010-07-07 16:01:42 +00005568 const Driver &D = getToolChain().getDriver();
5569 ArgStringList CmdArgs;
5570
Daniel Dunbarb440f562010-08-02 02:38:21 +00005571 if (Output.isFilename()) {
Chris Lattner3e2ee142010-07-07 16:01:42 +00005572 CmdArgs.push_back("-o");
5573 CmdArgs.push_back(Output.getFilename());
5574 } else {
5575 assert(Output.isNothing() && "Invalid output.");
5576 }
5577
5578 if (!Args.hasArg(options::OPT_nostdlib) &&
Eli Friedman83de5132011-12-08 23:54:21 +00005579 !Args.hasArg(options::OPT_nostartfiles)) {
5580 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crt1.o")));
5581 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
5582 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
5583 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
5584 }
Chris Lattner3e2ee142010-07-07 16:01:42 +00005585
5586 Args.AddAllArgs(CmdArgs, options::OPT_L);
5587 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
5588 Args.AddAllArgs(CmdArgs, options::OPT_e);
5589
Daniel Dunbar54423b22010-09-17 00:24:54 +00005590 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Chris Lattner3e2ee142010-07-07 16:01:42 +00005591
Eli Friedman83de5132011-12-08 23:54:21 +00005592 addProfileRT(getToolChain(), Args, CmdArgs, getToolChain().getTriple());
5593
Chris Lattner3e2ee142010-07-07 16:01:42 +00005594 if (!Args.hasArg(options::OPT_nostdlib) &&
5595 !Args.hasArg(options::OPT_nodefaultlibs)) {
5596 if (D.CCCIsCXX) {
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00005597 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Chris Lattner3e2ee142010-07-07 16:01:42 +00005598 CmdArgs.push_back("-lm");
5599 }
Chris Lattner3e2ee142010-07-07 16:01:42 +00005600 }
5601
5602 if (!Args.hasArg(options::OPT_nostdlib) &&
5603 !Args.hasArg(options::OPT_nostartfiles)) {
Eli Friedman83de5132011-12-08 23:54:21 +00005604 if (Args.hasArg(options::OPT_pthread))
5605 CmdArgs.push_back("-lpthread");
5606 CmdArgs.push_back("-lc");
5607 CmdArgs.push_back("-lCompilerRT-Generic");
5608 CmdArgs.push_back("-L/usr/pkg/compiler-rt/lib");
5609 CmdArgs.push_back(
5610 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Chris Lattner3e2ee142010-07-07 16:01:42 +00005611 }
5612
Eli Friedman83de5132011-12-08 23:54:21 +00005613 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("ld"));
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00005614 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Chris Lattner3e2ee142010-07-07 16:01:42 +00005615}
5616
Daniel Dunbarcc912342009-05-02 18:28:39 +00005617/// DragonFly Tools
5618
5619// For now, DragonFly Assemble does just about the same as for
5620// FreeBSD, but this may change soon.
5621void dragonfly::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00005622 const InputInfo &Output,
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00005623 const InputInfoList &Inputs,
5624 const ArgList &Args,
5625 const char *LinkingOutput) const {
Daniel Dunbarcc912342009-05-02 18:28:39 +00005626 ArgStringList CmdArgs;
5627
5628 // When building 32-bit code on DragonFly/pc64, we have to explicitly
5629 // instruct as in the base system to assemble 32-bit code.
Rafael Espindola35ca7d92012-10-07 04:44:33 +00005630 if (getToolChain().getArch() == llvm::Triple::x86)
Daniel Dunbarcc912342009-05-02 18:28:39 +00005631 CmdArgs.push_back("--32");
5632
5633 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
5634 options::OPT_Xassembler);
5635
5636 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00005637 CmdArgs.push_back(Output.getFilename());
Daniel Dunbarcc912342009-05-02 18:28:39 +00005638
5639 for (InputInfoList::const_iterator
5640 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
5641 const InputInfo &II = *it;
Daniel Dunbarb440f562010-08-02 02:38:21 +00005642 CmdArgs.push_back(II.getFilename());
Daniel Dunbarcc912342009-05-02 18:28:39 +00005643 }
5644
5645 const char *Exec =
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00005646 Args.MakeArgString(getToolChain().GetProgramPath("as"));
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00005647 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbarcc912342009-05-02 18:28:39 +00005648}
5649
5650void dragonfly::Link::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00005651 const InputInfo &Output,
5652 const InputInfoList &Inputs,
5653 const ArgList &Args,
5654 const char *LinkingOutput) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00005655 const Driver &D = getToolChain().getDriver();
Daniel Dunbarcc912342009-05-02 18:28:39 +00005656 ArgStringList CmdArgs;
5657
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00005658 if (!D.SysRoot.empty())
5659 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
5660
Daniel Dunbarcc912342009-05-02 18:28:39 +00005661 if (Args.hasArg(options::OPT_static)) {
5662 CmdArgs.push_back("-Bstatic");
5663 } else {
5664 if (Args.hasArg(options::OPT_shared))
5665 CmdArgs.push_back("-Bshareable");
5666 else {
5667 CmdArgs.push_back("-dynamic-linker");
5668 CmdArgs.push_back("/usr/libexec/ld-elf.so.2");
5669 }
5670 }
5671
5672 // When building 32-bit code on DragonFly/pc64, we have to explicitly
5673 // instruct ld in the base system to link 32-bit code.
Rafael Espindola35ca7d92012-10-07 04:44:33 +00005674 if (getToolChain().getArch() == llvm::Triple::x86) {
Daniel Dunbarcc912342009-05-02 18:28:39 +00005675 CmdArgs.push_back("-m");
5676 CmdArgs.push_back("elf_i386");
5677 }
5678
Daniel Dunbarb440f562010-08-02 02:38:21 +00005679 if (Output.isFilename()) {
Daniel Dunbarcc912342009-05-02 18:28:39 +00005680 CmdArgs.push_back("-o");
5681 CmdArgs.push_back(Output.getFilename());
5682 } else {
5683 assert(Output.isNothing() && "Invalid output.");
5684 }
5685
5686 if (!Args.hasArg(options::OPT_nostdlib) &&
5687 !Args.hasArg(options::OPT_nostartfiles)) {
5688 if (!Args.hasArg(options::OPT_shared)) {
Chris Lattner3e2ee142010-07-07 16:01:42 +00005689 CmdArgs.push_back(
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00005690 Args.MakeArgString(getToolChain().GetFilePath("crt1.o")));
Chris Lattner3e2ee142010-07-07 16:01:42 +00005691 CmdArgs.push_back(
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00005692 Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
Chris Lattner3e2ee142010-07-07 16:01:42 +00005693 CmdArgs.push_back(
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00005694 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
Daniel Dunbarcc912342009-05-02 18:28:39 +00005695 } else {
Chris Lattner3e2ee142010-07-07 16:01:42 +00005696 CmdArgs.push_back(
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00005697 Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
Chris Lattner3e2ee142010-07-07 16:01:42 +00005698 CmdArgs.push_back(
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00005699 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.o")));
Daniel Dunbarcc912342009-05-02 18:28:39 +00005700 }
5701 }
5702
5703 Args.AddAllArgs(CmdArgs, options::OPT_L);
5704 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
5705 Args.AddAllArgs(CmdArgs, options::OPT_e);
5706
Daniel Dunbar54423b22010-09-17 00:24:54 +00005707 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Daniel Dunbarcc912342009-05-02 18:28:39 +00005708
5709 if (!Args.hasArg(options::OPT_nostdlib) &&
5710 !Args.hasArg(options::OPT_nodefaultlibs)) {
5711 // FIXME: GCC passes on -lgcc, -lgcc_pic and a whole lot of
5712 // rpaths
5713 CmdArgs.push_back("-L/usr/lib/gcc41");
5714
5715 if (!Args.hasArg(options::OPT_static)) {
5716 CmdArgs.push_back("-rpath");
5717 CmdArgs.push_back("/usr/lib/gcc41");
5718
5719 CmdArgs.push_back("-rpath-link");
5720 CmdArgs.push_back("/usr/lib/gcc41");
5721
5722 CmdArgs.push_back("-rpath");
5723 CmdArgs.push_back("/usr/lib");
5724
5725 CmdArgs.push_back("-rpath-link");
5726 CmdArgs.push_back("/usr/lib");
5727 }
5728
Rafael Espindola38360b32010-07-20 12:59:03 +00005729 if (D.CCCIsCXX) {
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00005730 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Rafael Espindola38360b32010-07-20 12:59:03 +00005731 CmdArgs.push_back("-lm");
5732 }
5733
Daniel Dunbarcc912342009-05-02 18:28:39 +00005734 if (Args.hasArg(options::OPT_shared)) {
5735 CmdArgs.push_back("-lgcc_pic");
5736 } else {
5737 CmdArgs.push_back("-lgcc");
5738 }
5739
5740
5741 if (Args.hasArg(options::OPT_pthread))
Mike Stump0a65b632009-10-31 20:11:46 +00005742 CmdArgs.push_back("-lpthread");
Daniel Dunbarcc912342009-05-02 18:28:39 +00005743
5744 if (!Args.hasArg(options::OPT_nolibc)) {
5745 CmdArgs.push_back("-lc");
5746 }
5747
5748 if (Args.hasArg(options::OPT_shared)) {
5749 CmdArgs.push_back("-lgcc_pic");
5750 } else {
5751 CmdArgs.push_back("-lgcc");
5752 }
5753 }
5754
5755 if (!Args.hasArg(options::OPT_nostdlib) &&
5756 !Args.hasArg(options::OPT_nostartfiles)) {
5757 if (!Args.hasArg(options::OPT_shared))
Chris Lattner3e2ee142010-07-07 16:01:42 +00005758 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00005759 getToolChain().GetFilePath("crtend.o")));
Daniel Dunbarcc912342009-05-02 18:28:39 +00005760 else
Chris Lattner3e2ee142010-07-07 16:01:42 +00005761 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00005762 getToolChain().GetFilePath("crtendS.o")));
Chris Lattner3e2ee142010-07-07 16:01:42 +00005763 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00005764 getToolChain().GetFilePath("crtn.o")));
Daniel Dunbarcc912342009-05-02 18:28:39 +00005765 }
5766
Bill Wendling08760582011-06-27 19:15:03 +00005767 addProfileRT(getToolChain(), Args, CmdArgs, getToolChain().getTriple());
Nick Lewycky82fe5f42011-05-24 21:54:59 +00005768
Daniel Dunbarcc912342009-05-02 18:28:39 +00005769 const char *Exec =
Daniel Dunbar9c3ed5f2010-07-14 18:46:23 +00005770 Args.MakeArgString(getToolChain().GetProgramPath("ld"));
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00005771 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbarcc912342009-05-02 18:28:39 +00005772}
Michael J. Spencerb186bc32010-08-21 21:55:07 +00005773
5774void visualstudio::Link::ConstructJob(Compilation &C, const JobAction &JA,
5775 const InputInfo &Output,
5776 const InputInfoList &Inputs,
5777 const ArgList &Args,
5778 const char *LinkingOutput) const {
Michael J. Spencerb186bc32010-08-21 21:55:07 +00005779 ArgStringList CmdArgs;
5780
5781 if (Output.isFilename()) {
Daniel Dunbar2cc3f172010-09-17 00:45:02 +00005782 CmdArgs.push_back(Args.MakeArgString(std::string("-out:") +
5783 Output.getFilename()));
Michael J. Spencerb186bc32010-08-21 21:55:07 +00005784 } else {
5785 assert(Output.isNothing() && "Invalid output.");
5786 }
5787
5788 if (!Args.hasArg(options::OPT_nostdlib) &&
5789 !Args.hasArg(options::OPT_nostartfiles)) {
5790 CmdArgs.push_back("-defaultlib:libcmt");
5791 }
5792
5793 CmdArgs.push_back("-nologo");
5794
Michael J. Spencere2f49362012-06-18 16:56:04 +00005795 Args.AddAllArgValues(CmdArgs, options::OPT_l);
5796
5797 // Add filenames immediately.
5798 for (InputInfoList::const_iterator
5799 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
5800 if (it->isFilename())
5801 CmdArgs.push_back(it->getFilename());
5802 }
Michael J. Spencerb186bc32010-08-21 21:55:07 +00005803
5804 const char *Exec =
Daniel Dunbar54423b22010-09-17 00:24:54 +00005805 Args.MakeArgString(getToolChain().GetProgramPath("link.exe"));
Michael J. Spencerb186bc32010-08-21 21:55:07 +00005806 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
5807}