blob: 38f21c08829e27709d389aa6448501d4c705ee86 [file] [log] [blame]
Nick Lewyckye3365aa2010-09-23 23:48:20 +00001//===--- Tools.cpp - Tools Implementations --------------------------------===//
Daniel Dunbar47ac7d22009-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"
11
Daniel Dunbar1d460332009-03-18 10:01:51 +000012#include "clang/Driver/Action.h"
Daniel Dunbar871adcf2009-03-18 07:06:02 +000013#include "clang/Driver/Arg.h"
Daniel Dunbarb488c1d2009-03-18 08:07:30 +000014#include "clang/Driver/ArgList.h"
Daniel Dunbaree848a72009-10-29 02:39:57 +000015#include "clang/Driver/Driver.h"
16#include "clang/Driver/DriverDiagnostic.h"
Daniel Dunbar871adcf2009-03-18 07:06:02 +000017#include "clang/Driver/Compilation.h"
18#include "clang/Driver/Job.h"
John McCall9f084a32011-07-06 00:26:06 +000019#include "clang/Driver/ObjCRuntime.h"
Daniel Dunbarb488c1d2009-03-18 08:07:30 +000020#include "clang/Driver/Option.h"
Daniel Dunbar265e9ef2009-11-19 04:25:22 +000021#include "clang/Driver/Options.h"
Daniel Dunbarb488c1d2009-03-18 08:07:30 +000022#include "clang/Driver/ToolChain.h"
Daniel Dunbar871adcf2009-03-18 07:06:02 +000023#include "clang/Driver/Util.h"
24
Daniel Dunbar88137642009-09-09 22:32:48 +000025#include "llvm/ADT/SmallString.h"
Douglas Gregor55d3f7a2009-10-29 00:41:01 +000026#include "llvm/ADT/StringSwitch.h"
Daniel Dunbar5b750fe2009-09-09 22:32:34 +000027#include "llvm/ADT/Twine.h"
Michael J. Spencer32bef4e2011-01-10 02:34:13 +000028#include "llvm/Support/FileSystem.h"
Daniel Dunbar02633b52009-03-26 16:23:12 +000029#include "llvm/Support/Format.h"
30#include "llvm/Support/raw_ostream.h"
Michael J. Spencer03013fa2010-11-29 18:12:39 +000031#include "llvm/Support/Host.h"
32#include "llvm/Support/Process.h"
John McCallf85e1932011-06-15 23:02:42 +000033#include "llvm/Support/ErrorHandling.h"
Daniel Dunbar871adcf2009-03-18 07:06:02 +000034
35#include "InputInfo.h"
Daniel Dunbar02633b52009-03-26 16:23:12 +000036#include "ToolChains.h"
Daniel Dunbar871adcf2009-03-18 07:06:02 +000037
Daniel Dunbar47ac7d22009-03-18 06:00:36 +000038using namespace clang::driver;
39using namespace clang::driver::tools;
Chris Lattner5f9e2722011-07-23 10:55:15 +000040using namespace clang;
Daniel Dunbar47ac7d22009-03-18 06:00:36 +000041
Daniel Dunbar88a3d6c2009-09-10 01:21:05 +000042/// CheckPreprocessingOptions - Perform some validation of preprocessing
43/// arguments that is shared with gcc.
44static void CheckPreprocessingOptions(const Driver &D, const ArgList &Args) {
45 if (Arg *A = Args.getLastArg(options::OPT_C, options::OPT_CC))
Joerg Sonnenberger9ade4ae2011-03-06 23:31:01 +000046 if (!Args.hasArg(options::OPT_E) && !D.CCCIsCPP)
Chris Lattner5f9e2722011-07-23 10:55:15 +000047 D.Diag(diag::err_drv_argument_only_allowed_with)
Daniel Dunbar88a3d6c2009-09-10 01:21:05 +000048 << A->getAsString(Args) << "-E";
49}
50
Daniel Dunbare2fd6642009-09-10 01:21:12 +000051/// CheckCodeGenerationOptions - Perform some validation of code generation
52/// arguments that is shared with gcc.
53static void CheckCodeGenerationOptions(const Driver &D, const ArgList &Args) {
54 // In gcc, only ARM checks this, but it seems reasonable to check universally.
55 if (Args.hasArg(options::OPT_static))
56 if (const Arg *A = Args.getLastArg(options::OPT_dynamic,
57 options::OPT_mdynamic_no_pic))
Chris Lattner5f9e2722011-07-23 10:55:15 +000058 D.Diag(diag::err_drv_argument_not_allowed_with)
Daniel Dunbare2fd6642009-09-10 01:21:12 +000059 << A->getAsString(Args) << "-static";
60}
61
Chris Lattner3edbeb72010-03-29 17:55:58 +000062// Quote target names for inclusion in GNU Make dependency files.
63// Only the characters '$', '#', ' ', '\t' are quoted.
Chris Lattner5f9e2722011-07-23 10:55:15 +000064static void QuoteTarget(StringRef Target,
65 SmallVectorImpl<char> &Res) {
Chris Lattner3edbeb72010-03-29 17:55:58 +000066 for (unsigned i = 0, e = Target.size(); i != e; ++i) {
67 switch (Target[i]) {
68 case ' ':
69 case '\t':
70 // Escape the preceding backslashes
71 for (int j = i - 1; j >= 0 && Target[j] == '\\'; --j)
72 Res.push_back('\\');
73
74 // Escape the space/tab
75 Res.push_back('\\');
76 break;
77 case '$':
78 Res.push_back('$');
79 break;
80 case '#':
81 Res.push_back('\\');
82 break;
83 default:
84 break;
85 }
86
87 Res.push_back(Target[i]);
88 }
89}
90
Daniel Dunbar2008fee2010-09-17 00:24:54 +000091static void AddLinkerInputs(const ToolChain &TC,
92 const InputInfoList &Inputs, const ArgList &Args,
93 ArgStringList &CmdArgs) {
94 const Driver &D = TC.getDriver();
95
Daniel Dunbar8ac38d72011-02-19 05:33:51 +000096 // Add extra linker input arguments which are not treated as inputs
97 // (constructed via -Xarch_).
98 Args.AddAllArgValues(CmdArgs, options::OPT_Zlinker_input);
99
Daniel Dunbar2008fee2010-09-17 00:24:54 +0000100 for (InputInfoList::const_iterator
101 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
102 const InputInfo &II = *it;
103
104 if (!TC.HasNativeLLVMSupport()) {
105 // Don't try to pass LLVM inputs unless we have native support.
106 if (II.getType() == types::TY_LLVM_IR ||
107 II.getType() == types::TY_LTO_IR ||
108 II.getType() == types::TY_LLVM_BC ||
109 II.getType() == types::TY_LTO_BC)
Chris Lattner5f9e2722011-07-23 10:55:15 +0000110 D.Diag(diag::err_drv_no_linker_llvm_support)
Daniel Dunbar2008fee2010-09-17 00:24:54 +0000111 << TC.getTripleString();
112 }
113
Daniel Dunbare5a37f42010-09-17 00:45:02 +0000114 // Add filenames immediately.
115 if (II.isFilename()) {
Daniel Dunbar2008fee2010-09-17 00:24:54 +0000116 CmdArgs.push_back(II.getFilename());
Daniel Dunbare5a37f42010-09-17 00:45:02 +0000117 continue;
118 }
119
120 // Otherwise, this is a linker input argument.
121 const Arg &A = II.getInputArg();
122
123 // Handle reserved library options.
124 if (A.getOption().matches(options::OPT_Z_reserved_lib_stdcxx)) {
Daniel Dunbar132e35d2010-09-17 01:20:05 +0000125 TC.AddCXXStdlibLibArgs(Args, CmdArgs);
Shantonu Sen7433fed2010-09-17 18:39:08 +0000126 } else if (A.getOption().matches(options::OPT_Z_reserved_lib_cckext)) {
127 TC.AddCCKextLibArgs(Args, CmdArgs);
Daniel Dunbare5a37f42010-09-17 00:45:02 +0000128 } else
129 A.renderAsInput(Args, CmdArgs);
Daniel Dunbar2008fee2010-09-17 00:24:54 +0000130 }
131}
132
John McCallf85e1932011-06-15 23:02:42 +0000133/// \brief Determine whether Objective-C automated reference counting is
134/// enabled.
135static bool isObjCAutoRefCount(const ArgList &Args) {
136 return Args.hasFlag(options::OPT_fobjc_arc, options::OPT_fno_objc_arc, false);
137}
138
Ted Kremenekebcb57a2012-03-06 20:05:56 +0000139/// \brief Determine whether we are linking the ObjC runtime.
140static bool isObjCRuntimeLinked(const ArgList &Args) {
141 if (isObjCAutoRefCount(Args))
142 return true;
143 return Args.hasArg(options::OPT_fobjc_link_runtime);
144}
145
Rafael Espindoladb3f24a2011-06-02 18:58:46 +0000146static void addProfileRT(const ToolChain &TC, const ArgList &Args,
Bill Wendling3f4be6f2011-06-27 19:15:03 +0000147 ArgStringList &CmdArgs,
148 llvm::Triple Triple) {
149 if (!(Args.hasArg(options::OPT_fprofile_arcs) ||
150 Args.hasArg(options::OPT_fprofile_generate) ||
151 Args.hasArg(options::OPT_fcreate_profile) ||
152 Args.hasArg(options::OPT_coverage)))
153 return;
154
155 // GCC links libgcov.a by adding -L<inst>/gcc/lib/gcc/<triple>/<ver> -lgcov to
156 // the link line. We cannot do the same thing because unlike gcov there is a
157 // libprofile_rt.so. We used to use the -l:libprofile_rt.a syntax, but that is
158 // not supported by old linkers.
Benjamin Kramerf2db04c2011-11-07 16:02:25 +0000159 std::string ProfileRT =
160 std::string(TC.getDriver().Dir) + "/../lib/libprofile_rt.a";
Bill Wendling3f4be6f2011-06-27 19:15:03 +0000161
Bill Wendling3f4be6f2011-06-27 19:15:03 +0000162 CmdArgs.push_back(Args.MakeArgString(ProfileRT));
Rafael Espindoladb3f24a2011-06-02 18:58:46 +0000163}
164
Benjamin Kramer47adebe2011-09-22 21:41:16 +0000165static void AddIncludeDirectoryList(const ArgList &Args,
166 ArgStringList &CmdArgs,
167 const char *ArgName,
168 const char *DirList) {
169 if (!DirList)
170 return; // Nothing to do.
171
172 StringRef Dirs(DirList);
173 if (Dirs.empty()) // Empty string should not add '.'.
174 return;
175
176 StringRef::size_type Delim;
177 while ((Delim = Dirs.find(llvm::sys::PathSeparator)) != StringRef::npos) {
178 if (Delim == 0) { // Leading colon.
179 CmdArgs.push_back(ArgName);
180 CmdArgs.push_back(".");
181 } else {
182 CmdArgs.push_back(ArgName);
183 CmdArgs.push_back(Args.MakeArgString(Dirs.substr(0, Delim)));
184 }
185 Dirs = Dirs.substr(Delim + 1);
186 }
187
188 if (Dirs.empty()) { // Trailing colon.
189 CmdArgs.push_back(ArgName);
190 CmdArgs.push_back(".");
191 } else { // Add the last path.
192 CmdArgs.push_back(ArgName);
193 CmdArgs.push_back(Args.MakeArgString(Dirs));
194 }
195}
196
Peter Collingbourne54db68b2011-11-06 00:40:05 +0000197void Clang::AddPreprocessingOptions(Compilation &C,
198 const Driver &D,
Douglas Gregordf91ef32009-04-18 00:34:01 +0000199 const ArgList &Args,
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000200 ArgStringList &CmdArgs,
201 const InputInfo &Output,
202 const InputInfoList &Inputs) const {
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000203 Arg *A;
Daniel Dunbar3a183d32009-06-08 21:48:20 +0000204
Daniel Dunbar88a3d6c2009-09-10 01:21:05 +0000205 CheckPreprocessingOptions(D, Args);
206
207 Args.AddLastArg(CmdArgs, options::OPT_C);
208 Args.AddLastArg(CmdArgs, options::OPT_CC);
Daniel Dunbar3a183d32009-06-08 21:48:20 +0000209
210 // Handle dependency file generation.
Daniel Dunbar9eb93b02010-12-08 21:33:40 +0000211 if ((A = Args.getLastArg(options::OPT_M, options::OPT_MM)) ||
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000212 (A = Args.getLastArg(options::OPT_MD)) ||
213 (A = Args.getLastArg(options::OPT_MMD))) {
214 // Determine the output location.
215 const char *DepFile;
216 if (Output.getType() == types::TY_Dependencies) {
Daniel Dunbar7c1e4652010-08-02 02:38:21 +0000217 DepFile = Output.getFilename();
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000218 } else if (Arg *MF = Args.getLastArg(options::OPT_MF)) {
219 DepFile = MF->getValue(Args);
Peter Collingbourne5d4d9802011-11-21 00:01:05 +0000220 C.addFailureResultFile(DepFile);
Daniel Dunbarb827a052009-11-19 03:26:40 +0000221 } else if (A->getOption().matches(options::OPT_M) ||
222 A->getOption().matches(options::OPT_MM)) {
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000223 DepFile = "-";
224 } else {
225 DepFile = darwin::CC1::getDependencyFileName(Args, Inputs);
Peter Collingbourne5d4d9802011-11-21 00:01:05 +0000226 C.addFailureResultFile(DepFile);
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000227 }
228 CmdArgs.push_back("-dependency-file");
229 CmdArgs.push_back(DepFile);
230
Chris Lattner3edbeb72010-03-29 17:55:58 +0000231 // Add a default target if one wasn't specified.
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000232 if (!Args.hasArg(options::OPT_MT) && !Args.hasArg(options::OPT_MQ)) {
233 const char *DepTarget;
234
235 // If user provided -o, that is the dependency target, except
236 // when we are only generating a dependency file.
237 Arg *OutputOpt = Args.getLastArg(options::OPT_o);
238 if (OutputOpt && Output.getType() != types::TY_Dependencies) {
239 DepTarget = OutputOpt->getValue(Args);
240 } else {
241 // Otherwise derive from the base input.
242 //
243 // FIXME: This should use the computed output file location.
Dylan Noblesmithf7ccbad2012-02-05 02:13:05 +0000244 SmallString<128> P(Inputs[0].getBaseInput());
Michael J. Spencer472ccff2010-12-18 00:19:12 +0000245 llvm::sys::path::replace_extension(P, "o");
246 DepTarget = Args.MakeArgString(llvm::sys::path::filename(P));
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000247 }
248
249 CmdArgs.push_back("-MT");
Dylan Noblesmithf7ccbad2012-02-05 02:13:05 +0000250 SmallString<128> Quoted;
Chris Lattner3edbeb72010-03-29 17:55:58 +0000251 QuoteTarget(DepTarget, Quoted);
252 CmdArgs.push_back(Args.MakeArgString(Quoted));
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000253 }
254
Daniel Dunbarb827a052009-11-19 03:26:40 +0000255 if (A->getOption().matches(options::OPT_M) ||
256 A->getOption().matches(options::OPT_MD))
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000257 CmdArgs.push_back("-sys-header-deps");
258 }
259
Peter Collingbournebb527862011-07-12 19:35:15 +0000260 if (Args.hasArg(options::OPT_MG)) {
261 if (!A || A->getOption().matches(options::OPT_MD) ||
262 A->getOption().matches(options::OPT_MMD))
Chris Lattner5f9e2722011-07-23 10:55:15 +0000263 D.Diag(diag::err_drv_mg_requires_m_or_mm);
Peter Collingbournebb527862011-07-12 19:35:15 +0000264 CmdArgs.push_back("-MG");
265 }
266
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000267 Args.AddLastArg(CmdArgs, options::OPT_MP);
Chris Lattner3edbeb72010-03-29 17:55:58 +0000268
269 // Convert all -MQ <target> args to -MT <quoted target>
270 for (arg_iterator it = Args.filtered_begin(options::OPT_MT,
271 options::OPT_MQ),
272 ie = Args.filtered_end(); it != ie; ++it) {
Daniel Dunbar7e4953e2010-06-11 22:00:13 +0000273 const Arg *A = *it;
274 A->claim();
Chris Lattner3edbeb72010-03-29 17:55:58 +0000275
Daniel Dunbar7e4953e2010-06-11 22:00:13 +0000276 if (A->getOption().matches(options::OPT_MQ)) {
Chris Lattner3edbeb72010-03-29 17:55:58 +0000277 CmdArgs.push_back("-MT");
Dylan Noblesmithf7ccbad2012-02-05 02:13:05 +0000278 SmallString<128> Quoted;
Daniel Dunbar7e4953e2010-06-11 22:00:13 +0000279 QuoteTarget(A->getValue(Args), Quoted);
Chris Lattner3edbeb72010-03-29 17:55:58 +0000280 CmdArgs.push_back(Args.MakeArgString(Quoted));
281
282 // -MT flag - no change
283 } else {
Daniel Dunbar7e4953e2010-06-11 22:00:13 +0000284 A->render(Args, CmdArgs);
Chris Lattner3edbeb72010-03-29 17:55:58 +0000285 }
286 }
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000287
Douglas Gregordf91ef32009-04-18 00:34:01 +0000288 // Add -i* options, and automatically translate to
289 // -include-pch/-include-pth for transparent PCH support. It's
290 // wonky, but we include looking for .gch so we can support seamless
291 // replacement into a build system already set up to be generating
292 // .gch files.
Argyrios Kyrtzidis990142a2010-09-30 16:53:47 +0000293 bool RenderedImplicitInclude = false;
Daniel Dunbarcdd96862009-11-25 11:53:23 +0000294 for (arg_iterator it = Args.filtered_begin(options::OPT_clang_i_Group),
295 ie = Args.filtered_end(); it != ie; ++it) {
296 const Arg *A = it;
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000297
298 if (A->getOption().matches(options::OPT_include)) {
Argyrios Kyrtzidis990142a2010-09-30 16:53:47 +0000299 bool IsFirstImplicitInclude = !RenderedImplicitInclude;
300 RenderedImplicitInclude = true;
301
Argyrios Kyrtzidise5c35372010-08-11 23:27:58 +0000302 // Use PCH if the user requested it.
Daniel Dunbar0ebd9322009-10-15 20:02:44 +0000303 bool UsePCH = D.CCCUsePCH;
Daniel Dunbar0ebd9322009-10-15 20:02:44 +0000304
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000305 bool FoundPTH = false;
Douglas Gregordf91ef32009-04-18 00:34:01 +0000306 bool FoundPCH = false;
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000307 llvm::sys::Path P(A->getValue(Args));
Michael J. Spencer32bef4e2011-01-10 02:34:13 +0000308 bool Exists;
Daniel Dunbar0ebd9322009-10-15 20:02:44 +0000309 if (UsePCH) {
Douglas Gregordf91ef32009-04-18 00:34:01 +0000310 P.appendSuffix("pch");
Michael J. Spencer32bef4e2011-01-10 02:34:13 +0000311 if (!llvm::sys::fs::exists(P.str(), Exists) && Exists)
Douglas Gregordf91ef32009-04-18 00:34:01 +0000312 FoundPCH = true;
Mike Stump1eb44332009-09-09 15:08:12 +0000313 else
Douglas Gregordf91ef32009-04-18 00:34:01 +0000314 P.eraseSuffix();
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000315 }
316
Douglas Gregordf91ef32009-04-18 00:34:01 +0000317 if (!FoundPCH) {
318 P.appendSuffix("pth");
Michael J. Spencer32bef4e2011-01-10 02:34:13 +0000319 if (!llvm::sys::fs::exists(P.str(), Exists) && Exists)
Douglas Gregordf91ef32009-04-18 00:34:01 +0000320 FoundPTH = true;
321 else
322 P.eraseSuffix();
Mike Stump1eb44332009-09-09 15:08:12 +0000323 }
324
Douglas Gregordf91ef32009-04-18 00:34:01 +0000325 if (!FoundPCH && !FoundPTH) {
326 P.appendSuffix("gch");
Michael J. Spencer32bef4e2011-01-10 02:34:13 +0000327 if (!llvm::sys::fs::exists(P.str(), Exists) && Exists) {
Daniel Dunbar0ebd9322009-10-15 20:02:44 +0000328 FoundPCH = UsePCH;
329 FoundPTH = !UsePCH;
Douglas Gregordf91ef32009-04-18 00:34:01 +0000330 }
Mike Stump1eb44332009-09-09 15:08:12 +0000331 else
Douglas Gregordf91ef32009-04-18 00:34:01 +0000332 P.eraseSuffix();
333 }
334
335 if (FoundPCH || FoundPTH) {
Argyrios Kyrtzidis990142a2010-09-30 16:53:47 +0000336 if (IsFirstImplicitInclude) {
337 A->claim();
338 if (UsePCH)
339 CmdArgs.push_back("-include-pch");
340 else
341 CmdArgs.push_back("-include-pth");
342 CmdArgs.push_back(Args.MakeArgString(P.str()));
343 continue;
344 } else {
345 // Ignore the PCH if not first on command line and emit warning.
Chris Lattner5f9e2722011-07-23 10:55:15 +0000346 D.Diag(diag::warn_drv_pch_not_first_include)
Argyrios Kyrtzidis990142a2010-09-30 16:53:47 +0000347 << P.str() << A->getAsString(Args);
348 }
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000349 }
350 }
351
352 // Not translated, render as usual.
353 A->claim();
354 A->render(Args, CmdArgs);
355 }
356
357 Args.AddAllArgs(CmdArgs, options::OPT_D, options::OPT_U);
Douglas Gregor65e02fa2011-07-28 04:45:53 +0000358 Args.AddAllArgs(CmdArgs, options::OPT_I_Group, options::OPT_F,
359 options::OPT_index_header_map);
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000360
361 // Add -Wp, and -Xassembler if using the preprocessor.
362
363 // FIXME: There is a very unfortunate problem here, some troubled
364 // souls abuse -Wp, to pass preprocessor options in gcc syntax. To
365 // really support that we would have to parse and then translate
366 // those options. :(
367 Args.AddAllArgValues(CmdArgs, options::OPT_Wp_COMMA,
368 options::OPT_Xpreprocessor);
Daniel Dunbar607d7f62009-10-29 01:53:44 +0000369
370 // -I- is a deprecated GCC feature, reject it.
371 if (Arg *A = Args.getLastArg(options::OPT_I_))
Chris Lattner5f9e2722011-07-23 10:55:15 +0000372 D.Diag(diag::err_drv_I_dash_not_supported) << A->getAsString(Args);
Chandler Carruthfeee58c2010-10-20 07:00:47 +0000373
374 // If we have a --sysroot, and don't have an explicit -isysroot flag, add an
375 // -isysroot to the CC1 invocation.
376 if (Arg *A = Args.getLastArg(options::OPT__sysroot_EQ)) {
377 if (!Args.hasArg(options::OPT_isysroot)) {
378 CmdArgs.push_back("-isysroot");
379 CmdArgs.push_back(A->getValue(Args));
380 }
381 }
Douglas Gregor8ee51ef2011-09-14 20:28:46 +0000382
383 // If a module path was provided, pass it along. Otherwise, use a temporary
384 // directory.
385 if (Arg *A = Args.getLastArg(options::OPT_fmodule_cache_path)) {
Douglas Gregor8ee51ef2011-09-14 20:28:46 +0000386 A->claim();
387 A->render(Args, CmdArgs);
388 } else {
Dylan Noblesmithf7ccbad2012-02-05 02:13:05 +0000389 SmallString<128> DefaultModuleCache;
Douglas Gregor8ee51ef2011-09-14 20:28:46 +0000390 llvm::sys::path::system_temp_directory(/*erasedOnReboot=*/false,
391 DefaultModuleCache);
392 llvm::sys::path::append(DefaultModuleCache, "clang-module-cache");
393 CmdArgs.push_back("-fmodule-cache-path");
394 CmdArgs.push_back(Args.MakeArgString(DefaultModuleCache));
395 }
Douglas Gregorfba18aa2011-09-15 22:00:41 +0000396
Benjamin Kramer47adebe2011-09-22 21:41:16 +0000397 // Parse additional include paths from environment variables.
Chandler Carruthb5870e72011-11-04 07:12:58 +0000398 // FIXME: We should probably sink the logic for handling these from the
399 // frontend into the driver. It will allow deleting 4 otherwise unused flags.
Benjamin Kramer47adebe2011-09-22 21:41:16 +0000400 // CPATH - included following the user specified includes (but prior to
401 // builtin and standard includes).
402 AddIncludeDirectoryList(Args, CmdArgs, "-I", ::getenv("CPATH"));
403 // C_INCLUDE_PATH - system includes enabled when compiling C.
404 AddIncludeDirectoryList(Args, CmdArgs, "-c-isystem",
405 ::getenv("C_INCLUDE_PATH"));
406 // CPLUS_INCLUDE_PATH - system includes enabled when compiling C++.
407 AddIncludeDirectoryList(Args, CmdArgs, "-cxx-isystem",
408 ::getenv("CPLUS_INCLUDE_PATH"));
409 // OBJC_INCLUDE_PATH - system includes enabled when compiling ObjC.
410 AddIncludeDirectoryList(Args, CmdArgs, "-objc-isystem",
411 ::getenv("OBJC_INCLUDE_PATH"));
412 // OBJCPLUS_INCLUDE_PATH - system includes enabled when compiling ObjC++.
413 AddIncludeDirectoryList(Args, CmdArgs, "-objcxx-isystem",
414 ::getenv("OBJCPLUS_INCLUDE_PATH"));
Chandler Carruth88491fc2011-11-04 07:12:53 +0000415
Chandler Carruth88491fc2011-11-04 07:12:53 +0000416 // Add C++ include arguments, if needed.
Chandler Carrutha4614422011-11-04 07:43:33 +0000417 if (types::isCXX(Inputs[0].getType()))
Chandler Carruth7ffa0322011-11-04 07:34:47 +0000418 getToolChain().AddClangCXXStdlibIncludeArgs(Args, CmdArgs);
Chandler Carruth7d7e9f92011-11-05 20:17:13 +0000419
420 // Add system include arguments.
421 getToolChain().AddClangSystemIncludeArgs(Args, CmdArgs);
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000422}
423
Chris Lattnerfc8f0e12011-04-15 05:22:18 +0000424/// getARMTargetCPU - Get the (LLVM) name of the ARM cpu we are targeting.
Daniel Dunbar728a5122009-09-10 06:49:20 +0000425//
426// FIXME: tblgen this.
Rafael Espindolabcd6df62010-06-28 17:18:09 +0000427static const char *getARMTargetCPU(const ArgList &Args,
428 const llvm::Triple &Triple) {
Daniel Dunbar728a5122009-09-10 06:49:20 +0000429 // FIXME: Warn on inconsistent use of -mcpu and -march.
Daniel Dunbarb163ef72009-09-10 04:57:17 +0000430
431 // If we have -mcpu=, use that.
432 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ))
433 return A->getValue(Args);
434
Chris Lattner5f9e2722011-07-23 10:55:15 +0000435 StringRef MArch;
Daniel Dunbarb163ef72009-09-10 04:57:17 +0000436 if (Arg *A = Args.getLastArg(options::OPT_march_EQ)) {
Rafael Espindolabcd6df62010-06-28 17:18:09 +0000437 // Otherwise, if we have -march= choose the base CPU for that arch.
438 MArch = A->getValue(Args);
439 } else {
440 // Otherwise, use the Arch from the triple.
441 MArch = Triple.getArchName();
Daniel Dunbarb163ef72009-09-10 04:57:17 +0000442 }
443
Chad Rosierae1aee62011-10-07 17:48:56 +0000444 return llvm::StringSwitch<const char *>(MArch)
445 .Cases("armv2", "armv2a","arm2")
446 .Case("armv3", "arm6")
447 .Case("armv3m", "arm7m")
448 .Cases("armv4", "armv4t", "arm7tdmi")
449 .Cases("armv5", "armv5t", "arm10tdmi")
450 .Cases("armv5e", "armv5te", "arm1026ejs")
451 .Case("armv5tej", "arm926ej-s")
452 .Cases("armv6", "armv6k", "arm1136jf-s")
453 .Case("armv6j", "arm1136j-s")
454 .Cases("armv6z", "armv6zk", "arm1176jzf-s")
455 .Case("armv6t2", "arm1156t2-s")
456 .Cases("armv7", "armv7a", "armv7-a", "cortex-a8")
457 .Cases("armv7r", "armv7-r", "cortex-r4")
458 .Cases("armv7m", "armv7-m", "cortex-m3")
459 .Case("ep9312", "ep9312")
460 .Case("iwmmxt", "iwmmxt")
461 .Case("xscale", "xscale")
462 .Cases("armv6m", "armv6-m", "cortex-m0")
463 // If all else failed, return the most base CPU LLVM supports.
464 .Default("arm7tdmi");
Daniel Dunbarb163ef72009-09-10 04:57:17 +0000465}
466
Daniel Dunbar1d65e4b2009-09-10 22:59:51 +0000467/// getLLVMArchSuffixForARM - Get the LLVM arch name to use for a particular
Daniel Dunbar728a5122009-09-10 06:49:20 +0000468/// CPU.
469//
470// FIXME: This is redundant with -mcpu, why does LLVM use this.
471// FIXME: tblgen this, or kill it!
Chris Lattner5f9e2722011-07-23 10:55:15 +0000472static const char *getLLVMArchSuffixForARM(StringRef CPU) {
Chad Rosierae1aee62011-10-07 17:48:56 +0000473 return llvm::StringSwitch<const char *>(CPU)
474 .Cases("arm7tdmi", "arm7tdmi-s", "arm710t", "v4t")
475 .Cases("arm720t", "arm9", "arm9tdmi", "v4t")
476 .Cases("arm920", "arm920t", "arm922t", "v4t")
477 .Cases("arm940t", "ep9312","v4t")
478 .Cases("arm10tdmi", "arm1020t", "v5")
479 .Cases("arm9e", "arm926ej-s", "arm946e-s", "v5e")
480 .Cases("arm966e-s", "arm968e-s", "arm10e", "v5e")
481 .Cases("arm1020e", "arm1022e", "xscale", "iwmmxt", "v5e")
482 .Cases("arm1136j-s", "arm1136jf-s", "arm1176jz-s", "v6")
483 .Cases("arm1176jzf-s", "mpcorenovfp", "mpcore", "v6")
484 .Cases("arm1156t2-s", "arm1156t2f-s", "v6t2")
485 .Cases("cortex-a8", "cortex-a9", "v7")
486 .Default("");
Daniel Dunbar728a5122009-09-10 06:49:20 +0000487}
488
Daniel Dunbar1f95e652009-11-17 06:37:03 +0000489// FIXME: Move to target hook.
490static bool isSignedCharDefault(const llvm::Triple &Triple) {
491 switch (Triple.getArch()) {
492 default:
493 return true;
494
Jim Grosbach5b4e7b12011-05-24 15:40:46 +0000495 case llvm::Triple::arm:
Daniel Dunbar1f95e652009-11-17 06:37:03 +0000496 case llvm::Triple::ppc:
497 case llvm::Triple::ppc64:
Bob Wilson905c45f2011-10-14 05:03:44 +0000498 if (Triple.isOSDarwin())
Daniel Dunbar1f95e652009-11-17 06:37:03 +0000499 return true;
500 return false;
Daniel Dunbar1f95e652009-11-17 06:37:03 +0000501 }
502}
503
Daniel Dunbarb163ef72009-09-10 04:57:17 +0000504void Clang::AddARMTargetArgs(const ArgList &Args,
Daniel Dunbarfa41d692011-03-17 17:10:06 +0000505 ArgStringList &CmdArgs,
506 bool KernelOrKext) const {
Daniel Dunbaree788e72009-12-21 18:54:17 +0000507 const Driver &D = getToolChain().getDriver();
Rafael Espindolabcd6df62010-06-28 17:18:09 +0000508 llvm::Triple Triple = getToolChain().getTriple();
Daniel Dunbarcbd19332009-09-10 23:00:09 +0000509
Daniel Dunbar2030d8f2009-09-14 00:34:46 +0000510 // Select the ABI to use.
511 //
512 // FIXME: Support -meabi.
513 const char *ABIName = 0;
514 if (Arg *A = Args.getLastArg(options::OPT_mabi_EQ)) {
515 ABIName = A->getValue(Args);
516 } else {
517 // Select the default based on the platform.
Bob Wilsonfc2bd7c2011-02-04 17:59:28 +0000518 switch(Triple.getEnvironment()) {
Chandler Carruthb43550b2012-01-10 19:47:42 +0000519 case llvm::Triple::ANDROIDEABI:
Bob Wilsonfc2bd7c2011-02-04 17:59:28 +0000520 case llvm::Triple::GNUEABI:
Daniel Dunbar2030d8f2009-09-14 00:34:46 +0000521 ABIName = "aapcs-linux";
Bob Wilsonfc2bd7c2011-02-04 17:59:28 +0000522 break;
523 case llvm::Triple::EABI:
Rafael Espindola1ed1a592010-06-16 19:01:17 +0000524 ABIName = "aapcs";
Bob Wilsonfc2bd7c2011-02-04 17:59:28 +0000525 break;
526 default:
Rafael Espindola1ed1a592010-06-16 19:01:17 +0000527 ABIName = "apcs-gnu";
Bob Wilsonfc2bd7c2011-02-04 17:59:28 +0000528 }
Daniel Dunbar2030d8f2009-09-14 00:34:46 +0000529 }
530 CmdArgs.push_back("-target-abi");
531 CmdArgs.push_back(ABIName);
532
Daniel Dunbarb163ef72009-09-10 04:57:17 +0000533 // Set the CPU based on -march= and -mcpu=.
Daniel Dunbar38b48af2009-12-18 06:30:12 +0000534 CmdArgs.push_back("-target-cpu");
Rafael Espindolabcd6df62010-06-28 17:18:09 +0000535 CmdArgs.push_back(getARMTargetCPU(Args, Triple));
Daniel Dunbarb163ef72009-09-10 04:57:17 +0000536
Daniel Dunbarcbd19332009-09-10 23:00:09 +0000537 // Select the float ABI as determined by -msoft-float, -mhard-float, and
538 // -mfloat-abi=.
Chris Lattner5f9e2722011-07-23 10:55:15 +0000539 StringRef FloatABI;
Daniel Dunbarcbd19332009-09-10 23:00:09 +0000540 if (Arg *A = Args.getLastArg(options::OPT_msoft_float,
541 options::OPT_mhard_float,
542 options::OPT_mfloat_abi_EQ)) {
543 if (A->getOption().matches(options::OPT_msoft_float))
544 FloatABI = "soft";
545 else if (A->getOption().matches(options::OPT_mhard_float))
546 FloatABI = "hard";
547 else {
548 FloatABI = A->getValue(Args);
549 if (FloatABI != "soft" && FloatABI != "softfp" && FloatABI != "hard") {
Chris Lattner5f9e2722011-07-23 10:55:15 +0000550 D.Diag(diag::err_drv_invalid_mfloat_abi)
Daniel Dunbarcbd19332009-09-10 23:00:09 +0000551 << A->getAsString(Args);
552 FloatABI = "soft";
553 }
554 }
555 }
556
557 // If unspecified, choose the default based on the platform.
558 if (FloatABI.empty()) {
Rafael Espindolabcd6df62010-06-28 17:18:09 +0000559 switch (Triple.getOS()) {
Bob Wilson905c45f2011-10-14 05:03:44 +0000560 case llvm::Triple::Darwin:
561 case llvm::Triple::MacOSX:
562 case llvm::Triple::IOS: {
Daniel Dunbarcbd19332009-09-10 23:00:09 +0000563 // Darwin defaults to "softfp" for v6 and v7.
564 //
565 // FIXME: Factor out an ARM class so we can cache the arch somewhere.
Chris Lattner5f9e2722011-07-23 10:55:15 +0000566 StringRef ArchName =
Rafael Espindolabcd6df62010-06-28 17:18:09 +0000567 getLLVMArchSuffixForARM(getARMTargetCPU(Args, Triple));
Daniel Dunbarcbd19332009-09-10 23:00:09 +0000568 if (ArchName.startswith("v6") || ArchName.startswith("v7"))
569 FloatABI = "softfp";
570 else
571 FloatABI = "soft";
572 break;
573 }
574
Rafael Espindola7e9cebf2010-06-27 18:29:21 +0000575 case llvm::Triple::Linux: {
Bob Wilson4ce83eb2011-12-08 01:10:19 +0000576 if (Triple.getEnvironment() == llvm::Triple::GNUEABI) {
Rafael Espindola7e9cebf2010-06-27 18:29:21 +0000577 FloatABI = "softfp";
578 break;
579 }
580 }
581 // fall through
582
Daniel Dunbarcbd19332009-09-10 23:00:09 +0000583 default:
Bob Wilsonfc2bd7c2011-02-04 17:59:28 +0000584 switch(Triple.getEnvironment()) {
585 case llvm::Triple::GNUEABI:
586 FloatABI = "softfp";
587 break;
588 case llvm::Triple::EABI:
589 // EABI is always AAPCS, and if it was not marked 'hard', it's softfp
590 FloatABI = "softfp";
591 break;
Chandler Carruthb43550b2012-01-10 19:47:42 +0000592 case llvm::Triple::ANDROIDEABI: {
593 StringRef ArchName =
594 getLLVMArchSuffixForARM(getARMTargetCPU(Args, Triple));
595 if (ArchName.startswith("v7"))
596 FloatABI = "softfp";
597 else
598 FloatABI = "soft";
599 break;
600 }
Bob Wilsonfc2bd7c2011-02-04 17:59:28 +0000601 default:
602 // Assume "soft", but warn the user we are guessing.
603 FloatABI = "soft";
Chris Lattner5f9e2722011-07-23 10:55:15 +0000604 D.Diag(diag::warn_drv_assuming_mfloat_abi_is) << "soft";
Bob Wilsonfc2bd7c2011-02-04 17:59:28 +0000605 break;
606 }
Daniel Dunbarcbd19332009-09-10 23:00:09 +0000607 }
608 }
609
610 if (FloatABI == "soft") {
611 // Floating point operations and argument passing are soft.
612 //
613 // FIXME: This changes CPP defines, we need -target-soft-float.
Daniel Dunbar3b315262009-11-30 08:42:00 +0000614 CmdArgs.push_back("-msoft-float");
Daniel Dunbar87667aa2009-12-08 19:49:51 +0000615 CmdArgs.push_back("-mfloat-abi");
616 CmdArgs.push_back("soft");
Daniel Dunbarcbd19332009-09-10 23:00:09 +0000617 } else if (FloatABI == "softfp") {
618 // Floating point operations are hard, but argument passing is soft.
Daniel Dunbar87667aa2009-12-08 19:49:51 +0000619 CmdArgs.push_back("-mfloat-abi");
620 CmdArgs.push_back("soft");
Daniel Dunbarcbd19332009-09-10 23:00:09 +0000621 } else {
622 // Floating point operations and argument passing are hard.
623 assert(FloatABI == "hard" && "Invalid float abi!");
Daniel Dunbar87667aa2009-12-08 19:49:51 +0000624 CmdArgs.push_back("-mfloat-abi");
625 CmdArgs.push_back("hard");
Daniel Dunbarcbd19332009-09-10 23:00:09 +0000626 }
Daniel Dunbar97f52ac2009-12-19 04:15:38 +0000627
628 // Set appropriate target features for floating point mode.
629 //
630 // FIXME: Note, this is a hack, the LLVM backend doesn't actually use these
631 // yet (it uses the -mfloat-abi and -msoft-float options above), and it is
632 // stripped out by the ARM target.
633
634 // Use software floating point operations?
635 if (FloatABI == "soft") {
636 CmdArgs.push_back("-target-feature");
637 CmdArgs.push_back("+soft-float");
638 }
639
640 // Use software floating point argument passing?
641 if (FloatABI != "hard") {
642 CmdArgs.push_back("-target-feature");
643 CmdArgs.push_back("+soft-float-abi");
644 }
Daniel Dunbara91320b2009-12-21 23:28:17 +0000645
646 // Honor -mfpu=.
647 //
648 // FIXME: Centralize feature selection, defaulting shouldn't be also in the
649 // frontend target.
650 if (const Arg *A = Args.getLastArg(options::OPT_mfpu_EQ)) {
Chris Lattner5f9e2722011-07-23 10:55:15 +0000651 StringRef FPU = A->getValue(Args);
Daniel Dunbara91320b2009-12-21 23:28:17 +0000652
653 // Set the target features based on the FPU.
654 if (FPU == "fpa" || FPU == "fpe2" || FPU == "fpe3" || FPU == "maverick") {
655 // Disable any default FPU support.
656 CmdArgs.push_back("-target-feature");
657 CmdArgs.push_back("-vfp2");
658 CmdArgs.push_back("-target-feature");
659 CmdArgs.push_back("-vfp3");
660 CmdArgs.push_back("-target-feature");
661 CmdArgs.push_back("-neon");
Evgeniy Stepanov35dd7322012-01-11 11:21:31 +0000662 } else if (FPU == "vfp3-d16" || FPU == "vfpv3-d16") {
663 CmdArgs.push_back("-target-feature");
664 CmdArgs.push_back("+vfp3");
665 CmdArgs.push_back("-target-feature");
666 CmdArgs.push_back("+d16");
667 CmdArgs.push_back("-target-feature");
668 CmdArgs.push_back("-neon");
Daniel Dunbara91320b2009-12-21 23:28:17 +0000669 } else if (FPU == "vfp") {
670 CmdArgs.push_back("-target-feature");
671 CmdArgs.push_back("+vfp2");
Evgeniy Stepanov35dd7322012-01-11 11:21:31 +0000672 CmdArgs.push_back("-target-feature");
673 CmdArgs.push_back("-neon");
674 } else if (FPU == "vfp3" || FPU == "vfpv3") {
Daniel Dunbara91320b2009-12-21 23:28:17 +0000675 CmdArgs.push_back("-target-feature");
676 CmdArgs.push_back("+vfp3");
Evgeniy Stepanov35dd7322012-01-11 11:21:31 +0000677 CmdArgs.push_back("-target-feature");
678 CmdArgs.push_back("-neon");
Daniel Dunbara91320b2009-12-21 23:28:17 +0000679 } else if (FPU == "neon") {
680 CmdArgs.push_back("-target-feature");
681 CmdArgs.push_back("+neon");
682 } else
Chris Lattner5f9e2722011-07-23 10:55:15 +0000683 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
Daniel Dunbara91320b2009-12-21 23:28:17 +0000684 }
Daniel Dunbar7187fac2011-03-17 00:07:34 +0000685
686 // Setting -msoft-float effectively disables NEON because of the GCC
687 // implementation, although the same isn't true of VFP or VFP3.
688 if (FloatABI == "soft") {
Daniel Dunbarfa41d692011-03-17 17:10:06 +0000689 CmdArgs.push_back("-target-feature");
690 CmdArgs.push_back("-neon");
691 }
692
693 // Kernel code has more strict alignment requirements.
694 if (KernelOrKext) {
Daniel Dunbar3c66d302011-03-22 16:48:17 +0000695 CmdArgs.push_back("-backend-option");
Daniel Dunbarfa41d692011-03-17 17:10:06 +0000696 CmdArgs.push_back("-arm-long-calls");
697
Daniel Dunbar3c66d302011-03-22 16:48:17 +0000698 CmdArgs.push_back("-backend-option");
Daniel Dunbarfa41d692011-03-17 17:10:06 +0000699 CmdArgs.push_back("-arm-strict-align");
Daniel Dunbarb5fbb892011-04-18 21:26:42 +0000700
701 // The kext linker doesn't know how to deal with movw/movt.
Daniel Dunbarb5fbb892011-04-18 21:26:42 +0000702 CmdArgs.push_back("-backend-option");
703 CmdArgs.push_back("-arm-darwin-use-movt=0");
Daniel Dunbar7187fac2011-03-17 00:07:34 +0000704 }
Chad Rosier1b906052011-08-26 00:26:29 +0000705
706 // Setting -mno-global-merge disables the codegen global merge pass. Setting
707 // -mglobal-merge has no effect as the pass is enabled by default.
708 if (Arg *A = Args.getLastArg(options::OPT_mglobal_merge,
709 options::OPT_mno_global_merge)) {
710 if (A->getOption().matches(options::OPT_mno_global_merge))
711 CmdArgs.push_back("-mno-global-merge");
712 }
Daniel Dunbarb163ef72009-09-10 04:57:17 +0000713}
714
Akira Hatanaka9f360622011-09-26 21:07:52 +0000715// Get default architecture.
716static const char* getMipsArchFromCPU(StringRef CPUName) {
Akira Hatanaka592d26e2011-11-29 23:09:24 +0000717 if (CPUName == "mips32" || CPUName == "mips32r2")
Akira Hatanaka9f360622011-09-26 21:07:52 +0000718 return "mips";
719
Akira Hatanaka592d26e2011-11-29 23:09:24 +0000720 assert((CPUName == "mips64" || CPUName == "mips64r2") &&
Akira Hatanaka9f360622011-09-26 21:07:52 +0000721 "Unexpected cpu name.");
722
723 return "mips64";
724}
725
Akira Hatanakac85900f2011-11-30 19:31:38 +0000726// Check that ArchName is a known Mips architecture name.
727static bool checkMipsArchName(StringRef ArchName) {
728 return ArchName == "mips" ||
729 ArchName == "mipsel" ||
730 ArchName == "mips64" ||
731 ArchName == "mips64el";
732}
733
Akira Hatanaka9f360622011-09-26 21:07:52 +0000734// Get default target cpu.
Akira Hatanakac85900f2011-11-30 19:31:38 +0000735static const char* getMipsCPUFromArch(StringRef ArchName) {
Akira Hatanaka9f360622011-09-26 21:07:52 +0000736 if (ArchName == "mips" || ArchName == "mipsel")
Akira Hatanaka592d26e2011-11-29 23:09:24 +0000737 return "mips32";
Akira Hatanaka9f360622011-09-26 21:07:52 +0000738
Akira Hatanakac85900f2011-11-30 19:31:38 +0000739 assert((ArchName == "mips64" || ArchName == "mips64el") &&
740 "Unexpected arch name.");
741
742 return "mips64";
Akira Hatanaka9f360622011-09-26 21:07:52 +0000743}
744
745// Get default ABI.
746static const char* getMipsABIFromArch(StringRef ArchName) {
747 if (ArchName == "mips" || ArchName == "mipsel")
748 return "o32";
749
750 assert((ArchName == "mips64" || ArchName == "mips64el") &&
751 "Unexpected arch name.");
752 return "n64";
753}
754
Eric Christophered734732010-03-02 02:41:08 +0000755void Clang::AddMIPSTargetArgs(const ArgList &Args,
756 ArgStringList &CmdArgs) const {
757 const Driver &D = getToolChain().getDriver();
758
Akira Hatanaka9f360622011-09-26 21:07:52 +0000759 StringRef ArchName;
Eli Friedmand97927d2012-01-06 20:42:20 +0000760 const char *CPUName;
Akira Hatanaka9f360622011-09-26 21:07:52 +0000761
762 // Set target cpu and architecture.
763 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ)) {
764 CPUName = A->getValue(Args);
765 ArchName = getMipsArchFromCPU(CPUName);
766 }
767 else {
768 ArchName = Args.MakeArgString(getToolChain().getArchName());
Akira Hatanakac85900f2011-11-30 19:31:38 +0000769 if (!checkMipsArchName(ArchName))
770 D.Diag(diag::err_drv_invalid_arch_name) << ArchName;
771 else
772 CPUName = getMipsCPUFromArch(ArchName);
Akira Hatanaka9f360622011-09-26 21:07:52 +0000773 }
774
775 CmdArgs.push_back("-target-cpu");
776 CmdArgs.push_back(CPUName);
777
Eric Christophered734732010-03-02 02:41:08 +0000778 // Select the ABI to use.
779 const char *ABIName = 0;
Akira Hatanaka9f360622011-09-26 21:07:52 +0000780 if (Arg *A = Args.getLastArg(options::OPT_mabi_EQ))
Eric Christophered734732010-03-02 02:41:08 +0000781 ABIName = A->getValue(Args);
Akira Hatanaka9f360622011-09-26 21:07:52 +0000782 else
783 ABIName = getMipsABIFromArch(ArchName);
Eric Christophered734732010-03-02 02:41:08 +0000784
785 CmdArgs.push_back("-target-abi");
786 CmdArgs.push_back(ABIName);
787
Eric Christophered734732010-03-02 02:41:08 +0000788 // Select the float ABI as determined by -msoft-float, -mhard-float, and
Chris Lattner5f9e2722011-07-23 10:55:15 +0000789 StringRef FloatABI;
Eric Christophered734732010-03-02 02:41:08 +0000790 if (Arg *A = Args.getLastArg(options::OPT_msoft_float,
791 options::OPT_mhard_float)) {
792 if (A->getOption().matches(options::OPT_msoft_float))
793 FloatABI = "soft";
794 else if (A->getOption().matches(options::OPT_mhard_float))
795 FloatABI = "hard";
796 }
797
798 // If unspecified, choose the default based on the platform.
799 if (FloatABI.empty()) {
Benjamin Kramer71c972a2010-04-08 15:44:22 +0000800 // Assume "soft", but warn the user we are guessing.
801 FloatABI = "soft";
Chris Lattner5f9e2722011-07-23 10:55:15 +0000802 D.Diag(diag::warn_drv_assuming_mfloat_abi_is) << "soft";
Eric Christophered734732010-03-02 02:41:08 +0000803 }
804
805 if (FloatABI == "soft") {
806 // Floating point operations and argument passing are soft.
807 //
808 // FIXME: This changes CPP defines, we need -target-soft-float.
809 CmdArgs.push_back("-msoft-float");
810 } else {
811 assert(FloatABI == "hard" && "Invalid float abi!");
812 CmdArgs.push_back("-mhard-float");
813 }
814}
815
Bruno Cardoso Lopes9284d212010-11-09 17:21:19 +0000816void Clang::AddSparcTargetArgs(const ArgList &Args,
817 ArgStringList &CmdArgs) const {
818 const Driver &D = getToolChain().getDriver();
819
820 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ)) {
Bruno Cardoso Lopes9284d212010-11-09 17:21:19 +0000821 CmdArgs.push_back("-target-cpu");
Benjamin Kramera11d3092011-12-26 14:18:37 +0000822 CmdArgs.push_back(A->getValue(Args));
Bruno Cardoso Lopes9284d212010-11-09 17:21:19 +0000823 }
824
825 // Select the float ABI as determined by -msoft-float, -mhard-float, and
Chris Lattner5f9e2722011-07-23 10:55:15 +0000826 StringRef FloatABI;
Bruno Cardoso Lopes9284d212010-11-09 17:21:19 +0000827 if (Arg *A = Args.getLastArg(options::OPT_msoft_float,
828 options::OPT_mhard_float)) {
829 if (A->getOption().matches(options::OPT_msoft_float))
830 FloatABI = "soft";
831 else if (A->getOption().matches(options::OPT_mhard_float))
832 FloatABI = "hard";
833 }
834
835 // If unspecified, choose the default based on the platform.
836 if (FloatABI.empty()) {
837 switch (getToolChain().getTriple().getOS()) {
838 default:
839 // Assume "soft", but warn the user we are guessing.
840 FloatABI = "soft";
Chris Lattner5f9e2722011-07-23 10:55:15 +0000841 D.Diag(diag::warn_drv_assuming_mfloat_abi_is) << "soft";
Bruno Cardoso Lopes9284d212010-11-09 17:21:19 +0000842 break;
843 }
844 }
845
846 if (FloatABI == "soft") {
847 // Floating point operations and argument passing are soft.
848 //
849 // FIXME: This changes CPP defines, we need -target-soft-float.
850 CmdArgs.push_back("-msoft-float");
Bruno Cardoso Lopes9284d212010-11-09 17:21:19 +0000851 CmdArgs.push_back("-target-feature");
852 CmdArgs.push_back("+soft-float");
853 } else {
854 assert(FloatABI == "hard" && "Invalid float abi!");
855 CmdArgs.push_back("-mhard-float");
856 }
857}
858
Daniel Dunbar6acda162009-09-09 22:33:08 +0000859void Clang::AddX86TargetArgs(const ArgList &Args,
860 ArgStringList &CmdArgs) const {
Daniel Dunbare6ad3f92009-09-10 22:59:57 +0000861 if (!Args.hasFlag(options::OPT_mred_zone,
862 options::OPT_mno_red_zone,
863 true) ||
864 Args.hasArg(options::OPT_mkernel) ||
865 Args.hasArg(options::OPT_fapple_kext))
Daniel Dunbar66861e02009-11-20 22:21:36 +0000866 CmdArgs.push_back("-disable-red-zone");
Daniel Dunbare6ad3f92009-09-10 22:59:57 +0000867
Daniel Dunbare6ad3f92009-09-10 22:59:57 +0000868 if (Args.hasFlag(options::OPT_msoft_float,
869 options::OPT_mno_soft_float,
870 false))
Daniel Dunbar66861e02009-11-20 22:21:36 +0000871 CmdArgs.push_back("-no-implicit-float");
Daniel Dunbare6ad3f92009-09-10 22:59:57 +0000872
Daniel Dunbarf86fedd2009-11-14 22:04:54 +0000873 const char *CPUName = 0;
Daniel Dunbar6acda162009-09-09 22:33:08 +0000874 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ)) {
Chris Lattner5f9e2722011-07-23 10:55:15 +0000875 if (StringRef(A->getValue(Args)) == "native") {
Daniel Dunbarf86fedd2009-11-14 22:04:54 +0000876 // FIXME: Reject attempts to use -march=native unless the target matches
877 // the host.
878 //
879 // FIXME: We should also incorporate the detected target features for use
880 // with -native.
881 std::string CPU = llvm::sys::getHostCPUName();
882 if (!CPU.empty())
883 CPUName = Args.MakeArgString(CPU);
884 } else
885 CPUName = A->getValue(Args);
886 }
Daniel Dunbar6acda162009-09-09 22:33:08 +0000887
Daniel Dunbarf86fedd2009-11-14 22:04:54 +0000888 // Select the default CPU if none was given (or detection failed).
889 if (!CPUName) {
Daniel Dunbar6acda162009-09-09 22:33:08 +0000890 // FIXME: Need target hooks.
Bob Wilson905c45f2011-10-14 05:03:44 +0000891 if (getToolChain().getTriple().isOSDarwin()) {
Daniel Dunbar951733d2011-05-31 15:58:55 +0000892 if (getToolChain().getArch() == llvm::Triple::x86_64)
Daniel Dunbarf86fedd2009-11-14 22:04:54 +0000893 CPUName = "core2";
Daniel Dunbar951733d2011-05-31 15:58:55 +0000894 else if (getToolChain().getArch() == llvm::Triple::x86)
Daniel Dunbarf86fedd2009-11-14 22:04:54 +0000895 CPUName = "yonah";
Chris Lattner86ed3a32010-04-11 19:29:39 +0000896 } else if (getToolChain().getOS().startswith("haiku")) {
Daniel Dunbar951733d2011-05-31 15:58:55 +0000897 if (getToolChain().getArch() == llvm::Triple::x86_64)
Chris Lattner86ed3a32010-04-11 19:29:39 +0000898 CPUName = "x86-64";
Daniel Dunbar951733d2011-05-31 15:58:55 +0000899 else if (getToolChain().getArch() == llvm::Triple::x86)
Chris Lattner86ed3a32010-04-11 19:29:39 +0000900 CPUName = "i586";
Daniel Dunbar95c04572010-08-01 23:13:54 +0000901 } else if (getToolChain().getOS().startswith("openbsd")) {
Daniel Dunbar951733d2011-05-31 15:58:55 +0000902 if (getToolChain().getArch() == llvm::Triple::x86_64)
Daniel Dunbar95c04572010-08-01 23:13:54 +0000903 CPUName = "x86-64";
Daniel Dunbar951733d2011-05-31 15:58:55 +0000904 else if (getToolChain().getArch() == llvm::Triple::x86)
Daniel Dunbar95c04572010-08-01 23:13:54 +0000905 CPUName = "i486";
Roman Divacky451f8ca2011-03-01 18:11:37 +0000906 } else if (getToolChain().getOS().startswith("freebsd")) {
Daniel Dunbar951733d2011-05-31 15:58:55 +0000907 if (getToolChain().getArch() == llvm::Triple::x86_64)
Roman Divacky451f8ca2011-03-01 18:11:37 +0000908 CPUName = "x86-64";
Daniel Dunbar951733d2011-05-31 15:58:55 +0000909 else if (getToolChain().getArch() == llvm::Triple::x86)
Roman Divacky451f8ca2011-03-01 18:11:37 +0000910 CPUName = "i486";
Benjamin Kramer8e50a962011-02-02 18:59:27 +0000911 } else if (getToolChain().getOS().startswith("netbsd")) {
Daniel Dunbar951733d2011-05-31 15:58:55 +0000912 if (getToolChain().getArch() == llvm::Triple::x86_64)
Benjamin Kramer8e50a962011-02-02 18:59:27 +0000913 CPUName = "x86-64";
Daniel Dunbar951733d2011-05-31 15:58:55 +0000914 else if (getToolChain().getArch() == llvm::Triple::x86)
Benjamin Kramer8e50a962011-02-02 18:59:27 +0000915 CPUName = "i486";
Daniel Dunbar6acda162009-09-09 22:33:08 +0000916 } else {
Daniel Dunbar951733d2011-05-31 15:58:55 +0000917 if (getToolChain().getArch() == llvm::Triple::x86_64)
Daniel Dunbarf86fedd2009-11-14 22:04:54 +0000918 CPUName = "x86-64";
Daniel Dunbar951733d2011-05-31 15:58:55 +0000919 else if (getToolChain().getArch() == llvm::Triple::x86)
Daniel Dunbarf86fedd2009-11-14 22:04:54 +0000920 CPUName = "pentium4";
Daniel Dunbar6acda162009-09-09 22:33:08 +0000921 }
922 }
923
Daniel Dunbarf86fedd2009-11-14 22:04:54 +0000924 if (CPUName) {
Daniel Dunbar38b48af2009-12-18 06:30:12 +0000925 CmdArgs.push_back("-target-cpu");
Daniel Dunbarf86fedd2009-11-14 22:04:54 +0000926 CmdArgs.push_back(CPUName);
927 }
928
Eli Friedmand18eeca2011-07-02 00:34:19 +0000929 // The required algorithm here is slightly strange: the options are applied
930 // in order (so -mno-sse -msse2 disables SSE3), but any option that gets
931 // directly overridden later is ignored (so "-mno-sse -msse2 -mno-sse2 -msse"
932 // is equivalent to "-mno-sse2 -msse"). The -cc1 handling deals with the
933 // former correctly, but not the latter; handle directly-overridden
934 // attributes here.
935 llvm::StringMap<unsigned> PrevFeature;
936 std::vector<const char*> Features;
Daniel Dunbarcdd96862009-11-25 11:53:23 +0000937 for (arg_iterator it = Args.filtered_begin(options::OPT_m_x86_Features_Group),
938 ie = Args.filtered_end(); it != ie; ++it) {
Chris Lattner5f9e2722011-07-23 10:55:15 +0000939 StringRef Name = (*it)->getOption().getName();
Daniel Dunbar7e4953e2010-06-11 22:00:13 +0000940 (*it)->claim();
Daniel Dunbar6acda162009-09-09 22:33:08 +0000941
Daniel Dunbarcdd96862009-11-25 11:53:23 +0000942 // Skip over "-m".
943 assert(Name.startswith("-m") && "Invalid feature name.");
944 Name = Name.substr(2);
Daniel Dunbar6acda162009-09-09 22:33:08 +0000945
Daniel Dunbarcdd96862009-11-25 11:53:23 +0000946 bool IsNegative = Name.startswith("no-");
947 if (IsNegative)
948 Name = Name.substr(3);
Daniel Dunbar6acda162009-09-09 22:33:08 +0000949
Eli Friedmand18eeca2011-07-02 00:34:19 +0000950 unsigned& Prev = PrevFeature[Name];
951 if (Prev)
952 Features[Prev - 1] = 0;
953 Prev = Features.size() + 1;
954 Features.push_back(Args.MakeArgString((IsNegative ? "-" : "+") + Name));
955 }
956 for (unsigned i = 0; i < Features.size(); i++) {
957 if (Features[i]) {
958 CmdArgs.push_back("-target-feature");
959 CmdArgs.push_back(Features[i]);
960 }
Daniel Dunbar6acda162009-09-09 22:33:08 +0000961 }
962}
963
Tony Linthicum96319392011-12-12 21:14:55 +0000964static Arg* getLastHexagonArchArg (const ArgList &Args)
965{
966 Arg * A = NULL;
967
Sebastian Pop43115d42012-01-13 20:37:10 +0000968 for (ArgList::const_iterator it = Args.begin(), ie = Args.end();
969 it != ie; ++it) {
970 if ((*it)->getOption().matches(options::OPT_march_EQ) ||
Tony Linthicum96319392011-12-12 21:14:55 +0000971 (*it)->getOption().matches(options::OPT_mcpu_EQ)) {
972 A = *it;
973 A->claim();
974 }
Sebastian Pop43115d42012-01-13 20:37:10 +0000975 else if ((*it)->getOption().matches(options::OPT_m_Joined)){
976 StringRef Value = (*it)->getValue(Args,0);
977 if (Value.startswith("v")) {
978 A = *it;
979 A->claim();
980 }
981 }
Tony Linthicum96319392011-12-12 21:14:55 +0000982 }
983 return A;
984}
985
Sebastian Pop43115d42012-01-13 20:37:10 +0000986static StringRef getHexagonTargetCPU(const ArgList &Args)
Tony Linthicum96319392011-12-12 21:14:55 +0000987{
988 Arg *A;
989 llvm::StringRef WhichHexagon;
990
Sebastian Pop43115d42012-01-13 20:37:10 +0000991 // Select the default CPU (v4) if none was given or detection failed.
Tony Linthicum96319392011-12-12 21:14:55 +0000992 if ((A = getLastHexagonArchArg (Args))) {
Sebastian Pop43115d42012-01-13 20:37:10 +0000993 WhichHexagon = A->getValue(Args);
994 if (WhichHexagon == "")
995 return "v4";
996 else
997 return WhichHexagon;
Tony Linthicum96319392011-12-12 21:14:55 +0000998 }
Sebastian Pop43115d42012-01-13 20:37:10 +0000999 else
1000 return "v4";
Tony Linthicum96319392011-12-12 21:14:55 +00001001}
1002
1003void Clang::AddHexagonTargetArgs(const ArgList &Args,
1004 ArgStringList &CmdArgs) const {
1005 llvm::Triple Triple = getToolChain().getTriple();
1006
1007 CmdArgs.push_back("-target-cpu");
Sebastian Pop43115d42012-01-13 20:37:10 +00001008 CmdArgs.push_back(Args.MakeArgString("hexagon" + getHexagonTargetCPU(Args)));
Tony Linthicum96319392011-12-12 21:14:55 +00001009 CmdArgs.push_back("-fno-signed-char");
1010 CmdArgs.push_back("-nobuiltininc");
1011
1012 if (Args.hasArg(options::OPT_mqdsp6_compat))
1013 CmdArgs.push_back("-mqdsp6-compat");
1014
1015 if (Arg *A = Args.getLastArg(options::OPT_G,
1016 options::OPT_msmall_data_threshold_EQ)) {
1017 std::string SmallDataThreshold="-small-data-threshold=";
1018 SmallDataThreshold += A->getValue(Args);
1019 CmdArgs.push_back ("-mllvm");
1020 CmdArgs.push_back(Args.MakeArgString(SmallDataThreshold));
1021 A->claim();
1022 }
1023
1024 CmdArgs.push_back ("-mllvm");
1025 CmdArgs.push_back ("-machine-sink-split=0");
1026}
1027
Eric Christopher88b7cf02011-08-19 00:30:14 +00001028static bool
John McCalld71315c2011-06-22 00:53:57 +00001029shouldUseExceptionTablesForObjCExceptions(unsigned objcABIVersion,
Anders Carlsson525544d2011-02-28 00:44:51 +00001030 const llvm::Triple &Triple) {
1031 // We use the zero-cost exception tables for Objective-C if the non-fragile
1032 // ABI is enabled or when compiling for x86_64 and ARM on Snow Leopard and
1033 // later.
1034
John McCalld71315c2011-06-22 00:53:57 +00001035 if (objcABIVersion >= 2)
Anders Carlsson525544d2011-02-28 00:44:51 +00001036 return true;
1037
Bob Wilson905c45f2011-10-14 05:03:44 +00001038 if (!Triple.isOSDarwin())
Anders Carlsson525544d2011-02-28 00:44:51 +00001039 return false;
1040
Eric Christopheraa7333c2011-07-02 00:20:22 +00001041 return (!Triple.isMacOSXVersionLT(10,5) &&
Anders Carlsson525544d2011-02-28 00:44:51 +00001042 (Triple.getArch() == llvm::Triple::x86_64 ||
Eric Christopher88b7cf02011-08-19 00:30:14 +00001043 Triple.getArch() == llvm::Triple::arm));
Anders Carlsson525544d2011-02-28 00:44:51 +00001044}
1045
Anders Carlsson15348ae2011-02-28 02:27:16 +00001046/// addExceptionArgs - Adds exception related arguments to the driver command
1047/// arguments. There's a master flag, -fexceptions and also language specific
1048/// flags to enable/disable C++ and Objective-C exceptions.
1049/// This makes it possible to for example disable C++ exceptions but enable
1050/// Objective-C exceptions.
1051static void addExceptionArgs(const ArgList &Args, types::ID InputType,
1052 const llvm::Triple &Triple,
1053 bool KernelOrKext, bool IsRewriter,
John McCalld71315c2011-06-22 00:53:57 +00001054 unsigned objcABIVersion,
Anders Carlsson15348ae2011-02-28 02:27:16 +00001055 ArgStringList &CmdArgs) {
1056 if (KernelOrKext)
1057 return;
1058
1059 // Exceptions are enabled by default.
1060 bool ExceptionsEnabled = true;
1061
1062 // This keeps track of whether exceptions were explicitly turned on or off.
1063 bool DidHaveExplicitExceptionFlag = false;
1064
Rafael Espindolaf759df02009-10-01 13:33:33 +00001065 if (Arg *A = Args.getLastArg(options::OPT_fexceptions,
1066 options::OPT_fno_exceptions)) {
1067 if (A->getOption().matches(options::OPT_fexceptions))
Anders Carlsson15348ae2011-02-28 02:27:16 +00001068 ExceptionsEnabled = true;
Eric Christopher88b7cf02011-08-19 00:30:14 +00001069 else
Anders Carlsson15348ae2011-02-28 02:27:16 +00001070 ExceptionsEnabled = false;
1071
1072 DidHaveExplicitExceptionFlag = true;
Rafael Espindolaf759df02009-10-01 13:33:33 +00001073 }
Daniel Dunbar1a2cd4f2010-09-14 23:12:31 +00001074
Anders Carlsson15348ae2011-02-28 02:27:16 +00001075 bool ShouldUseExceptionTables = false;
Fariborz Jahanian85caf032009-10-01 20:30:46 +00001076
Anders Carlsson15348ae2011-02-28 02:27:16 +00001077 // Exception tables and cleanups can be enabled with -fexceptions even if the
1078 // language itself doesn't support exceptions.
1079 if (ExceptionsEnabled && DidHaveExplicitExceptionFlag)
1080 ShouldUseExceptionTables = true;
Daniel Dunbar1a2cd4f2010-09-14 23:12:31 +00001081
Daniel Dunbard47ea692011-03-17 23:28:31 +00001082 // Obj-C exceptions are enabled by default, regardless of -fexceptions. This
1083 // is not necessarily sensible, but follows GCC.
1084 if (types::isObjC(InputType) &&
Eric Christopher88b7cf02011-08-19 00:30:14 +00001085 Args.hasFlag(options::OPT_fobjc_exceptions,
Daniel Dunbard47ea692011-03-17 23:28:31 +00001086 options::OPT_fno_objc_exceptions,
1087 true)) {
1088 CmdArgs.push_back("-fobjc-exceptions");
Anders Carlsson15348ae2011-02-28 02:27:16 +00001089
Eric Christopher88b7cf02011-08-19 00:30:14 +00001090 ShouldUseExceptionTables |=
John McCalld71315c2011-06-22 00:53:57 +00001091 shouldUseExceptionTablesForObjCExceptions(objcABIVersion, Triple);
Anders Carlsson15348ae2011-02-28 02:27:16 +00001092 }
1093
1094 if (types::isCXX(InputType)) {
1095 bool CXXExceptionsEnabled = ExceptionsEnabled;
1096
Eric Christopher88b7cf02011-08-19 00:30:14 +00001097 if (Arg *A = Args.getLastArg(options::OPT_fcxx_exceptions,
1098 options::OPT_fno_cxx_exceptions,
Anders Carlsson15348ae2011-02-28 02:27:16 +00001099 options::OPT_fexceptions,
1100 options::OPT_fno_exceptions)) {
1101 if (A->getOption().matches(options::OPT_fcxx_exceptions))
1102 CXXExceptionsEnabled = true;
Chandler Carruth43f220f2011-02-28 07:25:18 +00001103 else if (A->getOption().matches(options::OPT_fno_cxx_exceptions))
Anders Carlsson15348ae2011-02-28 02:27:16 +00001104 CXXExceptionsEnabled = false;
1105 }
1106
1107 if (CXXExceptionsEnabled) {
1108 CmdArgs.push_back("-fcxx-exceptions");
1109
1110 ShouldUseExceptionTables = true;
1111 }
1112 }
1113
1114 if (ShouldUseExceptionTables)
1115 CmdArgs.push_back("-fexceptions");
Rafael Espindolaf759df02009-10-01 13:33:33 +00001116}
1117
Rafael Espindola61b1efe2011-05-02 17:43:32 +00001118static bool ShouldDisableCFI(const ArgList &Args,
1119 const ToolChain &TC) {
Bob Wilson905c45f2011-10-14 05:03:44 +00001120 if (TC.getTriple().isOSDarwin()) {
Rafael Espindola97f6abb2011-05-17 16:26:17 +00001121 // The native darwin assembler doesn't support cfi directives, so
Rafael Espindolacb773922011-05-17 19:06:58 +00001122 // we disable them if we think the .s file will be passed to it.
Rafael Espindola97f6abb2011-05-17 16:26:17 +00001123 bool UseIntegratedAs = Args.hasFlag(options::OPT_integrated_as,
1124 options::OPT_no_integrated_as,
Bob Wilson1a1764b2011-10-30 00:20:28 +00001125 TC.IsIntegratedAssemblerDefault());
Rafael Espindola97f6abb2011-05-17 16:26:17 +00001126 bool UseCFI = Args.hasFlag(options::OPT_fdwarf2_cfi_asm,
1127 options::OPT_fno_dwarf2_cfi_asm,
1128 UseIntegratedAs);
1129 return !UseCFI;
1130 }
1131
1132 // For now we assume that every other assembler support CFI.
1133 return false;
Rafael Espindola61b1efe2011-05-02 17:43:32 +00001134}
1135
Nick Lewyckyea523d72011-10-17 23:05:52 +00001136static bool ShouldDisableDwarfDirectory(const ArgList &Args,
1137 const ToolChain &TC) {
1138 bool IsIADefault = TC.IsIntegratedAssemblerDefault();
1139 bool UseIntegratedAs = Args.hasFlag(options::OPT_integrated_as,
1140 options::OPT_no_integrated_as,
1141 IsIADefault);
1142 bool UseDwarfDirectory = Args.hasFlag(options::OPT_fdwarf_directory_asm,
1143 options::OPT_fno_dwarf_directory_asm,
1144 UseIntegratedAs);
1145 return !UseDwarfDirectory;
1146}
1147
Joerg Sonnenberger359cf922011-05-06 14:35:16 +00001148/// \brief Check whether the given input tree contains any compilation actions.
1149static bool ContainsCompileAction(const Action *A) {
Chris Lattner5f9e2722011-07-23 10:55:15 +00001150 if (isa<CompileJobAction>(A))
Joerg Sonnenberger359cf922011-05-06 14:35:16 +00001151 return true;
1152
1153 for (Action::const_iterator it = A->begin(), ie = A->end(); it != ie; ++it)
1154 if (ContainsCompileAction(*it))
1155 return true;
1156
1157 return false;
1158}
1159
1160/// \brief Check if -relax-all should be passed to the internal assembler.
1161/// This is done by default when compiling non-assembler source with -O0.
1162static bool UseRelaxAll(Compilation &C, const ArgList &Args) {
1163 bool RelaxDefault = true;
1164
1165 if (Arg *A = Args.getLastArg(options::OPT_O_Group))
1166 RelaxDefault = A->getOption().matches(options::OPT_O0);
1167
1168 if (RelaxDefault) {
1169 RelaxDefault = false;
1170 for (ActionList::const_iterator it = C.getActions().begin(),
1171 ie = C.getActions().end(); it != ie; ++it) {
1172 if (ContainsCompileAction(*it)) {
1173 RelaxDefault = true;
1174 break;
1175 }
1176 }
1177 }
1178
1179 return Args.hasFlag(options::OPT_mrelax_all, options::OPT_mno_relax_all,
1180 RelaxDefault);
1181}
1182
Kostya Serebryanydff466c2011-11-30 01:39:16 +00001183/// If AddressSanitizer is enabled, add appropriate linker flags (Linux).
1184/// This needs to be called before we add the C run-time (malloc, etc).
1185static void addAsanRTLinux(const ToolChain &TC, const ArgList &Args,
Kostya Serebryany7b5f1012011-12-06 19:18:44 +00001186 ArgStringList &CmdArgs) {
Kostya Serebryanydff466c2011-11-30 01:39:16 +00001187 // Add asan linker flags when linking an executable, but not a shared object.
1188 if (Args.hasArg(options::OPT_shared) ||
1189 !Args.hasFlag(options::OPT_faddress_sanitizer,
1190 options::OPT_fno_address_sanitizer, false))
1191 return;
Daniel Dunbar8cd0d252011-12-07 23:22:17 +00001192
1193 // LibAsan is "libclang_rt.asan-<ArchName>.a" in the Linux library resource
1194 // directory.
Dylan Noblesmithf7ccbad2012-02-05 02:13:05 +00001195 SmallString<128> LibAsan(TC.getDriver().ResourceDir);
Daniel Dunbar8cd0d252011-12-07 23:22:17 +00001196 llvm::sys::path::append(LibAsan, "lib", "linux",
1197 (Twine("libclang_rt.asan-") +
1198 TC.getArchName() + ".a"));
Kostya Serebryanydff466c2011-11-30 01:39:16 +00001199 CmdArgs.push_back(Args.MakeArgString(LibAsan));
1200 CmdArgs.push_back("-lpthread");
1201 CmdArgs.push_back("-ldl");
1202 CmdArgs.push_back("-export-dynamic");
Kostya Serebryanydff466c2011-11-30 01:39:16 +00001203}
1204
Rafael Espindola6af27ec2011-12-14 21:02:23 +00001205static bool shouldUseFramePointer(const ArgList &Args,
1206 const llvm::Triple &Triple) {
1207 if (Arg *A = Args.getLastArg(options::OPT_fno_omit_frame_pointer,
1208 options::OPT_fomit_frame_pointer))
1209 return A->getOption().matches(options::OPT_fno_omit_frame_pointer);
1210
Rafael Espindolaa2a17892011-12-14 21:50:24 +00001211 // Don't use a frame pointer on linux x86 and x86_64 if optimizing.
Rafael Espindola6af27ec2011-12-14 21:02:23 +00001212 if ((Triple.getArch() == llvm::Triple::x86_64 ||
1213 Triple.getArch() == llvm::Triple::x86) &&
1214 Triple.getOS() == llvm::Triple::Linux) {
1215 if (Arg *A = Args.getLastArg(options::OPT_O_Group))
1216 if (!A->getOption().matches(options::OPT_O0))
1217 return false;
1218 }
1219
1220 return true;
1221}
1222
Daniel Dunbar47ac7d22009-03-18 06:00:36 +00001223void Clang::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar871adcf2009-03-18 07:06:02 +00001224 const InputInfo &Output,
Daniel Dunbar62cf6012009-03-18 06:07:59 +00001225 const InputInfoList &Inputs,
Daniel Dunbar1d460332009-03-18 10:01:51 +00001226 const ArgList &Args,
Daniel Dunbar47ac7d22009-03-18 06:00:36 +00001227 const char *LinkingOutput) const {
Daniel Dunbar0a80ba72010-03-20 04:52:14 +00001228 bool KernelOrKext = Args.hasArg(options::OPT_mkernel,
1229 options::OPT_fapple_kext);
Daniel Dunbaree788e72009-12-21 18:54:17 +00001230 const Driver &D = getToolChain().getDriver();
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00001231 ArgStringList CmdArgs;
1232
Daniel Dunbar077ba6a2009-03-31 20:53:55 +00001233 assert(Inputs.size() == 1 && "Unable to handle multiple inputs.");
1234
Daniel Dunbar8ff5b282009-12-11 23:00:49 +00001235 // Invoke ourselves in -cc1 mode.
1236 //
1237 // FIXME: Implement custom jobs for internal actions.
1238 CmdArgs.push_back("-cc1");
1239
Daniel Dunbardd4fe002009-10-30 18:12:20 +00001240 // Add the "effective" target triple.
Daniel Dunbaraf07f932009-03-31 17:35:15 +00001241 CmdArgs.push_back("-triple");
Daniel Dunbar00577ad2010-08-23 22:35:37 +00001242 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
Daniel Dunbardd4fe002009-10-30 18:12:20 +00001243 CmdArgs.push_back(Args.MakeArgString(TripleStr));
Daniel Dunbar728a5122009-09-10 06:49:20 +00001244
Daniel Dunbardd4fe002009-10-30 18:12:20 +00001245 // Select the appropriate action.
Daniel Dunbar5314e442010-07-19 19:44:22 +00001246 bool IsRewriter = false;
Daniel Dunbar1d460332009-03-18 10:01:51 +00001247 if (isa<AnalyzeJobAction>(JA)) {
1248 assert(JA.getType() == types::TY_Plist && "Invalid output type.");
1249 CmdArgs.push_back("-analyze");
1250 } else if (isa<PreprocessJobAction>(JA)) {
Daniel Dunbarcd8e4c42009-03-30 06:36:42 +00001251 if (Output.getType() == types::TY_Dependencies)
1252 CmdArgs.push_back("-Eonly");
1253 else
1254 CmdArgs.push_back("-E");
Daniel Dunbar8767cbc2010-02-03 03:07:56 +00001255 } else if (isa<AssembleJobAction>(JA)) {
1256 CmdArgs.push_back("-emit-obj");
Daniel Dunbar99298002010-05-27 06:18:05 +00001257
Joerg Sonnenberger359cf922011-05-06 14:35:16 +00001258 if (UseRelaxAll(C, Args))
Daniel Dunbar99298002010-05-27 06:18:05 +00001259 CmdArgs.push_back("-mrelax-all");
Daniel Dunbarca0e0542010-08-24 16:47:49 +00001260
Daniel Dunbarfcec10b2010-10-18 22:36:15 +00001261 // When using an integrated assembler, translate -Wa, and -Xassembler
1262 // options.
1263 for (arg_iterator it = Args.filtered_begin(options::OPT_Wa_COMMA,
1264 options::OPT_Xassembler),
1265 ie = Args.filtered_end(); it != ie; ++it) {
1266 const Arg *A = *it;
1267 A->claim();
1268
1269 for (unsigned i = 0, e = A->getNumValues(); i != e; ++i) {
Chris Lattner5f9e2722011-07-23 10:55:15 +00001270 StringRef Value = A->getValue(Args, i);
Daniel Dunbarfcec10b2010-10-18 22:36:15 +00001271
1272 if (Value == "-force_cpusubtype_ALL") {
1273 // Do nothing, this is the default and we don't support anything else.
Daniel Dunbarb14eed02010-10-28 20:36:23 +00001274 } else if (Value == "-L") {
Daniel Dunbar96932322011-03-28 22:49:28 +00001275 CmdArgs.push_back("-msave-temp-labels");
Joerg Sonnenberger46a49392011-05-19 20:46:39 +00001276 } else if (Value == "--fatal-warnings") {
Joerg Sonnenbergerd7933502011-05-19 18:42:29 +00001277 CmdArgs.push_back("-mllvm");
1278 CmdArgs.push_back("-fatal-assembler-warnings");
Nick Lewyckyc3b90142011-06-21 00:14:18 +00001279 } else if (Value == "--noexecstack") {
1280 CmdArgs.push_back("-mnoexecstack");
Daniel Dunbarfcec10b2010-10-18 22:36:15 +00001281 } else {
Chris Lattner5f9e2722011-07-23 10:55:15 +00001282 D.Diag(diag::err_drv_unsupported_option_argument)
Daniel Dunbarfcec10b2010-10-18 22:36:15 +00001283 << A->getOption().getName() << Value;
1284 }
1285 }
1286 }
Daniel Dunbard02bba82010-11-19 16:23:35 +00001287
1288 // Also ignore explicit -force_cpusubtype_ALL option.
1289 (void) Args.hasArg(options::OPT_force__cpusubtype__ALL);
Daniel Dunbar1d460332009-03-18 10:01:51 +00001290 } else if (isa<PrecompileJobAction>(JA)) {
Argyrios Kyrtzidise5c35372010-08-11 23:27:58 +00001291 // Use PCH if the user requested it.
Daniel Dunbar0ebd9322009-10-15 20:02:44 +00001292 bool UsePCH = D.CCCUsePCH;
Daniel Dunbar0ebd9322009-10-15 20:02:44 +00001293
1294 if (UsePCH)
Douglas Gregordf91ef32009-04-18 00:34:01 +00001295 CmdArgs.push_back("-emit-pch");
1296 else
1297 CmdArgs.push_back("-emit-pth");
Daniel Dunbar1d460332009-03-18 10:01:51 +00001298 } else {
1299 assert(isa<CompileJobAction>(JA) && "Invalid action for clang tool.");
Daniel Dunbarc21c4852009-04-08 23:54:23 +00001300
Daniel Dunbar1d460332009-03-18 10:01:51 +00001301 if (JA.getType() == types::TY_Nothing) {
1302 CmdArgs.push_back("-fsyntax-only");
Daniel Dunbar6c6424b2010-06-07 23:28:45 +00001303 } else if (JA.getType() == types::TY_LLVM_IR ||
1304 JA.getType() == types::TY_LTO_IR) {
Daniel Dunbar1d460332009-03-18 10:01:51 +00001305 CmdArgs.push_back("-emit-llvm");
Daniel Dunbar6c6424b2010-06-07 23:28:45 +00001306 } else if (JA.getType() == types::TY_LLVM_BC ||
1307 JA.getType() == types::TY_LTO_BC) {
Daniel Dunbar1d460332009-03-18 10:01:51 +00001308 CmdArgs.push_back("-emit-llvm-bc");
1309 } else if (JA.getType() == types::TY_PP_Asm) {
Daniel Dunbare3b8d072009-09-17 00:47:53 +00001310 CmdArgs.push_back("-S");
Daniel Dunbar5915fbf2009-09-01 16:57:46 +00001311 } else if (JA.getType() == types::TY_AST) {
1312 CmdArgs.push_back("-emit-pch");
Daniel Dunbar64952502010-02-11 03:16:21 +00001313 } else if (JA.getType() == types::TY_RewrittenObjC) {
1314 CmdArgs.push_back("-rewrite-objc");
Daniel Dunbar5314e442010-07-19 19:44:22 +00001315 IsRewriter = true;
Daniel Dunbar64952502010-02-11 03:16:21 +00001316 } else {
1317 assert(JA.getType() == types::TY_PP_Asm &&
1318 "Unexpected output type!");
Daniel Dunbar1d460332009-03-18 10:01:51 +00001319 }
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00001320 }
1321
Daniel Dunbar1d460332009-03-18 10:01:51 +00001322 // The make clang go fast button.
1323 CmdArgs.push_back("-disable-free");
1324
John McCallb689afb2010-02-13 03:50:24 +00001325 // Disable the verification pass in -asserts builds.
1326#ifdef NDEBUG
1327 CmdArgs.push_back("-disable-llvm-verifier");
1328#endif
1329
Daniel Dunbarc9abc042009-04-08 05:11:16 +00001330 // Set the main file name, so that debug info works even with
1331 // -save-temps.
1332 CmdArgs.push_back("-main-file-name");
1333 CmdArgs.push_back(darwin::CC1::getBaseInputName(Args, Inputs));
1334
Daniel Dunbar3bbc7532009-04-08 18:03:55 +00001335 // Some flags which affect the language (via preprocessor
1336 // defines). See darwin::CC1::AddCPPArgs.
1337 if (Args.hasArg(options::OPT_static))
1338 CmdArgs.push_back("-static-define");
1339
Daniel Dunbar1d460332009-03-18 10:01:51 +00001340 if (isa<AnalyzeJobAction>(JA)) {
Ted Kremenekb8bb3e72009-09-25 05:55:59 +00001341 // Enable region store model by default.
1342 CmdArgs.push_back("-analyzer-store=region");
1343
Ted Kremenekb40d06d2009-12-07 22:26:14 +00001344 // Treat blocks as analysis entry points.
1345 CmdArgs.push_back("-analyzer-opt-analyze-nested-blocks");
1346
Ted Kremenek51885072011-03-24 00:28:47 +00001347 CmdArgs.push_back("-analyzer-eagerly-assume");
1348
Anna Zaks278f1f82012-03-01 22:37:46 +00001349 CmdArgs.push_back("-analyzer-inline-call");
1350
Daniel Dunbar1d460332009-03-18 10:01:51 +00001351 // Add default argument set.
Daniel Dunbard8fc0f22009-05-22 00:38:15 +00001352 if (!Args.hasArg(options::OPT__analyzer_no_default_checks)) {
Argyrios Kyrtzidis027a6ab2011-02-15 07:42:33 +00001353 CmdArgs.push_back("-analyzer-checker=core");
Ted Kremenek51885072011-03-24 00:28:47 +00001354
Argyrios Kyrtzidis027a6ab2011-02-15 07:42:33 +00001355 if (getToolChain().getTriple().getOS() != llvm::Triple::Win32)
1356 CmdArgs.push_back("-analyzer-checker=unix");
Ted Kremenek51885072011-03-24 00:28:47 +00001357
Argyrios Kyrtzidis027a6ab2011-02-15 07:42:33 +00001358 if (getToolChain().getTriple().getVendor() == llvm::Triple::Apple)
Ted Kremenek51885072011-03-24 00:28:47 +00001359 CmdArgs.push_back("-analyzer-checker=osx");
Ted Kremeneka8180e52012-01-20 06:00:17 +00001360
1361 CmdArgs.push_back("-analyzer-checker=deadcode");
Ted Kremenek8dc05062012-01-26 02:27:38 +00001362
1363 // Enable the following experimental checkers for testing.
Ted Kremenek8dc05062012-01-26 02:27:38 +00001364 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.UncheckedReturn");
1365 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.getpw");
1366 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.gets");
1367 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.mktemp");
1368 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.mkstemp");
1369 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.vfork");
Daniel Dunbard8fc0f22009-05-22 00:38:15 +00001370 }
Daniel Dunbarc21c4852009-04-08 23:54:23 +00001371
Daniel Dunbard8fc0f22009-05-22 00:38:15 +00001372 // Set the output format. The default is plist, for (lame) historical
1373 // reasons.
1374 CmdArgs.push_back("-analyzer-output");
1375 if (Arg *A = Args.getLastArg(options::OPT__analyzer_output))
1376 CmdArgs.push_back(A->getValue(Args));
1377 else
1378 CmdArgs.push_back("plist");
Daniel Dunbar1d460332009-03-18 10:01:51 +00001379
Ted Kremenek0647a7b2010-03-22 22:32:05 +00001380 // Disable the presentation of standard compiler warnings when
1381 // using --analyze. We only want to show static analyzer diagnostics
1382 // or frontend errors.
1383 CmdArgs.push_back("-w");
1384
Daniel Dunbar1d460332009-03-18 10:01:51 +00001385 // Add -Xanalyzer arguments when running as analyzer.
1386 Args.AddAllArgValues(CmdArgs, options::OPT_Xanalyzer);
Mike Stump1eb44332009-09-09 15:08:12 +00001387 }
1388
Daniel Dunbare2fd6642009-09-10 01:21:12 +00001389 CheckCodeGenerationOptions(D, Args);
1390
Daniel Dunbarbc85be82009-04-29 18:32:25 +00001391 // Perform argument translation for LLVM backend. This
1392 // takes some care in reconciling with llvm-gcc. The
1393 // issue is that llvm-gcc translates these options based on
1394 // the values in cc1, whereas we are processing based on
1395 // the driver arguments.
Daniel Dunbarc21c4852009-04-08 23:54:23 +00001396
Daniel Dunbarbc85be82009-04-29 18:32:25 +00001397 // This comes from the default translation the driver + cc1
1398 // would do to enable flag_pic.
1399 //
1400 // FIXME: Centralize this code.
1401 bool PICEnabled = (Args.hasArg(options::OPT_fPIC) ||
1402 Args.hasArg(options::OPT_fpic) ||
1403 Args.hasArg(options::OPT_fPIE) ||
1404 Args.hasArg(options::OPT_fpie));
1405 bool PICDisabled = (Args.hasArg(options::OPT_mkernel) ||
1406 Args.hasArg(options::OPT_static));
1407 const char *Model = getToolChain().GetForcedPicModel();
1408 if (!Model) {
1409 if (Args.hasArg(options::OPT_mdynamic_no_pic))
1410 Model = "dynamic-no-pic";
1411 else if (PICDisabled)
1412 Model = "static";
1413 else if (PICEnabled)
1414 Model = "pic";
Daniel Dunbar1d460332009-03-18 10:01:51 +00001415 else
Daniel Dunbarbc85be82009-04-29 18:32:25 +00001416 Model = getToolChain().GetDefaultRelocationModel();
Daniel Dunbar1d460332009-03-18 10:01:51 +00001417 }
Chris Lattner5f9e2722011-07-23 10:55:15 +00001418 if (StringRef(Model) != "pic") {
Daniel Dunbarf219e7c2009-11-29 07:18:39 +00001419 CmdArgs.push_back("-mrelocation-model");
1420 CmdArgs.push_back(Model);
1421 }
Daniel Dunbarbc85be82009-04-29 18:32:25 +00001422
1423 // Infer the __PIC__ value.
1424 //
1425 // FIXME: This isn't quite right on Darwin, which always sets
1426 // __PIC__=2.
1427 if (strcmp(Model, "pic") == 0 || strcmp(Model, "dynamic-no-pic") == 0) {
Daniel Dunbar76743522009-11-29 02:39:08 +00001428 CmdArgs.push_back("-pic-level");
1429 CmdArgs.push_back(Args.hasArg(options::OPT_fPIC) ? "2" : "1");
Daniel Dunbarbc85be82009-04-29 18:32:25 +00001430 }
Tanya Lattner59876c22009-11-04 01:18:09 +00001431 if (!Args.hasFlag(options::OPT_fmerge_all_constants,
1432 options::OPT_fno_merge_all_constants))
Chris Lattnerf44a1a02011-04-08 18:06:54 +00001433 CmdArgs.push_back("-fno-merge-all-constants");
Daniel Dunbar6bea73b2009-09-16 06:17:29 +00001434
Daniel Dunbarf219e7c2009-11-29 07:18:39 +00001435 // LLVM Code Generator Options.
1436
Daniel Dunbar17d3fea2011-02-09 17:54:19 +00001437 if (Arg *A = Args.getLastArg(options::OPT_mregparm_EQ)) {
1438 CmdArgs.push_back("-mregparm");
1439 CmdArgs.push_back(A->getValue(Args));
1440 }
1441
Roman Divackycfe9af22011-03-01 17:40:53 +00001442 if (Args.hasFlag(options::OPT_mrtd, options::OPT_mno_rtd, false))
1443 CmdArgs.push_back("-mrtd");
1444
Rafael Espindola6af27ec2011-12-14 21:02:23 +00001445 if (shouldUseFramePointer(Args, getToolChain().getTriple()))
Daniel Dunbarf219e7c2009-11-29 07:18:39 +00001446 CmdArgs.push_back("-mdisable-fp-elim");
1447 if (!Args.hasFlag(options::OPT_fzero_initialized_in_bss,
1448 options::OPT_fno_zero_initialized_in_bss))
1449 CmdArgs.push_back("-mno-zero-initialized-in-bss");
Daniel Dunbar398c6102011-02-04 02:20:39 +00001450 if (!Args.hasFlag(options::OPT_fstrict_aliasing,
1451 options::OPT_fno_strict_aliasing,
1452 getToolChain().IsStrictAliasingDefault()))
Dan Gohman4d5625e2010-10-14 22:36:56 +00001453 CmdArgs.push_back("-relaxed-aliasing");
Nick Lewycky1db772b2012-01-23 08:29:12 +00001454 if (!Args.hasFlag(options::OPT_foptimize_sibling_calls,
1455 options::OPT_fno_optimize_sibling_calls))
1456 CmdArgs.push_back("-mdisable-tail-calls");
Daniel Dunbar1b718482010-05-14 22:00:22 +00001457
Chandler Carruthabf07a72012-01-02 14:19:45 +00001458 // Handle various floating point optimization flags, mapping them to the
1459 // appropriate LLVM code generation flags. The pattern for all of these is to
1460 // default off the codegen optimizations, and if any flag enables them and no
1461 // flag disables them after the flag enabling them, enable the codegen
1462 // optimization. This is complicated by several "umbrella" flags.
1463 if (Arg *A = Args.getLastArg(options::OPT_ffast_math,
1464 options::OPT_ffinite_math_only,
1465 options::OPT_fno_finite_math_only,
1466 options::OPT_fhonor_infinities,
1467 options::OPT_fno_honor_infinities))
1468 if (A->getOption().getID() != options::OPT_fno_finite_math_only &&
1469 A->getOption().getID() != options::OPT_fhonor_infinities)
1470 CmdArgs.push_back("-menable-no-infs");
1471 if (Arg *A = Args.getLastArg(options::OPT_ffast_math,
1472 options::OPT_ffinite_math_only,
1473 options::OPT_fno_finite_math_only,
1474 options::OPT_fhonor_nans,
1475 options::OPT_fno_honor_nans))
1476 if (A->getOption().getID() != options::OPT_fno_finite_math_only &&
1477 A->getOption().getID() != options::OPT_fhonor_nans)
1478 CmdArgs.push_back("-menable-no-nans");
1479
1480 // -fno-math-errno is default.
1481 bool MathErrno = false;
1482 if (Arg *A = Args.getLastArg(options::OPT_ffast_math,
1483 options::OPT_fmath_errno,
1484 options::OPT_fno_math_errno)) {
1485 if (A->getOption().getID() == options::OPT_fmath_errno) {
1486 CmdArgs.push_back("-fmath-errno");
1487 MathErrno = true;
1488 }
1489 }
1490
1491 // There are several flags which require disabling very specific
1492 // optimizations. Any of these being disabled forces us to turn off the
1493 // entire set of LLVM optimizations, so collect them through all the flag
1494 // madness.
1495 bool AssociativeMath = false;
1496 if (Arg *A = Args.getLastArg(options::OPT_ffast_math,
1497 options::OPT_funsafe_math_optimizations,
1498 options::OPT_fno_unsafe_math_optimizations,
1499 options::OPT_fassociative_math,
1500 options::OPT_fno_associative_math))
1501 if (A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
1502 A->getOption().getID() != options::OPT_fno_associative_math)
1503 AssociativeMath = true;
1504 bool ReciprocalMath = false;
1505 if (Arg *A = Args.getLastArg(options::OPT_ffast_math,
1506 options::OPT_funsafe_math_optimizations,
1507 options::OPT_fno_unsafe_math_optimizations,
1508 options::OPT_freciprocal_math,
1509 options::OPT_fno_reciprocal_math))
1510 if (A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
1511 A->getOption().getID() != options::OPT_fno_reciprocal_math)
1512 ReciprocalMath = true;
1513 bool SignedZeros = true;
1514 if (Arg *A = Args.getLastArg(options::OPT_ffast_math,
1515 options::OPT_funsafe_math_optimizations,
1516 options::OPT_fno_unsafe_math_optimizations,
1517 options::OPT_fsigned_zeros,
1518 options::OPT_fno_signed_zeros))
1519 if (A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
1520 A->getOption().getID() != options::OPT_fsigned_zeros)
1521 SignedZeros = false;
1522 bool TrappingMath = true;
1523 if (Arg *A = Args.getLastArg(options::OPT_ffast_math,
1524 options::OPT_funsafe_math_optimizations,
1525 options::OPT_fno_unsafe_math_optimizations,
1526 options::OPT_ftrapping_math,
1527 options::OPT_fno_trapping_math))
1528 if (A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
1529 A->getOption().getID() != options::OPT_ftrapping_math)
1530 TrappingMath = false;
1531 if (!MathErrno && AssociativeMath && ReciprocalMath && !SignedZeros &&
1532 !TrappingMath)
1533 CmdArgs.push_back("-menable-unsafe-fp-math");
1534
1535 // We separately look for the '-ffast-math' flag, and if we find it, tell the
1536 // frontend to provide the appropriate preprocessor macros. This is distinct
1537 // from enabling any optimizations as it induces a language change which must
1538 // survive serialization and deserialization, etc.
1539 if (Args.hasArg(options::OPT_ffast_math))
1540 CmdArgs.push_back("-ffast-math");
1541
Daniel Dunbar1b718482010-05-14 22:00:22 +00001542 // Decide whether to use verbose asm. Verbose assembly is the default on
1543 // toolchains which have the integrated assembler on by default.
1544 bool IsVerboseAsmDefault = getToolChain().IsIntegratedAssemblerDefault();
1545 if (Args.hasFlag(options::OPT_fverbose_asm, options::OPT_fno_verbose_asm,
Michael J. Spencer20249a12010-10-21 03:16:25 +00001546 IsVerboseAsmDefault) ||
Daniel Dunbar1b718482010-05-14 22:00:22 +00001547 Args.hasArg(options::OPT_dA))
Daniel Dunbarf219e7c2009-11-29 07:18:39 +00001548 CmdArgs.push_back("-masm-verbose");
Daniel Dunbar1b718482010-05-14 22:00:22 +00001549
Daniel Dunbarf219e7c2009-11-29 07:18:39 +00001550 if (Args.hasArg(options::OPT_fdebug_pass_structure)) {
1551 CmdArgs.push_back("-mdebug-pass");
1552 CmdArgs.push_back("Structure");
1553 }
1554 if (Args.hasArg(options::OPT_fdebug_pass_arguments)) {
1555 CmdArgs.push_back("-mdebug-pass");
1556 CmdArgs.push_back("Arguments");
1557 }
1558
John McCalld0c2ec42010-02-19 02:45:38 +00001559 // Enable -mconstructor-aliases except on darwin, where we have to
1560 // work around a linker bug; see <rdar://problem/7651567>.
Bob Wilson905c45f2011-10-14 05:03:44 +00001561 if (!getToolChain().getTriple().isOSDarwin())
John McCalld0c2ec42010-02-19 02:45:38 +00001562 CmdArgs.push_back("-mconstructor-aliases");
NAKAMURA Takumi125b4cb2011-02-17 08:50:50 +00001563
John McCall32096692011-03-18 02:56:14 +00001564 // Darwin's kernel doesn't support guard variables; just die if we
1565 // try to use them.
Bob Wilson905c45f2011-10-14 05:03:44 +00001566 if (KernelOrKext && getToolChain().getTriple().isOSDarwin())
John McCall32096692011-03-18 02:56:14 +00001567 CmdArgs.push_back("-fforbid-guard-variables");
1568
Douglas Gregor6f755502011-02-01 15:15:22 +00001569 if (Args.hasArg(options::OPT_mms_bitfields)) {
1570 CmdArgs.push_back("-mms-bitfields");
1571 }
John McCalld0c2ec42010-02-19 02:45:38 +00001572
Daniel Dunbar6bea73b2009-09-16 06:17:29 +00001573 // This is a coarse approximation of what llvm-gcc actually does, both
1574 // -fasynchronous-unwind-tables and -fnon-call-exceptions interact in more
1575 // complicated ways.
1576 bool AsynchronousUnwindTables =
1577 Args.hasFlag(options::OPT_fasynchronous_unwind_tables,
1578 options::OPT_fno_asynchronous_unwind_tables,
1579 getToolChain().IsUnwindTablesDefault() &&
Daniel Dunbar0a80ba72010-03-20 04:52:14 +00001580 !KernelOrKext);
Daniel Dunbar6bea73b2009-09-16 06:17:29 +00001581 if (Args.hasFlag(options::OPT_funwind_tables, options::OPT_fno_unwind_tables,
1582 AsynchronousUnwindTables))
Daniel Dunbarf219e7c2009-11-29 07:18:39 +00001583 CmdArgs.push_back("-munwind-tables");
1584
1585 if (Arg *A = Args.getLastArg(options::OPT_flimited_precision_EQ)) {
1586 CmdArgs.push_back("-mlimit-float-precision");
1587 CmdArgs.push_back(A->getValue(Args));
1588 }
Daniel Dunbarbc85be82009-04-29 18:32:25 +00001589
Daniel Dunbar868bd0a2009-05-06 03:16:41 +00001590 // FIXME: Handle -mtune=.
1591 (void) Args.hasArg(options::OPT_mtune_EQ);
Daniel Dunbarbc85be82009-04-29 18:32:25 +00001592
Benjamin Kramer8e9ef0d2009-08-05 14:30:52 +00001593 if (Arg *A = Args.getLastArg(options::OPT_mcmodel_EQ)) {
Daniel Dunbarf219e7c2009-11-29 07:18:39 +00001594 CmdArgs.push_back("-mcode-model");
Benjamin Kramer8e9ef0d2009-08-05 14:30:52 +00001595 CmdArgs.push_back(A->getValue(Args));
1596 }
1597
Daniel Dunbar6acda162009-09-09 22:33:08 +00001598 // Add target specific cpu and features flags.
1599 switch(getToolChain().getTriple().getArch()) {
1600 default:
1601 break;
Daniel Dunbar868bd0a2009-05-06 03:16:41 +00001602
Daniel Dunbarb163ef72009-09-10 04:57:17 +00001603 case llvm::Triple::arm:
1604 case llvm::Triple::thumb:
Daniel Dunbarfa41d692011-03-17 17:10:06 +00001605 AddARMTargetArgs(Args, CmdArgs, KernelOrKext);
Daniel Dunbarb163ef72009-09-10 04:57:17 +00001606 break;
1607
Eric Christophered734732010-03-02 02:41:08 +00001608 case llvm::Triple::mips:
1609 case llvm::Triple::mipsel:
Akira Hatanaka7ec02582011-09-21 02:13:07 +00001610 case llvm::Triple::mips64:
1611 case llvm::Triple::mips64el:
Eric Christophered734732010-03-02 02:41:08 +00001612 AddMIPSTargetArgs(Args, CmdArgs);
1613 break;
1614
Bruno Cardoso Lopes9284d212010-11-09 17:21:19 +00001615 case llvm::Triple::sparc:
1616 AddSparcTargetArgs(Args, CmdArgs);
1617 break;
1618
Daniel Dunbar6acda162009-09-09 22:33:08 +00001619 case llvm::Triple::x86:
1620 case llvm::Triple::x86_64:
1621 AddX86TargetArgs(Args, CmdArgs);
1622 break;
Tony Linthicum96319392011-12-12 21:14:55 +00001623
1624 case llvm::Triple::hexagon:
1625 AddHexagonTargetArgs(Args, CmdArgs);
1626 break;
Daniel Dunbarbc85be82009-04-29 18:32:25 +00001627 }
1628
Tony Linthicum96319392011-12-12 21:14:55 +00001629
1630
Daniel Dunbarc176bc62010-08-11 23:07:47 +00001631 // Pass the linker version in use.
1632 if (Arg *A = Args.getLastArg(options::OPT_mlinker_version_EQ)) {
1633 CmdArgs.push_back("-target-linker-version");
1634 CmdArgs.push_back(A->getValue(Args));
1635 }
1636
Nick Lewyckyb2d11cc2011-02-02 06:43:03 +00001637 // -mno-omit-leaf-frame-pointer is the default on Darwin.
Daniel Dunbar1ad66482010-07-01 01:31:45 +00001638 if (Args.hasFlag(options::OPT_momit_leaf_frame_pointer,
Nick Lewyckyb2d11cc2011-02-02 06:43:03 +00001639 options::OPT_mno_omit_leaf_frame_pointer,
Bob Wilson905c45f2011-10-14 05:03:44 +00001640 !getToolChain().getTriple().isOSDarwin()))
Daniel Dunbar1ad66482010-07-01 01:31:45 +00001641 CmdArgs.push_back("-momit-leaf-frame-pointer");
1642
Daniel Dunbarb30575c2010-05-12 18:19:58 +00001643 // Explicitly error on some things we know we don't support and can't just
1644 // ignore.
1645 types::ID InputType = Inputs[0].getType();
Daniel Dunbare94db472010-09-24 19:39:37 +00001646 if (!Args.hasArg(options::OPT_fallow_unsupported)) {
1647 Arg *Unsupported;
Daniel Dunbare94db472010-09-24 19:39:37 +00001648 if (types::isCXX(InputType) &&
Bob Wilson905c45f2011-10-14 05:03:44 +00001649 getToolChain().getTriple().isOSDarwin() &&
Daniel Dunbare94db472010-09-24 19:39:37 +00001650 getToolChain().getTriple().getArch() == llvm::Triple::x86) {
Bob Wilsona544aee2011-08-13 23:48:55 +00001651 if ((Unsupported = Args.getLastArg(options::OPT_fapple_kext)) ||
1652 (Unsupported = Args.getLastArg(options::OPT_mkernel)))
Chris Lattner5f9e2722011-07-23 10:55:15 +00001653 D.Diag(diag::err_drv_clang_unsupported_opt_cxx_darwin_i386)
Daniel Dunbare94db472010-09-24 19:39:37 +00001654 << Unsupported->getOption().getName();
1655 }
Daniel Dunbarb30575c2010-05-12 18:19:58 +00001656 }
1657
Daniel Dunbar1d460332009-03-18 10:01:51 +00001658 Args.AddAllArgs(CmdArgs, options::OPT_v);
Daniel Dunbarf7c16d92010-08-24 22:44:13 +00001659 Args.AddLastArg(CmdArgs, options::OPT_H);
Chad Rosier2b819102011-08-02 17:58:04 +00001660 if (D.CCPrintHeaders && !D.CCGenDiagnostics) {
Daniel Dunbar322c29f2011-02-02 21:11:35 +00001661 CmdArgs.push_back("-header-include-file");
1662 CmdArgs.push_back(D.CCPrintHeadersFilename ?
1663 D.CCPrintHeadersFilename : "-");
1664 }
Daniel Dunbar1d460332009-03-18 10:01:51 +00001665 Args.AddLastArg(CmdArgs, options::OPT_P);
Mike Stump1eb44332009-09-09 15:08:12 +00001666 Args.AddLastArg(CmdArgs, options::OPT_print_ivar_layout);
Daniel Dunbar1d460332009-03-18 10:01:51 +00001667
Chad Rosier2b819102011-08-02 17:58:04 +00001668 if (D.CCLogDiagnostics && !D.CCGenDiagnostics) {
Daniel Dunbarc8a22b02011-04-07 18:01:20 +00001669 CmdArgs.push_back("-diagnostic-log-file");
1670 CmdArgs.push_back(D.CCLogDiagnosticsFilename ?
1671 D.CCLogDiagnosticsFilename : "-");
1672 }
1673
Daniel Dunbar1d460332009-03-18 10:01:51 +00001674 // Special case debug options to only pass -g to clang. This is
1675 // wrong.
Rafael Espindola18f36d92010-03-07 04:46:18 +00001676 Args.ClaimAllArgs(options::OPT_g_Group);
Daniel Dunbar6b3d5a62010-05-12 18:19:55 +00001677 if (Arg *A = Args.getLastArg(options::OPT_g_Group))
Chad Rosier2875bda2011-11-04 19:28:44 +00001678 if (!A->getOption().matches(options::OPT_g0)) {
Chad Rosiercf6ba2e2011-11-07 19:52:29 +00001679 CmdArgs.push_back("-g");
Chad Rosier2875bda2011-11-04 19:28:44 +00001680 }
Daniel Dunbar1d460332009-03-18 10:01:51 +00001681
Rafael Espindola9cf933a2010-05-06 21:06:04 +00001682 Args.AddAllArgs(CmdArgs, options::OPT_ffunction_sections);
1683 Args.AddAllArgs(CmdArgs, options::OPT_fdata_sections);
1684
Chris Lattner7255a2d2010-06-22 00:03:40 +00001685 Args.AddAllArgs(CmdArgs, options::OPT_finstrument_functions);
1686
Nick Lewyckye8ba8d72011-04-21 23:44:07 +00001687 if (Args.hasArg(options::OPT_ftest_coverage) ||
1688 Args.hasArg(options::OPT_coverage))
1689 CmdArgs.push_back("-femit-coverage-notes");
1690 if (Args.hasArg(options::OPT_fprofile_arcs) ||
1691 Args.hasArg(options::OPT_coverage))
1692 CmdArgs.push_back("-femit-coverage-data");
1693
Nick Lewycky5ea4f442011-05-04 20:46:58 +00001694 if (C.getArgs().hasArg(options::OPT_c) ||
1695 C.getArgs().hasArg(options::OPT_S)) {
1696 if (Output.isFilename()) {
Nick Lewycky3dc05412011-05-05 00:08:20 +00001697 CmdArgs.push_back("-coverage-file");
1698 CmdArgs.push_back(Args.MakeArgString(Output.getFilename()));
Nick Lewycky5ea4f442011-05-04 20:46:58 +00001699 }
1700 }
1701
Daniel Dunbara268fc02011-10-11 18:20:10 +00001702 // Pass options for controlling the default header search paths.
1703 if (Args.hasArg(options::OPT_nostdinc)) {
1704 CmdArgs.push_back("-nostdsysteminc");
1705 CmdArgs.push_back("-nobuiltininc");
1706 } else {
Daniel Dunbar92d6d402011-10-11 18:20:16 +00001707 if (Args.hasArg(options::OPT_nostdlibinc))
1708 CmdArgs.push_back("-nostdsysteminc");
Daniel Dunbara268fc02011-10-11 18:20:10 +00001709 Args.AddLastArg(CmdArgs, options::OPT_nostdincxx);
1710 Args.AddLastArg(CmdArgs, options::OPT_nobuiltininc);
1711 }
Daniel Dunbar1d460332009-03-18 10:01:51 +00001712
Daniel Dunbar5f122322009-12-15 01:02:52 +00001713 // Pass the path to compiler resource files.
Daniel Dunbar5f122322009-12-15 01:02:52 +00001714 CmdArgs.push_back("-resource-dir");
Daniel Dunbar225c4172010-01-20 02:35:16 +00001715 CmdArgs.push_back(D.ResourceDir.c_str());
Daniel Dunbar2ac9fc22009-04-07 21:42:00 +00001716
Argyrios Kyrtzidis389db162010-11-03 22:45:23 +00001717 Args.AddLastArg(CmdArgs, options::OPT_working_directory);
1718
John McCall8f0e8d22011-06-15 23:25:17 +00001719 if (!Args.hasArg(options::OPT_fno_objc_arc)) {
Argyrios Kyrtzidis72ac1202011-07-07 04:00:39 +00001720 if (const Arg *A = Args.getLastArg(options::OPT_ccc_arcmt_check,
Argyrios Kyrtzidis69325d52011-07-09 20:00:58 +00001721 options::OPT_ccc_arcmt_modify,
1722 options::OPT_ccc_arcmt_migrate)) {
John McCall8f0e8d22011-06-15 23:25:17 +00001723 switch (A->getOption().getID()) {
1724 default:
1725 llvm_unreachable("missed a case");
Argyrios Kyrtzidis72ac1202011-07-07 04:00:39 +00001726 case options::OPT_ccc_arcmt_check:
John McCall8f0e8d22011-06-15 23:25:17 +00001727 CmdArgs.push_back("-arcmt-check");
1728 break;
Argyrios Kyrtzidis72ac1202011-07-07 04:00:39 +00001729 case options::OPT_ccc_arcmt_modify:
John McCall8f0e8d22011-06-15 23:25:17 +00001730 CmdArgs.push_back("-arcmt-modify");
1731 break;
Argyrios Kyrtzidis69325d52011-07-09 20:00:58 +00001732 case options::OPT_ccc_arcmt_migrate:
1733 CmdArgs.push_back("-arcmt-migrate");
1734 CmdArgs.push_back("-arcmt-migrate-directory");
1735 CmdArgs.push_back(A->getValue(Args));
Argyrios Kyrtzidis7ee20492011-07-19 17:20:03 +00001736
1737 Args.AddLastArg(CmdArgs, options::OPT_arcmt_migrate_report_output);
1738 Args.AddLastArg(CmdArgs, options::OPT_arcmt_migrate_emit_arc_errors);
Argyrios Kyrtzidis69325d52011-07-09 20:00:58 +00001739 break;
John McCall8f0e8d22011-06-15 23:25:17 +00001740 }
1741 }
1742 }
Eric Christopher88b7cf02011-08-19 00:30:14 +00001743
Daniel Dunbarc21c4852009-04-08 23:54:23 +00001744 // Add preprocessing options like -I, -D, etc. if we are using the
1745 // preprocessor.
1746 //
1747 // FIXME: Support -fpreprocessed
Daniel Dunbarc21c4852009-04-08 23:54:23 +00001748 if (types::getPreprocessedType(InputType) != types::TY_INVALID)
Peter Collingbourne54db68b2011-11-06 00:40:05 +00001749 AddPreprocessingOptions(C, D, Args, CmdArgs, Output, Inputs);
Daniel Dunbar1d460332009-03-18 10:01:51 +00001750
Rafael Espindola19d9d2e2011-07-21 23:40:37 +00001751 // Don't warn about "clang -c -DPIC -fPIC test.i" because libtool.m4 assumes
1752 // that "The compiler can only warn and ignore the option if not recognized".
1753 // When building with ccache, it will pass -D options to clang even on
1754 // preprocessed inputs and configure concludes that -fPIC is not supported.
1755 Args.ClaimAllArgs(options::OPT_D);
1756
Daniel Dunbar20f0eac2009-09-17 06:53:36 +00001757 // Manually translate -O to -O2 and -O4 to -O3; let clang reject
Daniel Dunbar337a6272009-03-24 20:17:30 +00001758 // others.
1759 if (Arg *A = Args.getLastArg(options::OPT_O_Group)) {
Daniel Dunbarb827a052009-11-19 03:26:40 +00001760 if (A->getOption().matches(options::OPT_O4))
Daniel Dunbar337a6272009-03-24 20:17:30 +00001761 CmdArgs.push_back("-O3");
Daniel Dunbar473916c2010-05-27 06:51:08 +00001762 else if (A->getOption().matches(options::OPT_O) &&
1763 A->getValue(Args)[0] == '\0')
Daniel Dunbar20f0eac2009-09-17 06:53:36 +00001764 CmdArgs.push_back("-O2");
Daniel Dunbar1d460332009-03-18 10:01:51 +00001765 else
Daniel Dunbar5697aa02009-03-18 23:39:35 +00001766 A->render(Args, CmdArgs);
Daniel Dunbar1d460332009-03-18 10:01:51 +00001767 }
1768
Daniel Dunbar6e8371e2009-10-29 02:24:45 +00001769 Args.AddAllArgs(CmdArgs, options::OPT_W_Group);
1770 Args.AddLastArg(CmdArgs, options::OPT_pedantic);
1771 Args.AddLastArg(CmdArgs, options::OPT_pedantic_errors);
Daniel Dunbar1d460332009-03-18 10:01:51 +00001772 Args.AddLastArg(CmdArgs, options::OPT_w);
Daniel Dunbard573d262009-04-07 22:13:21 +00001773
1774 // Handle -{std, ansi, trigraphs} -- take the last of -{std, ansi}
1775 // (-ansi is equivalent to -std=c89).
1776 //
1777 // If a std is supplied, only add -trigraphs if it follows the
1778 // option.
1779 if (Arg *Std = Args.getLastArg(options::OPT_std_EQ, options::OPT_ansi)) {
1780 if (Std->getOption().matches(options::OPT_ansi))
Nuno Lopes528365d2009-10-16 14:28:06 +00001781 if (types::isCXX(InputType))
Daniel Dunbar294691e2009-11-04 06:24:38 +00001782 CmdArgs.push_back("-std=c++98");
Nuno Lopes528365d2009-10-16 14:28:06 +00001783 else
Daniel Dunbar294691e2009-11-04 06:24:38 +00001784 CmdArgs.push_back("-std=c89");
Daniel Dunbard573d262009-04-07 22:13:21 +00001785 else
1786 Std->render(Args, CmdArgs);
1787
Daniel Dunbar0e100312010-06-14 21:23:08 +00001788 if (Arg *A = Args.getLastArg(options::OPT_std_EQ, options::OPT_ansi,
1789 options::OPT_trigraphs))
1790 if (A != Std)
Daniel Dunbard573d262009-04-07 22:13:21 +00001791 A->render(Args, CmdArgs);
Daniel Dunbara3ff2022009-04-26 01:10:38 +00001792 } else {
1793 // Honor -std-default.
Daniel Dunbar4a5290e2010-01-29 21:03:02 +00001794 //
1795 // FIXME: Clang doesn't correctly handle -std= when the input language
1796 // doesn't match. For the time being just ignore this for C++ inputs;
1797 // eventually we want to do all the standard defaulting here instead of
1798 // splitting it between the driver and clang -cc1.
1799 if (!types::isCXX(InputType))
1800 Args.AddAllArgsTranslated(CmdArgs, options::OPT_std_default_EQ,
1801 "-std=", /*Joined=*/true);
Daniel Dunbard573d262009-04-07 22:13:21 +00001802 Args.AddLastArg(CmdArgs, options::OPT_trigraphs);
Daniel Dunbara3ff2022009-04-26 01:10:38 +00001803 }
Daniel Dunbarc21c4852009-04-08 23:54:23 +00001804
Chandler Carruth50465d12011-04-23 06:30:43 +00001805 // Map the bizarre '-Wwrite-strings' flag to a more sensible
1806 // '-fconst-strings'; this better indicates its actual behavior.
1807 if (Args.hasFlag(options::OPT_Wwrite_strings, options::OPT_Wno_write_strings,
1808 false)) {
1809 // For perfect compatibility with GCC, we do this even in the presence of
1810 // '-w'. This flag names something other than a warning for GCC.
1811 CmdArgs.push_back("-fconst-strings");
1812 }
1813
Chandler Carruth1cfe3c32011-04-23 09:27:53 +00001814 // GCC provides a macro definition '__DEPRECATED' when -Wdeprecated is active
Chandler Carruthf8c247d2011-04-23 19:48:40 +00001815 // during C++ compilation, which it is by default. GCC keeps this define even
1816 // in the presence of '-w', match this behavior bug-for-bug.
1817 if (types::isCXX(InputType) &&
1818 Args.hasFlag(options::OPT_Wdeprecated, options::OPT_Wno_deprecated,
1819 true)) {
1820 CmdArgs.push_back("-fdeprecated-macro");
Chandler Carruth1cfe3c32011-04-23 09:27:53 +00001821 }
1822
Chandler Carruthc304ba32010-05-22 02:21:53 +00001823 // Translate GCC's misnamer '-fasm' arguments to '-fgnu-keywords'.
1824 if (Arg *Asm = Args.getLastArg(options::OPT_fasm, options::OPT_fno_asm)) {
1825 if (Asm->getOption().matches(options::OPT_fasm))
1826 CmdArgs.push_back("-fgnu-keywords");
1827 else
1828 CmdArgs.push_back("-fno-gnu-keywords");
1829 }
1830
Rafael Espindola61b1efe2011-05-02 17:43:32 +00001831 if (ShouldDisableCFI(Args, getToolChain()))
1832 CmdArgs.push_back("-fno-dwarf2-cfi-asm");
Rafael Espindolaf24a1512011-04-30 18:35:43 +00001833
Nick Lewyckyea523d72011-10-17 23:05:52 +00001834 if (ShouldDisableDwarfDirectory(Args, getToolChain()))
1835 CmdArgs.push_back("-fno-dwarf-directory-asm");
1836
Nick Lewycky7c4fd912011-10-21 02:32:14 +00001837 if (const char *pwd = ::getenv("PWD")) {
1838 // GCC also verifies that stat(pwd) and stat(".") have the same inode
1839 // number. Not doing those because stats are slow, but we could.
NAKAMURA Takumi813a4072011-10-22 10:25:25 +00001840 if (llvm::sys::path::is_absolute(pwd)) {
Nick Lewycky7c4fd912011-10-21 02:32:14 +00001841 std::string CompDir = pwd;
1842 CmdArgs.push_back("-fdebug-compilation-dir");
1843 CmdArgs.push_back(Args.MakeArgString(CompDir));
1844 }
1845 }
1846
Richard Smithc18c4232011-11-21 19:36:32 +00001847 if (Arg *A = Args.getLastArg(options::OPT_ftemplate_depth_,
1848 options::OPT_ftemplate_depth_EQ)) {
Daniel Dunbar1d460332009-03-18 10:01:51 +00001849 CmdArgs.push_back("-ftemplate-depth");
1850 CmdArgs.push_back(A->getValue(Args));
1851 }
1852
Richard Smithc18c4232011-11-21 19:36:32 +00001853 if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_depth_EQ)) {
1854 CmdArgs.push_back("-fconstexpr-depth");
1855 CmdArgs.push_back(A->getValue(Args));
1856 }
1857
Argyrios Kyrtzidis1380a142010-11-18 00:20:36 +00001858 if (Arg *A = Args.getLastArg(options::OPT_Wlarge_by_value_copy_EQ,
1859 options::OPT_Wlarge_by_value_copy_def)) {
1860 CmdArgs.push_back("-Wlarge-by-value-copy");
Argyrios Kyrtzidis3532fdd2010-11-17 23:11:54 +00001861 if (A->getNumValues())
1862 CmdArgs.push_back(A->getValue(Args));
1863 else
Argyrios Kyrtzidis1380a142010-11-18 00:20:36 +00001864 CmdArgs.push_back("64"); // default value for -Wlarge-by-value-copy.
Argyrios Kyrtzidis3532fdd2010-11-17 23:11:54 +00001865 }
1866
Daniel Dunbare4bdae72009-11-19 04:00:53 +00001867 if (Args.hasArg(options::OPT__relocatable_pch))
Daniel Dunbar66861e02009-11-20 22:21:36 +00001868 CmdArgs.push_back("-relocatable-pch");
Mike Stump1eb44332009-09-09 15:08:12 +00001869
Daniel Dunbar294691e2009-11-04 06:24:38 +00001870 if (Arg *A = Args.getLastArg(options::OPT_fconstant_string_class_EQ)) {
1871 CmdArgs.push_back("-fconstant-string-class");
1872 CmdArgs.push_back(A->getValue(Args));
1873 }
David Chisnall8a5a9aa2009-08-31 16:41:57 +00001874
Chris Lattner124fca52010-01-09 21:54:33 +00001875 if (Arg *A = Args.getLastArg(options::OPT_ftabstop_EQ)) {
1876 CmdArgs.push_back("-ftabstop");
1877 CmdArgs.push_back(A->getValue(Args));
1878 }
1879
Chris Lattner0f0c9632010-04-07 20:49:23 +00001880 CmdArgs.push_back("-ferror-limit");
1881 if (Arg *A = Args.getLastArg(options::OPT_ferror_limit_EQ))
1882 CmdArgs.push_back(A->getValue(Args));
1883 else
1884 CmdArgs.push_back("19");
Douglas Gregor575cf372010-04-20 07:18:24 +00001885
Chandler Carruthc40f73c2010-05-06 04:55:18 +00001886 if (Arg *A = Args.getLastArg(options::OPT_fmacro_backtrace_limit_EQ)) {
1887 CmdArgs.push_back("-fmacro-backtrace-limit");
Douglas Gregor6c1cb992010-05-04 17:13:42 +00001888 CmdArgs.push_back(A->getValue(Args));
Chandler Carruthc40f73c2010-05-06 04:55:18 +00001889 }
1890
1891 if (Arg *A = Args.getLastArg(options::OPT_ftemplate_backtrace_limit_EQ)) {
1892 CmdArgs.push_back("-ftemplate-backtrace-limit");
Douglas Gregor575cf372010-04-20 07:18:24 +00001893 CmdArgs.push_back(A->getValue(Args));
Chandler Carruthc40f73c2010-05-06 04:55:18 +00001894 }
1895
Richard Smith08d6e032011-12-16 19:06:07 +00001896 if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_backtrace_limit_EQ)) {
1897 CmdArgs.push_back("-fconstexpr-backtrace-limit");
1898 CmdArgs.push_back(A->getValue(Args));
1899 }
1900
Daniel Dunbar55efe142009-11-04 06:24:47 +00001901 // Pass -fmessage-length=.
Daniel Dunbara28690e2009-11-30 08:40:54 +00001902 CmdArgs.push_back("-fmessage-length");
Daniel Dunbar55efe142009-11-04 06:24:47 +00001903 if (Arg *A = Args.getLastArg(options::OPT_fmessage_length_EQ)) {
Daniel Dunbara28690e2009-11-30 08:40:54 +00001904 CmdArgs.push_back(A->getValue(Args));
Daniel Dunbar55efe142009-11-04 06:24:47 +00001905 } else {
1906 // If -fmessage-length=N was not specified, determine whether this is a
1907 // terminal and, if so, implicitly define -fmessage-length appropriately.
1908 unsigned N = llvm::sys::Process::StandardErrColumns();
Chris Lattner5f9e2722011-07-23 10:55:15 +00001909 CmdArgs.push_back(Args.MakeArgString(Twine(N)));
Daniel Dunbar55efe142009-11-04 06:24:47 +00001910 }
1911
Daniel Dunbarba8d8612009-12-03 18:42:11 +00001912 if (const Arg *A = Args.getLastArg(options::OPT_fvisibility_EQ)) {
1913 CmdArgs.push_back("-fvisibility");
1914 CmdArgs.push_back(A->getValue(Args));
1915 }
1916
Douglas Gregor7cf84d62010-06-15 17:05:35 +00001917 Args.AddLastArg(CmdArgs, options::OPT_fvisibility_inlines_hidden);
Michael J. Spencer20249a12010-10-21 03:16:25 +00001918
Daniel Dunbar0a80ba72010-03-20 04:52:14 +00001919 // -fhosted is default.
1920 if (KernelOrKext || Args.hasFlag(options::OPT_ffreestanding,
1921 options::OPT_fhosted,
1922 false))
1923 CmdArgs.push_back("-ffreestanding");
1924
Daniel Dunbarba8d8612009-12-03 18:42:11 +00001925 // Forward -f (flag) options which we can pass directly.
Mike Stump9c276ae2009-12-12 01:27:46 +00001926 Args.AddLastArg(CmdArgs, options::OPT_fcatch_undefined_behavior);
Daniel Dunbar3aaf0822009-04-07 21:51:40 +00001927 Args.AddLastArg(CmdArgs, options::OPT_femit_all_decls);
Daniel Dunbar3aaf0822009-04-07 21:51:40 +00001928 Args.AddLastArg(CmdArgs, options::OPT_fheinous_gnu_extensions);
Devang Patelc69e1cf2010-09-30 19:05:55 +00001929 Args.AddLastArg(CmdArgs, options::OPT_flimit_debug_info);
Devang Patel033be8b2011-11-04 20:05:58 +00001930 Args.AddLastArg(CmdArgs, options::OPT_fno_limit_debug_info);
Eric Christophere88c4512011-10-25 07:13:06 +00001931 Args.AddLastArg(CmdArgs, options::OPT_fno_operator_names);
Anton Yartsev17ba2672011-12-23 20:23:19 +00001932 Args.AddLastArg(CmdArgs, options::OPT_faltivec);
Daniel Dunbarbbe8e3e2011-03-01 18:49:30 +00001933 if (getToolChain().SupportsProfiling())
1934 Args.AddLastArg(CmdArgs, options::OPT_pg);
Daniel Dunbar8c6fa842010-03-16 16:57:46 +00001935
Kostya Serebryany1b4eca62011-11-16 17:34:26 +00001936 if (Args.hasFlag(options::OPT_faddress_sanitizer,
1937 options::OPT_fno_address_sanitizer, false))
1938 CmdArgs.push_back("-faddress-sanitizer");
1939
Kostya Serebryany3c931222012-03-01 22:27:08 +00001940 if (Args.hasFlag(options::OPT_fthread_sanitizer,
1941 options::OPT_fno_thread_sanitizer, false))
1942 CmdArgs.push_back("-fthread-sanitizer");
1943
Daniel Dunbar8c6fa842010-03-16 16:57:46 +00001944 // -flax-vector-conversions is default.
1945 if (!Args.hasFlag(options::OPT_flax_vector_conversions,
1946 options::OPT_fno_lax_vector_conversions))
1947 CmdArgs.push_back("-fno-lax-vector-conversions");
1948
Fariborz Jahanianb466d012011-01-07 01:05:02 +00001949 if (Args.getLastArg(options::OPT_fapple_kext))
1950 CmdArgs.push_back("-fapple-kext");
1951
Fariborz Jahanian34e65772009-05-22 20:17:16 +00001952 Args.AddLastArg(CmdArgs, options::OPT_fobjc_sender_dependent_dispatch);
Chris Lattner182e0922009-04-21 05:34:31 +00001953 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_print_source_range_info);
Douglas Gregor4786c152010-08-19 20:24:43 +00001954 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_parseable_fixits);
Daniel Dunbar3aaf0822009-04-07 21:51:40 +00001955 Args.AddLastArg(CmdArgs, options::OPT_ftime_report);
1956 Args.AddLastArg(CmdArgs, options::OPT_ftrapv);
David Chisnall7f18e672010-09-17 18:29:54 +00001957
1958 if (Arg *A = Args.getLastArg(options::OPT_ftrapv_handler_EQ)) {
1959 CmdArgs.push_back("-ftrapv-handler");
1960 CmdArgs.push_back(A->getValue(Args));
1961 }
1962
Bob Wilson71fd6cc2012-02-03 06:27:22 +00001963 Args.AddLastArg(CmdArgs, options::OPT_ftrap_function_EQ);
Evan Cheng49af1f32011-04-08 21:37:45 +00001964
Chandler Carruth5adb5a82011-03-27 00:04:55 +00001965 // -fno-strict-overflow implies -fwrapv if it isn't disabled, but
1966 // -fstrict-overflow won't turn off an explicitly enabled -fwrapv.
1967 if (Arg *A = Args.getLastArg(options::OPT_fwrapv,
1968 options::OPT_fno_wrapv)) {
1969 if (A->getOption().matches(options::OPT_fwrapv))
1970 CmdArgs.push_back("-fwrapv");
1971 } else if (Arg *A = Args.getLastArg(options::OPT_fstrict_overflow,
1972 options::OPT_fno_strict_overflow)) {
1973 if (A->getOption().matches(options::OPT_fno_strict_overflow))
1974 CmdArgs.push_back("-fwrapv");
1975 }
Daniel Dunbar3aaf0822009-04-07 21:51:40 +00001976 Args.AddLastArg(CmdArgs, options::OPT_fwritable_strings);
Eric Christopherf84d4092010-08-07 23:08:14 +00001977 Args.AddLastArg(CmdArgs, options::OPT_funroll_loops);
Daniel Dunbar1d460332009-03-18 10:01:51 +00001978
Daniel Dunbar5345c392009-09-03 04:54:28 +00001979 Args.AddLastArg(CmdArgs, options::OPT_pthread);
1980
Daniel Dunbar9e5cc6b2009-11-17 08:07:36 +00001981 // -stack-protector=0 is default.
1982 unsigned StackProtectorLevel = 0;
Bill Wendling45483f72009-06-28 07:36:13 +00001983 if (Arg *A = Args.getLastArg(options::OPT_fno_stack_protector,
1984 options::OPT_fstack_protector_all,
1985 options::OPT_fstack_protector)) {
Daniel Dunbar9e5cc6b2009-11-17 08:07:36 +00001986 if (A->getOption().matches(options::OPT_fstack_protector))
1987 StackProtectorLevel = 1;
1988 else if (A->getOption().matches(options::OPT_fstack_protector_all))
1989 StackProtectorLevel = 2;
Nico Weber2fef1112011-08-23 07:38:27 +00001990 } else {
1991 StackProtectorLevel =
1992 getToolChain().GetDefaultStackProtectorLevel(KernelOrKext);
1993 }
Daniel Dunbar9e5cc6b2009-11-17 08:07:36 +00001994 if (StackProtectorLevel) {
1995 CmdArgs.push_back("-stack-protector");
Chris Lattner5f9e2722011-07-23 10:55:15 +00001996 CmdArgs.push_back(Args.MakeArgString(Twine(StackProtectorLevel)));
Bill Wendling45483f72009-06-28 07:36:13 +00001997 }
1998
Nick Lewycky4e785c92011-12-06 03:33:03 +00001999 // Translate -mstackrealign
2000 if (Args.hasFlag(options::OPT_mstackrealign, options::OPT_mno_stackrealign,
2001 false)) {
2002 CmdArgs.push_back("-backend-option");
2003 CmdArgs.push_back("-force-align-stack");
2004 }
2005 if (!Args.hasFlag(options::OPT_mno_stackrealign, options::OPT_mstackrealign,
2006 false)) {
2007 CmdArgs.push_back(Args.MakeArgString("-mstackrealign"));
2008 }
2009
Joerg Sonnenbergere9d11db2011-12-05 23:05:23 +00002010 if (Args.hasArg(options::OPT_mstack_alignment)) {
2011 StringRef alignment = Args.getLastArgValue(options::OPT_mstack_alignment);
2012 CmdArgs.push_back(Args.MakeArgString("-mstack-alignment=" + alignment));
Eric Christopher1a584022011-05-02 21:18:22 +00002013 }
Eric Christopher88b7cf02011-08-19 00:30:14 +00002014
Daniel Dunbar48d1ef72009-04-07 21:16:11 +00002015 // Forward -f options with positive and negative forms; we translate
2016 // these by hand.
2017
Fariborz Jahanianb466d012011-01-07 01:05:02 +00002018 if (Args.hasArg(options::OPT_mkernel)) {
Daniel Dunbar2843c192011-02-04 17:24:47 +00002019 if (!Args.hasArg(options::OPT_fapple_kext) && types::isCXX(InputType))
Fariborz Jahanianb466d012011-01-07 01:05:02 +00002020 CmdArgs.push_back("-fapple-kext");
2021 if (!Args.hasArg(options::OPT_fbuiltin))
2022 CmdArgs.push_back("-fno-builtin");
2023 }
Daniel Dunbar9e5cc6b2009-11-17 08:07:36 +00002024 // -fbuiltin is default.
Fariborz Jahanianb466d012011-01-07 01:05:02 +00002025 else if (!Args.hasFlag(options::OPT_fbuiltin, options::OPT_fno_builtin))
Daniel Dunbar53e84842009-11-19 04:55:23 +00002026 CmdArgs.push_back("-fno-builtin");
Daniel Dunbar48d1ef72009-04-07 21:16:11 +00002027
Nuno Lopesfc284482009-12-16 16:59:22 +00002028 if (!Args.hasFlag(options::OPT_fassume_sane_operator_new,
2029 options::OPT_fno_assume_sane_operator_new))
2030 CmdArgs.push_back("-fno-assume-sane-operator-new");
2031
Daniel Dunbar9e5cc6b2009-11-17 08:07:36 +00002032 // -fblocks=0 is default.
2033 if (Args.hasFlag(options::OPT_fblocks, options::OPT_fno_blocks,
David Chisnalle6533ff2011-02-28 17:11:43 +00002034 getToolChain().IsBlocksDefault()) ||
2035 (Args.hasArg(options::OPT_fgnu_runtime) &&
2036 Args.hasArg(options::OPT_fobjc_nonfragile_abi) &&
2037 !Args.hasArg(options::OPT_fno_blocks))) {
Daniel Dunbar9e5cc6b2009-11-17 08:07:36 +00002038 CmdArgs.push_back("-fblocks");
John McCall13db5cf2011-09-09 20:41:01 +00002039
2040 if (!Args.hasArg(options::OPT_fgnu_runtime) &&
2041 !getToolChain().hasBlocksRuntime())
2042 CmdArgs.push_back("-fblocks-runtime-optional");
David Chisnall5e530af2009-11-17 19:33:30 +00002043 }
Daniel Dunbar48d1ef72009-04-07 21:16:11 +00002044
Douglas Gregor64554ba2012-01-18 15:19:58 +00002045 // -fmodules enables modules (off by default). However, for C++/Objective-C++,
2046 // users must also pass -fcxx-modules. The latter flag will disappear once the
2047 // modules implementation is solid for C++/Objective-C++ programs as well.
2048 if (Args.hasFlag(options::OPT_fmodules, options::OPT_fno_modules, false)) {
2049 bool AllowedInCXX = Args.hasFlag(options::OPT_fcxx_modules,
2050 options::OPT_fno_cxx_modules,
2051 false);
2052 if (AllowedInCXX || !types::isCXX(InputType))
2053 CmdArgs.push_back("-fmodules");
2054 }
Douglas Gregor7025d2c2012-01-03 17:13:05 +00002055
John McCall32579cf2010-04-09 19:12:06 +00002056 // -faccess-control is default.
John McCall7002f4c2010-04-09 19:03:51 +00002057 if (Args.hasFlag(options::OPT_fno_access_control,
2058 options::OPT_faccess_control,
John McCall32579cf2010-04-09 19:12:06 +00002059 false))
John McCall7002f4c2010-04-09 19:03:51 +00002060 CmdArgs.push_back("-fno-access-control");
John McCall3ddd6e02010-03-17 01:32:13 +00002061
Anders Carlssona4c24752010-11-21 00:09:52 +00002062 // -felide-constructors is the default.
2063 if (Args.hasFlag(options::OPT_fno_elide_constructors,
2064 options::OPT_felide_constructors,
2065 false))
2066 CmdArgs.push_back("-fno-elide-constructors");
2067
Daniel Dunbar0be42c42009-11-17 07:06:20 +00002068 // -frtti is default.
Daniel Dunbar0a80ba72010-03-20 04:52:14 +00002069 if (KernelOrKext ||
2070 !Args.hasFlag(options::OPT_frtti, options::OPT_fno_rtti))
Daniel Dunbar53e84842009-11-19 04:55:23 +00002071 CmdArgs.push_back("-fno-rtti");
Mike Stump738f8c22009-07-31 23:15:31 +00002072
Tony Linthicum96319392011-12-12 21:14:55 +00002073 // -fshort-enums=0 is default for all architectures except Hexagon.
Argyrios Kyrtzidis9a2b9d72010-10-08 00:25:19 +00002074 if (Args.hasFlag(options::OPT_fshort_enums,
Tony Linthicum96319392011-12-12 21:14:55 +00002075 options::OPT_fno_short_enums,
2076 getToolChain().getTriple().getArch() ==
2077 llvm::Triple::hexagon))
Argyrios Kyrtzidis9a2b9d72010-10-08 00:25:19 +00002078 CmdArgs.push_back("-fshort-enums");
2079
Daniel Dunbar1f95e652009-11-17 06:37:03 +00002080 // -fsigned-char is default.
Daniel Dunbar6d2eb4d2009-11-25 10:14:30 +00002081 if (!Args.hasFlag(options::OPT_fsigned_char, options::OPT_funsigned_char,
Daniel Dunbar1f95e652009-11-17 06:37:03 +00002082 isSignedCharDefault(getToolChain().getTriple())))
Daniel Dunbar76743522009-11-29 02:39:08 +00002083 CmdArgs.push_back("-fno-signed-char");
Eli Friedman5a779732009-06-05 07:21:14 +00002084
Anders Carlssona508b7d2010-02-06 23:23:06 +00002085 // -fthreadsafe-static is default.
Michael J. Spencer20249a12010-10-21 03:16:25 +00002086 if (!Args.hasFlag(options::OPT_fthreadsafe_statics,
Anders Carlssona508b7d2010-02-06 23:23:06 +00002087 options::OPT_fno_threadsafe_statics))
2088 CmdArgs.push_back("-fno-threadsafe-statics");
2089
Daniel Dunbarefb0fa92010-03-20 04:15:41 +00002090 // -fuse-cxa-atexit is default.
Anton Korobeynikovd0a57d52010-09-11 11:17:06 +00002091 if (KernelOrKext ||
2092 !Args.hasFlag(options::OPT_fuse_cxa_atexit, options::OPT_fno_use_cxa_atexit,
NAKAMURA Takumicd7a30b2010-10-10 01:53:03 +00002093 getToolChain().getTriple().getOS() != llvm::Triple::Cygwin &&
Tony Linthicum96319392011-12-12 21:14:55 +00002094 getToolChain().getTriple().getOS() != llvm::Triple::MinGW32 &&
2095 getToolChain().getTriple().getArch() !=
2096 llvm::Triple::hexagon))
Daniel Dunbarefb0fa92010-03-20 04:15:41 +00002097 CmdArgs.push_back("-fno-use-cxa-atexit");
2098
Daniel Dunbar0be42c42009-11-17 07:06:20 +00002099 // -fms-extensions=0 is default.
Daniel Dunbar6d2eb4d2009-11-25 10:14:30 +00002100 if (Args.hasFlag(options::OPT_fms_extensions, options::OPT_fno_ms_extensions,
Daniel Dunbar0be42c42009-11-17 07:06:20 +00002101 getToolChain().getTriple().getOS() == llvm::Triple::Win32))
2102 CmdArgs.push_back("-fms-extensions");
2103
Francois Pichetae556082011-09-17 04:32:15 +00002104 // -fms-compatibility=0 is default.
Douglas Gregorba97b6e2011-10-24 15:49:38 +00002105 if (Args.hasFlag(options::OPT_fms_compatibility,
2106 options::OPT_fno_ms_compatibility,
2107 (getToolChain().getTriple().getOS() == llvm::Triple::Win32 &&
2108 Args.hasFlag(options::OPT_fms_extensions,
2109 options::OPT_fno_ms_extensions,
2110 true))))
Francois Pichetae556082011-09-17 04:32:15 +00002111 CmdArgs.push_back("-fms-compatibility");
2112
Michael J. Spencerdae4ac42010-10-21 05:21:48 +00002113 // -fmsc-version=1300 is default.
2114 if (Args.hasFlag(options::OPT_fms_extensions, options::OPT_fno_ms_extensions,
2115 getToolChain().getTriple().getOS() == llvm::Triple::Win32) ||
2116 Args.hasArg(options::OPT_fmsc_version)) {
Chris Lattner5f9e2722011-07-23 10:55:15 +00002117 StringRef msc_ver = Args.getLastArgValue(options::OPT_fmsc_version);
Michael J. Spencerdae4ac42010-10-21 05:21:48 +00002118 if (msc_ver.empty())
2119 CmdArgs.push_back("-fmsc-version=1300");
2120 else
2121 CmdArgs.push_back(Args.MakeArgString("-fmsc-version=" + msc_ver));
2122 }
2123
2124
Dawn Perchik400b6072010-09-02 23:59:25 +00002125 // -fborland-extensions=0 is default.
2126 if (Args.hasFlag(options::OPT_fborland_extensions,
2127 options::OPT_fno_borland_extensions, false))
2128 CmdArgs.push_back("-fborland-extensions");
2129
Francois Pichet8efcc012011-09-01 16:38:08 +00002130 // -fno-delayed-template-parsing is default, except for Windows where MSVC STL
2131 // needs it.
Francois Pichet8387e2a2011-04-22 22:18:13 +00002132 if (Args.hasFlag(options::OPT_fdelayed_template_parsing,
2133 options::OPT_fno_delayed_template_parsing,
Francois Pichet8efcc012011-09-01 16:38:08 +00002134 getToolChain().getTriple().getOS() == llvm::Triple::Win32))
Francois Pichet805bc1f2011-08-26 00:22:34 +00002135 CmdArgs.push_back("-fdelayed-template-parsing");
Francois Pichet8387e2a2011-04-22 22:18:13 +00002136
Chandler Carrutheb5d7b72010-04-17 20:17:31 +00002137 // -fgnu-keywords default varies depending on language; only pass if
2138 // specified.
2139 if (Arg *A = Args.getLastArg(options::OPT_fgnu_keywords,
Daniel Dunbar40788d92010-04-24 17:56:39 +00002140 options::OPT_fno_gnu_keywords))
2141 A->render(Args, CmdArgs);
Chandler Carrutheb5d7b72010-04-17 20:17:31 +00002142
Rafael Espindola01ba8542011-06-02 17:30:53 +00002143 if (Args.hasFlag(options::OPT_fgnu89_inline,
2144 options::OPT_fno_gnu89_inline,
2145 false))
Rafael Espindolafb3f4aa2011-06-02 16:13:27 +00002146 CmdArgs.push_back("-fgnu89-inline");
2147
Chad Rosier250008b2012-03-06 18:49:20 +00002148 if (Args.hasArg(options::OPT_fno_inline))
2149 CmdArgs.push_back("-fno-inline");
2150
Daniel Dunbar9e5cc6b2009-11-17 08:07:36 +00002151 // -fobjc-nonfragile-abi=0 is default.
John McCall9f084a32011-07-06 00:26:06 +00002152 ObjCRuntime objCRuntime;
John McCalld71315c2011-06-22 00:53:57 +00002153 unsigned objcABIVersion = 0;
David Chisnall3c3ccd22011-09-30 13:32:35 +00002154 bool NeXTRuntimeIsDefault
2155 = (IsRewriter || getToolChain().getTriple().isOSDarwin());
2156 if (Args.hasFlag(options::OPT_fnext_runtime, options::OPT_fgnu_runtime,
2157 NeXTRuntimeIsDefault)) {
2158 objCRuntime.setKind(ObjCRuntime::NeXT);
2159 } else {
2160 CmdArgs.push_back("-fgnu-runtime");
2161 objCRuntime.setKind(ObjCRuntime::GNU);
2162 }
2163 getToolChain().configureObjCRuntime(objCRuntime);
2164 if (objCRuntime.HasARC)
2165 CmdArgs.push_back("-fobjc-runtime-has-arc");
2166 if (objCRuntime.HasWeak)
2167 CmdArgs.push_back("-fobjc-runtime-has-weak");
2168 if (objCRuntime.HasTerminate)
2169 CmdArgs.push_back("-fobjc-runtime-has-terminate");
John McCall9f084a32011-07-06 00:26:06 +00002170
David Chisnall3c3ccd22011-09-30 13:32:35 +00002171 // Compute the Objective-C ABI "version" to use. Version numbers are
2172 // slightly confusing for historical reasons:
2173 // 1 - Traditional "fragile" ABI
2174 // 2 - Non-fragile ABI, version 1
2175 // 3 - Non-fragile ABI, version 2
2176 objcABIVersion = 1;
2177 // If -fobjc-abi-version= is present, use that to set the version.
2178 if (Arg *A = Args.getLastArg(options::OPT_fobjc_abi_version_EQ)) {
2179 if (StringRef(A->getValue(Args)) == "1")
2180 objcABIVersion = 1;
2181 else if (StringRef(A->getValue(Args)) == "2")
2182 objcABIVersion = 2;
2183 else if (StringRef(A->getValue(Args)) == "3")
2184 objcABIVersion = 3;
2185 else
2186 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
2187 } else {
2188 // Otherwise, determine if we are using the non-fragile ABI.
Douglas Gregord596c4d2011-10-12 18:28:53 +00002189 bool NonFragileABIIsDefault
2190 = (!IsRewriter && getToolChain().IsObjCNonFragileABIDefault());
David Chisnall3c3ccd22011-09-30 13:32:35 +00002191 if (Args.hasFlag(options::OPT_fobjc_nonfragile_abi,
2192 options::OPT_fno_objc_nonfragile_abi,
Douglas Gregord596c4d2011-10-12 18:28:53 +00002193 NonFragileABIIsDefault)) {
David Chisnall3c3ccd22011-09-30 13:32:35 +00002194 // Determine the non-fragile ABI version to use.
Daniel Dunbarde17ba72010-11-11 16:08:59 +00002195#ifdef DISABLE_DEFAULT_NONFRAGILEABI_TWO
David Chisnall3c3ccd22011-09-30 13:32:35 +00002196 unsigned NonFragileABIVersion = 1;
Daniel Dunbarde17ba72010-11-11 16:08:59 +00002197#else
David Chisnall3c3ccd22011-09-30 13:32:35 +00002198 unsigned NonFragileABIVersion = 2;
Daniel Dunbarde17ba72010-11-11 16:08:59 +00002199#endif
Daniel Dunbardea63132010-09-20 18:19:55 +00002200
David Chisnall3c3ccd22011-09-30 13:32:35 +00002201 if (Arg *A = Args.getLastArg(
2202 options::OPT_fobjc_nonfragile_abi_version_EQ)) {
2203 if (StringRef(A->getValue(Args)) == "1")
2204 NonFragileABIVersion = 1;
2205 else if (StringRef(A->getValue(Args)) == "2")
2206 NonFragileABIVersion = 2;
Daniel Dunbarf643b9b2010-04-24 17:56:46 +00002207 else
David Chisnall3c3ccd22011-09-30 13:32:35 +00002208 D.Diag(diag::err_drv_clang_unsupported)
2209 << A->getAsString(Args);
Daniel Dunbarf643b9b2010-04-24 17:56:46 +00002210 }
NAKAMURA Takumi125b4cb2011-02-17 08:50:50 +00002211
David Chisnall3c3ccd22011-09-30 13:32:35 +00002212 objcABIVersion = 1 + NonFragileABIVersion;
2213 } else {
2214 objcABIVersion = 1;
Ted Kremenekc32647d2010-12-23 21:35:43 +00002215 }
Daniel Dunbar9e5cc6b2009-11-17 08:07:36 +00002216 }
2217
John McCalld1e40d52011-10-02 01:16:38 +00002218 if (objcABIVersion == 1) {
2219 CmdArgs.push_back("-fobjc-fragile-abi");
2220 } else {
David Chisnall3c3ccd22011-09-30 13:32:35 +00002221 // -fobjc-dispatch-method is only relevant with the nonfragile-abi, and
2222 // legacy is the default.
2223 if (!Args.hasFlag(options::OPT_fobjc_legacy_dispatch,
2224 options::OPT_fno_objc_legacy_dispatch,
2225 getToolChain().IsObjCLegacyDispatchDefault())) {
2226 if (getToolChain().UseObjCMixedDispatch())
2227 CmdArgs.push_back("-fobjc-dispatch-method=mixed");
2228 else
2229 CmdArgs.push_back("-fobjc-dispatch-method=non-legacy");
2230 }
2231 }
2232
2233 // -fobjc-default-synthesize-properties=0 is default.
2234 if (Args.hasFlag(options::OPT_fobjc_default_synthesize_properties,
2235 options::OPT_fno_objc_default_synthesize_properties,
2236 getToolChain().IsObjCDefaultSynthPropertiesDefault())) {
2237 CmdArgs.push_back("-fobjc-default-synthesize-properties");
2238 }
2239
John McCall9f084a32011-07-06 00:26:06 +00002240 // Allow -fno-objc-arr to trump -fobjc-arr/-fobjc-arc.
2241 // NOTE: This logic is duplicated in ToolChains.cpp.
2242 bool ARC = isObjCAutoRefCount(Args);
2243 if (ARC) {
Argyrios Kyrtzidis5840dd92012-02-29 03:43:52 +00002244 if (!getToolChain().SupportsObjCARC())
2245 D.Diag(diag::err_arc_unsupported);
2246
John McCall9f084a32011-07-06 00:26:06 +00002247 CmdArgs.push_back("-fobjc-arc");
2248
Chandler Carruth7ffa0322011-11-04 07:34:47 +00002249 // FIXME: It seems like this entire block, and several around it should be
2250 // wrapped in isObjC, but for now we just use it here as this is where it
2251 // was being used previously.
2252 if (types::isCXX(InputType) && types::isObjC(InputType)) {
2253 if (getToolChain().GetCXXStdlibType(Args) == ToolChain::CST_Libcxx)
2254 CmdArgs.push_back("-fobjc-arc-cxxlib=libc++");
2255 else
2256 CmdArgs.push_back("-fobjc-arc-cxxlib=libstdc++");
2257 }
2258
John McCall9f084a32011-07-06 00:26:06 +00002259 // Allow the user to enable full exceptions code emission.
2260 // We define off for Objective-CC, on for Objective-C++.
2261 if (Args.hasFlag(options::OPT_fobjc_arc_exceptions,
2262 options::OPT_fno_objc_arc_exceptions,
2263 /*default*/ types::isCXX(InputType)))
2264 CmdArgs.push_back("-fobjc-arc-exceptions");
2265 }
2266
2267 // -fobjc-infer-related-result-type is the default, except in the Objective-C
2268 // rewriter.
2269 if (IsRewriter)
2270 CmdArgs.push_back("-fno-objc-infer-related-result-type");
Eric Christopher88b7cf02011-08-19 00:30:14 +00002271
John McCall9f084a32011-07-06 00:26:06 +00002272 // Handle -fobjc-gc and -fobjc-gc-only. They are exclusive, and -fobjc-gc-only
2273 // takes precedence.
2274 const Arg *GCArg = Args.getLastArg(options::OPT_fobjc_gc_only);
2275 if (!GCArg)
2276 GCArg = Args.getLastArg(options::OPT_fobjc_gc);
2277 if (GCArg) {
2278 if (ARC) {
Chris Lattner5f9e2722011-07-23 10:55:15 +00002279 D.Diag(diag::err_drv_objc_gc_arr)
John McCall9f084a32011-07-06 00:26:06 +00002280 << GCArg->getAsString(Args);
2281 } else if (getToolChain().SupportsObjCGC()) {
2282 GCArg->render(Args, CmdArgs);
2283 } else {
2284 // FIXME: We should move this to a hard error.
Chris Lattner5f9e2722011-07-23 10:55:15 +00002285 D.Diag(diag::warn_drv_objc_gc_unsupported)
John McCall9f084a32011-07-06 00:26:06 +00002286 << GCArg->getAsString(Args);
2287 }
2288 }
2289
John McCalld71315c2011-06-22 00:53:57 +00002290 // Add exception args.
2291 addExceptionArgs(Args, InputType, getToolChain().getTriple(),
2292 KernelOrKext, IsRewriter, objcABIVersion, CmdArgs);
2293
2294 if (getToolChain().UseSjLjExceptions())
2295 CmdArgs.push_back("-fsjlj-exceptions");
2296
2297 // C++ "sane" operator new.
Daniel Dunbar984eb862010-02-01 21:07:25 +00002298 if (!Args.hasFlag(options::OPT_fassume_sane_operator_new,
2299 options::OPT_fno_assume_sane_operator_new))
2300 CmdArgs.push_back("-fno-assume-sane-operator-new");
2301
Daniel Dunbarf35f14d2010-04-27 15:34:57 +00002302 // -fconstant-cfstrings is default, and may be subject to argument translation
2303 // on Darwin.
2304 if (!Args.hasFlag(options::OPT_fconstant_cfstrings,
2305 options::OPT_fno_constant_cfstrings) ||
2306 !Args.hasFlag(options::OPT_mconstant_cfstrings,
2307 options::OPT_mno_constant_cfstrings))
2308 CmdArgs.push_back("-fno-constant-cfstrings");
2309
John Thompsona6fda122009-11-05 20:14:16 +00002310 // -fshort-wchar default varies depending on platform; only
2311 // pass if specified.
Daniel Dunbar1744a352010-04-27 15:35:03 +00002312 if (Arg *A = Args.getLastArg(options::OPT_fshort_wchar))
2313 A->render(Args, CmdArgs);
John Thompsona6fda122009-11-05 20:14:16 +00002314
Daniel Dunbaree848a72009-10-29 02:39:57 +00002315 // -fno-pascal-strings is default, only pass non-default. If the tool chain
2316 // happened to translate to -mpascal-strings, we want to back translate here.
Daniel Dunbar82d00682009-04-07 23:51:44 +00002317 //
2318 // FIXME: This is gross; that translation should be pulled from the
2319 // tool chain.
Daniel Dunbarc21c4852009-04-08 23:54:23 +00002320 if (Args.hasFlag(options::OPT_fpascal_strings,
Daniel Dunbar82d00682009-04-07 23:51:44 +00002321 options::OPT_fno_pascal_strings,
2322 false) ||
2323 Args.hasFlag(options::OPT_mpascal_strings,
2324 options::OPT_mno_pascal_strings,
2325 false))
Daniel Dunbar48d1ef72009-04-07 21:16:11 +00002326 CmdArgs.push_back("-fpascal-strings");
NAKAMURA Takumi125b4cb2011-02-17 08:50:50 +00002327
Daniel Dunbar88934e82011-10-05 21:04:55 +00002328 // Honor -fpack-struct= and -fpack-struct, if given. Note that
2329 // -fno-pack-struct doesn't apply to -fpack-struct=.
2330 if (Arg *A = Args.getLastArg(options::OPT_fpack_struct_EQ)) {
2331 CmdArgs.push_back("-fpack-struct");
2332 CmdArgs.push_back(A->getValue(Args));
2333 } else if (Args.hasFlag(options::OPT_fpack_struct,
2334 options::OPT_fno_pack_struct, false)) {
2335 CmdArgs.push_back("-fpack-struct");
2336 CmdArgs.push_back("1");
2337 }
2338
Fariborz Jahanianb466d012011-01-07 01:05:02 +00002339 if (Args.hasArg(options::OPT_mkernel) ||
2340 Args.hasArg(options::OPT_fapple_kext)) {
2341 if (!Args.hasArg(options::OPT_fcommon))
2342 CmdArgs.push_back("-fno-common");
2343 }
Daniel Dunbar88934e82011-10-05 21:04:55 +00002344
Daniel Dunbar48d1ef72009-04-07 21:16:11 +00002345 // -fcommon is default, only pass non-default.
Fariborz Jahanianb466d012011-01-07 01:05:02 +00002346 else if (!Args.hasFlag(options::OPT_fcommon, options::OPT_fno_common))
Daniel Dunbar48d1ef72009-04-07 21:16:11 +00002347 CmdArgs.push_back("-fno-common");
2348
Daniel Dunbar70d3c922009-04-15 02:37:43 +00002349 // -fsigned-bitfields is default, and clang doesn't yet support
Daniel Dunbar06205ca2010-10-15 22:30:42 +00002350 // -funsigned-bitfields.
Mike Stump1eb44332009-09-09 15:08:12 +00002351 if (!Args.hasFlag(options::OPT_fsigned_bitfields,
Daniel Dunbar70d3c922009-04-15 02:37:43 +00002352 options::OPT_funsigned_bitfields))
Chris Lattner5f9e2722011-07-23 10:55:15 +00002353 D.Diag(diag::warn_drv_clang_unsupported)
Daniel Dunbar70d3c922009-04-15 02:37:43 +00002354 << Args.getLastArg(options::OPT_funsigned_bitfields)->getAsString(Args);
2355
Daniel Dunbar06205ca2010-10-15 22:30:42 +00002356 // -fsigned-bitfields is default, and clang doesn't support -fno-for-scope.
2357 if (!Args.hasFlag(options::OPT_ffor_scope,
2358 options::OPT_fno_for_scope))
Chris Lattner5f9e2722011-07-23 10:55:15 +00002359 D.Diag(diag::err_drv_clang_unsupported)
Daniel Dunbar06205ca2010-10-15 22:30:42 +00002360 << Args.getLastArg(options::OPT_fno_for_scope)->getAsString(Args);
2361
Jeffrey Yasskin0ea22fd2010-06-08 04:56:20 +00002362 // -fcaret-diagnostics is default.
2363 if (!Args.hasFlag(options::OPT_fcaret_diagnostics,
2364 options::OPT_fno_caret_diagnostics, true))
2365 CmdArgs.push_back("-fno-caret-diagnostics");
2366
Daniel Dunbar49138fc2009-04-19 21:09:34 +00002367 // -fdiagnostics-fixit-info is default, only pass non-default.
Mike Stump1eb44332009-09-09 15:08:12 +00002368 if (!Args.hasFlag(options::OPT_fdiagnostics_fixit_info,
Daniel Dunbar49138fc2009-04-19 21:09:34 +00002369 options::OPT_fno_diagnostics_fixit_info))
2370 CmdArgs.push_back("-fno-diagnostics-fixit-info");
Eric Christopher88b7cf02011-08-19 00:30:14 +00002371
Daniel Dunbar9e820ee2009-04-16 06:32:38 +00002372 // Enable -fdiagnostics-show-option by default.
Mike Stump1eb44332009-09-09 15:08:12 +00002373 if (Args.hasFlag(options::OPT_fdiagnostics_show_option,
Daniel Dunbar9e820ee2009-04-16 06:32:38 +00002374 options::OPT_fno_diagnostics_show_option))
2375 CmdArgs.push_back("-fdiagnostics-show-option");
Daniel Dunbar838be482009-11-04 06:24:57 +00002376
Chris Lattner6fbe8392010-05-04 21:55:25 +00002377 if (const Arg *A =
2378 Args.getLastArg(options::OPT_fdiagnostics_show_category_EQ)) {
2379 CmdArgs.push_back("-fdiagnostics-show-category");
2380 CmdArgs.push_back(A->getValue(Args));
2381 }
Daniel Dunbarca0e0542010-08-24 16:47:49 +00002382
Douglas Gregorc9471b02011-05-21 17:07:29 +00002383 if (const Arg *A =
2384 Args.getLastArg(options::OPT_fdiagnostics_format_EQ)) {
2385 CmdArgs.push_back("-fdiagnostics-format");
2386 CmdArgs.push_back(A->getValue(Args));
2387 }
2388
Chandler Carruthabaca7a2011-03-27 01:50:55 +00002389 if (Arg *A = Args.getLastArg(
2390 options::OPT_fdiagnostics_show_note_include_stack,
2391 options::OPT_fno_diagnostics_show_note_include_stack)) {
2392 if (A->getOption().matches(
2393 options::OPT_fdiagnostics_show_note_include_stack))
2394 CmdArgs.push_back("-fdiagnostics-show-note-include-stack");
2395 else
2396 CmdArgs.push_back("-fno-diagnostics-show-note-include-stack");
2397 }
2398
Daniel Dunbar838be482009-11-04 06:24:57 +00002399 // Color diagnostics are the default, unless the terminal doesn't support
2400 // them.
2401 if (Args.hasFlag(options::OPT_fcolor_diagnostics,
Argyrios Kyrtzidisf765d762010-09-23 12:56:06 +00002402 options::OPT_fno_color_diagnostics,
2403 llvm::sys::Process::StandardErrHasColors()))
Daniel Dunbar838be482009-11-04 06:24:57 +00002404 CmdArgs.push_back("-fcolor-diagnostics");
2405
Daniel Dunbar75eb1d62009-06-08 21:13:54 +00002406 if (!Args.hasFlag(options::OPT_fshow_source_location,
2407 options::OPT_fno_show_source_location))
2408 CmdArgs.push_back("-fno-show-source-location");
Daniel Dunbar9e820ee2009-04-16 06:32:38 +00002409
Douglas Gregorc9471b02011-05-21 17:07:29 +00002410 if (!Args.hasFlag(options::OPT_fshow_column,
2411 options::OPT_fno_show_column,
2412 true))
2413 CmdArgs.push_back("-fno-show-column");
2414
Douglas Gregora0068fc2010-07-09 17:35:33 +00002415 if (!Args.hasFlag(options::OPT_fspell_checking,
2416 options::OPT_fno_spell_checking))
2417 CmdArgs.push_back("-fno-spell-checking");
Daniel Dunbarca0e0542010-08-24 16:47:49 +00002418
Daniel Dunbar25b26eb2010-10-18 22:49:46 +00002419
Daniel Dunbar16894392010-11-02 19:42:04 +00002420 // Silently ignore -fasm-blocks for now.
2421 (void) Args.hasFlag(options::OPT_fasm_blocks, options::OPT_fno_asm_blocks,
2422 false);
Daniel Dunbar25b26eb2010-10-18 22:49:46 +00002423
Jeffrey Yasskin5edbdcc2010-06-11 05:57:47 +00002424 if (Arg *A = Args.getLastArg(options::OPT_fshow_overloads_EQ))
2425 A->render(Args, CmdArgs);
2426
Daniel Dunbar7695fba2009-04-19 21:20:32 +00002427 // -fdollars-in-identifiers default varies depending on platform and
2428 // language; only pass if specified.
Mike Stump1eb44332009-09-09 15:08:12 +00002429 if (Arg *A = Args.getLastArg(options::OPT_fdollars_in_identifiers,
Daniel Dunbar7695fba2009-04-19 21:20:32 +00002430 options::OPT_fno_dollars_in_identifiers)) {
2431 if (A->getOption().matches(options::OPT_fdollars_in_identifiers))
Daniel Dunbar8663b182009-12-16 20:10:18 +00002432 CmdArgs.push_back("-fdollars-in-identifiers");
Daniel Dunbar7695fba2009-04-19 21:20:32 +00002433 else
Daniel Dunbar8663b182009-12-16 20:10:18 +00002434 CmdArgs.push_back("-fno-dollars-in-identifiers");
Daniel Dunbar7695fba2009-04-19 21:20:32 +00002435 }
2436
Daniel Dunbare027a4b2009-05-22 19:02:20 +00002437 // -funit-at-a-time is default, and we don't support -fno-unit-at-a-time for
2438 // practical purposes.
Mike Stump1eb44332009-09-09 15:08:12 +00002439 if (Arg *A = Args.getLastArg(options::OPT_funit_at_a_time,
Daniel Dunbare027a4b2009-05-22 19:02:20 +00002440 options::OPT_fno_unit_at_a_time)) {
2441 if (A->getOption().matches(options::OPT_fno_unit_at_a_time))
Chris Lattner5f9e2722011-07-23 10:55:15 +00002442 D.Diag(diag::warn_drv_clang_unsupported) << A->getAsString(Args);
Daniel Dunbare027a4b2009-05-22 19:02:20 +00002443 }
Eli Friedmanceb5c5b2009-07-14 21:58:17 +00002444
Eli Friedman19bda3a2011-11-02 01:53:16 +00002445 if (Args.hasFlag(options::OPT_fapple_pragma_pack,
2446 options::OPT_fno_apple_pragma_pack, false))
2447 CmdArgs.push_back("-fapple-pragma-pack");
2448
Daniel Dunbar2ba91572009-09-10 03:37:02 +00002449 // Default to -fno-builtin-str{cat,cpy} on Darwin for ARM.
Daniel Dunbarf84a4a42009-09-10 04:57:27 +00002450 //
Daniel Dunbar8ff5b282009-12-11 23:00:49 +00002451 // FIXME: This is disabled until clang -cc1 supports -fno-builtin-foo. PR4941.
Daniel Dunbarf84a4a42009-09-10 04:57:27 +00002452#if 0
Bob Wilson905c45f2011-10-14 05:03:44 +00002453 if (getToolChain().getTriple().isOSDarwin() &&
Daniel Dunbar2ba91572009-09-10 03:37:02 +00002454 (getToolChain().getTriple().getArch() == llvm::Triple::arm ||
2455 getToolChain().getTriple().getArch() == llvm::Triple::thumb)) {
2456 if (!Args.hasArg(options::OPT_fbuiltin_strcat))
2457 CmdArgs.push_back("-fno-builtin-strcat");
2458 if (!Args.hasArg(options::OPT_fbuiltin_strcpy))
2459 CmdArgs.push_back("-fno-builtin-strcpy");
2460 }
Daniel Dunbarf84a4a42009-09-10 04:57:27 +00002461#endif
Daniel Dunbar2ba91572009-09-10 03:37:02 +00002462
Daniel Dunbard98750f2011-03-18 21:23:40 +00002463 // Only allow -traditional or -traditional-cpp outside in preprocessing modes.
Mike Stump1eb44332009-09-09 15:08:12 +00002464 if (Arg *A = Args.getLastArg(options::OPT_traditional,
Daniel Dunbard98750f2011-03-18 21:23:40 +00002465 options::OPT_traditional_cpp)) {
2466 if (isa<PreprocessJobAction>(JA))
2467 CmdArgs.push_back("-traditional-cpp");
Eric Christopher88b7cf02011-08-19 00:30:14 +00002468 else
Chris Lattner5f9e2722011-07-23 10:55:15 +00002469 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
Daniel Dunbard98750f2011-03-18 21:23:40 +00002470 }
Eli Friedmanceb5c5b2009-07-14 21:58:17 +00002471
Daniel Dunbar1d460332009-03-18 10:01:51 +00002472 Args.AddLastArg(CmdArgs, options::OPT_dM);
Chris Lattnerd82df3a2009-04-12 01:56:53 +00002473 Args.AddLastArg(CmdArgs, options::OPT_dD);
Ted Kremenek36f6e302011-11-11 00:07:43 +00002474
2475 // Handle serialized diagnostics.
2476 if (Arg *A = Args.getLastArg(options::OPT__serialize_diags)) {
2477 CmdArgs.push_back("-serialize-diagnostic-file");
2478 CmdArgs.push_back(Args.MakeArgString(A->getValue(Args)));
2479 }
Daniel Dunbar1d460332009-03-18 10:01:51 +00002480
Daniel Dunbar3f87fb02010-04-15 06:09:03 +00002481 // Forward -Xclang arguments to -cc1, and -mllvm arguments to the LLVM option
2482 // parser.
Daniel Dunbar1d460332009-03-18 10:01:51 +00002483 Args.AddAllArgValues(CmdArgs, options::OPT_Xclang);
Daniel Dunbar3f87fb02010-04-15 06:09:03 +00002484 for (arg_iterator it = Args.filtered_begin(options::OPT_mllvm),
2485 ie = Args.filtered_end(); it != ie; ++it) {
Daniel Dunbar7e4953e2010-06-11 22:00:13 +00002486 (*it)->claim();
Daniel Dunbarfb36d212010-04-17 06:10:00 +00002487
Daniel Dunbar3f87fb02010-04-15 06:09:03 +00002488 // We translate this by hand to the -cc1 argument, since nightly test uses
2489 // it and developers have been trained to spell it with -mllvm.
Chris Lattner5f9e2722011-07-23 10:55:15 +00002490 if (StringRef((*it)->getValue(Args, 0)) == "-disable-llvm-optzns")
Daniel Dunbar3f87fb02010-04-15 06:09:03 +00002491 CmdArgs.push_back("-disable-llvm-optzns");
2492 else
Daniel Dunbar7e4953e2010-06-11 22:00:13 +00002493 (*it)->render(Args, CmdArgs);
Daniel Dunbar3f87fb02010-04-15 06:09:03 +00002494 }
Daniel Dunbar1d460332009-03-18 10:01:51 +00002495
Daniel Dunbarcd8e4c42009-03-30 06:36:42 +00002496 if (Output.getType() == types::TY_Dependencies) {
2497 // Handled with other dependency code.
Daniel Dunbar115a7922009-03-19 07:29:38 +00002498 } else if (Output.isFilename()) {
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00002499 CmdArgs.push_back("-o");
Daniel Dunbar115a7922009-03-19 07:29:38 +00002500 CmdArgs.push_back(Output.getFilename());
2501 } else {
2502 assert(Output.isNothing() && "Invalid output.");
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00002503 }
2504
Daniel Dunbar1d460332009-03-18 10:01:51 +00002505 for (InputInfoList::const_iterator
2506 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
2507 const InputInfo &II = *it;
2508 CmdArgs.push_back("-x");
2509 CmdArgs.push_back(types::getTypeName(II.getType()));
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00002510 if (II.isFilename())
Daniel Dunbar115a7922009-03-19 07:29:38 +00002511 CmdArgs.push_back(II.getFilename());
Daniel Dunbar1d460332009-03-18 10:01:51 +00002512 else
Daniel Dunbar115a7922009-03-19 07:29:38 +00002513 II.getInputArg().renderAsInput(Args, CmdArgs);
Daniel Dunbar1d460332009-03-18 10:01:51 +00002514 }
Daniel Dunbarc21c4852009-04-08 23:54:23 +00002515
Chris Lattnere6113de2009-11-03 19:50:27 +00002516 Args.AddAllArgs(CmdArgs, options::OPT_undef);
2517
Daniel Dunbara001c1c2010-07-18 21:16:15 +00002518 const char *Exec = getToolChain().getDriver().getClangProgramPath();
Daniel Dunbarf2d8b9f2009-12-18 02:43:17 +00002519
2520 // Optionally embed the -cc1 level arguments into the debug info, for build
2521 // analysis.
2522 if (getToolChain().UseDwarfDebugFlags()) {
Daniel Dunbar6e900472010-06-04 18:47:06 +00002523 ArgStringList OriginalArgs;
2524 for (ArgList::const_iterator it = Args.begin(),
2525 ie = Args.end(); it != ie; ++it)
2526 (*it)->render(Args, OriginalArgs);
Daniel Dunbarca0e0542010-08-24 16:47:49 +00002527
Dylan Noblesmithf7ccbad2012-02-05 02:13:05 +00002528 SmallString<256> Flags;
Daniel Dunbarf2d8b9f2009-12-18 02:43:17 +00002529 Flags += Exec;
Daniel Dunbar6e900472010-06-04 18:47:06 +00002530 for (unsigned i = 0, e = OriginalArgs.size(); i != e; ++i) {
Daniel Dunbarf2d8b9f2009-12-18 02:43:17 +00002531 Flags += " ";
Daniel Dunbar6e900472010-06-04 18:47:06 +00002532 Flags += OriginalArgs[i];
Daniel Dunbarf2d8b9f2009-12-18 02:43:17 +00002533 }
2534 CmdArgs.push_back("-dwarf-debug-flags");
2535 CmdArgs.push_back(Args.MakeArgString(Flags.str()));
2536 }
2537
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00002538 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbara880db02009-03-23 19:03:36 +00002539
Roman Divackybe4c8702011-02-10 16:52:03 +00002540 if (Arg *A = Args.getLastArg(options::OPT_pg))
2541 if (Args.hasArg(options::OPT_fomit_frame_pointer))
Chris Lattner5f9e2722011-07-23 10:55:15 +00002542 D.Diag(diag::err_drv_argument_not_allowed_with)
Roman Divackybe4c8702011-02-10 16:52:03 +00002543 << "-fomit-frame-pointer" << A->getAsString(Args);
Michael J. Spencer20249a12010-10-21 03:16:25 +00002544
Daniel Dunbar68fb4692009-04-03 20:51:31 +00002545 // Claim some arguments which clang supports automatically.
2546
Daniel Dunbarf4046862010-04-15 06:18:42 +00002547 // -fpch-preprocess is used with gcc to add a special marker in the output to
2548 // include the PCH file. Clang's PTH solution is completely transparent, so we
2549 // do not need to deal with it at all.
Daniel Dunbar68fb4692009-04-03 20:51:31 +00002550 Args.ClaimAllArgs(options::OPT_fpch_preprocess);
Daniel Dunbarc21c4852009-04-08 23:54:23 +00002551
Daniel Dunbara880db02009-03-23 19:03:36 +00002552 // Claim some arguments which clang doesn't support, but we don't
2553 // care to warn the user about.
Daniel Dunbarcdd96862009-11-25 11:53:23 +00002554 Args.ClaimAllArgs(options::OPT_clang_ignored_f_Group);
2555 Args.ClaimAllArgs(options::OPT_clang_ignored_m_Group);
Rafael Espindola035ff0c2011-02-28 23:29:45 +00002556
Rafael Espindola9c094fb2011-03-01 05:25:27 +00002557 // Disable warnings for clang -E -use-gold-plugin -emit-llvm foo.c
Rafael Espindola035ff0c2011-02-28 23:29:45 +00002558 Args.ClaimAllArgs(options::OPT_use_gold_plugin);
Rafael Espindola9c094fb2011-03-01 05:25:27 +00002559 Args.ClaimAllArgs(options::OPT_emit_llvm);
Daniel Dunbar47ac7d22009-03-18 06:00:36 +00002560}
2561
Jim Grosbachfc308292012-02-10 20:37:10 +00002562void ClangAs::AddARMTargetArgs(const ArgList &Args,
2563 ArgStringList &CmdArgs) const {
2564 const Driver &D = getToolChain().getDriver();
2565 llvm::Triple Triple = getToolChain().getTriple();
2566
2567 // Set the CPU based on -march= and -mcpu=.
2568 CmdArgs.push_back("-target-cpu");
2569 CmdArgs.push_back(getARMTargetCPU(Args, Triple));
2570
2571 // Honor -mfpu=.
2572 //
2573 // FIXME: Centralize feature selection, defaulting shouldn't be also in the
2574 // frontend target.
2575 if (const Arg *A = Args.getLastArg(options::OPT_mfpu_EQ)) {
2576 StringRef FPU = A->getValue(Args);
2577
2578 // Set the target features based on the FPU.
2579 if (FPU == "fpa" || FPU == "fpe2" || FPU == "fpe3" || FPU == "maverick") {
2580 // Disable any default FPU support.
2581 CmdArgs.push_back("-target-feature");
2582 CmdArgs.push_back("-vfp2");
2583 CmdArgs.push_back("-target-feature");
2584 CmdArgs.push_back("-vfp3");
2585 CmdArgs.push_back("-target-feature");
2586 CmdArgs.push_back("-neon");
2587 } else if (FPU == "vfp3-d16" || FPU == "vfpv3-d16") {
2588 CmdArgs.push_back("-target-feature");
2589 CmdArgs.push_back("+vfp3");
2590 CmdArgs.push_back("-target-feature");
2591 CmdArgs.push_back("+d16");
2592 CmdArgs.push_back("-target-feature");
2593 CmdArgs.push_back("-neon");
2594 } else if (FPU == "vfp") {
2595 CmdArgs.push_back("-target-feature");
2596 CmdArgs.push_back("+vfp2");
2597 CmdArgs.push_back("-target-feature");
2598 CmdArgs.push_back("-neon");
2599 } else if (FPU == "vfp3" || FPU == "vfpv3") {
2600 CmdArgs.push_back("-target-feature");
2601 CmdArgs.push_back("+vfp3");
2602 CmdArgs.push_back("-target-feature");
2603 CmdArgs.push_back("-neon");
2604 } else if (FPU == "neon") {
2605 CmdArgs.push_back("-target-feature");
2606 CmdArgs.push_back("+neon");
2607 } else
2608 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
2609 }
2610}
2611
Daniel Dunbar20a9aa52010-05-20 21:30:13 +00002612void ClangAs::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar20a9aa52010-05-20 21:30:13 +00002613 const InputInfo &Output,
2614 const InputInfoList &Inputs,
2615 const ArgList &Args,
2616 const char *LinkingOutput) const {
Daniel Dunbar20a9aa52010-05-20 21:30:13 +00002617 ArgStringList CmdArgs;
2618
2619 assert(Inputs.size() == 1 && "Unexpected number of inputs.");
2620 const InputInfo &Input = Inputs[0];
2621
Rafael Espindoladbe80d92010-11-17 22:13:25 +00002622 // Don't warn about "clang -w -c foo.s"
2623 Args.ClaimAllArgs(options::OPT_w);
Rafael Espindola9c094fb2011-03-01 05:25:27 +00002624 // and "clang -emit-llvm -c foo.s"
2625 Args.ClaimAllArgs(options::OPT_emit_llvm);
2626 // and "clang -use-gold-plugin -c foo.s"
2627 Args.ClaimAllArgs(options::OPT_use_gold_plugin);
Rafael Espindoladbe80d92010-11-17 22:13:25 +00002628
Daniel Dunbar20a9aa52010-05-20 21:30:13 +00002629 // Invoke ourselves in -cc1as mode.
2630 //
2631 // FIXME: Implement custom jobs for internal actions.
2632 CmdArgs.push_back("-cc1as");
2633
2634 // Add the "effective" target triple.
2635 CmdArgs.push_back("-triple");
Chad Rosier61ab80a2011-09-20 20:44:06 +00002636 std::string TripleStr =
2637 getToolChain().ComputeEffectiveClangTriple(Args, Input.getType());
Daniel Dunbar20a9aa52010-05-20 21:30:13 +00002638 CmdArgs.push_back(Args.MakeArgString(TripleStr));
2639
2640 // Set the output mode, we currently only expect to be used as a real
2641 // assembler.
2642 CmdArgs.push_back("-filetype");
2643 CmdArgs.push_back("obj");
2644
Joerg Sonnenberger359cf922011-05-06 14:35:16 +00002645 if (UseRelaxAll(C, Args))
Daniel Dunbar469d40e2010-05-28 16:43:21 +00002646 CmdArgs.push_back("-relax-all");
Daniel Dunbar99298002010-05-27 06:18:05 +00002647
Jim Grosbachfc308292012-02-10 20:37:10 +00002648 // Add target specific cpu and features flags.
2649 switch(getToolChain().getTriple().getArch()) {
2650 default:
2651 break;
2652
2653 case llvm::Triple::arm:
2654 case llvm::Triple::thumb:
2655 AddARMTargetArgs(Args, CmdArgs);
2656 break;
2657 }
2658
Daniel Dunbar7f6f8c82011-03-17 17:37:29 +00002659 // Ignore explicit -force_cpusubtype_ALL option.
2660 (void) Args.hasArg(options::OPT_force__cpusubtype__ALL);
Daniel Dunbar20a9aa52010-05-20 21:30:13 +00002661
Eric Christopher8f0a4032012-01-10 00:38:01 +00002662 // Determine the original source input.
2663 const Action *SourceAction = &JA;
2664 while (SourceAction->getKind() != Action::InputClass) {
2665 assert(!SourceAction->getInputs().empty() && "unexpected root action!");
2666 SourceAction = SourceAction->getInputs()[0];
2667 }
2668
2669 // Forward -g, assuming we are dealing with an actual assembly file.
2670 if (SourceAction->getType() == types::TY_Asm ||
2671 SourceAction->getType() == types::TY_PP_Asm) {
2672 Args.ClaimAllArgs(options::OPT_g_Group);
2673 if (Arg *A = Args.getLastArg(options::OPT_g_Group))
2674 if (!A->getOption().matches(options::OPT_g0))
2675 CmdArgs.push_back("-g");
2676 }
Kevin Enderby567003e2011-12-22 19:31:58 +00002677
2678 // Optionally embed the -cc1as level arguments into the debug info, for build
2679 // analysis.
2680 if (getToolChain().UseDwarfDebugFlags()) {
2681 ArgStringList OriginalArgs;
2682 for (ArgList::const_iterator it = Args.begin(),
2683 ie = Args.end(); it != ie; ++it)
2684 (*it)->render(Args, OriginalArgs);
2685
Dylan Noblesmithf7ccbad2012-02-05 02:13:05 +00002686 SmallString<256> Flags;
Kevin Enderby567003e2011-12-22 19:31:58 +00002687 const char *Exec = getToolChain().getDriver().getClangProgramPath();
2688 Flags += Exec;
2689 for (unsigned i = 0, e = OriginalArgs.size(); i != e; ++i) {
2690 Flags += " ";
2691 Flags += OriginalArgs[i];
2692 }
2693 CmdArgs.push_back("-dwarf-debug-flags");
2694 CmdArgs.push_back(Args.MakeArgString(Flags.str()));
2695 }
Daniel Dunbar20a9aa52010-05-20 21:30:13 +00002696
2697 // FIXME: Add -static support, once we have it.
2698
2699 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
2700 options::OPT_Xassembler);
Daniel Dunbar3df23252011-04-29 17:53:18 +00002701 Args.AddAllArgs(CmdArgs, options::OPT_mllvm);
Daniel Dunbar20a9aa52010-05-20 21:30:13 +00002702
2703 assert(Output.isFilename() && "Unexpected lipo output.");
2704 CmdArgs.push_back("-o");
2705 CmdArgs.push_back(Output.getFilename());
2706
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00002707 assert(Input.isFilename() && "Invalid input.");
2708 CmdArgs.push_back(Input.getFilename());
Daniel Dunbar20a9aa52010-05-20 21:30:13 +00002709
Daniel Dunbara001c1c2010-07-18 21:16:15 +00002710 const char *Exec = getToolChain().getDriver().getClangProgramPath();
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00002711 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbar20a9aa52010-05-20 21:30:13 +00002712}
2713
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00002714void gcc::Common::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00002715 const InputInfo &Output,
2716 const InputInfoList &Inputs,
Daniel Dunbar1d460332009-03-18 10:01:51 +00002717 const ArgList &Args,
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00002718 const char *LinkingOutput) const {
Daniel Dunbaree788e72009-12-21 18:54:17 +00002719 const Driver &D = getToolChain().getDriver();
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00002720 ArgStringList CmdArgs;
Daniel Dunbar47ac7d22009-03-18 06:00:36 +00002721
Daniel Dunbarc21c4852009-04-08 23:54:23 +00002722 for (ArgList::const_iterator
Daniel Dunbar1d460332009-03-18 10:01:51 +00002723 it = Args.begin(), ie = Args.end(); it != ie; ++it) {
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00002724 Arg *A = *it;
Daniel Dunbar75877192009-03-19 07:55:12 +00002725 if (A->getOption().hasForwardToGCC()) {
Daniel Dunbar2dffe2d2010-08-03 16:14:14 +00002726 // Don't forward any -g arguments to assembly steps.
2727 if (isa<AssembleJobAction>(JA) &&
2728 A->getOption().matches(options::OPT_g_Group))
2729 continue;
2730
Daniel Dunbar75877192009-03-19 07:55:12 +00002731 // It is unfortunate that we have to claim here, as this means
2732 // we will basically never report anything interesting for
Daniel Dunbar6ecc7a92009-05-02 21:41:52 +00002733 // platforms using a generic gcc, even if we are just using gcc
2734 // to get to the assembler.
Daniel Dunbar75877192009-03-19 07:55:12 +00002735 A->claim();
Daniel Dunbar1d460332009-03-18 10:01:51 +00002736 A->render(Args, CmdArgs);
Daniel Dunbar75877192009-03-19 07:55:12 +00002737 }
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00002738 }
Daniel Dunbarc21c4852009-04-08 23:54:23 +00002739
Daniel Dunbar82b51cc2010-01-25 22:35:08 +00002740 RenderExtraToolArgs(JA, CmdArgs);
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00002741
2742 // If using a driver driver, force the arch.
Daniel Dunbar7cfe31a2009-05-22 02:21:04 +00002743 const std::string &Arch = getToolChain().getArchName();
Bob Wilson905c45f2011-10-14 05:03:44 +00002744 if (getToolChain().getTriple().isOSDarwin()) {
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00002745 CmdArgs.push_back("-arch");
Daniel Dunbarbf54a062009-04-01 20:33:11 +00002746
2747 // FIXME: Remove these special cases.
Daniel Dunbar7cfe31a2009-05-22 02:21:04 +00002748 if (Arch == "powerpc")
2749 CmdArgs.push_back("ppc");
2750 else if (Arch == "powerpc64")
2751 CmdArgs.push_back("ppc64");
2752 else
Daniel Dunbar88137642009-09-09 22:32:48 +00002753 CmdArgs.push_back(Args.MakeArgString(Arch));
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00002754 }
2755
Daniel Dunbar6ecc7a92009-05-02 21:41:52 +00002756 // Try to force gcc to match the tool chain we want, if we recognize
2757 // the arch.
Daniel Dunbar7cfe31a2009-05-22 02:21:04 +00002758 //
2759 // FIXME: The triple class should directly provide the information we want
2760 // here.
2761 if (Arch == "i386" || Arch == "powerpc")
Daniel Dunbar6ecc7a92009-05-02 21:41:52 +00002762 CmdArgs.push_back("-m32");
Daniel Dunbar7cfe31a2009-05-22 02:21:04 +00002763 else if (Arch == "x86_64" || Arch == "powerpc64")
Daniel Dunbar6ecc7a92009-05-02 21:41:52 +00002764 CmdArgs.push_back("-m64");
2765
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00002766 if (Output.isFilename()) {
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00002767 CmdArgs.push_back("-o");
Daniel Dunbar115a7922009-03-19 07:29:38 +00002768 CmdArgs.push_back(Output.getFilename());
2769 } else {
2770 assert(Output.isNothing() && "Unexpected output");
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00002771 CmdArgs.push_back("-fsyntax-only");
Daniel Dunbar115a7922009-03-19 07:29:38 +00002772 }
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00002773
Tony Linthicum96319392011-12-12 21:14:55 +00002774 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
2775 options::OPT_Xassembler);
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00002776
2777 // Only pass -x if gcc will understand it; otherwise hope gcc
2778 // understands the suffix correctly. The main use case this would go
2779 // wrong in is for linker inputs if they happened to have an odd
2780 // suffix; really the only way to get this to happen is a command
2781 // like '-x foobar a.c' which will treat a.c like a linker input.
2782 //
2783 // FIXME: For the linker case specifically, can we safely convert
2784 // inputs into '-Wl,' options?
2785 for (InputInfoList::const_iterator
2786 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
2787 const InputInfo &II = *it;
Daniel Dunbara8304f62009-05-02 20:14:53 +00002788
Daniel Dunbar5915fbf2009-09-01 16:57:46 +00002789 // Don't try to pass LLVM or AST inputs to a generic gcc.
Daniel Dunbar6c6424b2010-06-07 23:28:45 +00002790 if (II.getType() == types::TY_LLVM_IR || II.getType() == types::TY_LTO_IR ||
2791 II.getType() == types::TY_LLVM_BC || II.getType() == types::TY_LTO_BC)
Chris Lattner5f9e2722011-07-23 10:55:15 +00002792 D.Diag(diag::err_drv_no_linker_llvm_support)
Daniel Dunbar88137642009-09-09 22:32:48 +00002793 << getToolChain().getTripleString();
Daniel Dunbar5915fbf2009-09-01 16:57:46 +00002794 else if (II.getType() == types::TY_AST)
Chris Lattner5f9e2722011-07-23 10:55:15 +00002795 D.Diag(diag::err_drv_no_ast_support)
Daniel Dunbar88137642009-09-09 22:32:48 +00002796 << getToolChain().getTripleString();
Daniel Dunbara8304f62009-05-02 20:14:53 +00002797
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00002798 if (types::canTypeBeUserSpecified(II.getType())) {
2799 CmdArgs.push_back("-x");
2800 CmdArgs.push_back(types::getTypeName(II.getType()));
2801 }
2802
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00002803 if (II.isFilename())
Daniel Dunbar115a7922009-03-19 07:29:38 +00002804 CmdArgs.push_back(II.getFilename());
Daniel Dunbar48f99942010-09-25 18:10:05 +00002805 else {
2806 const Arg &A = II.getInputArg();
2807
2808 // Reverse translate some rewritten options.
2809 if (A.getOption().matches(options::OPT_Z_reserved_lib_stdcxx)) {
2810 CmdArgs.push_back("-lstdc++");
2811 continue;
2812 }
2813
Daniel Dunbar115a7922009-03-19 07:29:38 +00002814 // Don't render as input, we need gcc to do the translations.
Daniel Dunbar48f99942010-09-25 18:10:05 +00002815 A.render(Args, CmdArgs);
2816 }
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00002817 }
2818
Dylan Noblesmithb8a3e812011-04-09 13:31:59 +00002819 const std::string customGCCName = D.getCCCGenericGCCName();
2820 const char *GCCName;
2821 if (!customGCCName.empty())
2822 GCCName = customGCCName.c_str();
2823 else if (D.CCCIsCXX) {
Dylan Noblesmithb8a3e812011-04-09 13:31:59 +00002824 GCCName = "g++";
Dylan Noblesmithb8a3e812011-04-09 13:31:59 +00002825 } else
2826 GCCName = "gcc";
2827
Daniel Dunbarc21c4852009-04-08 23:54:23 +00002828 const char *Exec =
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00002829 Args.MakeArgString(getToolChain().GetProgramPath(GCCName));
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00002830 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbar47ac7d22009-03-18 06:00:36 +00002831}
2832
Daniel Dunbar82b51cc2010-01-25 22:35:08 +00002833void gcc::Preprocess::RenderExtraToolArgs(const JobAction &JA,
2834 ArgStringList &CmdArgs) const {
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00002835 CmdArgs.push_back("-E");
Daniel Dunbar47ac7d22009-03-18 06:00:36 +00002836}
2837
Daniel Dunbar82b51cc2010-01-25 22:35:08 +00002838void gcc::Precompile::RenderExtraToolArgs(const JobAction &JA,
2839 ArgStringList &CmdArgs) const {
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00002840 // The type is good enough.
Daniel Dunbar47ac7d22009-03-18 06:00:36 +00002841}
2842
Daniel Dunbar82b51cc2010-01-25 22:35:08 +00002843void gcc::Compile::RenderExtraToolArgs(const JobAction &JA,
2844 ArgStringList &CmdArgs) const {
Daniel Dunbar64952502010-02-11 03:16:21 +00002845 const Driver &D = getToolChain().getDriver();
2846
Daniel Dunbar82b51cc2010-01-25 22:35:08 +00002847 // If -flto, etc. are present then make sure not to force assembly output.
Daniel Dunbar6c6424b2010-06-07 23:28:45 +00002848 if (JA.getType() == types::TY_LLVM_IR || JA.getType() == types::TY_LTO_IR ||
2849 JA.getType() == types::TY_LLVM_BC || JA.getType() == types::TY_LTO_BC)
Daniel Dunbar82b51cc2010-01-25 22:35:08 +00002850 CmdArgs.push_back("-c");
Daniel Dunbar64952502010-02-11 03:16:21 +00002851 else {
2852 if (JA.getType() != types::TY_PP_Asm)
Chris Lattner5f9e2722011-07-23 10:55:15 +00002853 D.Diag(diag::err_drv_invalid_gcc_output_type)
Daniel Dunbar64952502010-02-11 03:16:21 +00002854 << getTypeName(JA.getType());
Michael J. Spencer20249a12010-10-21 03:16:25 +00002855
Daniel Dunbar82b51cc2010-01-25 22:35:08 +00002856 CmdArgs.push_back("-S");
Daniel Dunbar64952502010-02-11 03:16:21 +00002857 }
Daniel Dunbar47ac7d22009-03-18 06:00:36 +00002858}
2859
Daniel Dunbar82b51cc2010-01-25 22:35:08 +00002860void gcc::Assemble::RenderExtraToolArgs(const JobAction &JA,
2861 ArgStringList &CmdArgs) const {
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00002862 CmdArgs.push_back("-c");
Daniel Dunbar47ac7d22009-03-18 06:00:36 +00002863}
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00002864
Daniel Dunbar82b51cc2010-01-25 22:35:08 +00002865void gcc::Link::RenderExtraToolArgs(const JobAction &JA,
2866 ArgStringList &CmdArgs) const {
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00002867 // The types are (hopefully) good enough.
2868}
2869
Tony Linthicum96319392011-12-12 21:14:55 +00002870// Hexagon tools start.
2871void hexagon::Assemble::RenderExtraToolArgs(const JobAction &JA,
2872 ArgStringList &CmdArgs) const {
2873
2874}
2875void hexagon::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
2876 const InputInfo &Output,
2877 const InputInfoList &Inputs,
2878 const ArgList &Args,
2879 const char *LinkingOutput) const {
2880
2881 const Driver &D = getToolChain().getDriver();
2882 ArgStringList CmdArgs;
2883
2884 std::string MarchString = "-march=";
2885 MarchString += getHexagonTargetCPU(Args);
2886 CmdArgs.push_back(Args.MakeArgString(MarchString));
2887
2888 RenderExtraToolArgs(JA, CmdArgs);
2889
2890 if (Output.isFilename()) {
2891 CmdArgs.push_back("-o");
2892 CmdArgs.push_back(Output.getFilename());
2893 } else {
2894 assert(Output.isNothing() && "Unexpected output");
2895 CmdArgs.push_back("-fsyntax-only");
2896 }
2897
2898
2899 // Only pass -x if gcc will understand it; otherwise hope gcc
2900 // understands the suffix correctly. The main use case this would go
2901 // wrong in is for linker inputs if they happened to have an odd
2902 // suffix; really the only way to get this to happen is a command
2903 // like '-x foobar a.c' which will treat a.c like a linker input.
2904 //
2905 // FIXME: For the linker case specifically, can we safely convert
2906 // inputs into '-Wl,' options?
2907 for (InputInfoList::const_iterator
2908 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
2909 const InputInfo &II = *it;
2910
2911 // Don't try to pass LLVM or AST inputs to a generic gcc.
2912 if (II.getType() == types::TY_LLVM_IR || II.getType() == types::TY_LTO_IR ||
2913 II.getType() == types::TY_LLVM_BC || II.getType() == types::TY_LTO_BC)
2914 D.Diag(clang::diag::err_drv_no_linker_llvm_support)
2915 << getToolChain().getTripleString();
2916 else if (II.getType() == types::TY_AST)
2917 D.Diag(clang::diag::err_drv_no_ast_support)
2918 << getToolChain().getTripleString();
2919
2920 if (II.isFilename())
2921 CmdArgs.push_back(II.getFilename());
2922 else
2923 // Don't render as input, we need gcc to do the translations. FIXME: Pranav: What is this ?
2924 II.getInputArg().render(Args, CmdArgs);
2925 }
2926
2927 const char *GCCName = "hexagon-as";
2928 const char *Exec =
2929 Args.MakeArgString(getToolChain().GetProgramPath(GCCName));
2930 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
2931
2932}
2933void hexagon::Link::RenderExtraToolArgs(const JobAction &JA,
2934 ArgStringList &CmdArgs) const {
2935 // The types are (hopefully) good enough.
2936}
2937
2938void hexagon::Link::ConstructJob(Compilation &C, const JobAction &JA,
2939 const InputInfo &Output,
2940 const InputInfoList &Inputs,
2941 const ArgList &Args,
2942 const char *LinkingOutput) const {
2943
2944 const Driver &D = getToolChain().getDriver();
2945 ArgStringList CmdArgs;
2946
2947 for (ArgList::const_iterator
2948 it = Args.begin(), ie = Args.end(); it != ie; ++it) {
2949 Arg *A = *it;
2950 if (A->getOption().hasForwardToGCC()) {
2951 // Don't forward any -g arguments to assembly steps.
2952 if (isa<AssembleJobAction>(JA) &&
2953 A->getOption().matches(options::OPT_g_Group))
2954 continue;
2955
2956 // It is unfortunate that we have to claim here, as this means
2957 // we will basically never report anything interesting for
2958 // platforms using a generic gcc, even if we are just using gcc
2959 // to get to the assembler.
2960 A->claim();
2961 A->render(Args, CmdArgs);
2962 }
2963 }
2964
2965 RenderExtraToolArgs(JA, CmdArgs);
2966
2967 // Add Arch Information
2968 Arg *A;
Sebastian Pop43115d42012-01-13 20:37:10 +00002969 if ((A = getLastHexagonArchArg(Args))) {
2970 if (A->getOption().matches(options::OPT_m_Joined))
2971 A->render(Args, CmdArgs);
Tony Linthicum96319392011-12-12 21:14:55 +00002972 else
Sebastian Pop43115d42012-01-13 20:37:10 +00002973 CmdArgs.push_back (Args.MakeArgString("-m" + getHexagonTargetCPU(Args)));
Tony Linthicum96319392011-12-12 21:14:55 +00002974 }
Sebastian Pop43115d42012-01-13 20:37:10 +00002975 else {
2976 CmdArgs.push_back (Args.MakeArgString("-m" + getHexagonTargetCPU(Args)));
2977 }
2978
Tony Linthicum96319392011-12-12 21:14:55 +00002979 CmdArgs.push_back("-mqdsp6-compat");
2980
2981 const char *GCCName;
2982 if (C.getDriver().CCCIsCXX)
2983 GCCName = "hexagon-g++";
2984 else
2985 GCCName = "hexagon-gcc";
2986 const char *Exec =
2987 Args.MakeArgString(getToolChain().GetProgramPath(GCCName));
2988
2989 if (Output.isFilename()) {
2990 CmdArgs.push_back("-o");
2991 CmdArgs.push_back(Output.getFilename());
2992 }
2993
2994 for (InputInfoList::const_iterator
2995 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
2996 const InputInfo &II = *it;
2997
2998 // Don't try to pass LLVM or AST inputs to a generic gcc.
2999 if (II.getType() == types::TY_LLVM_IR || II.getType() == types::TY_LTO_IR ||
3000 II.getType() == types::TY_LLVM_BC || II.getType() == types::TY_LTO_BC)
3001 D.Diag(clang::diag::err_drv_no_linker_llvm_support)
3002 << getToolChain().getTripleString();
3003 else if (II.getType() == types::TY_AST)
3004 D.Diag(clang::diag::err_drv_no_ast_support)
3005 << getToolChain().getTripleString();
3006
3007 if (II.isFilename())
3008 CmdArgs.push_back(II.getFilename());
3009 else
3010 // Don't render as input, we need gcc to do the translations. FIXME: Pranav: What is this ?
3011 II.getInputArg().render(Args, CmdArgs);
3012 }
3013 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
3014
3015}
3016// Hexagon tools end.
3017
3018
Daniel Dunbar40f12652009-03-29 17:08:39 +00003019const char *darwin::CC1::getCC1Name(types::ID Type) const {
3020 switch (Type) {
3021 default:
David Blaikieb219cfc2011-09-23 05:06:16 +00003022 llvm_unreachable("Unexpected type for Darwin CC1 tool.");
Daniel Dunbar40f12652009-03-29 17:08:39 +00003023 case types::TY_Asm:
3024 case types::TY_C: case types::TY_CHeader:
3025 case types::TY_PP_C: case types::TY_PP_CHeader:
3026 return "cc1";
3027 case types::TY_ObjC: case types::TY_ObjCHeader:
Nico Webercc52a062011-08-13 23:13:37 +00003028 case types::TY_PP_ObjC: case types::TY_PP_ObjC_Alias:
3029 case types::TY_PP_ObjCHeader:
Daniel Dunbar40f12652009-03-29 17:08:39 +00003030 return "cc1obj";
3031 case types::TY_CXX: case types::TY_CXXHeader:
3032 case types::TY_PP_CXX: case types::TY_PP_CXXHeader:
3033 return "cc1plus";
3034 case types::TY_ObjCXX: case types::TY_ObjCXXHeader:
Nico Webercc52a062011-08-13 23:13:37 +00003035 case types::TY_PP_ObjCXX: case types::TY_PP_ObjCXX_Alias:
3036 case types::TY_PP_ObjCXXHeader:
Daniel Dunbar40f12652009-03-29 17:08:39 +00003037 return "cc1objplus";
3038 }
3039}
3040
David Blaikie99ba9e32011-12-20 02:48:34 +00003041void darwin::CC1::anchor() {}
3042
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003043const char *darwin::CC1::getBaseInputName(const ArgList &Args,
Daniel Dunbara5a7bd02009-03-30 00:34:04 +00003044 const InputInfoList &Inputs) {
Michael J. Spencer472ccff2010-12-18 00:19:12 +00003045 return Args.MakeArgString(
3046 llvm::sys::path::filename(Inputs[0].getBaseInput()));
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003047}
3048
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003049const char *darwin::CC1::getBaseInputStem(const ArgList &Args,
Daniel Dunbara5a7bd02009-03-30 00:34:04 +00003050 const InputInfoList &Inputs) {
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003051 const char *Str = getBaseInputName(Args, Inputs);
3052
Chris Lattner657ca662011-01-16 08:14:11 +00003053 if (const char *End = strrchr(Str, '.'))
Daniel Dunbar88137642009-09-09 22:32:48 +00003054 return Args.MakeArgString(std::string(Str, End));
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003055
3056 return Str;
3057}
3058
3059const char *
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003060darwin::CC1::getDependencyFileName(const ArgList &Args,
Daniel Dunbara5a7bd02009-03-30 00:34:04 +00003061 const InputInfoList &Inputs) {
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003062 // FIXME: Think about this more.
3063 std::string Res;
3064
3065 if (Arg *OutputOpt = Args.getLastArg(options::OPT_o)) {
3066 std::string Str(OutputOpt->getValue(Args));
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003067 Res = Str.substr(0, Str.rfind('.'));
Chad Rosier30601782011-08-17 23:08:45 +00003068 } else {
Daniel Dunbara5a7bd02009-03-30 00:34:04 +00003069 Res = darwin::CC1::getBaseInputStem(Args, Inputs);
Chad Rosier30601782011-08-17 23:08:45 +00003070 }
Daniel Dunbar88137642009-09-09 22:32:48 +00003071 return Args.MakeArgString(Res + ".d");
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003072}
3073
Chad Rosier285f9a22011-08-17 18:24:55 +00003074void darwin::CC1::RemoveCC1UnsupportedArgs(ArgStringList &CmdArgs) const {
Eric Christopher88b7cf02011-08-19 00:30:14 +00003075 for (ArgStringList::iterator it = CmdArgs.begin(), ie = CmdArgs.end();
Chad Rosier285f9a22011-08-17 18:24:55 +00003076 it != ie;) {
Chad Rosier8722a5d2011-08-18 17:56:32 +00003077
3078 StringRef Option = *it;
Chad Rosier80717972011-08-26 18:30:43 +00003079 bool RemoveOption = false;
Chad Rosier04225c12011-08-18 01:18:28 +00003080
Bob Wilson2872c8d2012-02-07 01:17:55 +00003081 // Erase both -fmodule-cache-path and its argument.
3082 if (Option.equals("-fmodule-cache-path") && it+2 != ie) {
3083 it = CmdArgs.erase(it, it+2);
Chad Rosier80717972011-08-26 18:30:43 +00003084 ie = CmdArgs.end();
Chad Rosier04225c12011-08-18 01:18:28 +00003085 continue;
3086 }
3087
Bob Wilson2872c8d2012-02-07 01:17:55 +00003088 // Remove unsupported -f options.
3089 if (Option.startswith("-f")) {
3090 // Remove -f/-fno- to reduce the number of cases.
3091 if (Option.startswith("-fno-"))
3092 Option = Option.substr(5);
3093 else
3094 Option = Option.substr(2);
3095 RemoveOption = llvm::StringSwitch<bool>(Option)
3096 .Case("altivec", true)
3097 .Case("modules", true)
3098 .Case("diagnostics-show-note-include-stack", true)
3099 .Default(false);
3100 }
3101
Chad Rosier80717972011-08-26 18:30:43 +00003102 // Handle machine specific options.
3103 if (Option.startswith("-m")) {
3104 RemoveOption = llvm::StringSwitch<bool>(Option)
3105 .Case("-mthumb", true)
3106 .Case("-mno-thumb", true)
3107 .Case("-mno-fused-madd", true)
3108 .Case("-mlong-branch", true)
3109 .Case("-mlongcall", true)
3110 .Case("-mcpu=G4", true)
3111 .Case("-mcpu=G5", true)
3112 .Default(false);
3113 }
3114
3115 // Handle warning options.
3116 if (Option.startswith("-W")) {
3117 // Remove -W/-Wno- to reduce the number of cases.
3118 if (Option.startswith("-Wno-"))
3119 Option = Option.substr(5);
3120 else
3121 Option = Option.substr(2);
3122
3123 RemoveOption = llvm::StringSwitch<bool>(Option)
3124 .Case("address-of-temporary", true)
3125 .Case("ambiguous-member-template", true)
3126 .Case("analyzer-incompatible-plugin", true)
3127 .Case("array-bounds", true)
3128 .Case("array-bounds-pointer-arithmetic", true)
3129 .Case("bind-to-temporary-copy", true)
3130 .Case("bitwise-op-parentheses", true)
3131 .Case("bool-conversions", true)
3132 .Case("builtin-macro-redefined", true)
3133 .Case("c++-hex-floats", true)
3134 .Case("c++0x-compat", true)
3135 .Case("c++0x-extensions", true)
3136 .Case("c++0x-narrowing", true)
Richard Smith575fdda2011-10-13 23:32:09 +00003137 .Case("c++11-compat", true)
3138 .Case("c++11-extensions", true)
3139 .Case("c++11-narrowing", true)
Chad Rosier80717972011-08-26 18:30:43 +00003140 .Case("conditional-uninitialized", true)
3141 .Case("constant-conversion", true)
3142 .Case("CFString-literal", true)
3143 .Case("constant-logical-operand", true)
3144 .Case("custom-atomic-properties", true)
3145 .Case("default-arg-special-member", true)
3146 .Case("delegating-ctor-cycles", true)
3147 .Case("delete-non-virtual-dtor", true)
3148 .Case("deprecated-implementations", true)
3149 .Case("deprecated-writable-strings", true)
3150 .Case("distributed-object-modifiers", true)
3151 .Case("duplicate-method-arg", true)
3152 .Case("dynamic-class-memaccess", true)
3153 .Case("enum-compare", true)
3154 .Case("exit-time-destructors", true)
3155 .Case("gnu", true)
3156 .Case("gnu-designator", true)
3157 .Case("header-hygiene", true)
3158 .Case("idiomatic-parentheses", true)
3159 .Case("ignored-qualifiers", true)
3160 .Case("implicit-atomic-properties", true)
3161 .Case("incompatible-pointer-types", true)
3162 .Case("incomplete-implementation", true)
3163 .Case("initializer-overrides", true)
3164 .Case("invalid-noreturn", true)
3165 .Case("invalid-token-paste", true)
Ivan Krasin08f35a72011-10-06 02:46:34 +00003166 .Case("language-extension-token", true)
Chad Rosier80717972011-08-26 18:30:43 +00003167 .Case("literal-conversion", true)
3168 .Case("literal-range", true)
3169 .Case("local-type-template-args", true)
3170 .Case("logical-op-parentheses", true)
3171 .Case("method-signatures", true)
3172 .Case("microsoft", true)
3173 .Case("mismatched-tags", true)
3174 .Case("missing-method-return-type", true)
3175 .Case("non-pod-varargs", true)
3176 .Case("nonfragile-abi2", true)
3177 .Case("null-arithmetic", true)
3178 .Case("null-dereference", true)
3179 .Case("out-of-line-declaration", true)
3180 .Case("overriding-method-mismatch", true)
3181 .Case("readonly-setter-attrs", true)
3182 .Case("return-stack-address", true)
3183 .Case("self-assign", true)
3184 .Case("semicolon-before-method-body", true)
3185 .Case("sentinel", true)
3186 .Case("shift-overflow", true)
3187 .Case("shift-sign-overflow", true)
3188 .Case("sign-conversion", true)
3189 .Case("sizeof-array-argument", true)
3190 .Case("sizeof-pointer-memaccess", true)
3191 .Case("string-compare", true)
3192 .Case("super-class-method-mismatch", true)
3193 .Case("tautological-compare", true)
3194 .Case("typedef-redefinition", true)
3195 .Case("typename-missing", true)
3196 .Case("undefined-reinterpret-cast", true)
3197 .Case("unknown-warning-option", true)
3198 .Case("unnamed-type-template-args", true)
3199 .Case("unneeded-internal-declaration", true)
3200 .Case("unneeded-member-function", true)
3201 .Case("unused-comparison", true)
3202 .Case("unused-exception-parameter", true)
3203 .Case("unused-member-function", true)
3204 .Case("unused-result", true)
3205 .Case("vector-conversions", true)
3206 .Case("vla", true)
3207 .Case("used-but-marked-unused", true)
3208 .Case("weak-vtables", true)
3209 .Default(false);
3210 } // if (Option.startswith("-W"))
Chad Rosier04225c12011-08-18 01:18:28 +00003211 if (RemoveOption) {
Chad Rosier285f9a22011-08-17 18:24:55 +00003212 it = CmdArgs.erase(it);
Chad Rosiercc0de8c2011-08-17 18:51:56 +00003213 ie = CmdArgs.end();
Chad Rosier30601782011-08-17 23:08:45 +00003214 } else {
Chad Rosier285f9a22011-08-17 18:24:55 +00003215 ++it;
Chad Rosier30601782011-08-17 23:08:45 +00003216 }
Chad Rosier285f9a22011-08-17 18:24:55 +00003217 }
3218}
3219
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003220void darwin::CC1::AddCC1Args(const ArgList &Args,
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003221 ArgStringList &CmdArgs) const {
Daniel Dunbaree788e72009-12-21 18:54:17 +00003222 const Driver &D = getToolChain().getDriver();
Daniel Dunbare2fd6642009-09-10 01:21:12 +00003223
3224 CheckCodeGenerationOptions(D, Args);
3225
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003226 // Derived from cc1 spec.
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003227 if (!Args.hasArg(options::OPT_mkernel) && !Args.hasArg(options::OPT_static) &&
3228 !Args.hasArg(options::OPT_mdynamic_no_pic))
3229 CmdArgs.push_back("-fPIC");
3230
Daniel Dunbar2ba91572009-09-10 03:37:02 +00003231 if (getToolChain().getTriple().getArch() == llvm::Triple::arm ||
3232 getToolChain().getTriple().getArch() == llvm::Triple::thumb) {
3233 if (!Args.hasArg(options::OPT_fbuiltin_strcat))
3234 CmdArgs.push_back("-fno-builtin-strcat");
3235 if (!Args.hasArg(options::OPT_fbuiltin_strcpy))
3236 CmdArgs.push_back("-fno-builtin-strcpy");
3237 }
3238
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003239 if (Args.hasArg(options::OPT_g_Flag) &&
3240 !Args.hasArg(options::OPT_fno_eliminate_unused_debug_symbols))
3241 CmdArgs.push_back("-feliminate-unused-debug-symbols");
3242}
3243
3244void darwin::CC1::AddCC1OptionsArgs(const ArgList &Args, ArgStringList &CmdArgs,
3245 const InputInfoList &Inputs,
3246 const ArgStringList &OutputArgs) const {
Daniel Dunbaree788e72009-12-21 18:54:17 +00003247 const Driver &D = getToolChain().getDriver();
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003248
3249 // Derived from cc1_options spec.
3250 if (Args.hasArg(options::OPT_fast) ||
3251 Args.hasArg(options::OPT_fastf) ||
3252 Args.hasArg(options::OPT_fastcp))
3253 CmdArgs.push_back("-O3");
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003254
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003255 if (Arg *A = Args.getLastArg(options::OPT_pg))
3256 if (Args.hasArg(options::OPT_fomit_frame_pointer))
Chris Lattner5f9e2722011-07-23 10:55:15 +00003257 D.Diag(diag::err_drv_argument_not_allowed_with)
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003258 << A->getAsString(Args) << "-fomit-frame-pointer";
3259
3260 AddCC1Args(Args, CmdArgs);
3261
3262 if (!Args.hasArg(options::OPT_Q))
3263 CmdArgs.push_back("-quiet");
3264
3265 CmdArgs.push_back("-dumpbase");
Daniel Dunbara5a7bd02009-03-30 00:34:04 +00003266 CmdArgs.push_back(darwin::CC1::getBaseInputName(Args, Inputs));
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003267
3268 Args.AddAllArgs(CmdArgs, options::OPT_d_Group);
3269
3270 Args.AddAllArgs(CmdArgs, options::OPT_m_Group);
3271 Args.AddAllArgs(CmdArgs, options::OPT_a_Group);
3272
3273 // FIXME: The goal is to use the user provided -o if that is our
3274 // final output, otherwise to drive from the original input
3275 // name. Find a clean way to go about this.
3276 if ((Args.hasArg(options::OPT_c) || Args.hasArg(options::OPT_S)) &&
3277 Args.hasArg(options::OPT_o)) {
3278 Arg *OutputOpt = Args.getLastArg(options::OPT_o);
3279 CmdArgs.push_back("-auxbase-strip");
3280 CmdArgs.push_back(OutputOpt->getValue(Args));
3281 } else {
3282 CmdArgs.push_back("-auxbase");
Daniel Dunbara5a7bd02009-03-30 00:34:04 +00003283 CmdArgs.push_back(darwin::CC1::getBaseInputStem(Args, Inputs));
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003284 }
3285
3286 Args.AddAllArgs(CmdArgs, options::OPT_g_Group);
3287
3288 Args.AddAllArgs(CmdArgs, options::OPT_O);
3289 // FIXME: -Wall is getting some special treatment. Investigate.
3290 Args.AddAllArgs(CmdArgs, options::OPT_W_Group, options::OPT_pedantic_Group);
3291 Args.AddLastArg(CmdArgs, options::OPT_w);
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003292 Args.AddAllArgs(CmdArgs, options::OPT_std_EQ, options::OPT_ansi,
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003293 options::OPT_trigraphs);
Daniel Dunbara3ff2022009-04-26 01:10:38 +00003294 if (!Args.getLastArg(options::OPT_std_EQ, options::OPT_ansi)) {
3295 // Honor -std-default.
3296 Args.AddAllArgsTranslated(CmdArgs, options::OPT_std_default_EQ,
3297 "-std=", /*Joined=*/true);
3298 }
3299
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003300 if (Args.hasArg(options::OPT_v))
3301 CmdArgs.push_back("-version");
Daniel Dunbarbbe8e3e2011-03-01 18:49:30 +00003302 if (Args.hasArg(options::OPT_pg) &&
3303 getToolChain().SupportsProfiling())
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003304 CmdArgs.push_back("-p");
3305 Args.AddLastArg(CmdArgs, options::OPT_p);
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003306
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003307 // The driver treats -fsyntax-only specially.
Daniel Dunbar2ba91572009-09-10 03:37:02 +00003308 if (getToolChain().getTriple().getArch() == llvm::Triple::arm ||
3309 getToolChain().getTriple().getArch() == llvm::Triple::thumb) {
3310 // Removes -fbuiltin-str{cat,cpy}; these aren't recognized by cc1 but are
3311 // used to inhibit the default -fno-builtin-str{cat,cpy}.
3312 //
3313 // FIXME: Should we grow a better way to deal with "removing" args?
Daniel Dunbarcdd96862009-11-25 11:53:23 +00003314 for (arg_iterator it = Args.filtered_begin(options::OPT_f_Group,
3315 options::OPT_fsyntax_only),
3316 ie = Args.filtered_end(); it != ie; ++it) {
Daniel Dunbar7e4953e2010-06-11 22:00:13 +00003317 if (!(*it)->getOption().matches(options::OPT_fbuiltin_strcat) &&
3318 !(*it)->getOption().matches(options::OPT_fbuiltin_strcpy)) {
3319 (*it)->claim();
3320 (*it)->render(Args, CmdArgs);
Daniel Dunbar2ba91572009-09-10 03:37:02 +00003321 }
3322 }
3323 } else
3324 Args.AddAllArgs(CmdArgs, options::OPT_f_Group, options::OPT_fsyntax_only);
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003325
Daniel Dunbar089f8722011-04-07 20:41:03 +00003326 // Claim Clang only -f options, they aren't worth warning about.
3327 Args.ClaimAllArgs(options::OPT_f_clang_Group);
3328
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003329 Args.AddAllArgs(CmdArgs, options::OPT_undef);
3330 if (Args.hasArg(options::OPT_Qn))
3331 CmdArgs.push_back("-fno-ident");
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003332
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003333 // FIXME: This isn't correct.
3334 //Args.AddLastArg(CmdArgs, options::OPT__help)
3335 //Args.AddLastArg(CmdArgs, options::OPT__targetHelp)
3336
3337 CmdArgs.append(OutputArgs.begin(), OutputArgs.end());
3338
3339 // FIXME: Still don't get what is happening here. Investigate.
3340 Args.AddAllArgs(CmdArgs, options::OPT__param);
3341
3342 if (Args.hasArg(options::OPT_fmudflap) ||
3343 Args.hasArg(options::OPT_fmudflapth)) {
3344 CmdArgs.push_back("-fno-builtin");
3345 CmdArgs.push_back("-fno-merge-constants");
3346 }
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003347
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003348 if (Args.hasArg(options::OPT_coverage)) {
3349 CmdArgs.push_back("-fprofile-arcs");
3350 CmdArgs.push_back("-ftest-coverage");
3351 }
3352
3353 if (types::isCXX(Inputs[0].getType()))
3354 CmdArgs.push_back("-D__private_extern__=extern");
3355}
3356
3357void darwin::CC1::AddCPPOptionsArgs(const ArgList &Args, ArgStringList &CmdArgs,
3358 const InputInfoList &Inputs,
3359 const ArgStringList &OutputArgs) const {
3360 // Derived from cpp_options
3361 AddCPPUniqueOptionsArgs(Args, CmdArgs, Inputs);
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003362
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003363 CmdArgs.append(OutputArgs.begin(), OutputArgs.end());
3364
3365 AddCC1Args(Args, CmdArgs);
3366
3367 // NOTE: The code below has some commonality with cpp_options, but
3368 // in classic gcc style ends up sending things in different
3369 // orders. This may be a good merge candidate once we drop pedantic
3370 // compatibility.
3371
3372 Args.AddAllArgs(CmdArgs, options::OPT_m_Group);
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003373 Args.AddAllArgs(CmdArgs, options::OPT_std_EQ, options::OPT_ansi,
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003374 options::OPT_trigraphs);
Daniel Dunbara3ff2022009-04-26 01:10:38 +00003375 if (!Args.getLastArg(options::OPT_std_EQ, options::OPT_ansi)) {
3376 // Honor -std-default.
3377 Args.AddAllArgsTranslated(CmdArgs, options::OPT_std_default_EQ,
3378 "-std=", /*Joined=*/true);
3379 }
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003380 Args.AddAllArgs(CmdArgs, options::OPT_W_Group, options::OPT_pedantic_Group);
3381 Args.AddLastArg(CmdArgs, options::OPT_w);
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003382
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003383 // The driver treats -fsyntax-only specially.
3384 Args.AddAllArgs(CmdArgs, options::OPT_f_Group, options::OPT_fsyntax_only);
3385
Daniel Dunbar089f8722011-04-07 20:41:03 +00003386 // Claim Clang only -f options, they aren't worth warning about.
3387 Args.ClaimAllArgs(options::OPT_f_clang_Group);
3388
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003389 if (Args.hasArg(options::OPT_g_Group) && !Args.hasArg(options::OPT_g0) &&
3390 !Args.hasArg(options::OPT_fno_working_directory))
3391 CmdArgs.push_back("-fworking-directory");
3392
3393 Args.AddAllArgs(CmdArgs, options::OPT_O);
3394 Args.AddAllArgs(CmdArgs, options::OPT_undef);
3395 if (Args.hasArg(options::OPT_save_temps))
3396 CmdArgs.push_back("-fpch-preprocess");
3397}
3398
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003399void darwin::CC1::AddCPPUniqueOptionsArgs(const ArgList &Args,
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003400 ArgStringList &CmdArgs,
Mike Stump1eb44332009-09-09 15:08:12 +00003401 const InputInfoList &Inputs) const {
Daniel Dunbaree788e72009-12-21 18:54:17 +00003402 const Driver &D = getToolChain().getDriver();
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003403
Daniel Dunbar88a3d6c2009-09-10 01:21:05 +00003404 CheckPreprocessingOptions(D, Args);
3405
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003406 // Derived from cpp_unique_options.
Daniel Dunbar88a3d6c2009-09-10 01:21:05 +00003407 // -{C,CC} only with -E is checked in CheckPreprocessingOptions().
3408 Args.AddLastArg(CmdArgs, options::OPT_C);
3409 Args.AddLastArg(CmdArgs, options::OPT_CC);
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003410 if (!Args.hasArg(options::OPT_Q))
3411 CmdArgs.push_back("-quiet");
3412 Args.AddAllArgs(CmdArgs, options::OPT_nostdinc);
Douglas Gregor4c2bcad2010-03-24 20:13:48 +00003413 Args.AddAllArgs(CmdArgs, options::OPT_nostdincxx);
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003414 Args.AddLastArg(CmdArgs, options::OPT_v);
3415 Args.AddAllArgs(CmdArgs, options::OPT_I_Group, options::OPT_F);
3416 Args.AddLastArg(CmdArgs, options::OPT_P);
3417
3418 // FIXME: Handle %I properly.
3419 if (getToolChain().getArchName() == "x86_64") {
3420 CmdArgs.push_back("-imultilib");
3421 CmdArgs.push_back("x86_64");
3422 }
3423
3424 if (Args.hasArg(options::OPT_MD)) {
3425 CmdArgs.push_back("-MD");
Daniel Dunbara5a7bd02009-03-30 00:34:04 +00003426 CmdArgs.push_back(darwin::CC1::getDependencyFileName(Args, Inputs));
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003427 }
3428
3429 if (Args.hasArg(options::OPT_MMD)) {
3430 CmdArgs.push_back("-MMD");
Daniel Dunbara5a7bd02009-03-30 00:34:04 +00003431 CmdArgs.push_back(darwin::CC1::getDependencyFileName(Args, Inputs));
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003432 }
3433
3434 Args.AddLastArg(CmdArgs, options::OPT_M);
3435 Args.AddLastArg(CmdArgs, options::OPT_MM);
3436 Args.AddAllArgs(CmdArgs, options::OPT_MF);
3437 Args.AddLastArg(CmdArgs, options::OPT_MG);
3438 Args.AddLastArg(CmdArgs, options::OPT_MP);
3439 Args.AddAllArgs(CmdArgs, options::OPT_MQ);
3440 Args.AddAllArgs(CmdArgs, options::OPT_MT);
3441 if (!Args.hasArg(options::OPT_M) && !Args.hasArg(options::OPT_MM) &&
3442 (Args.hasArg(options::OPT_MD) || Args.hasArg(options::OPT_MMD))) {
3443 if (Arg *OutputOpt = Args.getLastArg(options::OPT_o)) {
3444 CmdArgs.push_back("-MQ");
3445 CmdArgs.push_back(OutputOpt->getValue(Args));
3446 }
3447 }
3448
3449 Args.AddLastArg(CmdArgs, options::OPT_remap);
3450 if (Args.hasArg(options::OPT_g3))
3451 CmdArgs.push_back("-dD");
3452 Args.AddLastArg(CmdArgs, options::OPT_H);
3453
3454 AddCPPArgs(Args, CmdArgs);
3455
3456 Args.AddAllArgs(CmdArgs, options::OPT_D, options::OPT_U, options::OPT_A);
3457 Args.AddAllArgs(CmdArgs, options::OPT_i_Group);
3458
3459 for (InputInfoList::const_iterator
3460 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
3461 const InputInfo &II = *it;
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003462
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00003463 CmdArgs.push_back(II.getFilename());
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003464 }
3465
3466 Args.AddAllArgValues(CmdArgs, options::OPT_Wp_COMMA,
3467 options::OPT_Xpreprocessor);
3468
3469 if (Args.hasArg(options::OPT_fmudflap)) {
3470 CmdArgs.push_back("-D_MUDFLAP");
3471 CmdArgs.push_back("-include");
3472 CmdArgs.push_back("mf-runtime.h");
3473 }
3474
3475 if (Args.hasArg(options::OPT_fmudflapth)) {
3476 CmdArgs.push_back("-D_MUDFLAP");
3477 CmdArgs.push_back("-D_MUDFLAPTH");
3478 CmdArgs.push_back("-include");
3479 CmdArgs.push_back("mf-runtime.h");
3480 }
3481}
3482
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003483void darwin::CC1::AddCPPArgs(const ArgList &Args,
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003484 ArgStringList &CmdArgs) const {
3485 // Derived from cpp spec.
3486
3487 if (Args.hasArg(options::OPT_static)) {
3488 // The gcc spec is broken here, it refers to dynamic but
3489 // that has been translated. Start by being bug compatible.
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003490
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003491 // if (!Args.hasArg(arglist.parser.dynamicOption))
3492 CmdArgs.push_back("-D__STATIC__");
3493 } else
3494 CmdArgs.push_back("-D__DYNAMIC__");
3495
3496 if (Args.hasArg(options::OPT_pthread))
3497 CmdArgs.push_back("-D_REENTRANT");
3498}
3499
Daniel Dunbar40f12652009-03-29 17:08:39 +00003500void darwin::Preprocess::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00003501 const InputInfo &Output,
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003502 const InputInfoList &Inputs,
3503 const ArgList &Args,
Daniel Dunbar40f12652009-03-29 17:08:39 +00003504 const char *LinkingOutput) const {
3505 ArgStringList CmdArgs;
3506
3507 assert(Inputs.size() == 1 && "Unexpected number of inputs!");
3508
3509 CmdArgs.push_back("-E");
3510
3511 if (Args.hasArg(options::OPT_traditional) ||
Daniel Dunbar40f12652009-03-29 17:08:39 +00003512 Args.hasArg(options::OPT_traditional_cpp))
3513 CmdArgs.push_back("-traditional-cpp");
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003514
Daniel Dunbar40f12652009-03-29 17:08:39 +00003515 ArgStringList OutputArgs;
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00003516 assert(Output.isFilename() && "Unexpected CC1 output.");
3517 OutputArgs.push_back("-o");
3518 OutputArgs.push_back(Output.getFilename());
Daniel Dunbar40f12652009-03-29 17:08:39 +00003519
Joerg Sonnenberger9ade4ae2011-03-06 23:31:01 +00003520 if (Args.hasArg(options::OPT_E) || getToolChain().getDriver().CCCIsCPP) {
Daniel Dunbar9120f172009-03-29 22:27:40 +00003521 AddCPPOptionsArgs(Args, CmdArgs, Inputs, OutputArgs);
3522 } else {
3523 AddCPPOptionsArgs(Args, CmdArgs, Inputs, ArgStringList());
3524 CmdArgs.append(OutputArgs.begin(), OutputArgs.end());
3525 }
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003526
Daniel Dunbar8a2073a2009-04-03 01:27:06 +00003527 Args.AddAllArgs(CmdArgs, options::OPT_d_Group);
3528
Chad Rosier4fe4d732011-09-08 00:38:00 +00003529 RemoveCC1UnsupportedArgs(CmdArgs);
3530
Daniel Dunbar40f12652009-03-29 17:08:39 +00003531 const char *CC1Name = getCC1Name(Inputs[0].getType());
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003532 const char *Exec =
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00003533 Args.MakeArgString(getToolChain().GetProgramPath(CC1Name));
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00003534 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbar40f12652009-03-29 17:08:39 +00003535}
3536
3537void darwin::Compile::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00003538 const InputInfo &Output,
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003539 const InputInfoList &Inputs,
3540 const ArgList &Args,
Daniel Dunbar40f12652009-03-29 17:08:39 +00003541 const char *LinkingOutput) const {
Daniel Dunbaree788e72009-12-21 18:54:17 +00003542 const Driver &D = getToolChain().getDriver();
Daniel Dunbar40f12652009-03-29 17:08:39 +00003543 ArgStringList CmdArgs;
3544
3545 assert(Inputs.size() == 1 && "Unexpected number of inputs!");
3546
3547 types::ID InputType = Inputs[0].getType();
3548 const Arg *A;
Eli Friedmanceb5c5b2009-07-14 21:58:17 +00003549 if ((A = Args.getLastArg(options::OPT_traditional)))
Chris Lattner5f9e2722011-07-23 10:55:15 +00003550 D.Diag(diag::err_drv_argument_only_allowed_with)
Daniel Dunbar40f12652009-03-29 17:08:39 +00003551 << A->getAsString(Args) << "-E";
3552
Daniel Dunbar6c6424b2010-06-07 23:28:45 +00003553 if (JA.getType() == types::TY_LLVM_IR ||
3554 JA.getType() == types::TY_LTO_IR)
Daniel Dunbar40f12652009-03-29 17:08:39 +00003555 CmdArgs.push_back("-emit-llvm");
Daniel Dunbar6c6424b2010-06-07 23:28:45 +00003556 else if (JA.getType() == types::TY_LLVM_BC ||
3557 JA.getType() == types::TY_LTO_BC)
Daniel Dunbar40f12652009-03-29 17:08:39 +00003558 CmdArgs.push_back("-emit-llvm-bc");
Daniel Dunbar5915fbf2009-09-01 16:57:46 +00003559 else if (Output.getType() == types::TY_AST)
Chris Lattner5f9e2722011-07-23 10:55:15 +00003560 D.Diag(diag::err_drv_no_ast_support)
Daniel Dunbar88137642009-09-09 22:32:48 +00003561 << getToolChain().getTripleString();
Daniel Dunbarae24a882010-02-11 17:33:45 +00003562 else if (JA.getType() != types::TY_PP_Asm &&
3563 JA.getType() != types::TY_PCH)
Chris Lattner5f9e2722011-07-23 10:55:15 +00003564 D.Diag(diag::err_drv_invalid_gcc_output_type)
Daniel Dunbar64952502010-02-11 03:16:21 +00003565 << getTypeName(JA.getType());
Daniel Dunbar40f12652009-03-29 17:08:39 +00003566
3567 ArgStringList OutputArgs;
3568 if (Output.getType() != types::TY_PCH) {
3569 OutputArgs.push_back("-o");
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00003570 if (Output.isNothing())
Daniel Dunbar40f12652009-03-29 17:08:39 +00003571 OutputArgs.push_back("/dev/null");
3572 else
3573 OutputArgs.push_back(Output.getFilename());
3574 }
3575
3576 // There is no need for this level of compatibility, but it makes
3577 // diffing easier.
3578 bool OutputArgsEarly = (Args.hasArg(options::OPT_fsyntax_only) ||
3579 Args.hasArg(options::OPT_S));
3580
3581 if (types::getPreprocessedType(InputType) != types::TY_INVALID) {
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00003582 AddCPPUniqueOptionsArgs(Args, CmdArgs, Inputs);
Daniel Dunbar40f12652009-03-29 17:08:39 +00003583 if (OutputArgsEarly) {
3584 AddCC1OptionsArgs(Args, CmdArgs, Inputs, OutputArgs);
3585 } else {
3586 AddCC1OptionsArgs(Args, CmdArgs, Inputs, ArgStringList());
3587 CmdArgs.append(OutputArgs.begin(), OutputArgs.end());
3588 }
3589 } else {
3590 CmdArgs.push_back("-fpreprocessed");
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003591
Daniel Dunbar40f12652009-03-29 17:08:39 +00003592 for (InputInfoList::const_iterator
3593 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
3594 const InputInfo &II = *it;
3595
Daniel Dunbar5915fbf2009-09-01 16:57:46 +00003596 // Reject AST inputs.
3597 if (II.getType() == types::TY_AST) {
Chris Lattner5f9e2722011-07-23 10:55:15 +00003598 D.Diag(diag::err_drv_no_ast_support)
Daniel Dunbar88137642009-09-09 22:32:48 +00003599 << getToolChain().getTripleString();
Daniel Dunbar5915fbf2009-09-01 16:57:46 +00003600 return;
3601 }
3602
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00003603 CmdArgs.push_back(II.getFilename());
Daniel Dunbar40f12652009-03-29 17:08:39 +00003604 }
3605
3606 if (OutputArgsEarly) {
3607 AddCC1OptionsArgs(Args, CmdArgs, Inputs, OutputArgs);
3608 } else {
3609 AddCC1OptionsArgs(Args, CmdArgs, Inputs, ArgStringList());
3610 CmdArgs.append(OutputArgs.begin(), OutputArgs.end());
3611 }
3612 }
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003613
Daniel Dunbar40f12652009-03-29 17:08:39 +00003614 if (Output.getType() == types::TY_PCH) {
3615 assert(Output.isFilename() && "Invalid PCH output.");
3616
3617 CmdArgs.push_back("-o");
3618 // NOTE: gcc uses a temp .s file for this, but there doesn't seem
3619 // to be a good reason.
Chad Rosier8c221b82011-08-01 19:58:48 +00003620 const char *TmpPath = C.getArgs().MakeArgString(
Chad Rosierfe87fc72011-08-26 21:28:44 +00003621 D.GetTemporaryPath("cc", "s"));
Chad Rosier8c221b82011-08-01 19:58:48 +00003622 C.addTempFile(TmpPath);
3623 CmdArgs.push_back(TmpPath);
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003624
Eric Christopher88b7cf02011-08-19 00:30:14 +00003625 // If we're emitting a pch file with the last 4 characters of ".pth"
3626 // and falling back to llvm-gcc we want to use ".gch" instead.
3627 std::string OutputFile(Output.getFilename());
3628 size_t loc = OutputFile.rfind(".pth");
3629 if (loc != std::string::npos)
3630 OutputFile.replace(loc, 4, ".gch");
3631 const char *Tmp = C.getArgs().MakeArgString("--output-pch="+OutputFile);
3632 CmdArgs.push_back(Tmp);
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003633 }
Daniel Dunbar40f12652009-03-29 17:08:39 +00003634
Chad Rosier285f9a22011-08-17 18:24:55 +00003635 RemoveCC1UnsupportedArgs(CmdArgs);
3636
Daniel Dunbar40f12652009-03-29 17:08:39 +00003637 const char *CC1Name = getCC1Name(Inputs[0].getType());
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003638 const char *Exec =
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00003639 Args.MakeArgString(getToolChain().GetProgramPath(CC1Name));
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00003640 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbar40f12652009-03-29 17:08:39 +00003641}
3642
Daniel Dunbar8cac5f72009-03-20 16:06:39 +00003643void darwin::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00003644 const InputInfo &Output,
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003645 const InputInfoList &Inputs,
3646 const ArgList &Args,
Daniel Dunbar8cac5f72009-03-20 16:06:39 +00003647 const char *LinkingOutput) const {
3648 ArgStringList CmdArgs;
3649
3650 assert(Inputs.size() == 1 && "Unexpected number of inputs.");
3651 const InputInfo &Input = Inputs[0];
3652
Daniel Dunbar34bac1f2011-04-12 23:59:20 +00003653 // Determine the original source input.
3654 const Action *SourceAction = &JA;
3655 while (SourceAction->getKind() != Action::InputClass) {
3656 assert(!SourceAction->getInputs().empty() && "unexpected root action!");
3657 SourceAction = SourceAction->getInputs()[0];
3658 }
3659
3660 // Forward -g, assuming we are dealing with an actual assembly file.
Eric Christopher88b7cf02011-08-19 00:30:14 +00003661 if (SourceAction->getType() == types::TY_Asm ||
Daniel Dunbar34bac1f2011-04-12 23:59:20 +00003662 SourceAction->getType() == types::TY_PP_Asm) {
Daniel Dunbar8e4fea62009-04-01 00:27:44 +00003663 if (Args.hasArg(options::OPT_gstabs))
3664 CmdArgs.push_back("--gstabs");
3665 else if (Args.hasArg(options::OPT_g_Group))
Bob Wilson591ff152011-11-02 05:10:45 +00003666 CmdArgs.push_back("-g");
Daniel Dunbar8e4fea62009-04-01 00:27:44 +00003667 }
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003668
Daniel Dunbar8cac5f72009-03-20 16:06:39 +00003669 // Derived from asm spec.
Daniel Dunbarcc6f8032009-09-09 18:36:27 +00003670 AddDarwinArch(Args, CmdArgs);
Daniel Dunbar8cac5f72009-03-20 16:06:39 +00003671
Daniel Dunbarf5438e32010-07-22 01:47:22 +00003672 // Use -force_cpusubtype_ALL on x86 by default.
3673 if (getToolChain().getTriple().getArch() == llvm::Triple::x86 ||
3674 getToolChain().getTriple().getArch() == llvm::Triple::x86_64 ||
Daniel Dunbarcc6f8032009-09-09 18:36:27 +00003675 Args.hasArg(options::OPT_force__cpusubtype__ALL))
3676 CmdArgs.push_back("-force_cpusubtype_ALL");
3677
Daniel Dunbar0e2679d2009-08-24 22:26:16 +00003678 if (getToolChain().getTriple().getArch() != llvm::Triple::x86_64 &&
3679 (Args.hasArg(options::OPT_mkernel) ||
Daniel Dunbar8cac5f72009-03-20 16:06:39 +00003680 Args.hasArg(options::OPT_static) ||
Daniel Dunbar0e2679d2009-08-24 22:26:16 +00003681 Args.hasArg(options::OPT_fapple_kext)))
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003682 CmdArgs.push_back("-static");
3683
Daniel Dunbar8cac5f72009-03-20 16:06:39 +00003684 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
3685 options::OPT_Xassembler);
3686
3687 assert(Output.isFilename() && "Unexpected lipo output.");
3688 CmdArgs.push_back("-o");
3689 CmdArgs.push_back(Output.getFilename());
3690
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00003691 assert(Input.isFilename() && "Invalid input.");
3692 CmdArgs.push_back(Input.getFilename());
Daniel Dunbar8cac5f72009-03-20 16:06:39 +00003693
3694 // asm_final spec is empty.
3695
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003696 const char *Exec =
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00003697 Args.MakeArgString(getToolChain().GetProgramPath("as"));
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00003698 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbar8cac5f72009-03-20 16:06:39 +00003699}
Daniel Dunbarff7488d2009-03-20 00:52:38 +00003700
David Blaikie99ba9e32011-12-20 02:48:34 +00003701void darwin::DarwinTool::anchor() {}
3702
Daniel Dunbarfbefe6b2009-09-09 18:36:20 +00003703void darwin::DarwinTool::AddDarwinArch(const ArgList &Args,
3704 ArgStringList &CmdArgs) const {
Chris Lattner5f9e2722011-07-23 10:55:15 +00003705 StringRef ArchName = getDarwinToolChain().getDarwinArchName(Args);
Daniel Dunbareeff4062010-01-22 02:04:58 +00003706
Daniel Dunbar02633b52009-03-26 16:23:12 +00003707 // Derived from darwin_arch spec.
3708 CmdArgs.push_back("-arch");
Daniel Dunbareeff4062010-01-22 02:04:58 +00003709 CmdArgs.push_back(Args.MakeArgString(ArchName));
Daniel Dunbar78dbd582009-09-04 18:35:31 +00003710
Daniel Dunbareeff4062010-01-22 02:04:58 +00003711 // FIXME: Is this needed anymore?
3712 if (ArchName == "arm")
Daniel Dunbar78dbd582009-09-04 18:35:31 +00003713 CmdArgs.push_back("-force_cpusubtype_ALL");
Daniel Dunbar02633b52009-03-26 16:23:12 +00003714}
3715
Daniel Dunbar748de8e2010-09-09 21:51:05 +00003716void darwin::Link::AddLinkArgs(Compilation &C,
3717 const ArgList &Args,
Daniel Dunbar02633b52009-03-26 16:23:12 +00003718 ArgStringList &CmdArgs) const {
Daniel Dunbaree788e72009-12-21 18:54:17 +00003719 const Driver &D = getToolChain().getDriver();
Daniel Dunbarce911f52011-04-28 21:23:41 +00003720 const toolchains::Darwin &DarwinTC = getDarwinToolChain();
Daniel Dunbar02633b52009-03-26 16:23:12 +00003721
Daniel Dunbarb18dc5b2010-08-11 23:07:50 +00003722 unsigned Version[3] = { 0, 0, 0 };
3723 if (Arg *A = Args.getLastArg(options::OPT_mlinker_version_EQ)) {
3724 bool HadExtra;
3725 if (!Driver::GetReleaseVersion(A->getValue(Args), Version[0],
3726 Version[1], Version[2], HadExtra) ||
3727 HadExtra)
Chris Lattner5f9e2722011-07-23 10:55:15 +00003728 D.Diag(diag::err_drv_invalid_version_number)
Daniel Dunbarb18dc5b2010-08-11 23:07:50 +00003729 << A->getAsString(Args);
3730 }
3731
3732 // Newer linkers support -demangle, pass it if supported and not disabled by
3733 // the user.
Daniel Dunbard2d20882012-01-04 21:45:27 +00003734 if (Version[0] >= 100 && !Args.hasArg(options::OPT_Z_Xlinker__no_demangle)) {
Daniel Dunbarbcf1da82010-09-07 17:07:49 +00003735 // Don't pass -demangle to ld_classic.
3736 //
3737 // FIXME: This is a temporary workaround, ld should be handling this.
3738 bool UsesLdClassic = (getToolChain().getArch() == llvm::Triple::x86 &&
3739 Args.hasArg(options::OPT_static));
Daniel Dunbar9ced7042010-09-07 17:50:41 +00003740 if (getToolChain().getArch() == llvm::Triple::x86) {
3741 for (arg_iterator it = Args.filtered_begin(options::OPT_Xlinker,
3742 options::OPT_Wl_COMMA),
3743 ie = Args.filtered_end(); it != ie; ++it) {
3744 const Arg *A = *it;
3745 for (unsigned i = 0, e = A->getNumValues(); i != e; ++i)
Chris Lattner5f9e2722011-07-23 10:55:15 +00003746 if (StringRef(A->getValue(Args, i)) == "-kext")
Daniel Dunbar9ced7042010-09-07 17:50:41 +00003747 UsesLdClassic = true;
3748 }
3749 }
Daniel Dunbarbcf1da82010-09-07 17:07:49 +00003750 if (!UsesLdClassic)
3751 CmdArgs.push_back("-demangle");
Daniel Dunbarb18dc5b2010-08-11 23:07:50 +00003752 }
3753
Daniel Dunbar5bfa6562011-06-21 20:55:11 +00003754 // If we are using LTO, then automatically create a temporary file path for
3755 // the linker to use, so that it's lifetime will extend past a possible
3756 // dsymutil step.
Daniel Dunbara68e1c32011-06-21 21:18:32 +00003757 if (Version[0] >= 116 && D.IsUsingLTO(Args)) {
Daniel Dunbar5bfa6562011-06-21 20:55:11 +00003758 const char *TmpPath = C.getArgs().MakeArgString(
Chad Rosierfe87fc72011-08-26 21:28:44 +00003759 D.GetTemporaryPath("cc", types::getTypeTempSuffix(types::TY_Object)));
Daniel Dunbar5bfa6562011-06-21 20:55:11 +00003760 C.addTempFile(TmpPath);
3761 CmdArgs.push_back("-object_path_lto");
3762 CmdArgs.push_back(TmpPath);
3763 }
3764
Daniel Dunbar02633b52009-03-26 16:23:12 +00003765 // Derived from the "link" spec.
3766 Args.AddAllArgs(CmdArgs, options::OPT_static);
3767 if (!Args.hasArg(options::OPT_static))
3768 CmdArgs.push_back("-dynamic");
3769 if (Args.hasArg(options::OPT_fgnu_runtime)) {
3770 // FIXME: gcc replaces -lobjc in forward args with -lobjc-gnu
3771 // here. How do we wish to handle such things?
3772 }
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003773
Daniel Dunbar02633b52009-03-26 16:23:12 +00003774 if (!Args.hasArg(options::OPT_dynamiclib)) {
Daniel Dunbara6d38492010-01-22 02:04:52 +00003775 AddDarwinArch(Args, CmdArgs);
Daniel Dunbara6d38492010-01-22 02:04:52 +00003776 // FIXME: Why do this only on this path?
Daniel Dunbar8917dd42010-01-22 03:37:33 +00003777 Args.AddLastArg(CmdArgs, options::OPT_force__cpusubtype__ALL);
Daniel Dunbar02633b52009-03-26 16:23:12 +00003778
3779 Args.AddLastArg(CmdArgs, options::OPT_bundle);
3780 Args.AddAllArgs(CmdArgs, options::OPT_bundle__loader);
3781 Args.AddAllArgs(CmdArgs, options::OPT_client__name);
3782
3783 Arg *A;
3784 if ((A = Args.getLastArg(options::OPT_compatibility__version)) ||
3785 (A = Args.getLastArg(options::OPT_current__version)) ||
3786 (A = Args.getLastArg(options::OPT_install__name)))
Chris Lattner5f9e2722011-07-23 10:55:15 +00003787 D.Diag(diag::err_drv_argument_only_allowed_with)
Daniel Dunbar02633b52009-03-26 16:23:12 +00003788 << A->getAsString(Args) << "-dynamiclib";
3789
3790 Args.AddLastArg(CmdArgs, options::OPT_force__flat__namespace);
3791 Args.AddLastArg(CmdArgs, options::OPT_keep__private__externs);
3792 Args.AddLastArg(CmdArgs, options::OPT_private__bundle);
3793 } else {
3794 CmdArgs.push_back("-dylib");
3795
3796 Arg *A;
3797 if ((A = Args.getLastArg(options::OPT_bundle)) ||
3798 (A = Args.getLastArg(options::OPT_bundle__loader)) ||
3799 (A = Args.getLastArg(options::OPT_client__name)) ||
3800 (A = Args.getLastArg(options::OPT_force__flat__namespace)) ||
3801 (A = Args.getLastArg(options::OPT_keep__private__externs)) ||
3802 (A = Args.getLastArg(options::OPT_private__bundle)))
Chris Lattner5f9e2722011-07-23 10:55:15 +00003803 D.Diag(diag::err_drv_argument_not_allowed_with)
Daniel Dunbar02633b52009-03-26 16:23:12 +00003804 << A->getAsString(Args) << "-dynamiclib";
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003805
Daniel Dunbar02633b52009-03-26 16:23:12 +00003806 Args.AddAllArgsTranslated(CmdArgs, options::OPT_compatibility__version,
3807 "-dylib_compatibility_version");
3808 Args.AddAllArgsTranslated(CmdArgs, options::OPT_current__version,
3809 "-dylib_current_version");
3810
Daniel Dunbara6d38492010-01-22 02:04:52 +00003811 AddDarwinArch(Args, CmdArgs);
Daniel Dunbar02633b52009-03-26 16:23:12 +00003812
3813 Args.AddAllArgsTranslated(CmdArgs, options::OPT_install__name,
3814 "-dylib_install_name");
3815 }
3816
3817 Args.AddLastArg(CmdArgs, options::OPT_all__load);
3818 Args.AddAllArgs(CmdArgs, options::OPT_allowable__client);
3819 Args.AddLastArg(CmdArgs, options::OPT_bind__at__load);
Daniel Dunbarce911f52011-04-28 21:23:41 +00003820 if (DarwinTC.isTargetIPhoneOS())
Daniel Dunbard82f8fa2009-09-04 18:35:41 +00003821 Args.AddLastArg(CmdArgs, options::OPT_arch__errors__fatal);
Daniel Dunbar02633b52009-03-26 16:23:12 +00003822 Args.AddLastArg(CmdArgs, options::OPT_dead__strip);
3823 Args.AddLastArg(CmdArgs, options::OPT_no__dead__strip__inits__and__terms);
3824 Args.AddAllArgs(CmdArgs, options::OPT_dylib__file);
3825 Args.AddLastArg(CmdArgs, options::OPT_dynamic);
3826 Args.AddAllArgs(CmdArgs, options::OPT_exported__symbols__list);
3827 Args.AddLastArg(CmdArgs, options::OPT_flat__namespace);
Daniel Dunbar99ca47b2011-06-28 20:16:02 +00003828 Args.AddAllArgs(CmdArgs, options::OPT_force__load);
Daniel Dunbar02633b52009-03-26 16:23:12 +00003829 Args.AddAllArgs(CmdArgs, options::OPT_headerpad__max__install__names);
3830 Args.AddAllArgs(CmdArgs, options::OPT_image__base);
3831 Args.AddAllArgs(CmdArgs, options::OPT_init);
3832
Daniel Dunbarce911f52011-04-28 21:23:41 +00003833 // Add the deployment target.
3834 unsigned TargetVersion[3];
3835 DarwinTC.getTargetVersion(TargetVersion);
Daniel Dunbarb7f5ef72011-04-30 04:22:58 +00003836
3837 // If we had an explicit -mios-simulator-version-min argument, honor that,
3838 // otherwise use the traditional deployment targets. We can't just check the
3839 // is-sim attribute because existing code follows this path, and the linker
3840 // may not handle the argument.
3841 //
3842 // FIXME: We may be able to remove this, once we can verify no one depends on
3843 // it.
3844 if (Args.hasArg(options::OPT_mios_simulator_version_min_EQ))
3845 CmdArgs.push_back("-ios_simulator_version_min");
3846 else if (DarwinTC.isTargetIPhoneOS())
3847 CmdArgs.push_back("-iphoneos_version_min");
3848 else
3849 CmdArgs.push_back("-macosx_version_min");
Chris Lattner5f9e2722011-07-23 10:55:15 +00003850 CmdArgs.push_back(Args.MakeArgString(Twine(TargetVersion[0]) + "." +
3851 Twine(TargetVersion[1]) + "." +
3852 Twine(TargetVersion[2])));
Daniel Dunbarce911f52011-04-28 21:23:41 +00003853
Daniel Dunbar02633b52009-03-26 16:23:12 +00003854 Args.AddLastArg(CmdArgs, options::OPT_nomultidefs);
3855 Args.AddLastArg(CmdArgs, options::OPT_multi__module);
3856 Args.AddLastArg(CmdArgs, options::OPT_single__module);
3857 Args.AddAllArgs(CmdArgs, options::OPT_multiply__defined);
3858 Args.AddAllArgs(CmdArgs, options::OPT_multiply__defined__unused);
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003859
Daniel Dunbar47e879d2010-07-13 23:31:40 +00003860 if (const Arg *A = Args.getLastArg(options::OPT_fpie, options::OPT_fPIE,
3861 options::OPT_fno_pie,
3862 options::OPT_fno_PIE)) {
3863 if (A->getOption().matches(options::OPT_fpie) ||
3864 A->getOption().matches(options::OPT_fPIE))
3865 CmdArgs.push_back("-pie");
3866 else
3867 CmdArgs.push_back("-no_pie");
3868 }
Daniel Dunbar02633b52009-03-26 16:23:12 +00003869
3870 Args.AddLastArg(CmdArgs, options::OPT_prebind);
3871 Args.AddLastArg(CmdArgs, options::OPT_noprebind);
3872 Args.AddLastArg(CmdArgs, options::OPT_nofixprebinding);
3873 Args.AddLastArg(CmdArgs, options::OPT_prebind__all__twolevel__modules);
3874 Args.AddLastArg(CmdArgs, options::OPT_read__only__relocs);
3875 Args.AddAllArgs(CmdArgs, options::OPT_sectcreate);
3876 Args.AddAllArgs(CmdArgs, options::OPT_sectorder);
3877 Args.AddAllArgs(CmdArgs, options::OPT_seg1addr);
3878 Args.AddAllArgs(CmdArgs, options::OPT_segprot);
3879 Args.AddAllArgs(CmdArgs, options::OPT_segaddr);
3880 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__only__addr);
3881 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__write__addr);
3882 Args.AddAllArgs(CmdArgs, options::OPT_seg__addr__table);
3883 Args.AddAllArgs(CmdArgs, options::OPT_seg__addr__table__filename);
3884 Args.AddAllArgs(CmdArgs, options::OPT_sub__library);
3885 Args.AddAllArgs(CmdArgs, options::OPT_sub__umbrella);
Daniel Dunbard82f8fa2009-09-04 18:35:41 +00003886
Daniel Dunbarcc957192011-05-02 21:03:47 +00003887 // Give --sysroot= preference, over the Apple specific behavior to also use
3888 // --isysroot as the syslibroot.
3889 if (const Arg *A = Args.getLastArg(options::OPT__sysroot_EQ)) {
3890 CmdArgs.push_back("-syslibroot");
3891 CmdArgs.push_back(A->getValue(Args));
3892 } else if (const Arg *A = Args.getLastArg(options::OPT_isysroot)) {
3893 CmdArgs.push_back("-syslibroot");
3894 CmdArgs.push_back(A->getValue(Args));
3895 } else if (getDarwinToolChain().isTargetIPhoneOS()) {
3896 CmdArgs.push_back("-syslibroot");
3897 CmdArgs.push_back("/Developer/SDKs/Extra");
Daniel Dunbard82f8fa2009-09-04 18:35:41 +00003898 }
3899
Daniel Dunbar02633b52009-03-26 16:23:12 +00003900 Args.AddLastArg(CmdArgs, options::OPT_twolevel__namespace);
3901 Args.AddLastArg(CmdArgs, options::OPT_twolevel__namespace__hints);
3902 Args.AddAllArgs(CmdArgs, options::OPT_umbrella);
3903 Args.AddAllArgs(CmdArgs, options::OPT_undefined);
3904 Args.AddAllArgs(CmdArgs, options::OPT_unexported__symbols__list);
Daniel Dunbard82f8fa2009-09-04 18:35:41 +00003905 Args.AddAllArgs(CmdArgs, options::OPT_weak__reference__mismatches);
Daniel Dunbar02633b52009-03-26 16:23:12 +00003906 Args.AddLastArg(CmdArgs, options::OPT_X_Flag);
3907 Args.AddAllArgs(CmdArgs, options::OPT_y);
3908 Args.AddLastArg(CmdArgs, options::OPT_w);
3909 Args.AddAllArgs(CmdArgs, options::OPT_pagezero__size);
3910 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__);
3911 Args.AddLastArg(CmdArgs, options::OPT_seglinkedit);
3912 Args.AddLastArg(CmdArgs, options::OPT_noseglinkedit);
3913 Args.AddAllArgs(CmdArgs, options::OPT_sectalign);
3914 Args.AddAllArgs(CmdArgs, options::OPT_sectobjectsymbols);
3915 Args.AddAllArgs(CmdArgs, options::OPT_segcreate);
3916 Args.AddLastArg(CmdArgs, options::OPT_whyload);
3917 Args.AddLastArg(CmdArgs, options::OPT_whatsloaded);
3918 Args.AddAllArgs(CmdArgs, options::OPT_dylinker__install__name);
3919 Args.AddLastArg(CmdArgs, options::OPT_dylinker);
3920 Args.AddLastArg(CmdArgs, options::OPT_Mach);
3921}
3922
3923void darwin::Link::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00003924 const InputInfo &Output,
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003925 const InputInfoList &Inputs,
3926 const ArgList &Args,
Daniel Dunbar02633b52009-03-26 16:23:12 +00003927 const char *LinkingOutput) const {
3928 assert(Output.getType() == types::TY_Image && "Invalid linker output type.");
Daniel Dunbare0be8b12009-09-08 16:39:16 +00003929
Daniel Dunbar02633b52009-03-26 16:23:12 +00003930 // The logic here is derived from gcc's behavior; most of which
3931 // comes from specs (starting with link_command). Consult gcc for
3932 // more information.
Daniel Dunbar02633b52009-03-26 16:23:12 +00003933 ArgStringList CmdArgs;
3934
Argyrios Kyrtzidis22897172011-10-07 22:58:08 +00003935 /// Hack(tm) to ignore linking errors when we are doing ARC migration.
3936 if (Args.hasArg(options::OPT_ccc_arcmt_check,
3937 options::OPT_ccc_arcmt_migrate)) {
3938 for (ArgList::const_iterator I = Args.begin(), E = Args.end(); I != E; ++I)
3939 (*I)->claim();
3940 const char *Exec =
3941 Args.MakeArgString(getToolChain().GetProgramPath("touch"));
3942 CmdArgs.push_back(Output.getFilename());
3943 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
3944 return;
3945 }
3946
Daniel Dunbar02633b52009-03-26 16:23:12 +00003947 // I'm not sure why this particular decomposition exists in gcc, but
3948 // we follow suite for ease of comparison.
Daniel Dunbar748de8e2010-09-09 21:51:05 +00003949 AddLinkArgs(C, Args, CmdArgs);
Daniel Dunbar02633b52009-03-26 16:23:12 +00003950
Daniel Dunbar02633b52009-03-26 16:23:12 +00003951 Args.AddAllArgs(CmdArgs, options::OPT_d_Flag);
3952 Args.AddAllArgs(CmdArgs, options::OPT_s);
3953 Args.AddAllArgs(CmdArgs, options::OPT_t);
3954 Args.AddAllArgs(CmdArgs, options::OPT_Z_Flag);
3955 Args.AddAllArgs(CmdArgs, options::OPT_u_Group);
3956 Args.AddAllArgs(CmdArgs, options::OPT_A);
3957 Args.AddLastArg(CmdArgs, options::OPT_e);
3958 Args.AddAllArgs(CmdArgs, options::OPT_m_Separate);
3959 Args.AddAllArgs(CmdArgs, options::OPT_r);
3960
Daniel Dunbar270073c2010-10-18 22:08:36 +00003961 // Forward -ObjC when either -ObjC or -ObjC++ is used, to force loading
3962 // members of static archive libraries which implement Objective-C classes or
3963 // categories.
3964 if (Args.hasArg(options::OPT_ObjC) || Args.hasArg(options::OPT_ObjCXX))
3965 CmdArgs.push_back("-ObjC");
Michael J. Spencer20249a12010-10-21 03:16:25 +00003966
Daniel Dunbar02633b52009-03-26 16:23:12 +00003967 CmdArgs.push_back("-o");
3968 CmdArgs.push_back(Output.getFilename());
3969
Daniel Dunbar02633b52009-03-26 16:23:12 +00003970 if (!Args.hasArg(options::OPT_A) &&
3971 !Args.hasArg(options::OPT_nostdlib) &&
3972 !Args.hasArg(options::OPT_nostartfiles)) {
3973 // Derived from startfile spec.
3974 if (Args.hasArg(options::OPT_dynamiclib)) {
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003975 // Derived from darwin_dylib1 spec.
Daniel Dunbar1051fc02011-04-01 21:02:42 +00003976 if (getDarwinToolChain().isTargetIOSSimulator()) {
3977 // The simulator doesn't have a versioned crt1 file.
3978 CmdArgs.push_back("-ldylib1.o");
3979 } else if (getDarwinToolChain().isTargetIPhoneOS()) {
Daniel Dunbarcacb0f02010-01-27 00:56:56 +00003980 if (getDarwinToolChain().isIPhoneOSVersionLT(3, 1))
3981 CmdArgs.push_back("-ldylib1.o");
3982 } else {
Daniel Dunbarce3fdf22010-01-27 00:57:03 +00003983 if (getDarwinToolChain().isMacosxVersionLT(10, 5))
Daniel Dunbarcacb0f02010-01-27 00:56:56 +00003984 CmdArgs.push_back("-ldylib1.o");
Daniel Dunbarce3fdf22010-01-27 00:57:03 +00003985 else if (getDarwinToolChain().isMacosxVersionLT(10, 6))
Daniel Dunbarcacb0f02010-01-27 00:56:56 +00003986 CmdArgs.push_back("-ldylib1.10.5.o");
3987 }
Daniel Dunbar02633b52009-03-26 16:23:12 +00003988 } else {
3989 if (Args.hasArg(options::OPT_bundle)) {
Daniel Dunbar8a8d8af2009-04-01 03:17:40 +00003990 if (!Args.hasArg(options::OPT_static)) {
3991 // Derived from darwin_bundle1 spec.
Daniel Dunbar1051fc02011-04-01 21:02:42 +00003992 if (getDarwinToolChain().isTargetIOSSimulator()) {
3993 // The simulator doesn't have a versioned crt1 file.
3994 CmdArgs.push_back("-lbundle1.o");
3995 } else if (getDarwinToolChain().isTargetIPhoneOS()) {
Daniel Dunbarcacb0f02010-01-27 00:56:56 +00003996 if (getDarwinToolChain().isIPhoneOSVersionLT(3, 1))
3997 CmdArgs.push_back("-lbundle1.o");
3998 } else {
Daniel Dunbarce3fdf22010-01-27 00:57:03 +00003999 if (getDarwinToolChain().isMacosxVersionLT(10, 6))
Daniel Dunbarcacb0f02010-01-27 00:56:56 +00004000 CmdArgs.push_back("-lbundle1.o");
4001 }
Daniel Dunbar8a8d8af2009-04-01 03:17:40 +00004002 }
Daniel Dunbar02633b52009-03-26 16:23:12 +00004003 } else {
Daniel Dunbarbbe8e3e2011-03-01 18:49:30 +00004004 if (Args.hasArg(options::OPT_pg) &&
4005 getToolChain().SupportsProfiling()) {
Daniel Dunbar02633b52009-03-26 16:23:12 +00004006 if (Args.hasArg(options::OPT_static) ||
4007 Args.hasArg(options::OPT_object) ||
4008 Args.hasArg(options::OPT_preload)) {
4009 CmdArgs.push_back("-lgcrt0.o");
4010 } else {
4011 CmdArgs.push_back("-lgcrt1.o");
Daniel Dunbarc21c4852009-04-08 23:54:23 +00004012
Daniel Dunbar02633b52009-03-26 16:23:12 +00004013 // darwin_crt2 spec is empty.
Daniel Dunbarc21c4852009-04-08 23:54:23 +00004014 }
Daniel Dunbar02633b52009-03-26 16:23:12 +00004015 } else {
4016 if (Args.hasArg(options::OPT_static) ||
4017 Args.hasArg(options::OPT_object) ||
4018 Args.hasArg(options::OPT_preload)) {
4019 CmdArgs.push_back("-lcrt0.o");
4020 } else {
4021 // Derived from darwin_crt1 spec.
Daniel Dunbar40355802011-03-31 17:12:33 +00004022 if (getDarwinToolChain().isTargetIOSSimulator()) {
4023 // The simulator doesn't have a versioned crt1 file.
4024 CmdArgs.push_back("-lcrt1.o");
4025 } else if (getDarwinToolChain().isTargetIPhoneOS()) {
Daniel Dunbarcacb0f02010-01-27 00:56:56 +00004026 if (getDarwinToolChain().isIPhoneOSVersionLT(3, 1))
4027 CmdArgs.push_back("-lcrt1.o");
4028 else
4029 CmdArgs.push_back("-lcrt1.3.1.o");
Daniel Dunbarce3fdf22010-01-27 00:57:03 +00004030 } else {
4031 if (getDarwinToolChain().isMacosxVersionLT(10, 5))
4032 CmdArgs.push_back("-lcrt1.o");
4033 else if (getDarwinToolChain().isMacosxVersionLT(10, 6))
4034 CmdArgs.push_back("-lcrt1.10.5.o");
Ted Kremenekebcb57a2012-03-06 20:05:56 +00004035 else if (getDarwinToolChain().isMacosxVersionLT(10, 8))
Daniel Dunbarce3fdf22010-01-27 00:57:03 +00004036 CmdArgs.push_back("-lcrt1.10.6.o");
Daniel Dunbarc21c4852009-04-08 23:54:23 +00004037
Daniel Dunbarce3fdf22010-01-27 00:57:03 +00004038 // darwin_crt2 spec is empty.
4039 }
Daniel Dunbar02633b52009-03-26 16:23:12 +00004040 }
4041 }
4042 }
4043 }
4044
Daniel Dunbarce3fdf22010-01-27 00:57:03 +00004045 if (!getDarwinToolChain().isTargetIPhoneOS() &&
4046 Args.hasArg(options::OPT_shared_libgcc) &&
4047 getDarwinToolChain().isMacosxVersionLT(10, 5)) {
Daniel Dunbar88137642009-09-09 22:32:48 +00004048 const char *Str =
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004049 Args.MakeArgString(getToolChain().GetFilePath("crt3.o"));
Daniel Dunbar88137642009-09-09 22:32:48 +00004050 CmdArgs.push_back(Str);
Daniel Dunbar02633b52009-03-26 16:23:12 +00004051 }
4052 }
4053
4054 Args.AddAllArgs(CmdArgs, options::OPT_L);
Daniel Dunbarc21c4852009-04-08 23:54:23 +00004055
Kostya Serebryany7b5f1012011-12-06 19:18:44 +00004056 // If we're building a dynamic lib with -faddress-sanitizer, unresolved
4057 // symbols may appear. Mark all of them as dynamic_lookup.
4058 // Linking executables is handled in lib/Driver/ToolChains.cpp.
4059 if (Args.hasFlag(options::OPT_faddress_sanitizer,
4060 options::OPT_fno_address_sanitizer, false)) {
4061 if (Args.hasArg(options::OPT_dynamiclib) ||
4062 Args.hasArg(options::OPT_bundle)) {
4063 CmdArgs.push_back("-undefined");
4064 CmdArgs.push_back("dynamic_lookup");
4065 }
4066 }
4067
Daniel Dunbar02633b52009-03-26 16:23:12 +00004068 if (Args.hasArg(options::OPT_fopenmp))
4069 // This is more complicated in gcc...
4070 CmdArgs.push_back("-lgomp");
4071
Daniel Dunbar6b200b22009-09-18 08:14:36 +00004072 getDarwinToolChain().AddLinkSearchPathArgs(Args, CmdArgs);
Daniel Dunbarc21c4852009-04-08 23:54:23 +00004073
Ted Kremenekebcb57a2012-03-06 20:05:56 +00004074 if (isObjCRuntimeLinked(Args)) {
4075 // Avoid linking compatibility stubs on i386 mac.
4076 if (!getDarwinToolChain().isTargetMacOS() ||
4077 getDarwinToolChain().getArchName() != "i386") {
4078 // If we don't have ARC or subscripting runtime support, link in the
4079 // runtime stubs. We have to do this *before* adding any of the normal
4080 // linker inputs so that its initializer gets run first.
4081 ObjCRuntime runtime;
4082 getDarwinToolChain().configureObjCRuntime(runtime);
4083 // We use arclite library for both ARC and subscripting support.
4084 if ((!runtime.HasARC && isObjCAutoRefCount(Args)) ||
4085 !runtime.HasSubscripting)
4086 getDarwinToolChain().AddLinkARCArgs(Args, CmdArgs);
4087 CmdArgs.push_back("-framework");
4088 CmdArgs.push_back("Foundation");
4089 }
4090 // Link libobj.
4091 CmdArgs.push_back("-lobjc");
John McCall9f084a32011-07-06 00:26:06 +00004092 }
John McCallf85e1932011-06-15 23:02:42 +00004093
Daniel Dunbar2008fee2010-09-17 00:24:54 +00004094 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Daniel Dunbar02633b52009-03-26 16:23:12 +00004095
4096 if (LinkingOutput) {
4097 CmdArgs.push_back("-arch_multiple");
4098 CmdArgs.push_back("-final_output");
4099 CmdArgs.push_back(LinkingOutput);
4100 }
4101
Daniel Dunbar02633b52009-03-26 16:23:12 +00004102 if (Args.hasArg(options::OPT_fnested_functions))
4103 CmdArgs.push_back("-allow_stack_execute");
Daniel Dunbarc21c4852009-04-08 23:54:23 +00004104
Daniel Dunbar02633b52009-03-26 16:23:12 +00004105 if (!Args.hasArg(options::OPT_nostdlib) &&
4106 !Args.hasArg(options::OPT_nodefaultlibs)) {
Daniel Dunbaree788e72009-12-21 18:54:17 +00004107 if (getToolChain().getDriver().CCCIsCXX)
Daniel Dunbar132e35d2010-09-17 01:20:05 +00004108 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Daniel Dunbaredfa02b2009-04-08 06:06:21 +00004109
Daniel Dunbar02633b52009-03-26 16:23:12 +00004110 // link_ssp spec is empty.
4111
Daniel Dunbar6cd41542009-09-18 08:15:03 +00004112 // Let the tool chain choose which runtime library to link.
4113 getDarwinToolChain().AddLinkRuntimeLibArgs(Args, CmdArgs);
Daniel Dunbar02633b52009-03-26 16:23:12 +00004114 }
4115
4116 if (!Args.hasArg(options::OPT_A) &&
4117 !Args.hasArg(options::OPT_nostdlib) &&
4118 !Args.hasArg(options::OPT_nostartfiles)) {
4119 // endfile_spec is empty.
4120 }
4121
4122 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
4123 Args.AddAllArgs(CmdArgs, options::OPT_F);
4124
Daniel Dunbarc21c4852009-04-08 23:54:23 +00004125 const char *Exec =
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004126 Args.MakeArgString(getToolChain().GetProgramPath("ld"));
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00004127 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbar02633b52009-03-26 16:23:12 +00004128}
4129
Daniel Dunbarff7488d2009-03-20 00:52:38 +00004130void darwin::Lipo::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00004131 const InputInfo &Output,
Daniel Dunbarc21c4852009-04-08 23:54:23 +00004132 const InputInfoList &Inputs,
4133 const ArgList &Args,
Daniel Dunbarff7488d2009-03-20 00:52:38 +00004134 const char *LinkingOutput) const {
4135 ArgStringList CmdArgs;
4136
4137 CmdArgs.push_back("-create");
4138 assert(Output.isFilename() && "Unexpected lipo output.");
Daniel Dunbara428df82009-03-24 00:24:37 +00004139
4140 CmdArgs.push_back("-output");
Daniel Dunbarff7488d2009-03-20 00:52:38 +00004141 CmdArgs.push_back(Output.getFilename());
Daniel Dunbara428df82009-03-24 00:24:37 +00004142
Daniel Dunbarff7488d2009-03-20 00:52:38 +00004143 for (InputInfoList::const_iterator
4144 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
4145 const InputInfo &II = *it;
4146 assert(II.isFilename() && "Unexpected lipo input.");
4147 CmdArgs.push_back(II.getFilename());
4148 }
Daniel Dunbarc21c4852009-04-08 23:54:23 +00004149 const char *Exec =
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004150 Args.MakeArgString(getToolChain().GetProgramPath("lipo"));
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00004151 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbarff7488d2009-03-20 00:52:38 +00004152}
Daniel Dunbar68a31d42009-03-31 17:45:15 +00004153
Daniel Dunbar6e0f2542010-06-04 18:28:36 +00004154void darwin::Dsymutil::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00004155 const InputInfo &Output,
Daniel Dunbar6e0f2542010-06-04 18:28:36 +00004156 const InputInfoList &Inputs,
4157 const ArgList &Args,
4158 const char *LinkingOutput) const {
4159 ArgStringList CmdArgs;
4160
Daniel Dunbar03e92302011-05-09 17:23:16 +00004161 CmdArgs.push_back("-o");
4162 CmdArgs.push_back(Output.getFilename());
4163
Daniel Dunbar6e0f2542010-06-04 18:28:36 +00004164 assert(Inputs.size() == 1 && "Unable to handle multiple inputs.");
4165 const InputInfo &Input = Inputs[0];
4166 assert(Input.isFilename() && "Unexpected dsymutil input.");
4167 CmdArgs.push_back(Input.getFilename());
4168
Daniel Dunbar6e0f2542010-06-04 18:28:36 +00004169 const char *Exec =
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004170 Args.MakeArgString(getToolChain().GetProgramPath("dsymutil"));
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00004171 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbar6e0f2542010-06-04 18:28:36 +00004172}
4173
Eric Christopherf8571862011-08-23 17:56:55 +00004174void darwin::VerifyDebug::ConstructJob(Compilation &C, const JobAction &JA,
4175 const InputInfo &Output,
4176 const InputInfoList &Inputs,
4177 const ArgList &Args,
4178 const char *LinkingOutput) const {
4179 ArgStringList CmdArgs;
4180 CmdArgs.push_back("--verify");
Eric Christopher1c79dc42012-02-06 19:13:09 +00004181 CmdArgs.push_back("--debug-info");
4182 CmdArgs.push_back("--eh-frame");
Eric Christopherb822f722012-02-06 19:43:51 +00004183 CmdArgs.push_back("--quiet");
Eric Christopherf8571862011-08-23 17:56:55 +00004184
4185 assert(Inputs.size() == 1 && "Unable to handle multiple inputs.");
4186 const InputInfo &Input = Inputs[0];
4187 assert(Input.isFilename() && "Unexpected verify input");
4188
4189 // Grabbing the output of the earlier dsymutil run.
4190 CmdArgs.push_back(Input.getFilename());
4191
4192 const char *Exec =
4193 Args.MakeArgString(getToolChain().GetProgramPath("dwarfdump"));
4194 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
4195}
4196
David Chisnall31c46902012-02-15 13:39:01 +00004197void solaris::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
4198 const InputInfo &Output,
4199 const InputInfoList &Inputs,
4200 const ArgList &Args,
4201 const char *LinkingOutput) const {
4202 ArgStringList CmdArgs;
4203
4204 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
4205 options::OPT_Xassembler);
4206
4207 CmdArgs.push_back("-o");
4208 CmdArgs.push_back(Output.getFilename());
4209
4210 for (InputInfoList::const_iterator
4211 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
4212 const InputInfo &II = *it;
4213 CmdArgs.push_back(II.getFilename());
4214 }
4215
4216 const char *Exec =
4217 Args.MakeArgString(getToolChain().GetProgramPath("as"));
4218 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
4219}
4220
4221
4222void solaris::Link::ConstructJob(Compilation &C, const JobAction &JA,
4223 const InputInfo &Output,
4224 const InputInfoList &Inputs,
4225 const ArgList &Args,
4226 const char *LinkingOutput) const {
4227 // FIXME: Find a real GCC, don't hard-code versions here
4228 std::string GCCLibPath = "/usr/gcc/4.5/lib/gcc/";
4229 const llvm::Triple &T = getToolChain().getTriple();
4230 std::string LibPath = "/usr/lib/";
4231 llvm::Triple::ArchType Arch = T.getArch();
4232 switch (Arch) {
4233 case llvm::Triple::x86:
4234 GCCLibPath += ("i386-" + T.getVendorName() + "-" +
4235 T.getOSName()).str() + "/4.5.2/";
4236 break;
4237 case llvm::Triple::x86_64:
4238 GCCLibPath += ("i386-" + T.getVendorName() + "-" +
4239 T.getOSName()).str();
4240 GCCLibPath += "/4.5.2/amd64/";
4241 LibPath += "amd64/";
4242 break;
4243 default:
4244 assert(0 && "Unsupported architecture");
4245 }
4246
4247 ArgStringList CmdArgs;
4248
David Chisnall41d476d2012-02-29 15:06:12 +00004249 // Demangle C++ names in errors
4250 CmdArgs.push_back("-C");
4251
David Chisnall31c46902012-02-15 13:39:01 +00004252 if ((!Args.hasArg(options::OPT_nostdlib)) &&
4253 (!Args.hasArg(options::OPT_shared))) {
4254 CmdArgs.push_back("-e");
4255 CmdArgs.push_back("_start");
4256 }
4257
4258 if (Args.hasArg(options::OPT_static)) {
4259 CmdArgs.push_back("-Bstatic");
4260 CmdArgs.push_back("-dn");
4261 } else {
4262 CmdArgs.push_back("-Bdynamic");
4263 if (Args.hasArg(options::OPT_shared)) {
4264 CmdArgs.push_back("-shared");
4265 } else {
4266 CmdArgs.push_back("--dynamic-linker");
4267 CmdArgs.push_back(Args.MakeArgString(LibPath + "ld.so.1"));
4268 }
4269 }
4270
4271 if (Output.isFilename()) {
4272 CmdArgs.push_back("-o");
4273 CmdArgs.push_back(Output.getFilename());
4274 } else {
4275 assert(Output.isNothing() && "Invalid output.");
4276 }
4277
4278 if (!Args.hasArg(options::OPT_nostdlib) &&
4279 !Args.hasArg(options::OPT_nostartfiles)) {
4280 if (!Args.hasArg(options::OPT_shared)) {
4281 CmdArgs.push_back(Args.MakeArgString(LibPath + "crt1.o"));
4282 CmdArgs.push_back(Args.MakeArgString(LibPath + "crti.o"));
David Chisnall165329c2012-02-28 17:10:04 +00004283 CmdArgs.push_back(Args.MakeArgString(LibPath + "values-Xa.o"));
David Chisnall31c46902012-02-15 13:39:01 +00004284 CmdArgs.push_back(Args.MakeArgString(GCCLibPath + "crtbegin.o"));
4285 } else {
David Chisnalld706a8d2012-02-28 19:15:06 +00004286 CmdArgs.push_back(Args.MakeArgString(LibPath + "cxa_finalize.o"));
David Chisnall31c46902012-02-15 13:39:01 +00004287 CmdArgs.push_back(Args.MakeArgString(LibPath + "crti.o"));
David Chisnall165329c2012-02-28 17:10:04 +00004288 CmdArgs.push_back(Args.MakeArgString(LibPath + "values-Xa.o"));
4289 CmdArgs.push_back(Args.MakeArgString(GCCLibPath + "crtbegin.o"));
David Chisnall31c46902012-02-15 13:39:01 +00004290 }
David Chisnall31c46902012-02-15 13:39:01 +00004291 }
4292
4293 CmdArgs.push_back(Args.MakeArgString("-L" + GCCLibPath));
4294
4295 Args.AddAllArgs(CmdArgs, options::OPT_L);
4296 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
4297 Args.AddAllArgs(CmdArgs, options::OPT_e);
David Chisnall165329c2012-02-28 17:10:04 +00004298 Args.AddAllArgs(CmdArgs, options::OPT_r);
David Chisnall31c46902012-02-15 13:39:01 +00004299
4300 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
David Chisnall165329c2012-02-28 17:10:04 +00004301 if (getToolChain().getDriver().CCCIsCXX)
4302 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
David Chisnall31c46902012-02-15 13:39:01 +00004303
4304 if (!Args.hasArg(options::OPT_nostdlib) &&
4305 !Args.hasArg(options::OPT_nodefaultlibs)) {
David Chisnallb6229592012-02-15 18:24:31 +00004306 CmdArgs.push_back("-lgcc_s");
David Chisnall165329c2012-02-28 17:10:04 +00004307 if (!Args.hasArg(options::OPT_shared)) {
4308 CmdArgs.push_back("-lgcc");
David Chisnall31c46902012-02-15 13:39:01 +00004309 CmdArgs.push_back("-lc");
David Chisnall7dbefe12012-02-28 20:06:45 +00004310 CmdArgs.push_back("-lm");
David Chisnall165329c2012-02-28 17:10:04 +00004311 }
David Chisnall31c46902012-02-15 13:39:01 +00004312 }
4313
4314 if (!Args.hasArg(options::OPT_nostdlib) &&
4315 !Args.hasArg(options::OPT_nostartfiles)) {
David Chisnall165329c2012-02-28 17:10:04 +00004316 CmdArgs.push_back(Args.MakeArgString(GCCLibPath + "crtend.o"));
David Chisnall31c46902012-02-15 13:39:01 +00004317 }
David Chisnalld1ac03e2012-02-16 16:00:47 +00004318 CmdArgs.push_back(Args.MakeArgString(LibPath + "crtn.o"));
David Chisnall31c46902012-02-15 13:39:01 +00004319
4320 addProfileRT(getToolChain(), Args, CmdArgs, getToolChain().getTriple());
4321
4322 const char *Exec =
4323 Args.MakeArgString(getToolChain().GetProgramPath("ld"));
4324 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
4325}
4326
Edward O'Callaghane7925a02009-08-22 01:06:46 +00004327void auroraux::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00004328 const InputInfo &Output,
Daniel Dunbar294691e2009-11-04 06:24:38 +00004329 const InputInfoList &Inputs,
4330 const ArgList &Args,
4331 const char *LinkingOutput) const {
Edward O'Callaghane7925a02009-08-22 01:06:46 +00004332 ArgStringList CmdArgs;
4333
4334 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
4335 options::OPT_Xassembler);
4336
4337 CmdArgs.push_back("-o");
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00004338 CmdArgs.push_back(Output.getFilename());
Edward O'Callaghane7925a02009-08-22 01:06:46 +00004339
4340 for (InputInfoList::const_iterator
4341 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
4342 const InputInfo &II = *it;
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00004343 CmdArgs.push_back(II.getFilename());
Edward O'Callaghane7925a02009-08-22 01:06:46 +00004344 }
4345
4346 const char *Exec =
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004347 Args.MakeArgString(getToolChain().GetProgramPath("gas"));
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00004348 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Edward O'Callaghane7925a02009-08-22 01:06:46 +00004349}
4350
4351void auroraux::Link::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00004352 const InputInfo &Output,
Daniel Dunbar294691e2009-11-04 06:24:38 +00004353 const InputInfoList &Inputs,
4354 const ArgList &Args,
4355 const char *LinkingOutput) const {
Edward O'Callaghane7925a02009-08-22 01:06:46 +00004356 ArgStringList CmdArgs;
4357
4358 if ((!Args.hasArg(options::OPT_nostdlib)) &&
Daniel Dunbar294691e2009-11-04 06:24:38 +00004359 (!Args.hasArg(options::OPT_shared))) {
Edward O'Callaghane7925a02009-08-22 01:06:46 +00004360 CmdArgs.push_back("-e");
Edward O'Callaghan7adf9492009-10-15 07:44:07 +00004361 CmdArgs.push_back("_start");
Edward O'Callaghane7925a02009-08-22 01:06:46 +00004362 }
4363
4364 if (Args.hasArg(options::OPT_static)) {
4365 CmdArgs.push_back("-Bstatic");
Edward O'Callaghan7adf9492009-10-15 07:44:07 +00004366 CmdArgs.push_back("-dn");
Edward O'Callaghane7925a02009-08-22 01:06:46 +00004367 } else {
Edward O'Callaghan7adf9492009-10-15 07:44:07 +00004368// CmdArgs.push_back("--eh-frame-hdr");
Edward O'Callaghane7925a02009-08-22 01:06:46 +00004369 CmdArgs.push_back("-Bdynamic");
4370 if (Args.hasArg(options::OPT_shared)) {
4371 CmdArgs.push_back("-shared");
4372 } else {
Edward O'Callaghan3cecc192009-10-16 19:44:18 +00004373 CmdArgs.push_back("--dynamic-linker");
Edward O'Callaghane7925a02009-08-22 01:06:46 +00004374 CmdArgs.push_back("/lib/ld.so.1"); // 64Bit Path /lib/amd64/ld.so.1
4375 }
4376 }
4377
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00004378 if (Output.isFilename()) {
Edward O'Callaghane7925a02009-08-22 01:06:46 +00004379 CmdArgs.push_back("-o");
4380 CmdArgs.push_back(Output.getFilename());
4381 } else {
4382 assert(Output.isNothing() && "Invalid output.");
4383 }
4384
4385 if (!Args.hasArg(options::OPT_nostdlib) &&
4386 !Args.hasArg(options::OPT_nostartfiles)) {
4387 if (!Args.hasArg(options::OPT_shared)) {
Chris Lattner38e317d2010-07-07 16:01:42 +00004388 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004389 getToolChain().GetFilePath("crt1.o")));
Chris Lattner38e317d2010-07-07 16:01:42 +00004390 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004391 getToolChain().GetFilePath("crti.o")));
Chris Lattner38e317d2010-07-07 16:01:42 +00004392 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004393 getToolChain().GetFilePath("crtbegin.o")));
Edward O'Callaghane7925a02009-08-22 01:06:46 +00004394 } else {
Chris Lattner38e317d2010-07-07 16:01:42 +00004395 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004396 getToolChain().GetFilePath("crti.o")));
Edward O'Callaghane7925a02009-08-22 01:06:46 +00004397 }
Chris Lattner38e317d2010-07-07 16:01:42 +00004398 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004399 getToolChain().GetFilePath("crtn.o")));
Edward O'Callaghane7925a02009-08-22 01:06:46 +00004400 }
4401
Daniel Dunbar294691e2009-11-04 06:24:38 +00004402 CmdArgs.push_back(Args.MakeArgString("-L/opt/gcc4/lib/gcc/"
4403 + getToolChain().getTripleString()
Daniel Dunbarf7fb31f2009-10-29 02:24:37 +00004404 + "/4.2.4"));
Edward O'Callaghane7925a02009-08-22 01:06:46 +00004405
4406 Args.AddAllArgs(CmdArgs, options::OPT_L);
4407 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
4408 Args.AddAllArgs(CmdArgs, options::OPT_e);
4409
Daniel Dunbar2008fee2010-09-17 00:24:54 +00004410 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Edward O'Callaghane7925a02009-08-22 01:06:46 +00004411
4412 if (!Args.hasArg(options::OPT_nostdlib) &&
4413 !Args.hasArg(options::OPT_nodefaultlibs)) {
4414 // FIXME: For some reason GCC passes -lgcc before adding
4415 // the default system libraries. Just mimic this for now.
4416 CmdArgs.push_back("-lgcc");
4417
4418 if (Args.hasArg(options::OPT_pthread))
4419 CmdArgs.push_back("-pthread");
4420 if (!Args.hasArg(options::OPT_shared))
4421 CmdArgs.push_back("-lc");
4422 CmdArgs.push_back("-lgcc");
4423 }
4424
4425 if (!Args.hasArg(options::OPT_nostdlib) &&
4426 !Args.hasArg(options::OPT_nostartfiles)) {
4427 if (!Args.hasArg(options::OPT_shared))
Chris Lattner38e317d2010-07-07 16:01:42 +00004428 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004429 getToolChain().GetFilePath("crtend.o")));
Edward O'Callaghane7925a02009-08-22 01:06:46 +00004430 }
4431
Bill Wendling3f4be6f2011-06-27 19:15:03 +00004432 addProfileRT(getToolChain(), Args, CmdArgs, getToolChain().getTriple());
Nick Lewycky2e95a6d2011-05-24 21:54:59 +00004433
Edward O'Callaghane7925a02009-08-22 01:06:46 +00004434 const char *Exec =
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004435 Args.MakeArgString(getToolChain().GetProgramPath("ld"));
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00004436 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Edward O'Callaghane7925a02009-08-22 01:06:46 +00004437}
4438
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00004439void openbsd::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00004440 const InputInfo &Output,
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00004441 const InputInfoList &Inputs,
4442 const ArgList &Args,
Mike Stump1eb44332009-09-09 15:08:12 +00004443 const char *LinkingOutput) const {
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00004444 ArgStringList CmdArgs;
4445
4446 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
4447 options::OPT_Xassembler);
4448
4449 CmdArgs.push_back("-o");
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00004450 CmdArgs.push_back(Output.getFilename());
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00004451
4452 for (InputInfoList::const_iterator
4453 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
4454 const InputInfo &II = *it;
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00004455 CmdArgs.push_back(II.getFilename());
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00004456 }
4457
4458 const char *Exec =
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004459 Args.MakeArgString(getToolChain().GetProgramPath("as"));
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00004460 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00004461}
4462
4463void openbsd::Link::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00004464 const InputInfo &Output,
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00004465 const InputInfoList &Inputs,
4466 const ArgList &Args,
4467 const char *LinkingOutput) const {
Daniel Dunbaree788e72009-12-21 18:54:17 +00004468 const Driver &D = getToolChain().getDriver();
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00004469 ArgStringList CmdArgs;
4470
Daniel Dunbar2bbcf662009-08-03 01:28:59 +00004471 if ((!Args.hasArg(options::OPT_nostdlib)) &&
Daniel Dunbar294691e2009-11-04 06:24:38 +00004472 (!Args.hasArg(options::OPT_shared))) {
Daniel Dunbar2bbcf662009-08-03 01:28:59 +00004473 CmdArgs.push_back("-e");
4474 CmdArgs.push_back("__start");
4475 }
4476
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00004477 if (Args.hasArg(options::OPT_static)) {
4478 CmdArgs.push_back("-Bstatic");
4479 } else {
Rafael Espindola65ba55d2010-11-11 02:17:51 +00004480 if (Args.hasArg(options::OPT_rdynamic))
4481 CmdArgs.push_back("-export-dynamic");
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00004482 CmdArgs.push_back("--eh-frame-hdr");
Daniel Dunbar2bbcf662009-08-03 01:28:59 +00004483 CmdArgs.push_back("-Bdynamic");
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00004484 if (Args.hasArg(options::OPT_shared)) {
Daniel Dunbar2bbcf662009-08-03 01:28:59 +00004485 CmdArgs.push_back("-shared");
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00004486 } else {
4487 CmdArgs.push_back("-dynamic-linker");
4488 CmdArgs.push_back("/usr/libexec/ld.so");
4489 }
4490 }
4491
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00004492 if (Output.isFilename()) {
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00004493 CmdArgs.push_back("-o");
4494 CmdArgs.push_back(Output.getFilename());
4495 } else {
4496 assert(Output.isNothing() && "Invalid output.");
4497 }
4498
4499 if (!Args.hasArg(options::OPT_nostdlib) &&
4500 !Args.hasArg(options::OPT_nostartfiles)) {
4501 if (!Args.hasArg(options::OPT_shared)) {
Eli Friedman62d829a2011-12-15 02:15:56 +00004502 if (Args.hasArg(options::OPT_pg))
4503 CmdArgs.push_back(Args.MakeArgString(
4504 getToolChain().GetFilePath("gcrt0.o")));
4505 else
4506 CmdArgs.push_back(Args.MakeArgString(
4507 getToolChain().GetFilePath("crt0.o")));
Chris Lattner38e317d2010-07-07 16:01:42 +00004508 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004509 getToolChain().GetFilePath("crtbegin.o")));
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00004510 } else {
Chris Lattner38e317d2010-07-07 16:01:42 +00004511 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004512 getToolChain().GetFilePath("crtbeginS.o")));
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00004513 }
4514 }
4515
Edward O'Callaghane7e18202009-10-28 15:13:08 +00004516 std::string Triple = getToolChain().getTripleString();
4517 if (Triple.substr(0, 6) == "x86_64")
Daniel Dunbar294691e2009-11-04 06:24:38 +00004518 Triple.replace(0, 6, "amd64");
Daniel Dunbarf7fb31f2009-10-29 02:24:37 +00004519 CmdArgs.push_back(Args.MakeArgString("-L/usr/lib/gcc-lib/" + Triple +
Daniel Dunbar95c04572010-08-01 23:13:54 +00004520 "/4.2.1"));
Daniel Dunbar2bbcf662009-08-03 01:28:59 +00004521
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00004522 Args.AddAllArgs(CmdArgs, options::OPT_L);
4523 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
4524 Args.AddAllArgs(CmdArgs, options::OPT_e);
4525
Daniel Dunbar2008fee2010-09-17 00:24:54 +00004526 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00004527
4528 if (!Args.hasArg(options::OPT_nostdlib) &&
4529 !Args.hasArg(options::OPT_nodefaultlibs)) {
Daniel Dunbar95c04572010-08-01 23:13:54 +00004530 if (D.CCCIsCXX) {
Daniel Dunbar132e35d2010-09-17 01:20:05 +00004531 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Eli Friedman62d829a2011-12-15 02:15:56 +00004532 if (Args.hasArg(options::OPT_pg))
4533 CmdArgs.push_back("-lm_p");
4534 else
4535 CmdArgs.push_back("-lm");
Daniel Dunbar95c04572010-08-01 23:13:54 +00004536 }
4537
Daniel Dunbar2bbcf662009-08-03 01:28:59 +00004538 // FIXME: For some reason GCC passes -lgcc before adding
4539 // the default system libraries. Just mimic this for now.
4540 CmdArgs.push_back("-lgcc");
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00004541
4542 if (Args.hasArg(options::OPT_pthread))
Chris Lattnera2e40212011-02-21 18:36:51 +00004543 CmdArgs.push_back("-lpthread");
Chandler Carruth657849c2011-12-17 22:32:42 +00004544 if (!Args.hasArg(options::OPT_shared)) {
Eli Friedman62d829a2011-12-15 02:15:56 +00004545 if (Args.hasArg(options::OPT_pg))
4546 CmdArgs.push_back("-lc_p");
4547 else
4548 CmdArgs.push_back("-lc");
Chandler Carruth657849c2011-12-17 22:32:42 +00004549 }
Daniel Dunbar2bbcf662009-08-03 01:28:59 +00004550 CmdArgs.push_back("-lgcc");
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00004551 }
4552
4553 if (!Args.hasArg(options::OPT_nostdlib) &&
4554 !Args.hasArg(options::OPT_nostartfiles)) {
4555 if (!Args.hasArg(options::OPT_shared))
Chris Lattner38e317d2010-07-07 16:01:42 +00004556 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004557 getToolChain().GetFilePath("crtend.o")));
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00004558 else
Chris Lattner38e317d2010-07-07 16:01:42 +00004559 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004560 getToolChain().GetFilePath("crtendS.o")));
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00004561 }
4562
4563 const char *Exec =
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004564 Args.MakeArgString(getToolChain().GetProgramPath("ld"));
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00004565 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00004566}
Ed Schoutenc66a5a32009-04-02 19:13:12 +00004567
Daniel Dunbar68a31d42009-03-31 17:45:15 +00004568void freebsd::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00004569 const InputInfo &Output,
Daniel Dunbarc21c4852009-04-08 23:54:23 +00004570 const InputInfoList &Inputs,
4571 const ArgList &Args,
Mike Stump1eb44332009-09-09 15:08:12 +00004572 const char *LinkingOutput) const {
Daniel Dunbar68a31d42009-03-31 17:45:15 +00004573 ArgStringList CmdArgs;
4574
Daniel Dunbar008f54a2009-04-01 19:36:32 +00004575 // When building 32-bit code on FreeBSD/amd64, we have to explicitly
4576 // instruct as in the base system to assemble 32-bit code.
4577 if (getToolChain().getArchName() == "i386")
Daniel Dunbar68a31d42009-03-31 17:45:15 +00004578 CmdArgs.push_back("--32");
4579
Roman Divacky3393cef2011-06-04 07:37:31 +00004580 if (getToolChain().getArchName() == "powerpc")
4581 CmdArgs.push_back("-a32");
Michael J. Spencer20249a12010-10-21 03:16:25 +00004582
Eric Christophered734732010-03-02 02:41:08 +00004583 // Set byte order explicitly
4584 if (getToolChain().getArchName() == "mips")
4585 CmdArgs.push_back("-EB");
4586 else if (getToolChain().getArchName() == "mipsel")
4587 CmdArgs.push_back("-EL");
4588
Daniel Dunbar68a31d42009-03-31 17:45:15 +00004589 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
4590 options::OPT_Xassembler);
4591
4592 CmdArgs.push_back("-o");
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00004593 CmdArgs.push_back(Output.getFilename());
Daniel Dunbar68a31d42009-03-31 17:45:15 +00004594
4595 for (InputInfoList::const_iterator
4596 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
4597 const InputInfo &II = *it;
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00004598 CmdArgs.push_back(II.getFilename());
Daniel Dunbar68a31d42009-03-31 17:45:15 +00004599 }
4600
Daniel Dunbarc21c4852009-04-08 23:54:23 +00004601 const char *Exec =
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004602 Args.MakeArgString(getToolChain().GetProgramPath("as"));
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00004603 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbar68a31d42009-03-31 17:45:15 +00004604}
Daniel Dunbar008f54a2009-04-01 19:36:32 +00004605
4606void freebsd::Link::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00004607 const InputInfo &Output,
Daniel Dunbarc21c4852009-04-08 23:54:23 +00004608 const InputInfoList &Inputs,
4609 const ArgList &Args,
Daniel Dunbara8304f62009-05-02 20:14:53 +00004610 const char *LinkingOutput) const {
Daniel Dunbaree788e72009-12-21 18:54:17 +00004611 const Driver &D = getToolChain().getDriver();
Daniel Dunbar008f54a2009-04-01 19:36:32 +00004612 ArgStringList CmdArgs;
4613
Joerg Sonnenberger8ab2bdc2011-03-21 13:51:29 +00004614 if (!D.SysRoot.empty())
4615 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
4616
Daniel Dunbar008f54a2009-04-01 19:36:32 +00004617 if (Args.hasArg(options::OPT_static)) {
4618 CmdArgs.push_back("-Bstatic");
4619 } else {
Rafael Espindola65ba55d2010-11-11 02:17:51 +00004620 if (Args.hasArg(options::OPT_rdynamic))
4621 CmdArgs.push_back("-export-dynamic");
Daniel Dunbar008f54a2009-04-01 19:36:32 +00004622 CmdArgs.push_back("--eh-frame-hdr");
4623 if (Args.hasArg(options::OPT_shared)) {
4624 CmdArgs.push_back("-Bshareable");
4625 } else {
4626 CmdArgs.push_back("-dynamic-linker");
4627 CmdArgs.push_back("/libexec/ld-elf.so.1");
4628 }
4629 }
4630
4631 // When building 32-bit code on FreeBSD/amd64, we have to explicitly
4632 // instruct ld in the base system to link 32-bit code.
4633 if (getToolChain().getArchName() == "i386") {
4634 CmdArgs.push_back("-m");
4635 CmdArgs.push_back("elf_i386_fbsd");
4636 }
4637
Roman Divacky000a6552011-06-04 07:40:24 +00004638 if (getToolChain().getArchName() == "powerpc") {
4639 CmdArgs.push_back("-m");
Roman Divacky1052c1d2011-11-21 16:50:32 +00004640 CmdArgs.push_back("elf32ppc_fbsd");
Roman Divacky000a6552011-06-04 07:40:24 +00004641 }
4642
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00004643 if (Output.isFilename()) {
Daniel Dunbar008f54a2009-04-01 19:36:32 +00004644 CmdArgs.push_back("-o");
4645 CmdArgs.push_back(Output.getFilename());
4646 } else {
4647 assert(Output.isNothing() && "Invalid output.");
4648 }
4649
4650 if (!Args.hasArg(options::OPT_nostdlib) &&
4651 !Args.hasArg(options::OPT_nostartfiles)) {
4652 if (!Args.hasArg(options::OPT_shared)) {
Roman Divackyc16bb762011-02-10 16:59:40 +00004653 if (Args.hasArg(options::OPT_pg))
4654 CmdArgs.push_back(Args.MakeArgString(
4655 getToolChain().GetFilePath("gcrt1.o")));
Roman Divacky8642f212011-10-10 19:47:45 +00004656 else {
4657 const char *crt = Args.hasArg(options::OPT_pie) ? "Scrt1.o" : "crt1.o";
Roman Divackyc16bb762011-02-10 16:59:40 +00004658 CmdArgs.push_back(Args.MakeArgString(
Roman Divacky8642f212011-10-10 19:47:45 +00004659 getToolChain().GetFilePath(crt)));
4660 }
Chris Lattner38e317d2010-07-07 16:01:42 +00004661 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004662 getToolChain().GetFilePath("crti.o")));
Chris Lattner38e317d2010-07-07 16:01:42 +00004663 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004664 getToolChain().GetFilePath("crtbegin.o")));
Daniel Dunbar008f54a2009-04-01 19:36:32 +00004665 } else {
Chris Lattner38e317d2010-07-07 16:01:42 +00004666 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004667 getToolChain().GetFilePath("crti.o")));
Chris Lattner38e317d2010-07-07 16:01:42 +00004668 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004669 getToolChain().GetFilePath("crtbeginS.o")));
Daniel Dunbar008f54a2009-04-01 19:36:32 +00004670 }
4671 }
4672
4673 Args.AddAllArgs(CmdArgs, options::OPT_L);
Roman Divacky58e5ac92011-03-01 17:53:14 +00004674 const ToolChain::path_list Paths = getToolChain().getFilePaths();
4675 for (ToolChain::path_list::const_iterator i = Paths.begin(), e = Paths.end();
4676 i != e; ++i)
Chris Lattner5f9e2722011-07-23 10:55:15 +00004677 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + *i));
Daniel Dunbar008f54a2009-04-01 19:36:32 +00004678 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
4679 Args.AddAllArgs(CmdArgs, options::OPT_e);
David Chisnallc7363772010-08-15 22:58:12 +00004680 Args.AddAllArgs(CmdArgs, options::OPT_s);
4681 Args.AddAllArgs(CmdArgs, options::OPT_t);
4682 Args.AddAllArgs(CmdArgs, options::OPT_Z_Flag);
4683 Args.AddAllArgs(CmdArgs, options::OPT_r);
Daniel Dunbar008f54a2009-04-01 19:36:32 +00004684
Daniel Dunbar2008fee2010-09-17 00:24:54 +00004685 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Daniel Dunbar008f54a2009-04-01 19:36:32 +00004686
4687 if (!Args.hasArg(options::OPT_nostdlib) &&
4688 !Args.hasArg(options::OPT_nodefaultlibs)) {
Daniel Dunbar20022632010-02-17 08:07:51 +00004689 if (D.CCCIsCXX) {
Daniel Dunbar132e35d2010-09-17 01:20:05 +00004690 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Roman Divackyc16bb762011-02-10 16:59:40 +00004691 if (Args.hasArg(options::OPT_pg))
4692 CmdArgs.push_back("-lm_p");
4693 else
4694 CmdArgs.push_back("-lm");
Daniel Dunbar20022632010-02-17 08:07:51 +00004695 }
Daniel Dunbar008f54a2009-04-01 19:36:32 +00004696 // FIXME: For some reason GCC passes -lgcc and -lgcc_s before adding
4697 // the default system libraries. Just mimic this for now.
Roman Divackyc16bb762011-02-10 16:59:40 +00004698 if (Args.hasArg(options::OPT_pg))
4699 CmdArgs.push_back("-lgcc_p");
4700 else
4701 CmdArgs.push_back("-lgcc");
Daniel Dunbar008f54a2009-04-01 19:36:32 +00004702 if (Args.hasArg(options::OPT_static)) {
4703 CmdArgs.push_back("-lgcc_eh");
Roman Divackyc16bb762011-02-10 16:59:40 +00004704 } else if (Args.hasArg(options::OPT_pg)) {
4705 CmdArgs.push_back("-lgcc_eh_p");
Daniel Dunbar008f54a2009-04-01 19:36:32 +00004706 } else {
4707 CmdArgs.push_back("--as-needed");
4708 CmdArgs.push_back("-lgcc_s");
4709 CmdArgs.push_back("--no-as-needed");
4710 }
4711
Matt Beaumont-Gay24230262011-02-10 20:35:01 +00004712 if (Args.hasArg(options::OPT_pthread)) {
Roman Divackyc16bb762011-02-10 16:59:40 +00004713 if (Args.hasArg(options::OPT_pg))
4714 CmdArgs.push_back("-lpthread_p");
4715 else
4716 CmdArgs.push_back("-lpthread");
Matt Beaumont-Gay24230262011-02-10 20:35:01 +00004717 }
Daniel Dunbar008f54a2009-04-01 19:36:32 +00004718
Roman Divackyc16bb762011-02-10 16:59:40 +00004719 if (Args.hasArg(options::OPT_pg)) {
4720 if (Args.hasArg(options::OPT_shared))
4721 CmdArgs.push_back("-lc");
4722 else
4723 CmdArgs.push_back("-lc_p");
4724 CmdArgs.push_back("-lgcc_p");
4725 } else {
4726 CmdArgs.push_back("-lc");
4727 CmdArgs.push_back("-lgcc");
4728 }
4729
Daniel Dunbar008f54a2009-04-01 19:36:32 +00004730 if (Args.hasArg(options::OPT_static)) {
4731 CmdArgs.push_back("-lgcc_eh");
Roman Divackyc16bb762011-02-10 16:59:40 +00004732 } else if (Args.hasArg(options::OPT_pg)) {
4733 CmdArgs.push_back("-lgcc_eh_p");
Daniel Dunbar008f54a2009-04-01 19:36:32 +00004734 } else {
4735 CmdArgs.push_back("--as-needed");
4736 CmdArgs.push_back("-lgcc_s");
4737 CmdArgs.push_back("--no-as-needed");
4738 }
4739 }
4740
4741 if (!Args.hasArg(options::OPT_nostdlib) &&
4742 !Args.hasArg(options::OPT_nostartfiles)) {
4743 if (!Args.hasArg(options::OPT_shared))
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004744 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath(
Chris Lattner38e317d2010-07-07 16:01:42 +00004745 "crtend.o")));
Daniel Dunbar008f54a2009-04-01 19:36:32 +00004746 else
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004747 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath(
Chris Lattner38e317d2010-07-07 16:01:42 +00004748 "crtendS.o")));
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004749 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath(
Chris Lattner38e317d2010-07-07 16:01:42 +00004750 "crtn.o")));
Daniel Dunbar008f54a2009-04-01 19:36:32 +00004751 }
4752
Bill Wendling3f4be6f2011-06-27 19:15:03 +00004753 addProfileRT(getToolChain(), Args, CmdArgs, getToolChain().getTriple());
Nick Lewycky2e95a6d2011-05-24 21:54:59 +00004754
Daniel Dunbarc21c4852009-04-08 23:54:23 +00004755 const char *Exec =
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00004756 Args.MakeArgString(getToolChain().GetProgramPath("ld"));
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00004757 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbar008f54a2009-04-01 19:36:32 +00004758}
Daniel Dunbar11e1b402009-05-02 18:28:39 +00004759
Benjamin Kramer8e50a962011-02-02 18:59:27 +00004760void netbsd::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
4761 const InputInfo &Output,
4762 const InputInfoList &Inputs,
4763 const ArgList &Args,
4764 const char *LinkingOutput) const {
4765 ArgStringList CmdArgs;
4766
4767 // When building 32-bit code on NetBSD/amd64, we have to explicitly
4768 // instruct as in the base system to assemble 32-bit code.
Joerg Sonnenberger1bd91372012-01-26 22:27:52 +00004769 if (getToolChain().getArch() == llvm::Triple::x86)
Benjamin Kramer8e50a962011-02-02 18:59:27 +00004770 CmdArgs.push_back("--32");
4771
4772
4773 // Set byte order explicitly
4774 if (getToolChain().getArchName() == "mips")
4775 CmdArgs.push_back("-EB");
4776 else if (getToolChain().getArchName() == "mipsel")
4777 CmdArgs.push_back("-EL");
4778
4779 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
4780 options::OPT_Xassembler);
4781
4782 CmdArgs.push_back("-o");
4783 CmdArgs.push_back(Output.getFilename());
4784
4785 for (InputInfoList::const_iterator
4786 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
4787 const InputInfo &II = *it;
4788 CmdArgs.push_back(II.getFilename());
4789 }
4790
David Chisnall5adcec12011-09-27 22:03:18 +00004791 const char *Exec = Args.MakeArgString((getToolChain().GetProgramPath("as")));
Benjamin Kramer8e50a962011-02-02 18:59:27 +00004792 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
4793}
4794
4795void netbsd::Link::ConstructJob(Compilation &C, const JobAction &JA,
4796 const InputInfo &Output,
4797 const InputInfoList &Inputs,
4798 const ArgList &Args,
4799 const char *LinkingOutput) const {
4800 const Driver &D = getToolChain().getDriver();
4801 ArgStringList CmdArgs;
4802
Joerg Sonnenberger8ab2bdc2011-03-21 13:51:29 +00004803 if (!D.SysRoot.empty())
4804 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
4805
Benjamin Kramer8e50a962011-02-02 18:59:27 +00004806 if (Args.hasArg(options::OPT_static)) {
4807 CmdArgs.push_back("-Bstatic");
4808 } else {
4809 if (Args.hasArg(options::OPT_rdynamic))
4810 CmdArgs.push_back("-export-dynamic");
4811 CmdArgs.push_back("--eh-frame-hdr");
4812 if (Args.hasArg(options::OPT_shared)) {
4813 CmdArgs.push_back("-Bshareable");
4814 } else {
4815 CmdArgs.push_back("-dynamic-linker");
4816 CmdArgs.push_back("/libexec/ld.elf_so");
4817 }
4818 }
4819
4820 // When building 32-bit code on NetBSD/amd64, we have to explicitly
4821 // instruct ld in the base system to link 32-bit code.
Joerg Sonnenberger1bd91372012-01-26 22:27:52 +00004822 if (getToolChain().getArch() == llvm::Triple::x86) {
Benjamin Kramer8e50a962011-02-02 18:59:27 +00004823 CmdArgs.push_back("-m");
4824 CmdArgs.push_back("elf_i386");
4825 }
4826
4827 if (Output.isFilename()) {
4828 CmdArgs.push_back("-o");
4829 CmdArgs.push_back(Output.getFilename());
4830 } else {
4831 assert(Output.isNothing() && "Invalid output.");
4832 }
4833
4834 if (!Args.hasArg(options::OPT_nostdlib) &&
4835 !Args.hasArg(options::OPT_nostartfiles)) {
4836 if (!Args.hasArg(options::OPT_shared)) {
4837 CmdArgs.push_back(Args.MakeArgString(
4838 getToolChain().GetFilePath("crt0.o")));
4839 CmdArgs.push_back(Args.MakeArgString(
4840 getToolChain().GetFilePath("crti.o")));
4841 CmdArgs.push_back(Args.MakeArgString(
4842 getToolChain().GetFilePath("crtbegin.o")));
4843 } else {
4844 CmdArgs.push_back(Args.MakeArgString(
4845 getToolChain().GetFilePath("crti.o")));
4846 CmdArgs.push_back(Args.MakeArgString(
4847 getToolChain().GetFilePath("crtbeginS.o")));
4848 }
4849 }
4850
4851 Args.AddAllArgs(CmdArgs, options::OPT_L);
4852 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
4853 Args.AddAllArgs(CmdArgs, options::OPT_e);
4854 Args.AddAllArgs(CmdArgs, options::OPT_s);
4855 Args.AddAllArgs(CmdArgs, options::OPT_t);
4856 Args.AddAllArgs(CmdArgs, options::OPT_Z_Flag);
4857 Args.AddAllArgs(CmdArgs, options::OPT_r);
4858
4859 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
4860
4861 if (!Args.hasArg(options::OPT_nostdlib) &&
4862 !Args.hasArg(options::OPT_nodefaultlibs)) {
4863 if (D.CCCIsCXX) {
4864 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
4865 CmdArgs.push_back("-lm");
4866 }
4867 // FIXME: For some reason GCC passes -lgcc and -lgcc_s before adding
4868 // the default system libraries. Just mimic this for now.
Benjamin Kramer8e50a962011-02-02 18:59:27 +00004869 if (Args.hasArg(options::OPT_static)) {
4870 CmdArgs.push_back("-lgcc_eh");
4871 } else {
4872 CmdArgs.push_back("--as-needed");
4873 CmdArgs.push_back("-lgcc_s");
4874 CmdArgs.push_back("--no-as-needed");
4875 }
Joerg Sonnenbergerdb6393f2011-06-07 23:39:17 +00004876 CmdArgs.push_back("-lgcc");
Benjamin Kramer8e50a962011-02-02 18:59:27 +00004877
4878 if (Args.hasArg(options::OPT_pthread))
4879 CmdArgs.push_back("-lpthread");
4880 CmdArgs.push_back("-lc");
4881
4882 CmdArgs.push_back("-lgcc");
4883 if (Args.hasArg(options::OPT_static)) {
4884 CmdArgs.push_back("-lgcc_eh");
4885 } else {
4886 CmdArgs.push_back("--as-needed");
4887 CmdArgs.push_back("-lgcc_s");
4888 CmdArgs.push_back("--no-as-needed");
4889 }
4890 }
4891
4892 if (!Args.hasArg(options::OPT_nostdlib) &&
4893 !Args.hasArg(options::OPT_nostartfiles)) {
4894 if (!Args.hasArg(options::OPT_shared))
4895 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath(
4896 "crtend.o")));
4897 else
4898 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath(
4899 "crtendS.o")));
4900 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath(
4901 "crtn.o")));
4902 }
4903
Bill Wendling3f4be6f2011-06-27 19:15:03 +00004904 addProfileRT(getToolChain(), Args, CmdArgs, getToolChain().getTriple());
Nick Lewycky2e95a6d2011-05-24 21:54:59 +00004905
David Chisnall5adcec12011-09-27 22:03:18 +00004906 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("ld"));
Benjamin Kramer8e50a962011-02-02 18:59:27 +00004907 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
4908}
4909
Rafael Espindolaba30bbe2010-08-10 00:25:48 +00004910void linuxtools::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
4911 const InputInfo &Output,
4912 const InputInfoList &Inputs,
4913 const ArgList &Args,
4914 const char *LinkingOutput) const {
4915 ArgStringList CmdArgs;
4916
4917 // Add --32/--64 to make sure we get the format we want.
4918 // This is incomplete
4919 if (getToolChain().getArch() == llvm::Triple::x86) {
4920 CmdArgs.push_back("--32");
4921 } else if (getToolChain().getArch() == llvm::Triple::x86_64) {
4922 CmdArgs.push_back("--64");
Eli Friedman7972c882011-11-28 23:46:52 +00004923 } else if (getToolChain().getArch() == llvm::Triple::ppc) {
4924 CmdArgs.push_back("-a32");
4925 CmdArgs.push_back("-mppc");
4926 CmdArgs.push_back("-many");
4927 } else if (getToolChain().getArch() == llvm::Triple::ppc64) {
4928 CmdArgs.push_back("-a64");
4929 CmdArgs.push_back("-mppc64");
4930 CmdArgs.push_back("-many");
Rafael Espindolaba30bbe2010-08-10 00:25:48 +00004931 } else if (getToolChain().getArch() == llvm::Triple::arm) {
Chris Lattner5f9e2722011-07-23 10:55:15 +00004932 StringRef MArch = getToolChain().getArchName();
Rafael Espindolaba30bbe2010-08-10 00:25:48 +00004933 if (MArch == "armv7" || MArch == "armv7a" || MArch == "armv7-a")
4934 CmdArgs.push_back("-mfpu=neon");
Akira Hatanakac85900f2011-11-30 19:31:38 +00004935 } else if (getToolChain().getArch() == llvm::Triple::mips ||
4936 getToolChain().getArch() == llvm::Triple::mipsel ||
4937 getToolChain().getArch() == llvm::Triple::mips64 ||
4938 getToolChain().getArch() == llvm::Triple::mips64el) {
4939 // Get Mips CPU name and pass it to 'as'.
4940 const char *CPUName;
4941 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ))
4942 CPUName = A->getValue(Args);
4943 else
4944 CPUName = getMipsCPUFromArch(getToolChain().getArchName());
4945
4946 if (CPUName) {
4947 CmdArgs.push_back("-march");
4948 CmdArgs.push_back(CPUName);
4949 }
Rafael Espindolaba30bbe2010-08-10 00:25:48 +00004950 }
4951
4952 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
4953 options::OPT_Xassembler);
4954
4955 CmdArgs.push_back("-o");
4956 CmdArgs.push_back(Output.getFilename());
4957
4958 for (InputInfoList::const_iterator
4959 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
4960 const InputInfo &II = *it;
4961 CmdArgs.push_back(II.getFilename());
4962 }
4963
4964 const char *Exec =
4965 Args.MakeArgString(getToolChain().GetProgramPath("as"));
4966 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
4967}
4968
Rafael Espindolaabf3ac72011-10-17 21:39:04 +00004969static void AddLibgcc(const Driver &D, ArgStringList &CmdArgs,
4970 const ArgList &Args) {
4971 bool StaticLibgcc = Args.hasArg(options::OPT_static) ||
4972 Args.hasArg(options::OPT_static_libgcc);
4973 if (!D.CCCIsCXX)
4974 CmdArgs.push_back("-lgcc");
4975
4976 if (StaticLibgcc) {
4977 if (D.CCCIsCXX)
4978 CmdArgs.push_back("-lgcc");
4979 } else {
4980 if (!D.CCCIsCXX)
4981 CmdArgs.push_back("--as-needed");
4982 CmdArgs.push_back("-lgcc_s");
4983 if (!D.CCCIsCXX)
4984 CmdArgs.push_back("--no-as-needed");
4985 }
4986
4987 if (StaticLibgcc)
4988 CmdArgs.push_back("-lgcc_eh");
4989 else if (!Args.hasArg(options::OPT_shared) && D.CCCIsCXX)
4990 CmdArgs.push_back("-lgcc");
4991}
4992
Rafael Espindolac1da9812010-11-07 20:14:31 +00004993void linuxtools::Link::ConstructJob(Compilation &C, const JobAction &JA,
4994 const InputInfo &Output,
4995 const InputInfoList &Inputs,
4996 const ArgList &Args,
4997 const char *LinkingOutput) const {
4998 const toolchains::Linux& ToolChain =
4999 static_cast<const toolchains::Linux&>(getToolChain());
5000 const Driver &D = ToolChain.getDriver();
5001 ArgStringList CmdArgs;
5002
Rafael Espindola26f14c32010-11-15 18:28:16 +00005003 // Silence warning for "clang -g foo.o -o foo"
5004 Args.ClaimAllArgs(options::OPT_g_Group);
Rafael Espindola9c094fb2011-03-01 05:25:27 +00005005 // and "clang -emit-llvm foo.o -o foo"
5006 Args.ClaimAllArgs(options::OPT_emit_llvm);
Rafael Espindola7f6458b2010-11-17 20:37:10 +00005007 // and for "clang -g foo.o -o foo". Other warning options are already
5008 // handled somewhere else.
5009 Args.ClaimAllArgs(options::OPT_w);
Rafael Espindola26f14c32010-11-15 18:28:16 +00005010
Joerg Sonnenberger8ab2bdc2011-03-21 13:51:29 +00005011 if (!D.SysRoot.empty())
5012 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
Rafael Espindolac1da9812010-11-07 20:14:31 +00005013
Rafael Espindolafdda1712010-11-17 22:26:15 +00005014 if (Args.hasArg(options::OPT_pie))
5015 CmdArgs.push_back("-pie");
5016
Rafael Espindoladc1b76d2010-11-07 22:57:16 +00005017 if (Args.hasArg(options::OPT_rdynamic))
5018 CmdArgs.push_back("-export-dynamic");
5019
Rafael Espindolae0e6d3b2010-11-11 19:34:42 +00005020 if (Args.hasArg(options::OPT_s))
5021 CmdArgs.push_back("-s");
5022
Rafael Espindolac1da9812010-11-07 20:14:31 +00005023 for (std::vector<std::string>::const_iterator i = ToolChain.ExtraOpts.begin(),
5024 e = ToolChain.ExtraOpts.end();
5025 i != e; ++i)
5026 CmdArgs.push_back(i->c_str());
5027
5028 if (!Args.hasArg(options::OPT_static)) {
5029 CmdArgs.push_back("--eh-frame-hdr");
5030 }
5031
5032 CmdArgs.push_back("-m");
5033 if (ToolChain.getArch() == llvm::Triple::x86)
5034 CmdArgs.push_back("elf_i386");
Eric Christopher88b7cf02011-08-19 00:30:14 +00005035 else if (ToolChain.getArch() == llvm::Triple::arm
Douglas Gregorf0594d82011-03-06 19:11:49 +00005036 || ToolChain.getArch() == llvm::Triple::thumb)
Rafael Espindolac1da9812010-11-07 20:14:31 +00005037 CmdArgs.push_back("armelf_linux_eabi");
Ted Kremenek43ac2972011-04-05 22:04:27 +00005038 else if (ToolChain.getArch() == llvm::Triple::ppc)
5039 CmdArgs.push_back("elf32ppclinux");
5040 else if (ToolChain.getArch() == llvm::Triple::ppc64)
5041 CmdArgs.push_back("elf64ppc");
Eli Friedman5bea4f62011-11-08 19:43:37 +00005042 else if (ToolChain.getArch() == llvm::Triple::mips)
5043 CmdArgs.push_back("elf32btsmip");
5044 else if (ToolChain.getArch() == llvm::Triple::mipsel)
5045 CmdArgs.push_back("elf32ltsmip");
5046 else if (ToolChain.getArch() == llvm::Triple::mips64)
5047 CmdArgs.push_back("elf64btsmip");
5048 else if (ToolChain.getArch() == llvm::Triple::mips64el)
5049 CmdArgs.push_back("elf64ltsmip");
Rafael Espindolac1da9812010-11-07 20:14:31 +00005050 else
5051 CmdArgs.push_back("elf_x86_64");
5052
5053 if (Args.hasArg(options::OPT_static)) {
Douglas Gregorf0594d82011-03-06 19:11:49 +00005054 if (ToolChain.getArch() == llvm::Triple::arm
5055 || ToolChain.getArch() == llvm::Triple::thumb)
Rafael Espindolac1da9812010-11-07 20:14:31 +00005056 CmdArgs.push_back("-Bstatic");
5057 else
5058 CmdArgs.push_back("-static");
5059 } else if (Args.hasArg(options::OPT_shared)) {
5060 CmdArgs.push_back("-shared");
5061 }
5062
5063 if (ToolChain.getArch() == llvm::Triple::arm ||
Douglas Gregorf0594d82011-03-06 19:11:49 +00005064 ToolChain.getArch() == llvm::Triple::thumb ||
Rafael Espindolac1da9812010-11-07 20:14:31 +00005065 (!Args.hasArg(options::OPT_static) &&
5066 !Args.hasArg(options::OPT_shared))) {
5067 CmdArgs.push_back("-dynamic-linker");
5068 if (ToolChain.getArch() == llvm::Triple::x86)
5069 CmdArgs.push_back("/lib/ld-linux.so.2");
Douglas Gregorf0594d82011-03-06 19:11:49 +00005070 else if (ToolChain.getArch() == llvm::Triple::arm ||
5071 ToolChain.getArch() == llvm::Triple::thumb)
Rafael Espindolac1da9812010-11-07 20:14:31 +00005072 CmdArgs.push_back("/lib/ld-linux.so.3");
Eli Friedman5bea4f62011-11-08 19:43:37 +00005073 else if (ToolChain.getArch() == llvm::Triple::mips ||
5074 ToolChain.getArch() == llvm::Triple::mipsel)
5075 CmdArgs.push_back("/lib/ld.so.1");
Ted Kremenek43ac2972011-04-05 22:04:27 +00005076 else if (ToolChain.getArch() == llvm::Triple::ppc)
Chris Lattner09f43ed2011-04-11 21:15:37 +00005077 CmdArgs.push_back("/lib/ld.so.1");
Ted Kremenek43ac2972011-04-05 22:04:27 +00005078 else if (ToolChain.getArch() == llvm::Triple::ppc64)
Chris Lattner09f43ed2011-04-11 21:15:37 +00005079 CmdArgs.push_back("/lib64/ld64.so.1");
Rafael Espindolac1da9812010-11-07 20:14:31 +00005080 else
5081 CmdArgs.push_back("/lib64/ld-linux-x86-64.so.2");
5082 }
5083
5084 CmdArgs.push_back("-o");
5085 CmdArgs.push_back(Output.getFilename());
5086
Rafael Espindola49c64fd2010-12-01 01:52:43 +00005087 if (!Args.hasArg(options::OPT_nostdlib) &&
5088 !Args.hasArg(options::OPT_nostartfiles)) {
Rafael Espindolafdda1712010-11-17 22:26:15 +00005089 const char *crt1 = NULL;
5090 if (!Args.hasArg(options::OPT_shared)){
5091 if (Args.hasArg(options::OPT_pie))
5092 crt1 = "Scrt1.o";
5093 else
5094 crt1 = "crt1.o";
5095 }
5096 if (crt1)
5097 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crt1)));
Rafael Espindolac1da9812010-11-07 20:14:31 +00005098
Rafael Espindola89414b32010-11-12 03:00:39 +00005099 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
Rafael Espindolac1da9812010-11-07 20:14:31 +00005100
Rafael Espindola89414b32010-11-12 03:00:39 +00005101 const char *crtbegin;
5102 if (Args.hasArg(options::OPT_static))
5103 crtbegin = "crtbeginT.o";
Rafael Espindolafdda1712010-11-17 22:26:15 +00005104 else if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_pie))
Rafael Espindola89414b32010-11-12 03:00:39 +00005105 crtbegin = "crtbeginS.o";
5106 else
5107 crtbegin = "crtbegin.o";
5108 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtbegin)));
5109 }
Rafael Espindolac1da9812010-11-07 20:14:31 +00005110
5111 Args.AddAllArgs(CmdArgs, options::OPT_L);
5112
5113 const ToolChain::path_list Paths = ToolChain.getFilePaths();
5114
Roman Divacky58e5ac92011-03-01 17:53:14 +00005115 for (ToolChain::path_list::const_iterator i = Paths.begin(), e = Paths.end();
5116 i != e; ++i)
Chris Lattner5f9e2722011-07-23 10:55:15 +00005117 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + *i));
Rafael Espindolac1da9812010-11-07 20:14:31 +00005118
5119 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
5120
Rafael Espindola89414b32010-11-12 03:00:39 +00005121 if (D.CCCIsCXX && !Args.hasArg(options::OPT_nostdlib)) {
Rafael Espindola19706f82011-10-17 22:14:51 +00005122 bool OnlyLibstdcxxStatic = Args.hasArg(options::OPT_static_libstdcxx) &&
5123 !Args.hasArg(options::OPT_static);
5124 if (OnlyLibstdcxxStatic)
5125 CmdArgs.push_back("-Bstatic");
Rafael Espindolac1da9812010-11-07 20:14:31 +00005126 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
Rafael Espindola19706f82011-10-17 22:14:51 +00005127 if (OnlyLibstdcxxStatic)
5128 CmdArgs.push_back("-Bdynamic");
Rafael Espindolac1da9812010-11-07 20:14:31 +00005129 CmdArgs.push_back("-lm");
5130 }
5131
Kostya Serebryanydff466c2011-11-30 01:39:16 +00005132 // Call this before we add the C run-time.
5133 addAsanRTLinux(getToolChain(), Args, CmdArgs);
5134
Rafael Espindola89414b32010-11-12 03:00:39 +00005135 if (!Args.hasArg(options::OPT_nostdlib)) {
Nick Lewycky80df0252011-06-04 06:27:06 +00005136 if (Args.hasArg(options::OPT_static))
5137 CmdArgs.push_back("--start-group");
5138
Rafael Espindolaabf3ac72011-10-17 21:39:04 +00005139 AddLibgcc(D, CmdArgs, Args);
Rafael Espindola89414b32010-11-12 03:00:39 +00005140
5141 if (Args.hasArg(options::OPT_pthread) ||
5142 Args.hasArg(options::OPT_pthreads))
5143 CmdArgs.push_back("-lpthread");
5144
5145 CmdArgs.push_back("-lc");
5146
5147 if (Args.hasArg(options::OPT_static))
5148 CmdArgs.push_back("--end-group");
Rafael Espindolaabf3ac72011-10-17 21:39:04 +00005149 else
5150 AddLibgcc(D, CmdArgs, Args);
Rafael Espindola89414b32010-11-12 03:00:39 +00005151
Rafael Espindolafdda1712010-11-17 22:26:15 +00005152
Rafael Espindola49c64fd2010-12-01 01:52:43 +00005153 if (!Args.hasArg(options::OPT_nostartfiles)) {
5154 const char *crtend;
5155 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_pie))
5156 crtend = "crtendS.o";
5157 else
5158 crtend = "crtend.o";
Rafael Espindola89414b32010-11-12 03:00:39 +00005159
Rafael Espindola49c64fd2010-12-01 01:52:43 +00005160 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtend)));
5161 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
5162 }
Rafael Espindolac1da9812010-11-07 20:14:31 +00005163 }
5164
Bill Wendling3f4be6f2011-06-27 19:15:03 +00005165 addProfileRT(getToolChain(), Args, CmdArgs, getToolChain().getTriple());
Nick Lewycky2e95a6d2011-05-24 21:54:59 +00005166
Peter Collingbourne79d481a2011-11-05 03:47:53 +00005167 if (D.IsUsingLTO(Args) || Args.hasArg(options::OPT_use_gold_plugin)) {
Rafael Espindolac1da9812010-11-07 20:14:31 +00005168 CmdArgs.push_back("-plugin");
5169 std::string Plugin = ToolChain.getDriver().Dir + "/../lib/LLVMgold.so";
5170 CmdArgs.push_back(Args.MakeArgString(Plugin));
5171 }
5172
5173 C.addCommand(new Command(JA, *this, ToolChain.Linker.c_str(), CmdArgs));
5174}
Rafael Espindolaba30bbe2010-08-10 00:25:48 +00005175
Chris Lattner38e317d2010-07-07 16:01:42 +00005176void minix::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00005177 const InputInfo &Output,
5178 const InputInfoList &Inputs,
5179 const ArgList &Args,
5180 const char *LinkingOutput) const {
Chris Lattner38e317d2010-07-07 16:01:42 +00005181 ArgStringList CmdArgs;
5182
5183 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
5184 options::OPT_Xassembler);
5185
5186 CmdArgs.push_back("-o");
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00005187 CmdArgs.push_back(Output.getFilename());
Chris Lattner38e317d2010-07-07 16:01:42 +00005188
5189 for (InputInfoList::const_iterator
5190 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
5191 const InputInfo &II = *it;
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00005192 CmdArgs.push_back(II.getFilename());
Chris Lattner38e317d2010-07-07 16:01:42 +00005193 }
5194
5195 const char *Exec =
Eli Friedman6d402dc2011-12-08 23:54:21 +00005196 Args.MakeArgString(getToolChain().GetProgramPath("as"));
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00005197 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Chris Lattner38e317d2010-07-07 16:01:42 +00005198}
5199
5200void minix::Link::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00005201 const InputInfo &Output,
5202 const InputInfoList &Inputs,
5203 const ArgList &Args,
5204 const char *LinkingOutput) const {
Chris Lattner38e317d2010-07-07 16:01:42 +00005205 const Driver &D = getToolChain().getDriver();
5206 ArgStringList CmdArgs;
5207
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00005208 if (Output.isFilename()) {
Chris Lattner38e317d2010-07-07 16:01:42 +00005209 CmdArgs.push_back("-o");
5210 CmdArgs.push_back(Output.getFilename());
5211 } else {
5212 assert(Output.isNothing() && "Invalid output.");
5213 }
5214
5215 if (!Args.hasArg(options::OPT_nostdlib) &&
Eli Friedman6d402dc2011-12-08 23:54:21 +00005216 !Args.hasArg(options::OPT_nostartfiles)) {
5217 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crt1.o")));
5218 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
5219 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
5220 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
5221 }
Chris Lattner38e317d2010-07-07 16:01:42 +00005222
5223 Args.AddAllArgs(CmdArgs, options::OPT_L);
5224 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
5225 Args.AddAllArgs(CmdArgs, options::OPT_e);
5226
Daniel Dunbar2008fee2010-09-17 00:24:54 +00005227 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Chris Lattner38e317d2010-07-07 16:01:42 +00005228
Eli Friedman6d402dc2011-12-08 23:54:21 +00005229 addProfileRT(getToolChain(), Args, CmdArgs, getToolChain().getTriple());
5230
Chris Lattner38e317d2010-07-07 16:01:42 +00005231 if (!Args.hasArg(options::OPT_nostdlib) &&
5232 !Args.hasArg(options::OPT_nodefaultlibs)) {
5233 if (D.CCCIsCXX) {
Daniel Dunbar132e35d2010-09-17 01:20:05 +00005234 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Chris Lattner38e317d2010-07-07 16:01:42 +00005235 CmdArgs.push_back("-lm");
5236 }
Chris Lattner38e317d2010-07-07 16:01:42 +00005237 }
5238
5239 if (!Args.hasArg(options::OPT_nostdlib) &&
5240 !Args.hasArg(options::OPT_nostartfiles)) {
Eli Friedman6d402dc2011-12-08 23:54:21 +00005241 if (Args.hasArg(options::OPT_pthread))
5242 CmdArgs.push_back("-lpthread");
5243 CmdArgs.push_back("-lc");
5244 CmdArgs.push_back("-lCompilerRT-Generic");
5245 CmdArgs.push_back("-L/usr/pkg/compiler-rt/lib");
5246 CmdArgs.push_back(
5247 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Chris Lattner38e317d2010-07-07 16:01:42 +00005248 }
5249
Eli Friedman6d402dc2011-12-08 23:54:21 +00005250 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("ld"));
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00005251 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Chris Lattner38e317d2010-07-07 16:01:42 +00005252}
5253
Daniel Dunbar11e1b402009-05-02 18:28:39 +00005254/// DragonFly Tools
5255
5256// For now, DragonFly Assemble does just about the same as for
5257// FreeBSD, but this may change soon.
5258void dragonfly::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00005259 const InputInfo &Output,
Daniel Dunbar294691e2009-11-04 06:24:38 +00005260 const InputInfoList &Inputs,
5261 const ArgList &Args,
5262 const char *LinkingOutput) const {
Daniel Dunbar11e1b402009-05-02 18:28:39 +00005263 ArgStringList CmdArgs;
5264
5265 // When building 32-bit code on DragonFly/pc64, we have to explicitly
5266 // instruct as in the base system to assemble 32-bit code.
5267 if (getToolChain().getArchName() == "i386")
5268 CmdArgs.push_back("--32");
5269
5270 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
5271 options::OPT_Xassembler);
5272
5273 CmdArgs.push_back("-o");
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00005274 CmdArgs.push_back(Output.getFilename());
Daniel Dunbar11e1b402009-05-02 18:28:39 +00005275
5276 for (InputInfoList::const_iterator
5277 it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) {
5278 const InputInfo &II = *it;
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00005279 CmdArgs.push_back(II.getFilename());
Daniel Dunbar11e1b402009-05-02 18:28:39 +00005280 }
5281
5282 const char *Exec =
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00005283 Args.MakeArgString(getToolChain().GetProgramPath("as"));
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00005284 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbar11e1b402009-05-02 18:28:39 +00005285}
5286
5287void dragonfly::Link::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00005288 const InputInfo &Output,
5289 const InputInfoList &Inputs,
5290 const ArgList &Args,
5291 const char *LinkingOutput) const {
Daniel Dunbaree788e72009-12-21 18:54:17 +00005292 const Driver &D = getToolChain().getDriver();
Daniel Dunbar11e1b402009-05-02 18:28:39 +00005293 ArgStringList CmdArgs;
5294
Joerg Sonnenberger8ab2bdc2011-03-21 13:51:29 +00005295 if (!D.SysRoot.empty())
5296 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
5297
Daniel Dunbar11e1b402009-05-02 18:28:39 +00005298 if (Args.hasArg(options::OPT_static)) {
5299 CmdArgs.push_back("-Bstatic");
5300 } else {
5301 if (Args.hasArg(options::OPT_shared))
5302 CmdArgs.push_back("-Bshareable");
5303 else {
5304 CmdArgs.push_back("-dynamic-linker");
5305 CmdArgs.push_back("/usr/libexec/ld-elf.so.2");
5306 }
5307 }
5308
5309 // When building 32-bit code on DragonFly/pc64, we have to explicitly
5310 // instruct ld in the base system to link 32-bit code.
5311 if (getToolChain().getArchName() == "i386") {
5312 CmdArgs.push_back("-m");
5313 CmdArgs.push_back("elf_i386");
5314 }
5315
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00005316 if (Output.isFilename()) {
Daniel Dunbar11e1b402009-05-02 18:28:39 +00005317 CmdArgs.push_back("-o");
5318 CmdArgs.push_back(Output.getFilename());
5319 } else {
5320 assert(Output.isNothing() && "Invalid output.");
5321 }
5322
5323 if (!Args.hasArg(options::OPT_nostdlib) &&
5324 !Args.hasArg(options::OPT_nostartfiles)) {
5325 if (!Args.hasArg(options::OPT_shared)) {
Chris Lattner38e317d2010-07-07 16:01:42 +00005326 CmdArgs.push_back(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00005327 Args.MakeArgString(getToolChain().GetFilePath("crt1.o")));
Chris Lattner38e317d2010-07-07 16:01:42 +00005328 CmdArgs.push_back(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00005329 Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
Chris Lattner38e317d2010-07-07 16:01:42 +00005330 CmdArgs.push_back(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00005331 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
Daniel Dunbar11e1b402009-05-02 18:28:39 +00005332 } else {
Chris Lattner38e317d2010-07-07 16:01:42 +00005333 CmdArgs.push_back(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00005334 Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
Chris Lattner38e317d2010-07-07 16:01:42 +00005335 CmdArgs.push_back(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00005336 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.o")));
Daniel Dunbar11e1b402009-05-02 18:28:39 +00005337 }
5338 }
5339
5340 Args.AddAllArgs(CmdArgs, options::OPT_L);
5341 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
5342 Args.AddAllArgs(CmdArgs, options::OPT_e);
5343
Daniel Dunbar2008fee2010-09-17 00:24:54 +00005344 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Daniel Dunbar11e1b402009-05-02 18:28:39 +00005345
5346 if (!Args.hasArg(options::OPT_nostdlib) &&
5347 !Args.hasArg(options::OPT_nodefaultlibs)) {
5348 // FIXME: GCC passes on -lgcc, -lgcc_pic and a whole lot of
5349 // rpaths
5350 CmdArgs.push_back("-L/usr/lib/gcc41");
5351
5352 if (!Args.hasArg(options::OPT_static)) {
5353 CmdArgs.push_back("-rpath");
5354 CmdArgs.push_back("/usr/lib/gcc41");
5355
5356 CmdArgs.push_back("-rpath-link");
5357 CmdArgs.push_back("/usr/lib/gcc41");
5358
5359 CmdArgs.push_back("-rpath");
5360 CmdArgs.push_back("/usr/lib");
5361
5362 CmdArgs.push_back("-rpath-link");
5363 CmdArgs.push_back("/usr/lib");
5364 }
5365
Rafael Espindola405861d2010-07-20 12:59:03 +00005366 if (D.CCCIsCXX) {
Daniel Dunbar132e35d2010-09-17 01:20:05 +00005367 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Rafael Espindola405861d2010-07-20 12:59:03 +00005368 CmdArgs.push_back("-lm");
5369 }
5370
Daniel Dunbar11e1b402009-05-02 18:28:39 +00005371 if (Args.hasArg(options::OPT_shared)) {
5372 CmdArgs.push_back("-lgcc_pic");
5373 } else {
5374 CmdArgs.push_back("-lgcc");
5375 }
5376
5377
5378 if (Args.hasArg(options::OPT_pthread))
Mike Stump4d63f8b2009-10-31 20:11:46 +00005379 CmdArgs.push_back("-lpthread");
Daniel Dunbar11e1b402009-05-02 18:28:39 +00005380
5381 if (!Args.hasArg(options::OPT_nolibc)) {
5382 CmdArgs.push_back("-lc");
5383 }
5384
5385 if (Args.hasArg(options::OPT_shared)) {
5386 CmdArgs.push_back("-lgcc_pic");
5387 } else {
5388 CmdArgs.push_back("-lgcc");
5389 }
5390 }
5391
5392 if (!Args.hasArg(options::OPT_nostdlib) &&
5393 !Args.hasArg(options::OPT_nostartfiles)) {
5394 if (!Args.hasArg(options::OPT_shared))
Chris Lattner38e317d2010-07-07 16:01:42 +00005395 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00005396 getToolChain().GetFilePath("crtend.o")));
Daniel Dunbar11e1b402009-05-02 18:28:39 +00005397 else
Chris Lattner38e317d2010-07-07 16:01:42 +00005398 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00005399 getToolChain().GetFilePath("crtendS.o")));
Chris Lattner38e317d2010-07-07 16:01:42 +00005400 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00005401 getToolChain().GetFilePath("crtn.o")));
Daniel Dunbar11e1b402009-05-02 18:28:39 +00005402 }
5403
Bill Wendling3f4be6f2011-06-27 19:15:03 +00005404 addProfileRT(getToolChain(), Args, CmdArgs, getToolChain().getTriple());
Nick Lewycky2e95a6d2011-05-24 21:54:59 +00005405
Daniel Dunbar11e1b402009-05-02 18:28:39 +00005406 const char *Exec =
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00005407 Args.MakeArgString(getToolChain().GetProgramPath("ld"));
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00005408 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
Daniel Dunbar11e1b402009-05-02 18:28:39 +00005409}
Michael J. Spencerff58e362010-08-21 21:55:07 +00005410
5411void visualstudio::Link::ConstructJob(Compilation &C, const JobAction &JA,
5412 const InputInfo &Output,
5413 const InputInfoList &Inputs,
5414 const ArgList &Args,
5415 const char *LinkingOutput) const {
Michael J. Spencerff58e362010-08-21 21:55:07 +00005416 ArgStringList CmdArgs;
5417
5418 if (Output.isFilename()) {
Daniel Dunbare5a37f42010-09-17 00:45:02 +00005419 CmdArgs.push_back(Args.MakeArgString(std::string("-out:") +
5420 Output.getFilename()));
Michael J. Spencerff58e362010-08-21 21:55:07 +00005421 } else {
5422 assert(Output.isNothing() && "Invalid output.");
5423 }
5424
5425 if (!Args.hasArg(options::OPT_nostdlib) &&
5426 !Args.hasArg(options::OPT_nostartfiles)) {
5427 CmdArgs.push_back("-defaultlib:libcmt");
5428 }
5429
5430 CmdArgs.push_back("-nologo");
5431
Daniel Dunbar2008fee2010-09-17 00:24:54 +00005432 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Michael J. Spencerff58e362010-08-21 21:55:07 +00005433
5434 const char *Exec =
Daniel Dunbar2008fee2010-09-17 00:24:54 +00005435 Args.MakeArgString(getToolChain().GetProgramPath("link.exe"));
Michael J. Spencerff58e362010-08-21 21:55:07 +00005436 C.addCommand(new Command(JA, *this, Exec, CmdArgs));
5437}