blob: b0e581bc78bd69a930a6de688d4bb384427be4b5 [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"
Chandler Carruth55fc8732012-12-04 09:13:33 +000011#include "InputInfo.h"
Chandler Carruth55fc8732012-12-04 09:13:33 +000012#include "ToolChains.h"
Stephen Hines0e2c34f2015-03-23 12:09:02 -070013#include "clang/Basic/CharInfo.h"
Stephen Hines651f13c2014-04-23 16:59:28 -070014#include "clang/Basic/LangOptions.h"
Chandler Carruth55fc8732012-12-04 09:13:33 +000015#include "clang/Basic/ObjCRuntime.h"
Kevin Enderby02341792013-01-17 21:38:06 +000016#include "clang/Basic/Version.h"
Stephen Hines0e2c34f2015-03-23 12:09:02 -070017#include "clang/Config/config.h"
Daniel Dunbar1d460332009-03-18 10:01:51 +000018#include "clang/Driver/Action.h"
Chandler Carruth55fc8732012-12-04 09:13:33 +000019#include "clang/Driver/Compilation.h"
Daniel Dunbaree848a72009-10-29 02:39:57 +000020#include "clang/Driver/Driver.h"
21#include "clang/Driver/DriverDiagnostic.h"
Daniel Dunbar871adcf2009-03-18 07:06:02 +000022#include "clang/Driver/Job.h"
Daniel Dunbar265e9ef2009-11-19 04:25:22 +000023#include "clang/Driver/Options.h"
Alexey Samsonov1b8f12d2013-08-19 09:14:21 +000024#include "clang/Driver/SanitizerArgs.h"
Daniel Dunbarb488c1d2009-03-18 08:07:30 +000025#include "clang/Driver/ToolChain.h"
Daniel Dunbar871adcf2009-03-18 07:06:02 +000026#include "clang/Driver/Util.h"
Daniel Dunbar88137642009-09-09 22:32:48 +000027#include "llvm/ADT/SmallString.h"
Hans Wennborgdc40bf92013-09-20 18:16:35 +000028#include "llvm/ADT/StringExtras.h"
Douglas Gregor55d3f7a2009-10-29 00:41:01 +000029#include "llvm/ADT/StringSwitch.h"
Daniel Dunbar5b750fe2009-09-09 22:32:34 +000030#include "llvm/ADT/Twine.h"
Reid Klecknerb1e25a12013-06-14 17:17:23 +000031#include "llvm/Option/Arg.h"
32#include "llvm/Option/ArgList.h"
33#include "llvm/Option/Option.h"
Stephen Hines651f13c2014-04-23 16:59:28 -070034#include "llvm/Support/Compression.h"
Chandler Carruth55fc8732012-12-04 09:13:33 +000035#include "llvm/Support/ErrorHandling.h"
Michael J. Spencer32bef4e2011-01-10 02:34:13 +000036#include "llvm/Support/FileSystem.h"
Michael J. Spencer03013fa2010-11-29 18:12:39 +000037#include "llvm/Support/Host.h"
Hans Wennborgdc40bf92013-09-20 18:16:35 +000038#include "llvm/Support/Path.h"
Michael J. Spencer03013fa2010-11-29 18:12:39 +000039#include "llvm/Support/Process.h"
Stephen Hines651f13c2014-04-23 16:59:28 -070040#include "llvm/Support/Program.h"
Chandler Carruth55fc8732012-12-04 09:13:33 +000041#include "llvm/Support/raw_ostream.h"
Daniel Dunbar871adcf2009-03-18 07:06:02 +000042
Stephen Hines0e2c34f2015-03-23 12:09:02 -070043#ifdef LLVM_ON_UNIX
44#include <unistd.h> // For getuid().
45#endif
46
Daniel Dunbar47ac7d22009-03-18 06:00:36 +000047using namespace clang::driver;
48using namespace clang::driver::tools;
Chris Lattner5f9e2722011-07-23 10:55:15 +000049using namespace clang;
Reid Klecknerb1e25a12013-06-14 17:17:23 +000050using namespace llvm::opt;
Daniel Dunbar47ac7d22009-03-18 06:00:36 +000051
Stephen Hines651f13c2014-04-23 16:59:28 -070052static void addAssemblerKPIC(const ArgList &Args, ArgStringList &CmdArgs) {
53 Arg *LastPICArg = Args.getLastArg(options::OPT_fPIC, options::OPT_fno_PIC,
54 options::OPT_fpic, options::OPT_fno_pic,
55 options::OPT_fPIE, options::OPT_fno_PIE,
56 options::OPT_fpie, options::OPT_fno_pie);
57 if (!LastPICArg)
58 return;
59 if (LastPICArg->getOption().matches(options::OPT_fPIC) ||
60 LastPICArg->getOption().matches(options::OPT_fpic) ||
61 LastPICArg->getOption().matches(options::OPT_fPIE) ||
62 LastPICArg->getOption().matches(options::OPT_fpie)) {
63 CmdArgs.push_back("-KPIC");
64 }
65}
66
Daniel Dunbar88a3d6c2009-09-10 01:21:05 +000067/// CheckPreprocessingOptions - Perform some validation of preprocessing
68/// arguments that is shared with gcc.
69static void CheckPreprocessingOptions(const Driver &D, const ArgList &Args) {
Stephen Hinesef822542014-07-21 00:47:37 -070070 if (Arg *A = Args.getLastArg(options::OPT_C, options::OPT_CC)) {
71 if (!Args.hasArg(options::OPT_E) && !Args.hasArg(options::OPT__SLASH_P) &&
72 !Args.hasArg(options::OPT__SLASH_EP) && !D.CCCIsCPP()) {
Chris Lattner5f9e2722011-07-23 10:55:15 +000073 D.Diag(diag::err_drv_argument_only_allowed_with)
Stephen Hinesef822542014-07-21 00:47:37 -070074 << A->getBaseArg().getAsString(Args)
75 << (D.IsCLMode() ? "/E, /P or /EP" : "-E");
76 }
77 }
Daniel Dunbar88a3d6c2009-09-10 01:21:05 +000078}
79
Daniel Dunbare2fd6642009-09-10 01:21:12 +000080/// CheckCodeGenerationOptions - Perform some validation of code generation
81/// arguments that is shared with gcc.
82static void CheckCodeGenerationOptions(const Driver &D, const ArgList &Args) {
83 // In gcc, only ARM checks this, but it seems reasonable to check universally.
84 if (Args.hasArg(options::OPT_static))
85 if (const Arg *A = Args.getLastArg(options::OPT_dynamic,
86 options::OPT_mdynamic_no_pic))
Chris Lattner5f9e2722011-07-23 10:55:15 +000087 D.Diag(diag::err_drv_argument_not_allowed_with)
Daniel Dunbare2fd6642009-09-10 01:21:12 +000088 << A->getAsString(Args) << "-static";
89}
90
Stephen Hines176edba2014-12-01 14:53:08 -080091// Add backslashes to escape spaces and other backslashes.
92// This is used for the space-separated argument list specified with
93// the -dwarf-debug-flags option.
94static void EscapeSpacesAndBackslashes(const char *Arg,
95 SmallVectorImpl<char> &Res) {
96 for ( ; *Arg; ++Arg) {
97 switch (*Arg) {
98 default: break;
99 case ' ':
100 case '\\':
101 Res.push_back('\\');
102 break;
103 }
104 Res.push_back(*Arg);
105 }
106}
107
Chris Lattner3edbeb72010-03-29 17:55:58 +0000108// Quote target names for inclusion in GNU Make dependency files.
109// Only the characters '$', '#', ' ', '\t' are quoted.
Chris Lattner5f9e2722011-07-23 10:55:15 +0000110static void QuoteTarget(StringRef Target,
111 SmallVectorImpl<char> &Res) {
Chris Lattner3edbeb72010-03-29 17:55:58 +0000112 for (unsigned i = 0, e = Target.size(); i != e; ++i) {
113 switch (Target[i]) {
114 case ' ':
115 case '\t':
116 // Escape the preceding backslashes
117 for (int j = i - 1; j >= 0 && Target[j] == '\\'; --j)
118 Res.push_back('\\');
119
120 // Escape the space/tab
121 Res.push_back('\\');
122 break;
123 case '$':
124 Res.push_back('$');
125 break;
126 case '#':
127 Res.push_back('\\');
128 break;
129 default:
130 break;
131 }
132
133 Res.push_back(Target[i]);
134 }
135}
136
Bill Wendling3d717152012-03-12 22:10:06 +0000137static void addDirectoryList(const ArgList &Args,
Bill Wendlingbdb8f3c2012-03-12 21:22:35 +0000138 ArgStringList &CmdArgs,
139 const char *ArgName,
Bill Wendling3d717152012-03-12 22:10:06 +0000140 const char *EnvVar) {
141 const char *DirList = ::getenv(EnvVar);
Chad Rosier89aa2ce2012-10-30 21:42:09 +0000142 bool CombinedArg = false;
143
Bill Wendlingbdb8f3c2012-03-12 21:22:35 +0000144 if (!DirList)
145 return; // Nothing to do.
146
Chad Rosier89aa2ce2012-10-30 21:42:09 +0000147 StringRef Name(ArgName);
148 if (Name.equals("-I") || Name.equals("-L"))
149 CombinedArg = true;
150
Bill Wendlingbdb8f3c2012-03-12 21:22:35 +0000151 StringRef Dirs(DirList);
152 if (Dirs.empty()) // Empty string should not add '.'.
153 return;
154
155 StringRef::size_type Delim;
Rafael Espindola8db7ec02013-06-25 14:29:51 +0000156 while ((Delim = Dirs.find(llvm::sys::EnvPathSeparator)) != StringRef::npos) {
Bill Wendlingbdb8f3c2012-03-12 21:22:35 +0000157 if (Delim == 0) { // Leading colon.
Chad Rosier89aa2ce2012-10-30 21:42:09 +0000158 if (CombinedArg) {
159 CmdArgs.push_back(Args.MakeArgString(std::string(ArgName) + "."));
160 } else {
161 CmdArgs.push_back(ArgName);
162 CmdArgs.push_back(".");
163 }
Bill Wendlingbdb8f3c2012-03-12 21:22:35 +0000164 } else {
Chad Rosier89aa2ce2012-10-30 21:42:09 +0000165 if (CombinedArg) {
166 CmdArgs.push_back(Args.MakeArgString(std::string(ArgName) + Dirs.substr(0, Delim)));
167 } else {
168 CmdArgs.push_back(ArgName);
169 CmdArgs.push_back(Args.MakeArgString(Dirs.substr(0, Delim)));
170 }
Bill Wendlingbdb8f3c2012-03-12 21:22:35 +0000171 }
Nico Weber09c5c392012-03-19 15:00:03 +0000172 Dirs = Dirs.substr(Delim + 1);
Bill Wendlingbdb8f3c2012-03-12 21:22:35 +0000173 }
174
175 if (Dirs.empty()) { // Trailing colon.
Chad Rosier89aa2ce2012-10-30 21:42:09 +0000176 if (CombinedArg) {
177 CmdArgs.push_back(Args.MakeArgString(std::string(ArgName) + "."));
178 } else {
179 CmdArgs.push_back(ArgName);
180 CmdArgs.push_back(".");
181 }
Bill Wendlingbdb8f3c2012-03-12 21:22:35 +0000182 } else { // Add the last path.
Chad Rosier89aa2ce2012-10-30 21:42:09 +0000183 if (CombinedArg) {
184 CmdArgs.push_back(Args.MakeArgString(std::string(ArgName) + Dirs));
185 } else {
186 CmdArgs.push_back(ArgName);
187 CmdArgs.push_back(Args.MakeArgString(Dirs));
188 }
Bill Wendlingbdb8f3c2012-03-12 21:22:35 +0000189 }
190}
191
Daniel Dunbar2008fee2010-09-17 00:24:54 +0000192static void AddLinkerInputs(const ToolChain &TC,
193 const InputInfoList &Inputs, const ArgList &Args,
194 ArgStringList &CmdArgs) {
195 const Driver &D = TC.getDriver();
196
Daniel Dunbar8ac38d72011-02-19 05:33:51 +0000197 // Add extra linker input arguments which are not treated as inputs
198 // (constructed via -Xarch_).
199 Args.AddAllArgValues(CmdArgs, options::OPT_Zlinker_input);
200
Stephen Hinesef822542014-07-21 00:47:37 -0700201 for (const auto &II : Inputs) {
Daniel Dunbar2008fee2010-09-17 00:24:54 +0000202 if (!TC.HasNativeLLVMSupport()) {
203 // Don't try to pass LLVM inputs unless we have native support.
204 if (II.getType() == types::TY_LLVM_IR ||
205 II.getType() == types::TY_LTO_IR ||
206 II.getType() == types::TY_LLVM_BC ||
207 II.getType() == types::TY_LTO_BC)
Chris Lattner5f9e2722011-07-23 10:55:15 +0000208 D.Diag(diag::err_drv_no_linker_llvm_support)
Daniel Dunbar2008fee2010-09-17 00:24:54 +0000209 << TC.getTripleString();
210 }
211
Daniel Dunbare5a37f42010-09-17 00:45:02 +0000212 // Add filenames immediately.
213 if (II.isFilename()) {
Daniel Dunbar2008fee2010-09-17 00:24:54 +0000214 CmdArgs.push_back(II.getFilename());
Daniel Dunbare5a37f42010-09-17 00:45:02 +0000215 continue;
216 }
217
218 // Otherwise, this is a linker input argument.
219 const Arg &A = II.getInputArg();
220
221 // Handle reserved library options.
Stephen Hinesef822542014-07-21 00:47:37 -0700222 if (A.getOption().matches(options::OPT_Z_reserved_lib_stdcxx))
Daniel Dunbar132e35d2010-09-17 01:20:05 +0000223 TC.AddCXXStdlibLibArgs(Args, CmdArgs);
Stephen Hinesef822542014-07-21 00:47:37 -0700224 else if (A.getOption().matches(options::OPT_Z_reserved_lib_cckext))
Shantonu Sen7433fed2010-09-17 18:39:08 +0000225 TC.AddCCKextLibArgs(Args, CmdArgs);
Stephen Hines176edba2014-12-01 14:53:08 -0800226 else if (A.getOption().matches(options::OPT_z)) {
227 // Pass -z prefix for gcc linker compatibility.
228 A.claim();
229 A.render(Args, CmdArgs);
230 } else {
231 A.renderAsInput(Args, CmdArgs);
232 }
Daniel Dunbar2008fee2010-09-17 00:24:54 +0000233 }
Bill Wendlingbdb8f3c2012-03-12 21:22:35 +0000234
235 // LIBRARY_PATH - included following the user specified library paths.
Stephen Hines651f13c2014-04-23 16:59:28 -0700236 // and only supported on native toolchains.
237 if (!TC.isCrossCompiling())
238 addDirectoryList(Args, CmdArgs, "-L", "LIBRARY_PATH");
Daniel Dunbar2008fee2010-09-17 00:24:54 +0000239}
240
John McCallf85e1932011-06-15 23:02:42 +0000241/// \brief Determine whether Objective-C automated reference counting is
242/// enabled.
243static bool isObjCAutoRefCount(const ArgList &Args) {
244 return Args.hasFlag(options::OPT_fobjc_arc, options::OPT_fno_objc_arc, false);
245}
246
Ted Kremenekebcb57a2012-03-06 20:05:56 +0000247/// \brief Determine whether we are linking the ObjC runtime.
248static bool isObjCRuntimeLinked(const ArgList &Args) {
Bob Wilsona7635f12012-08-07 19:58:00 +0000249 if (isObjCAutoRefCount(Args)) {
250 Args.ClaimAllArgs(options::OPT_fobjc_link_runtime);
Ted Kremenekebcb57a2012-03-06 20:05:56 +0000251 return true;
Bob Wilsona7635f12012-08-07 19:58:00 +0000252 }
Ted Kremenekebcb57a2012-03-06 20:05:56 +0000253 return Args.hasArg(options::OPT_fobjc_link_runtime);
254}
255
Michael J. Spencer91e06da2012-10-19 22:37:06 +0000256static bool forwardToGCC(const Option &O) {
Reid Kleckner4cd90df2013-06-19 15:09:06 +0000257 // Don't forward inputs from the original command line. They are added from
258 // InputInfoList.
Richard Smithe40bc4b2013-06-20 01:33:59 +0000259 return O.getKind() != Option::InputClass &&
Michael J. Spencer91e06da2012-10-19 22:37:06 +0000260 !O.hasFlag(options::DriverOption) &&
261 !O.hasFlag(options::LinkerInput);
262}
263
Peter Collingbourne54db68b2011-11-06 00:40:05 +0000264void Clang::AddPreprocessingOptions(Compilation &C,
Chad Rosier9d718632013-01-24 19:14:47 +0000265 const JobAction &JA,
Peter Collingbourne54db68b2011-11-06 00:40:05 +0000266 const Driver &D,
Douglas Gregordf91ef32009-04-18 00:34:01 +0000267 const ArgList &Args,
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000268 ArgStringList &CmdArgs,
269 const InputInfo &Output,
270 const InputInfoList &Inputs) const {
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000271 Arg *A;
Daniel Dunbar3a183d32009-06-08 21:48:20 +0000272
Daniel Dunbar88a3d6c2009-09-10 01:21:05 +0000273 CheckPreprocessingOptions(D, Args);
274
275 Args.AddLastArg(CmdArgs, options::OPT_C);
276 Args.AddLastArg(CmdArgs, options::OPT_CC);
Daniel Dunbar3a183d32009-06-08 21:48:20 +0000277
278 // Handle dependency file generation.
Daniel Dunbar9eb93b02010-12-08 21:33:40 +0000279 if ((A = Args.getLastArg(options::OPT_M, options::OPT_MM)) ||
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000280 (A = Args.getLastArg(options::OPT_MD)) ||
281 (A = Args.getLastArg(options::OPT_MMD))) {
282 // Determine the output location.
283 const char *DepFile;
Benjamin Kramer99c72082012-09-26 19:01:49 +0000284 if (Arg *MF = Args.getLastArg(options::OPT_MF)) {
Richard Smith1d489cf2012-11-01 04:30:05 +0000285 DepFile = MF->getValue();
Chad Rosier9d718632013-01-24 19:14:47 +0000286 C.addFailureResultFile(DepFile, &JA);
Benjamin Kramer99c72082012-09-26 19:01:49 +0000287 } else if (Output.getType() == types::TY_Dependencies) {
288 DepFile = Output.getFilename();
Daniel Dunbarb827a052009-11-19 03:26:40 +0000289 } else if (A->getOption().matches(options::OPT_M) ||
290 A->getOption().matches(options::OPT_MM)) {
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000291 DepFile = "-";
292 } else {
Bob Wilson66b8a662012-11-23 06:14:39 +0000293 DepFile = getDependencyFileName(Args, Inputs);
Chad Rosier9d718632013-01-24 19:14:47 +0000294 C.addFailureResultFile(DepFile, &JA);
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000295 }
296 CmdArgs.push_back("-dependency-file");
297 CmdArgs.push_back(DepFile);
298
Chris Lattner3edbeb72010-03-29 17:55:58 +0000299 // Add a default target if one wasn't specified.
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000300 if (!Args.hasArg(options::OPT_MT) && !Args.hasArg(options::OPT_MQ)) {
301 const char *DepTarget;
302
303 // If user provided -o, that is the dependency target, except
304 // when we are only generating a dependency file.
305 Arg *OutputOpt = Args.getLastArg(options::OPT_o);
306 if (OutputOpt && Output.getType() != types::TY_Dependencies) {
Richard Smith1d489cf2012-11-01 04:30:05 +0000307 DepTarget = OutputOpt->getValue();
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000308 } else {
309 // Otherwise derive from the base input.
310 //
311 // FIXME: This should use the computed output file location.
Dylan Noblesmithf7ccbad2012-02-05 02:13:05 +0000312 SmallString<128> P(Inputs[0].getBaseInput());
Michael J. Spencer472ccff2010-12-18 00:19:12 +0000313 llvm::sys::path::replace_extension(P, "o");
314 DepTarget = Args.MakeArgString(llvm::sys::path::filename(P));
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000315 }
316
317 CmdArgs.push_back("-MT");
Dylan Noblesmithf7ccbad2012-02-05 02:13:05 +0000318 SmallString<128> Quoted;
Chris Lattner3edbeb72010-03-29 17:55:58 +0000319 QuoteTarget(DepTarget, Quoted);
320 CmdArgs.push_back(Args.MakeArgString(Quoted));
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000321 }
322
Daniel Dunbarb827a052009-11-19 03:26:40 +0000323 if (A->getOption().matches(options::OPT_M) ||
324 A->getOption().matches(options::OPT_MD))
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000325 CmdArgs.push_back("-sys-header-deps");
Stephen Hines651f13c2014-04-23 16:59:28 -0700326
327 if (isa<PrecompileJobAction>(JA))
328 CmdArgs.push_back("-module-file-deps");
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000329 }
330
Peter Collingbournebb527862011-07-12 19:35:15 +0000331 if (Args.hasArg(options::OPT_MG)) {
332 if (!A || A->getOption().matches(options::OPT_MD) ||
333 A->getOption().matches(options::OPT_MMD))
Chris Lattner5f9e2722011-07-23 10:55:15 +0000334 D.Diag(diag::err_drv_mg_requires_m_or_mm);
Peter Collingbournebb527862011-07-12 19:35:15 +0000335 CmdArgs.push_back("-MG");
336 }
337
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000338 Args.AddLastArg(CmdArgs, options::OPT_MP);
Chris Lattner3edbeb72010-03-29 17:55:58 +0000339
340 // Convert all -MQ <target> args to -MT <quoted target>
341 for (arg_iterator it = Args.filtered_begin(options::OPT_MT,
342 options::OPT_MQ),
343 ie = Args.filtered_end(); it != ie; ++it) {
Daniel Dunbar7e4953e2010-06-11 22:00:13 +0000344 const Arg *A = *it;
345 A->claim();
Chris Lattner3edbeb72010-03-29 17:55:58 +0000346
Daniel Dunbar7e4953e2010-06-11 22:00:13 +0000347 if (A->getOption().matches(options::OPT_MQ)) {
Chris Lattner3edbeb72010-03-29 17:55:58 +0000348 CmdArgs.push_back("-MT");
Dylan Noblesmithf7ccbad2012-02-05 02:13:05 +0000349 SmallString<128> Quoted;
Richard Smith1d489cf2012-11-01 04:30:05 +0000350 QuoteTarget(A->getValue(), Quoted);
Chris Lattner3edbeb72010-03-29 17:55:58 +0000351 CmdArgs.push_back(Args.MakeArgString(Quoted));
352
353 // -MT flag - no change
354 } else {
Daniel Dunbar7e4953e2010-06-11 22:00:13 +0000355 A->render(Args, CmdArgs);
Chris Lattner3edbeb72010-03-29 17:55:58 +0000356 }
357 }
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000358
Douglas Gregordf91ef32009-04-18 00:34:01 +0000359 // Add -i* options, and automatically translate to
360 // -include-pch/-include-pth for transparent PCH support. It's
361 // wonky, but we include looking for .gch so we can support seamless
362 // replacement into a build system already set up to be generating
363 // .gch files.
Argyrios Kyrtzidis990142a2010-09-30 16:53:47 +0000364 bool RenderedImplicitInclude = false;
Daniel Dunbarcdd96862009-11-25 11:53:23 +0000365 for (arg_iterator it = Args.filtered_begin(options::OPT_clang_i_Group),
366 ie = Args.filtered_end(); it != ie; ++it) {
367 const Arg *A = it;
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000368
369 if (A->getOption().matches(options::OPT_include)) {
Argyrios Kyrtzidis990142a2010-09-30 16:53:47 +0000370 bool IsFirstImplicitInclude = !RenderedImplicitInclude;
371 RenderedImplicitInclude = true;
372
Argyrios Kyrtzidise5c35372010-08-11 23:27:58 +0000373 // Use PCH if the user requested it.
Daniel Dunbar0ebd9322009-10-15 20:02:44 +0000374 bool UsePCH = D.CCCUsePCH;
Daniel Dunbar0ebd9322009-10-15 20:02:44 +0000375
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000376 bool FoundPTH = false;
Douglas Gregordf91ef32009-04-18 00:34:01 +0000377 bool FoundPCH = false;
Rafael Espindolaf8edb992013-06-25 15:03:59 +0000378 SmallString<128> P(A->getValue());
379 // We want the files to have a name like foo.h.pch. Add a dummy extension
380 // so that replace_extension does the right thing.
381 P += ".dummy";
Daniel Dunbar0ebd9322009-10-15 20:02:44 +0000382 if (UsePCH) {
Rafael Espindolaf8edb992013-06-25 15:03:59 +0000383 llvm::sys::path::replace_extension(P, "pch");
Rafael Espindola829e88d2013-06-25 14:48:00 +0000384 if (llvm::sys::fs::exists(P.str()))
Douglas Gregordf91ef32009-04-18 00:34:01 +0000385 FoundPCH = true;
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000386 }
387
Douglas Gregordf91ef32009-04-18 00:34:01 +0000388 if (!FoundPCH) {
Rafael Espindolaf8edb992013-06-25 15:03:59 +0000389 llvm::sys::path::replace_extension(P, "pth");
Rafael Espindola829e88d2013-06-25 14:48:00 +0000390 if (llvm::sys::fs::exists(P.str()))
Douglas Gregordf91ef32009-04-18 00:34:01 +0000391 FoundPTH = true;
Mike Stump1eb44332009-09-09 15:08:12 +0000392 }
393
Douglas Gregordf91ef32009-04-18 00:34:01 +0000394 if (!FoundPCH && !FoundPTH) {
Rafael Espindolaf8edb992013-06-25 15:03:59 +0000395 llvm::sys::path::replace_extension(P, "gch");
Rafael Espindola829e88d2013-06-25 14:48:00 +0000396 if (llvm::sys::fs::exists(P.str())) {
Daniel Dunbar0ebd9322009-10-15 20:02:44 +0000397 FoundPCH = UsePCH;
398 FoundPTH = !UsePCH;
Douglas Gregordf91ef32009-04-18 00:34:01 +0000399 }
Douglas Gregordf91ef32009-04-18 00:34:01 +0000400 }
401
402 if (FoundPCH || FoundPTH) {
Argyrios Kyrtzidis990142a2010-09-30 16:53:47 +0000403 if (IsFirstImplicitInclude) {
404 A->claim();
405 if (UsePCH)
406 CmdArgs.push_back("-include-pch");
407 else
408 CmdArgs.push_back("-include-pth");
409 CmdArgs.push_back(Args.MakeArgString(P.str()));
410 continue;
411 } else {
412 // Ignore the PCH if not first on command line and emit warning.
Chris Lattner5f9e2722011-07-23 10:55:15 +0000413 D.Diag(diag::warn_drv_pch_not_first_include)
Argyrios Kyrtzidis990142a2010-09-30 16:53:47 +0000414 << P.str() << A->getAsString(Args);
415 }
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000416 }
417 }
418
419 // Not translated, render as usual.
420 A->claim();
421 A->render(Args, CmdArgs);
422 }
423
424 Args.AddAllArgs(CmdArgs, options::OPT_D, options::OPT_U);
Douglas Gregor65e02fa2011-07-28 04:45:53 +0000425 Args.AddAllArgs(CmdArgs, options::OPT_I_Group, options::OPT_F,
426 options::OPT_index_header_map);
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000427
428 // Add -Wp, and -Xassembler if using the preprocessor.
429
430 // FIXME: There is a very unfortunate problem here, some troubled
431 // souls abuse -Wp, to pass preprocessor options in gcc syntax. To
432 // really support that we would have to parse and then translate
433 // those options. :(
434 Args.AddAllArgValues(CmdArgs, options::OPT_Wp_COMMA,
435 options::OPT_Xpreprocessor);
Daniel Dunbar607d7f62009-10-29 01:53:44 +0000436
437 // -I- is a deprecated GCC feature, reject it.
438 if (Arg *A = Args.getLastArg(options::OPT_I_))
Chris Lattner5f9e2722011-07-23 10:55:15 +0000439 D.Diag(diag::err_drv_I_dash_not_supported) << A->getAsString(Args);
Chandler Carruthfeee58c2010-10-20 07:00:47 +0000440
441 // If we have a --sysroot, and don't have an explicit -isysroot flag, add an
442 // -isysroot to the CC1 invocation.
Sebastian Pop4762a2d2012-04-16 04:16:43 +0000443 StringRef sysroot = C.getSysRoot();
444 if (sysroot != "") {
Chandler Carruthfeee58c2010-10-20 07:00:47 +0000445 if (!Args.hasArg(options::OPT_isysroot)) {
446 CmdArgs.push_back("-isysroot");
Sebastian Pop4762a2d2012-04-16 04:16:43 +0000447 CmdArgs.push_back(C.getArgs().MakeArgString(sysroot));
Chandler Carruthfeee58c2010-10-20 07:00:47 +0000448 }
449 }
Douglas Gregor2a060852013-02-07 00:21:12 +0000450
Benjamin Kramer47adebe2011-09-22 21:41:16 +0000451 // Parse additional include paths from environment variables.
Chandler Carruthb5870e72011-11-04 07:12:58 +0000452 // FIXME: We should probably sink the logic for handling these from the
453 // frontend into the driver. It will allow deleting 4 otherwise unused flags.
Benjamin Kramer47adebe2011-09-22 21:41:16 +0000454 // CPATH - included following the user specified includes (but prior to
455 // builtin and standard includes).
Bill Wendling3d717152012-03-12 22:10:06 +0000456 addDirectoryList(Args, CmdArgs, "-I", "CPATH");
Benjamin Kramer47adebe2011-09-22 21:41:16 +0000457 // C_INCLUDE_PATH - system includes enabled when compiling C.
Bill Wendling3d717152012-03-12 22:10:06 +0000458 addDirectoryList(Args, CmdArgs, "-c-isystem", "C_INCLUDE_PATH");
Benjamin Kramer47adebe2011-09-22 21:41:16 +0000459 // CPLUS_INCLUDE_PATH - system includes enabled when compiling C++.
Bill Wendling3d717152012-03-12 22:10:06 +0000460 addDirectoryList(Args, CmdArgs, "-cxx-isystem", "CPLUS_INCLUDE_PATH");
Benjamin Kramer47adebe2011-09-22 21:41:16 +0000461 // OBJC_INCLUDE_PATH - system includes enabled when compiling ObjC.
Bill Wendling3d717152012-03-12 22:10:06 +0000462 addDirectoryList(Args, CmdArgs, "-objc-isystem", "OBJC_INCLUDE_PATH");
Benjamin Kramer47adebe2011-09-22 21:41:16 +0000463 // OBJCPLUS_INCLUDE_PATH - system includes enabled when compiling ObjC++.
Bill Wendling3d717152012-03-12 22:10:06 +0000464 addDirectoryList(Args, CmdArgs, "-objcxx-isystem", "OBJCPLUS_INCLUDE_PATH");
Chandler Carruth88491fc2011-11-04 07:12:53 +0000465
Chandler Carruth88491fc2011-11-04 07:12:53 +0000466 // Add C++ include arguments, if needed.
Chandler Carrutha4614422011-11-04 07:43:33 +0000467 if (types::isCXX(Inputs[0].getType()))
Chandler Carruth7ffa0322011-11-04 07:34:47 +0000468 getToolChain().AddClangCXXStdlibIncludeArgs(Args, CmdArgs);
Chandler Carruth7d7e9f92011-11-05 20:17:13 +0000469
470 // Add system include arguments.
471 getToolChain().AddClangSystemIncludeArgs(Args, CmdArgs);
Daniel Dunbarc21c4852009-04-08 23:54:23 +0000472}
473
Daniel Dunbar1f95e652009-11-17 06:37:03 +0000474// FIXME: Move to target hook.
475static bool isSignedCharDefault(const llvm::Triple &Triple) {
476 switch (Triple.getArch()) {
477 default:
478 return true;
479
Tim Northoverc264e162013-01-31 12:13:10 +0000480 case llvm::Triple::aarch64:
Stephen Hines651f13c2014-04-23 16:59:28 -0700481 case llvm::Triple::aarch64_be:
Jim Grosbach5b4e7b12011-05-24 15:40:46 +0000482 case llvm::Triple::arm:
Stephen Hines651f13c2014-04-23 16:59:28 -0700483 case llvm::Triple::armeb:
Stephen Hines176edba2014-12-01 14:53:08 -0800484 case llvm::Triple::thumb:
485 case llvm::Triple::thumbeb:
Stephen Hines6bcf27b2014-05-29 04:14:42 -0700486 if (Triple.isOSDarwin() || Triple.isOSWindows())
487 return true;
488 return false;
489
Daniel Dunbar1f95e652009-11-17 06:37:03 +0000490 case llvm::Triple::ppc:
491 case llvm::Triple::ppc64:
Bob Wilson905c45f2011-10-14 05:03:44 +0000492 if (Triple.isOSDarwin())
Daniel Dunbar1f95e652009-11-17 06:37:03 +0000493 return true;
494 return false;
Ulrich Weigandb8409212013-05-06 16:26:41 +0000495
Bill Schmidtea7fb0c2013-07-26 01:36:11 +0000496 case llvm::Triple::ppc64le:
Ulrich Weigandb8409212013-05-06 16:26:41 +0000497 case llvm::Triple::systemz:
Robert Lytton5f15f4d2013-08-13 09:43:10 +0000498 case llvm::Triple::xcore:
Ulrich Weigandb8409212013-05-06 16:26:41 +0000499 return false;
Daniel Dunbar1f95e652009-11-17 06:37:03 +0000500 }
501}
502
Robert Lytton5f15f4d2013-08-13 09:43:10 +0000503static bool isNoCommonDefault(const llvm::Triple &Triple) {
504 switch (Triple.getArch()) {
505 default:
506 return false;
507
508 case llvm::Triple::xcore:
509 return true;
510 }
511}
512
Silviu Baranga1db2e272013-10-21 10:54:53 +0000513// Handle -mhwdiv=.
514static void getARMHWDivFeatures(const Driver &D, const Arg *A,
515 const ArgList &Args,
516 std::vector<const char *> &Features) {
517 StringRef HWDiv = A->getValue();
518 if (HWDiv == "arm") {
519 Features.push_back("+hwdiv-arm");
520 Features.push_back("-hwdiv");
521 } else if (HWDiv == "thumb") {
522 Features.push_back("-hwdiv-arm");
523 Features.push_back("+hwdiv");
524 } else if (HWDiv == "arm,thumb" || HWDiv == "thumb,arm") {
525 Features.push_back("+hwdiv-arm");
526 Features.push_back("+hwdiv");
527 } else if (HWDiv == "none") {
528 Features.push_back("-hwdiv-arm");
529 Features.push_back("-hwdiv");
530 } else
531 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
532}
Stephen Hines176edba2014-12-01 14:53:08 -0800533
Amara Emersonfe7ed042013-10-01 10:20:54 +0000534// Handle -mfpu=.
535//
536// FIXME: Centralize feature selection, defaulting shouldn't be also in the
537// frontend target.
538static void getARMFPUFeatures(const Driver &D, const Arg *A,
539 const ArgList &Args,
540 std::vector<const char *> &Features) {
Richard Smith1d489cf2012-11-01 04:30:05 +0000541 StringRef FPU = A->getValue();
Chad Rosier99317272012-04-04 20:51:35 +0000542
543 // Set the target features based on the FPU.
544 if (FPU == "fpa" || FPU == "fpe2" || FPU == "fpe3" || FPU == "maverick") {
545 // Disable any default FPU support.
Rafael Espindola146dbbf2013-08-21 16:39:20 +0000546 Features.push_back("-vfp2");
547 Features.push_back("-vfp3");
548 Features.push_back("-neon");
Stephen Hines651f13c2014-04-23 16:59:28 -0700549 } else if (FPU == "vfp") {
550 Features.push_back("+vfp2");
551 Features.push_back("-neon");
Chad Rosier99317272012-04-04 20:51:35 +0000552 } else if (FPU == "vfp3-d16" || FPU == "vfpv3-d16") {
Rafael Espindola146dbbf2013-08-21 16:39:20 +0000553 Features.push_back("+vfp3");
554 Features.push_back("+d16");
555 Features.push_back("-neon");
Chad Rosier99317272012-04-04 20:51:35 +0000556 } else if (FPU == "vfp3" || FPU == "vfpv3") {
Rafael Espindola146dbbf2013-08-21 16:39:20 +0000557 Features.push_back("+vfp3");
558 Features.push_back("-neon");
Stephen Hines651f13c2014-04-23 16:59:28 -0700559 } else if (FPU == "vfp4-d16" || FPU == "vfpv4-d16") {
560 Features.push_back("+vfp4");
561 Features.push_back("+d16");
562 Features.push_back("-neon");
563 } else if (FPU == "vfp4" || FPU == "vfpv4") {
564 Features.push_back("+vfp4");
565 Features.push_back("-neon");
566 } else if (FPU == "fp4-sp-d16" || FPU == "fpv4-sp-d16") {
567 Features.push_back("+vfp4");
568 Features.push_back("+d16");
569 Features.push_back("+fp-only-sp");
570 Features.push_back("-neon");
Stephen Hines176edba2014-12-01 14:53:08 -0800571 } else if (FPU == "fp5-sp-d16" || FPU == "fpv5-sp-d16") {
572 Features.push_back("+fp-armv8");
573 Features.push_back("+fp-only-sp");
574 Features.push_back("+d16");
575 Features.push_back("-neon");
576 Features.push_back("-crypto");
577 } else if (FPU == "fp5-dp-d16" || FPU == "fpv5-dp-d16" ||
578 FPU == "fp5-d16" || FPU == "fpv5-d16") {
579 Features.push_back("+fp-armv8");
580 Features.push_back("+d16");
581 Features.push_back("-neon");
582 Features.push_back("-crypto");
Joey Goulycbed3bf2013-06-27 13:19:54 +0000583 } else if (FPU == "fp-armv8") {
Joey Gouly2b33b7e2013-09-13 13:48:33 +0000584 Features.push_back("+fp-armv8");
Bernard Ogdenf779e652013-10-24 18:32:51 +0000585 Features.push_back("-neon");
586 Features.push_back("-crypto");
Joey Goulycbed3bf2013-06-27 13:19:54 +0000587 } else if (FPU == "neon-fp-armv8") {
Joey Gouly2b33b7e2013-09-13 13:48:33 +0000588 Features.push_back("+fp-armv8");
Rafael Espindola146dbbf2013-08-21 16:39:20 +0000589 Features.push_back("+neon");
Bernard Ogdenf779e652013-10-24 18:32:51 +0000590 Features.push_back("-crypto");
Amara Emersoncdc532c2013-09-19 13:54:03 +0000591 } else if (FPU == "crypto-neon-fp-armv8") {
Amara Emersoncdc532c2013-09-19 13:54:03 +0000592 Features.push_back("+fp-armv8");
Bernard Ogdenf779e652013-10-24 18:32:51 +0000593 Features.push_back("+neon");
594 Features.push_back("+crypto");
Chad Rosier99317272012-04-04 20:51:35 +0000595 } else if (FPU == "neon") {
Rafael Espindola146dbbf2013-08-21 16:39:20 +0000596 Features.push_back("+neon");
Stephen Hines0e2c34f2015-03-23 12:09:02 -0700597 } else if (FPU == "neon-vfpv3") {
598 Features.push_back("+vfp3");
599 Features.push_back("+neon");
600 } else if (FPU == "neon-vfpv4") {
601 Features.push_back("+neon");
602 Features.push_back("+vfp4");
Amara Emersonfe7ed042013-10-01 10:20:54 +0000603 } else if (FPU == "none") {
604 Features.push_back("-vfp2");
605 Features.push_back("-vfp3");
606 Features.push_back("-vfp4");
607 Features.push_back("-fp-armv8");
608 Features.push_back("-crypto");
609 Features.push_back("-neon");
Chad Rosier99317272012-04-04 20:51:35 +0000610 } else
611 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
612}
613
Anton Korobeynikove2571792012-04-09 13:38:30 +0000614// Select the float ABI as determined by -msoft-float, -mhard-float, and
615// -mfloat-abi=.
Stephen Hines651f13c2014-04-23 16:59:28 -0700616StringRef tools::arm::getARMFloatABI(const Driver &D, const ArgList &Args,
617 const llvm::Triple &Triple) {
Chris Lattner5f9e2722011-07-23 10:55:15 +0000618 StringRef FloatABI;
Daniel Dunbarcbd19332009-09-10 23:00:09 +0000619 if (Arg *A = Args.getLastArg(options::OPT_msoft_float,
620 options::OPT_mhard_float,
621 options::OPT_mfloat_abi_EQ)) {
622 if (A->getOption().matches(options::OPT_msoft_float))
623 FloatABI = "soft";
624 else if (A->getOption().matches(options::OPT_mhard_float))
625 FloatABI = "hard";
626 else {
Richard Smith1d489cf2012-11-01 04:30:05 +0000627 FloatABI = A->getValue();
Daniel Dunbarcbd19332009-09-10 23:00:09 +0000628 if (FloatABI != "soft" && FloatABI != "softfp" && FloatABI != "hard") {
Chris Lattner5f9e2722011-07-23 10:55:15 +0000629 D.Diag(diag::err_drv_invalid_mfloat_abi)
Daniel Dunbarcbd19332009-09-10 23:00:09 +0000630 << A->getAsString(Args);
631 FloatABI = "soft";
632 }
633 }
634 }
635
636 // If unspecified, choose the default based on the platform.
637 if (FloatABI.empty()) {
Rafael Espindolabcd6df62010-06-28 17:18:09 +0000638 switch (Triple.getOS()) {
Bob Wilson905c45f2011-10-14 05:03:44 +0000639 case llvm::Triple::Darwin:
640 case llvm::Triple::MacOSX:
641 case llvm::Triple::IOS: {
Daniel Dunbarcbd19332009-09-10 23:00:09 +0000642 // Darwin defaults to "softfp" for v6 and v7.
643 //
644 // FIXME: Factor out an ARM class so we can cache the arch somewhere.
Benjamin Kramer92c4fd52012-06-26 22:20:06 +0000645 std::string ArchName =
Stephen Hines651f13c2014-04-23 16:59:28 -0700646 arm::getLLVMArchSuffixForARM(arm::getARMTargetCPU(Args, Triple));
Benjamin Kramer92c4fd52012-06-26 22:20:06 +0000647 if (StringRef(ArchName).startswith("v6") ||
648 StringRef(ArchName).startswith("v7"))
Daniel Dunbarcbd19332009-09-10 23:00:09 +0000649 FloatABI = "softfp";
650 else
651 FloatABI = "soft";
652 break;
653 }
654
Stephen Hines6bcf27b2014-05-29 04:14:42 -0700655 // FIXME: this is invalid for WindowsCE
656 case llvm::Triple::Win32:
657 FloatABI = "hard";
658 break;
659
Rafael Espindola27fa2362012-12-13 04:17:14 +0000660 case llvm::Triple::FreeBSD:
Stephen Hines651f13c2014-04-23 16:59:28 -0700661 switch(Triple.getEnvironment()) {
662 case llvm::Triple::GNUEABIHF:
663 FloatABI = "hard";
664 break;
665 default:
666 // FreeBSD defaults to soft float
667 FloatABI = "soft";
668 break;
669 }
Rafael Espindola27fa2362012-12-13 04:17:14 +0000670 break;
671
Daniel Dunbarcbd19332009-09-10 23:00:09 +0000672 default:
Bob Wilsonfc2bd7c2011-02-04 17:59:28 +0000673 switch(Triple.getEnvironment()) {
Jiangning Liuff104a12012-07-31 08:06:29 +0000674 case llvm::Triple::GNUEABIHF:
675 FloatABI = "hard";
676 break;
Bob Wilsonfc2bd7c2011-02-04 17:59:28 +0000677 case llvm::Triple::GNUEABI:
678 FloatABI = "softfp";
679 break;
Stephen Hines651f13c2014-04-23 16:59:28 -0700680 case llvm::Triple::EABIHF:
681 FloatABI = "hard";
682 break;
Bob Wilsonfc2bd7c2011-02-04 17:59:28 +0000683 case llvm::Triple::EABI:
684 // EABI is always AAPCS, and if it was not marked 'hard', it's softfp
685 FloatABI = "softfp";
686 break;
Logan Chien94a71422012-09-02 09:30:11 +0000687 case llvm::Triple::Android: {
Benjamin Kramer92c4fd52012-06-26 22:20:06 +0000688 std::string ArchName =
Stephen Hines651f13c2014-04-23 16:59:28 -0700689 arm::getLLVMArchSuffixForARM(arm::getARMTargetCPU(Args, Triple));
Benjamin Kramer92c4fd52012-06-26 22:20:06 +0000690 if (StringRef(ArchName).startswith("v7"))
Chandler Carruthb43550b2012-01-10 19:47:42 +0000691 FloatABI = "softfp";
692 else
693 FloatABI = "soft";
694 break;
695 }
Bob Wilsonfc2bd7c2011-02-04 17:59:28 +0000696 default:
697 // Assume "soft", but warn the user we are guessing.
698 FloatABI = "soft";
Stephen Hines651f13c2014-04-23 16:59:28 -0700699 if (Triple.getOS() != llvm::Triple::UnknownOS ||
700 !Triple.isOSBinFormatMachO())
701 D.Diag(diag::warn_drv_assuming_mfloat_abi_is) << "soft";
Bob Wilsonfc2bd7c2011-02-04 17:59:28 +0000702 break;
703 }
Daniel Dunbarcbd19332009-09-10 23:00:09 +0000704 }
705 }
706
Anton Korobeynikove2571792012-04-09 13:38:30 +0000707 return FloatABI;
708}
709
Rafael Espindola146dbbf2013-08-21 16:39:20 +0000710static void getARMTargetFeatures(const Driver &D, const llvm::Triple &Triple,
711 const ArgList &Args,
Stephen Hines651f13c2014-04-23 16:59:28 -0700712 std::vector<const char *> &Features,
713 bool ForAS) {
714 StringRef FloatABI = tools::arm::getARMFloatABI(D, Args, Triple);
715 if (!ForAS) {
716 // FIXME: Note, this is a hack, the LLVM backend doesn't actually use these
717 // yet (it uses the -mfloat-abi and -msoft-float options), and it is
718 // stripped out by the ARM target. We should probably pass this a new
719 // -target-option, which is handled by the -cc1/-cc1as invocation.
720 //
721 // FIXME2: For consistency, it would be ideal if we set up the target
722 // machine state the same when using the frontend or the assembler. We don't
723 // currently do that for the assembler, we pass the options directly to the
724 // backend and never even instantiate the frontend TargetInfo. If we did,
725 // and used its handleTargetFeatures hook, then we could ensure the
726 // assembler and the frontend behave the same.
Rafael Espindola146dbbf2013-08-21 16:39:20 +0000727
Stephen Hines651f13c2014-04-23 16:59:28 -0700728 // Use software floating point operations?
729 if (FloatABI == "soft")
730 Features.push_back("+soft-float");
731
732 // Use software floating point argument passing?
733 if (FloatABI != "hard")
734 Features.push_back("+soft-float-abi");
735 }
Rafael Espindola146dbbf2013-08-21 16:39:20 +0000736
737 // Honor -mfpu=.
738 if (const Arg *A = Args.getLastArg(options::OPT_mfpu_EQ))
Amara Emersonfe7ed042013-10-01 10:20:54 +0000739 getARMFPUFeatures(D, A, Args, Features);
Silviu Baranga1db2e272013-10-21 10:54:53 +0000740 if (const Arg *A = Args.getLastArg(options::OPT_mhwdiv_EQ))
741 getARMHWDivFeatures(D, A, Args, Features);
Rafael Espindola146dbbf2013-08-21 16:39:20 +0000742
Rafael Espindola146dbbf2013-08-21 16:39:20 +0000743 // Setting -msoft-float effectively disables NEON because of the GCC
744 // implementation, although the same isn't true of VFP or VFP3.
Stephen Hines651f13c2014-04-23 16:59:28 -0700745 if (FloatABI == "soft") {
Rafael Espindola146dbbf2013-08-21 16:39:20 +0000746 Features.push_back("-neon");
Stephen Hines651f13c2014-04-23 16:59:28 -0700747 // Also need to explicitly disable features which imply NEON.
748 Features.push_back("-crypto");
749 }
Bernard Ogden909f35a2013-10-29 09:47:51 +0000750
751 // En/disable crc
752 if (Arg *A = Args.getLastArg(options::OPT_mcrc,
753 options::OPT_mnocrc)) {
754 if (A->getOption().matches(options::OPT_mcrc))
755 Features.push_back("+crc");
756 else
757 Features.push_back("-crc");
758 }
Rafael Espindola146dbbf2013-08-21 16:39:20 +0000759}
Anton Korobeynikove2571792012-04-09 13:38:30 +0000760
761void Clang::AddARMTargetArgs(const ArgList &Args,
762 ArgStringList &CmdArgs,
763 bool KernelOrKext) const {
764 const Driver &D = getToolChain().getDriver();
Daniel Dunbar7a0c0642012-10-15 22:23:53 +0000765 // Get the effective triple, which takes into account the deployment target.
766 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
767 llvm::Triple Triple(TripleStr);
Stephen Hines651f13c2014-04-23 16:59:28 -0700768 std::string CPUName = arm::getARMTargetCPU(Args, Triple);
Anton Korobeynikove2571792012-04-09 13:38:30 +0000769
770 // Select the ABI to use.
771 //
772 // FIXME: Support -meabi.
Stephen Hines0e2c34f2015-03-23 12:09:02 -0700773 // FIXME: Parts of this are duplicated in the backend, unify this somehow.
Stephen Hines6bcf27b2014-05-29 04:14:42 -0700774 const char *ABIName = nullptr;
Anton Korobeynikove2571792012-04-09 13:38:30 +0000775 if (Arg *A = Args.getLastArg(options::OPT_mabi_EQ)) {
Richard Smith1d489cf2012-11-01 04:30:05 +0000776 ABIName = A->getValue();
Stephen Hines6bcf27b2014-05-29 04:14:42 -0700777 } else if (Triple.isOSBinFormatMachO()) {
Daniel Dunbar2e4e1102012-10-22 18:30:51 +0000778 // The backend is hardwired to assume AAPCS for M-class processors, ensure
779 // the frontend matches that.
Tim Northoverfc1a75b2013-10-03 14:23:28 +0000780 if (Triple.getEnvironment() == llvm::Triple::EABI ||
Stephen Hines0e2c34f2015-03-23 12:09:02 -0700781 Triple.getOS() == llvm::Triple::UnknownOS ||
Tim Northoverfc1a75b2013-10-03 14:23:28 +0000782 StringRef(CPUName).startswith("cortex-m")) {
Daniel Dunbar2e4e1102012-10-22 18:30:51 +0000783 ABIName = "aapcs";
784 } else {
785 ABIName = "apcs-gnu";
786 }
Stephen Hines6bcf27b2014-05-29 04:14:42 -0700787 } else if (Triple.isOSWindows()) {
788 // FIXME: this is invalid for WindowsCE
789 ABIName = "aapcs";
Anton Korobeynikove2571792012-04-09 13:38:30 +0000790 } else {
791 // Select the default based on the platform.
792 switch(Triple.getEnvironment()) {
Logan Chien94a71422012-09-02 09:30:11 +0000793 case llvm::Triple::Android:
Anton Korobeynikove2571792012-04-09 13:38:30 +0000794 case llvm::Triple::GNUEABI:
Jiangning Liuff104a12012-07-31 08:06:29 +0000795 case llvm::Triple::GNUEABIHF:
Anton Korobeynikove2571792012-04-09 13:38:30 +0000796 ABIName = "aapcs-linux";
797 break;
Stephen Hines651f13c2014-04-23 16:59:28 -0700798 case llvm::Triple::EABIHF:
Anton Korobeynikove2571792012-04-09 13:38:30 +0000799 case llvm::Triple::EABI:
800 ABIName = "aapcs";
801 break;
802 default:
Stephen Hines176edba2014-12-01 14:53:08 -0800803 if (Triple.getOS() == llvm::Triple::NetBSD)
804 ABIName = "apcs-gnu";
805 else
806 ABIName = "aapcs";
807 break;
Anton Korobeynikove2571792012-04-09 13:38:30 +0000808 }
809 }
810 CmdArgs.push_back("-target-abi");
811 CmdArgs.push_back(ABIName);
812
Anton Korobeynikove2571792012-04-09 13:38:30 +0000813 // Determine floating point ABI from the options & target defaults.
Stephen Hines651f13c2014-04-23 16:59:28 -0700814 StringRef FloatABI = tools::arm::getARMFloatABI(D, Args, Triple);
Daniel Dunbarcbd19332009-09-10 23:00:09 +0000815 if (FloatABI == "soft") {
816 // Floating point operations and argument passing are soft.
817 //
818 // FIXME: This changes CPP defines, we need -target-soft-float.
Daniel Dunbar3b315262009-11-30 08:42:00 +0000819 CmdArgs.push_back("-msoft-float");
Daniel Dunbar87667aa2009-12-08 19:49:51 +0000820 CmdArgs.push_back("-mfloat-abi");
821 CmdArgs.push_back("soft");
Daniel Dunbarcbd19332009-09-10 23:00:09 +0000822 } else if (FloatABI == "softfp") {
823 // Floating point operations are hard, but argument passing is soft.
Daniel Dunbar87667aa2009-12-08 19:49:51 +0000824 CmdArgs.push_back("-mfloat-abi");
825 CmdArgs.push_back("soft");
Daniel Dunbarcbd19332009-09-10 23:00:09 +0000826 } else {
827 // Floating point operations and argument passing are hard.
828 assert(FloatABI == "hard" && "Invalid float abi!");
Daniel Dunbar87667aa2009-12-08 19:49:51 +0000829 CmdArgs.push_back("-mfloat-abi");
830 CmdArgs.push_back("hard");
Daniel Dunbarcbd19332009-09-10 23:00:09 +0000831 }
Daniel Dunbar97f52ac2009-12-19 04:15:38 +0000832
Daniel Dunbarfa41d692011-03-17 17:10:06 +0000833 // Kernel code has more strict alignment requirements.
834 if (KernelOrKext) {
Cameron Esfahani57b1da12013-09-14 01:09:11 +0000835 if (!Triple.isiOS() || Triple.isOSVersionLT(6)) {
Daniel Dunbar7a0c0642012-10-15 22:23:53 +0000836 CmdArgs.push_back("-backend-option");
837 CmdArgs.push_back("-arm-long-calls");
838 }
Daniel Dunbarfa41d692011-03-17 17:10:06 +0000839
Daniel Dunbar3c66d302011-03-22 16:48:17 +0000840 CmdArgs.push_back("-backend-option");
Daniel Dunbarfa41d692011-03-17 17:10:06 +0000841 CmdArgs.push_back("-arm-strict-align");
Daniel Dunbarb5fbb892011-04-18 21:26:42 +0000842
843 // The kext linker doesn't know how to deal with movw/movt.
Daniel Dunbarb5fbb892011-04-18 21:26:42 +0000844 CmdArgs.push_back("-backend-option");
Renato Golinebc313d2013-08-15 20:54:45 +0000845 CmdArgs.push_back("-arm-use-movt=0");
Daniel Dunbar7187fac2011-03-17 00:07:34 +0000846 }
Chad Rosier1b906052011-08-26 00:26:29 +0000847
Stephen Hines176edba2014-12-01 14:53:08 -0800848 // -mkernel implies -mstrict-align; don't add the redundant option.
849 if (!KernelOrKext) {
850 if (Arg *A = Args.getLastArg(options::OPT_mno_unaligned_access,
851 options::OPT_munaligned_access)) {
852 CmdArgs.push_back("-backend-option");
853 if (A->getOption().matches(options::OPT_mno_unaligned_access))
854 CmdArgs.push_back("-arm-strict-align");
855 else {
856 if (Triple.getSubArch() == llvm::Triple::SubArchType::ARMSubArch_v6m)
857 D.Diag(diag::err_target_unsupported_unaligned) << "v6m";
858 CmdArgs.push_back("-arm-no-strict-align");
859 }
860 }
861 }
862
Chad Rosier1b906052011-08-26 00:26:29 +0000863 // Setting -mno-global-merge disables the codegen global merge pass. Setting
864 // -mglobal-merge has no effect as the pass is enabled by default.
865 if (Arg *A = Args.getLastArg(options::OPT_mglobal_merge,
866 options::OPT_mno_global_merge)) {
867 if (A->getOption().matches(options::OPT_mno_global_merge))
868 CmdArgs.push_back("-mno-global-merge");
869 }
Chad Rosieree9ad5c2012-05-16 20:40:09 +0000870
Bob Wilsonf6f77bd2013-04-11 18:53:25 +0000871 if (!Args.hasFlag(options::OPT_mimplicit_float,
872 options::OPT_mno_implicit_float,
873 true))
Chad Rosieree9ad5c2012-05-16 20:40:09 +0000874 CmdArgs.push_back("-no-implicit-float");
Renato Golin45bd2942013-08-24 14:44:35 +0000875
Stephen Hines651f13c2014-04-23 16:59:28 -0700876 // llvm does not support reserving registers in general. There is support
877 // for reserving r9 on ARM though (defined as a platform-specific register
878 // in ARM EABI).
879 if (Args.hasArg(options::OPT_ffixed_r9)) {
880 CmdArgs.push_back("-backend-option");
881 CmdArgs.push_back("-arm-reserve-r9");
882 }
883}
884
Stephen Hines6bcf27b2014-05-29 04:14:42 -0700885/// getAArch64TargetCPU - Get the (LLVM) name of the AArch64 cpu we are
886/// targeting.
887static std::string getAArch64TargetCPU(const ArgList &Args) {
Stephen Hines176edba2014-12-01 14:53:08 -0800888 Arg *A;
889 std::string CPU;
890 // If we have -mtune or -mcpu, use that.
891 if ((A = Args.getLastArg(options::OPT_mtune_EQ))) {
892 CPU = A->getValue();
893 } else if ((A = Args.getLastArg(options::OPT_mcpu_EQ))) {
894 StringRef Mcpu = A->getValue();
895 CPU = Mcpu.split("+").first;
Stephen Hines651f13c2014-04-23 16:59:28 -0700896 }
897
Stephen Hines176edba2014-12-01 14:53:08 -0800898 // Handle CPU name is 'native'.
899 if (CPU == "native")
900 return llvm::sys::getHostCPUName();
901 else if (CPU.size())
902 return CPU;
Stephen Hines651f13c2014-04-23 16:59:28 -0700903
Stephen Hines6bcf27b2014-05-29 04:14:42 -0700904 // Make sure we pick "cyclone" if -arch is used.
905 // FIXME: Should this be picked by checking the target triple instead?
906 if (Args.getLastArg(options::OPT_arch))
907 return "cyclone";
908
909 return "generic";
Stephen Hines651f13c2014-04-23 16:59:28 -0700910}
911
Stephen Hines6bcf27b2014-05-29 04:14:42 -0700912void Clang::AddAArch64TargetArgs(const ArgList &Args,
913 ArgStringList &CmdArgs) const {
Stephen Hines651f13c2014-04-23 16:59:28 -0700914 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
915 llvm::Triple Triple(TripleStr);
916
917 if (!Args.hasFlag(options::OPT_mred_zone, options::OPT_mno_red_zone, true) ||
918 Args.hasArg(options::OPT_mkernel) ||
919 Args.hasArg(options::OPT_fapple_kext))
920 CmdArgs.push_back("-disable-red-zone");
921
922 if (!Args.hasFlag(options::OPT_mimplicit_float,
923 options::OPT_mno_implicit_float, true))
924 CmdArgs.push_back("-no-implicit-float");
925
Stephen Hines6bcf27b2014-05-29 04:14:42 -0700926 const char *ABIName = nullptr;
Stephen Hines651f13c2014-04-23 16:59:28 -0700927 if (Arg *A = Args.getLastArg(options::OPT_mabi_EQ))
928 ABIName = A->getValue();
929 else if (Triple.isOSDarwin())
930 ABIName = "darwinpcs";
931 else
932 ABIName = "aapcs";
933
934 CmdArgs.push_back("-target-abi");
935 CmdArgs.push_back(ABIName);
936
Stephen Hines176edba2014-12-01 14:53:08 -0800937 if (Arg *A = Args.getLastArg(options::OPT_mno_unaligned_access,
938 options::OPT_munaligned_access)) {
Stephen Hines651f13c2014-04-23 16:59:28 -0700939 CmdArgs.push_back("-backend-option");
Stephen Hines176edba2014-12-01 14:53:08 -0800940 if (A->getOption().matches(options::OPT_mno_unaligned_access))
941 CmdArgs.push_back("-aarch64-strict-align");
942 else
943 CmdArgs.push_back("-aarch64-no-strict-align");
Stephen Hines651f13c2014-04-23 16:59:28 -0700944 }
Stephen Hinesef822542014-07-21 00:47:37 -0700945
Stephen Hines0e2c34f2015-03-23 12:09:02 -0700946 if (Arg *A = Args.getLastArg(options::OPT_mfix_cortex_a53_835769,
947 options::OPT_mno_fix_cortex_a53_835769)) {
948 CmdArgs.push_back("-backend-option");
949 if (A->getOption().matches(options::OPT_mfix_cortex_a53_835769))
950 CmdArgs.push_back("-aarch64-fix-cortex-a53-835769=1");
951 else
952 CmdArgs.push_back("-aarch64-fix-cortex-a53-835769=0");
953 } else if (Triple.getEnvironment() == llvm::Triple::Android) {
954 // Enabled A53 errata (835769) workaround by default on android
955 CmdArgs.push_back("-backend-option");
956 CmdArgs.push_back("-aarch64-fix-cortex-a53-835769=1");
957 }
958
Stephen Hinesef822542014-07-21 00:47:37 -0700959 // Setting -mno-global-merge disables the codegen global merge pass. Setting
960 // -mglobal-merge has no effect as the pass is enabled by default.
961 if (Arg *A = Args.getLastArg(options::OPT_mglobal_merge,
962 options::OPT_mno_global_merge)) {
963 if (A->getOption().matches(options::OPT_mno_global_merge))
964 CmdArgs.push_back("-mno-global-merge");
965 }
Stephen Hines0e2c34f2015-03-23 12:09:02 -0700966
967 if (Args.hasArg(options::OPT_ffixed_x18)) {
968 CmdArgs.push_back("-backend-option");
969 CmdArgs.push_back("-aarch64-reserve-x18");
970 }
Daniel Dunbarb163ef72009-09-10 04:57:17 +0000971}
972
Simon Atanasyana2768be2012-04-07 22:09:23 +0000973// Get CPU and ABI names. They are not independent
974// so we have to calculate them together.
Stephen Hines176edba2014-12-01 14:53:08 -0800975void mips::getMipsCPUAndABI(const ArgList &Args,
976 const llvm::Triple &Triple,
977 StringRef &CPUName,
978 StringRef &ABIName) {
Stephen Hines651f13c2014-04-23 16:59:28 -0700979 const char *DefMips32CPU = "mips32r2";
980 const char *DefMips64CPU = "mips64r2";
Akira Hatanaka9f360622011-09-26 21:07:52 +0000981
Stephen Hinesef822542014-07-21 00:47:37 -0700982 // MIPS32r6 is the default for mips(el)?-img-linux-gnu and MIPS64r6 is the
983 // default for mips64(el)?-img-linux-gnu.
984 if (Triple.getVendor() == llvm::Triple::ImaginationTechnologies &&
985 Triple.getEnvironment() == llvm::Triple::GNU) {
986 DefMips32CPU = "mips32r6";
987 DefMips64CPU = "mips64r6";
988 }
989
Stephen Hines0e2c34f2015-03-23 12:09:02 -0700990 // MIPS3 is the default for mips64*-unknown-openbsd.
991 if (Triple.getOS() == llvm::Triple::OpenBSD)
992 DefMips64CPU = "mips3";
993
Simon Atanasyan89d83ff2012-09-10 08:32:41 +0000994 if (Arg *A = Args.getLastArg(options::OPT_march_EQ,
Simon Atanasyan66751bc2013-10-09 12:12:24 +0000995 options::OPT_mcpu_EQ))
996 CPUName = A->getValue();
Simon Atanasyan89d83ff2012-09-10 08:32:41 +0000997
Simon Atanasyanc7e2a4e2013-04-21 13:30:10 +0000998 if (Arg *A = Args.getLastArg(options::OPT_mabi_EQ)) {
Richard Smith1d489cf2012-11-01 04:30:05 +0000999 ABIName = A->getValue();
Simon Atanasyanc7e2a4e2013-04-21 13:30:10 +00001000 // Convert a GNU style Mips ABI name to the name
1001 // accepted by LLVM Mips backend.
1002 ABIName = llvm::StringSwitch<llvm::StringRef>(ABIName)
1003 .Case("32", "o32")
1004 .Case("64", "n64")
1005 .Default(ABIName);
1006 }
Simon Atanasyan89d83ff2012-09-10 08:32:41 +00001007
1008 // Setup default CPU and ABI names.
1009 if (CPUName.empty() && ABIName.empty()) {
Rafael Espindolab330e402013-08-20 22:12:08 +00001010 switch (Triple.getArch()) {
Simon Atanasyan89d83ff2012-09-10 08:32:41 +00001011 default:
1012 llvm_unreachable("Unexpected triple arch name");
1013 case llvm::Triple::mips:
1014 case llvm::Triple::mipsel:
1015 CPUName = DefMips32CPU;
1016 break;
1017 case llvm::Triple::mips64:
1018 case llvm::Triple::mips64el:
1019 CPUName = DefMips64CPU;
1020 break;
1021 }
1022 }
1023
Stephen Hinesef822542014-07-21 00:47:37 -07001024 if (ABIName.empty()) {
1025 // Deduce ABI name from the target triple.
1026 if (Triple.getArch() == llvm::Triple::mips ||
1027 Triple.getArch() == llvm::Triple::mipsel)
1028 ABIName = "o32";
1029 else
1030 ABIName = "n64";
Simon Atanasyan89d83ff2012-09-10 08:32:41 +00001031 }
1032
Stephen Hinesef822542014-07-21 00:47:37 -07001033 if (CPUName.empty()) {
1034 // Deduce CPU name from ABI name.
1035 CPUName = llvm::StringSwitch<const char *>(ABIName)
1036 .Cases("o32", "eabi", DefMips32CPU)
1037 .Cases("n32", "n64", DefMips64CPU)
1038 .Default("");
1039 }
Stephen Hines176edba2014-12-01 14:53:08 -08001040
1041 // FIXME: Warn on inconsistent use of -march and -mabi.
Simon Atanasyana2768be2012-04-07 22:09:23 +00001042}
1043
Simon Atanasyane9616a42013-02-27 14:55:49 +00001044// Convert ABI name to the GNU tools acceptable variant.
1045static StringRef getGnuCompatibleMipsABIName(StringRef ABI) {
1046 return llvm::StringSwitch<llvm::StringRef>(ABI)
1047 .Case("o32", "32")
1048 .Case("n64", "64")
1049 .Default(ABI);
1050}
1051
Simon Atanasyan5e627792012-06-02 15:06:29 +00001052// Select the MIPS float ABI as determined by -msoft-float, -mhard-float,
1053// and -mfloat-abi=.
1054static StringRef getMipsFloatABI(const Driver &D, const ArgList &Args) {
Chris Lattner5f9e2722011-07-23 10:55:15 +00001055 StringRef FloatABI;
Eric Christophered734732010-03-02 02:41:08 +00001056 if (Arg *A = Args.getLastArg(options::OPT_msoft_float,
Akira Hatanakaad8d8a32012-03-23 23:07:09 +00001057 options::OPT_mhard_float,
1058 options::OPT_mfloat_abi_EQ)) {
Eric Christophered734732010-03-02 02:41:08 +00001059 if (A->getOption().matches(options::OPT_msoft_float))
1060 FloatABI = "soft";
1061 else if (A->getOption().matches(options::OPT_mhard_float))
1062 FloatABI = "hard";
Akira Hatanakaad8d8a32012-03-23 23:07:09 +00001063 else {
Richard Smith1d489cf2012-11-01 04:30:05 +00001064 FloatABI = A->getValue();
Simon Atanasyan2ed42b82013-04-14 08:37:15 +00001065 if (FloatABI != "soft" && FloatABI != "hard") {
Simon Atanasyan5e627792012-06-02 15:06:29 +00001066 D.Diag(diag::err_drv_invalid_mfloat_abi) << A->getAsString(Args);
Akira Hatanakaad8d8a32012-03-23 23:07:09 +00001067 FloatABI = "hard";
1068 }
1069 }
Eric Christophered734732010-03-02 02:41:08 +00001070 }
1071
1072 // If unspecified, choose the default based on the platform.
1073 if (FloatABI.empty()) {
Akira Hatanakaad8d8a32012-03-23 23:07:09 +00001074 // Assume "hard", because it's a default value used by gcc.
1075 // When we start to recognize specific target MIPS processors,
1076 // we will be able to select the default more correctly.
1077 FloatABI = "hard";
Eric Christophered734732010-03-02 02:41:08 +00001078 }
1079
Simon Atanasyan5e627792012-06-02 15:06:29 +00001080 return FloatABI;
1081}
1082
Simon Atanasyandc536f52012-07-05 18:51:43 +00001083static void AddTargetFeature(const ArgList &Args,
Rafael Espindola146dbbf2013-08-21 16:39:20 +00001084 std::vector<const char *> &Features,
1085 OptSpecifier OnOpt, OptSpecifier OffOpt,
Simon Atanasyandc536f52012-07-05 18:51:43 +00001086 StringRef FeatureName) {
1087 if (Arg *A = Args.getLastArg(OnOpt, OffOpt)) {
Simon Atanasyandc536f52012-07-05 18:51:43 +00001088 if (A->getOption().matches(OnOpt))
Rafael Espindola146dbbf2013-08-21 16:39:20 +00001089 Features.push_back(Args.MakeArgString("+" + FeatureName));
Simon Atanasyandc536f52012-07-05 18:51:43 +00001090 else
Rafael Espindola146dbbf2013-08-21 16:39:20 +00001091 Features.push_back(Args.MakeArgString("-" + FeatureName));
Simon Atanasyandc536f52012-07-05 18:51:43 +00001092 }
1093}
1094
Stephen Hines176edba2014-12-01 14:53:08 -08001095static void getMIPSTargetFeatures(const Driver &D, const llvm::Triple &Triple,
1096 const ArgList &Args,
Rafael Espindola146dbbf2013-08-21 16:39:20 +00001097 std::vector<const char *> &Features) {
Stephen Hines176edba2014-12-01 14:53:08 -08001098 StringRef CPUName;
1099 StringRef ABIName;
1100 mips::getMipsCPUAndABI(Args, Triple, CPUName, ABIName);
1101 ABIName = getGnuCompatibleMipsABIName(ABIName);
1102
Stephen Hines176edba2014-12-01 14:53:08 -08001103 AddTargetFeature(Args, Features, options::OPT_mno_abicalls,
1104 options::OPT_mabicalls, "noabicalls");
1105
Rafael Espindola146dbbf2013-08-21 16:39:20 +00001106 StringRef FloatABI = getMipsFloatABI(D, Args);
Stephen Hines651f13c2014-04-23 16:59:28 -07001107 if (FloatABI == "soft") {
Rafael Espindola146dbbf2013-08-21 16:39:20 +00001108 // FIXME: Note, this is a hack. We need to pass the selected float
1109 // mode to the MipsTargetInfoBase to define appropriate macros there.
1110 // Now it is the only method.
1111 Features.push_back("+soft-float");
1112 }
1113
Simon Atanasyanfc12c4a2013-09-24 09:09:16 +00001114 if (Arg *A = Args.getLastArg(options::OPT_mnan_EQ)) {
Stephen Hines6bcf27b2014-05-29 04:14:42 -07001115 StringRef Val = StringRef(A->getValue());
1116 if (Val == "2008")
Simon Atanasyanfc12c4a2013-09-24 09:09:16 +00001117 Features.push_back("+nan2008");
Stephen Hines6bcf27b2014-05-29 04:14:42 -07001118 else if (Val == "legacy")
1119 Features.push_back("-nan2008");
1120 else
1121 D.Diag(diag::err_drv_unsupported_option_argument)
1122 << A->getOption().getName() << Val;
Simon Atanasyanfc12c4a2013-09-24 09:09:16 +00001123 }
1124
Rafael Espindola146dbbf2013-08-21 16:39:20 +00001125 AddTargetFeature(Args, Features, options::OPT_msingle_float,
1126 options::OPT_mdouble_float, "single-float");
1127 AddTargetFeature(Args, Features, options::OPT_mips16, options::OPT_mno_mips16,
1128 "mips16");
1129 AddTargetFeature(Args, Features, options::OPT_mmicromips,
1130 options::OPT_mno_micromips, "micromips");
1131 AddTargetFeature(Args, Features, options::OPT_mdsp, options::OPT_mno_dsp,
1132 "dsp");
1133 AddTargetFeature(Args, Features, options::OPT_mdspr2, options::OPT_mno_dspr2,
1134 "dspr2");
1135 AddTargetFeature(Args, Features, options::OPT_mmsa, options::OPT_mno_msa,
1136 "msa");
Stephen Hines176edba2014-12-01 14:53:08 -08001137
1138 // Add the last -mfp32/-mfpxx/-mfp64 or if none are given and the ABI is O32
1139 // pass -mfpxx
1140 if (Arg *A = Args.getLastArg(options::OPT_mfp32, options::OPT_mfpxx,
1141 options::OPT_mfp64)) {
1142 if (A->getOption().matches(options::OPT_mfp32))
1143 Features.push_back(Args.MakeArgString("-fp64"));
1144 else if (A->getOption().matches(options::OPT_mfpxx)) {
1145 Features.push_back(Args.MakeArgString("+fpxx"));
1146 Features.push_back(Args.MakeArgString("+nooddspreg"));
1147 } else
1148 Features.push_back(Args.MakeArgString("+fp64"));
1149 } else if (mips::isFPXXDefault(Triple, CPUName, ABIName)) {
1150 Features.push_back(Args.MakeArgString("+fpxx"));
1151 Features.push_back(Args.MakeArgString("+nooddspreg"));
1152 }
1153
Stephen Hinesef822542014-07-21 00:47:37 -07001154 AddTargetFeature(Args, Features, options::OPT_mno_odd_spreg,
1155 options::OPT_modd_spreg, "nooddspreg");
Rafael Espindola146dbbf2013-08-21 16:39:20 +00001156}
1157
Simon Atanasyan5e627792012-06-02 15:06:29 +00001158void Clang::AddMIPSTargetArgs(const ArgList &Args,
Simon Atanasyana8141612013-04-14 14:07:41 +00001159 ArgStringList &CmdArgs) const {
Simon Atanasyan5e627792012-06-02 15:06:29 +00001160 const Driver &D = getToolChain().getDriver();
1161 StringRef CPUName;
1162 StringRef ABIName;
Rafael Espindolab330e402013-08-20 22:12:08 +00001163 const llvm::Triple &Triple = getToolChain().getTriple();
Stephen Hines176edba2014-12-01 14:53:08 -08001164 mips::getMipsCPUAndABI(Args, Triple, CPUName, ABIName);
Simon Atanasyan5e627792012-06-02 15:06:29 +00001165
1166 CmdArgs.push_back("-target-abi");
1167 CmdArgs.push_back(ABIName.data());
1168
1169 StringRef FloatABI = getMipsFloatABI(D, Args);
1170
Stephen Hines651f13c2014-04-23 16:59:28 -07001171 if (FloatABI == "soft") {
Eric Christophered734732010-03-02 02:41:08 +00001172 // Floating point operations and argument passing are soft.
Eric Christophered734732010-03-02 02:41:08 +00001173 CmdArgs.push_back("-msoft-float");
Akira Hatanakaad8d8a32012-03-23 23:07:09 +00001174 CmdArgs.push_back("-mfloat-abi");
1175 CmdArgs.push_back("soft");
Akira Hatanakaad8d8a32012-03-23 23:07:09 +00001176 }
Akira Hatanakaad8d8a32012-03-23 23:07:09 +00001177 else {
1178 // Floating point operations and argument passing are hard.
Eric Christophered734732010-03-02 02:41:08 +00001179 assert(FloatABI == "hard" && "Invalid float abi!");
Akira Hatanakaad8d8a32012-03-23 23:07:09 +00001180 CmdArgs.push_back("-mfloat-abi");
1181 CmdArgs.push_back("hard");
Eric Christophered734732010-03-02 02:41:08 +00001182 }
Simon Atanasyan0b273ef2012-07-05 14:19:39 +00001183
Simon Atanasyanbda07ac2012-12-01 18:27:21 +00001184 if (Arg *A = Args.getLastArg(options::OPT_mxgot, options::OPT_mno_xgot)) {
1185 if (A->getOption().matches(options::OPT_mxgot)) {
1186 CmdArgs.push_back("-mllvm");
1187 CmdArgs.push_back("-mxgot");
1188 }
1189 }
1190
Simon Atanasyan6bdc4c62013-05-11 06:33:44 +00001191 if (Arg *A = Args.getLastArg(options::OPT_mldc1_sdc1,
1192 options::OPT_mno_ldc1_sdc1)) {
1193 if (A->getOption().matches(options::OPT_mno_ldc1_sdc1)) {
1194 CmdArgs.push_back("-mllvm");
1195 CmdArgs.push_back("-mno-ldc1-sdc1");
1196 }
1197 }
1198
Akira Hatanakacdbc3b32013-07-19 18:58:48 +00001199 if (Arg *A = Args.getLastArg(options::OPT_mcheck_zero_division,
1200 options::OPT_mno_check_zero_division)) {
1201 if (A->getOption().matches(options::OPT_mno_check_zero_division)) {
1202 CmdArgs.push_back("-mllvm");
1203 CmdArgs.push_back("-mno-check-zero-division");
1204 }
1205 }
1206
Simon Atanasyan9804b762012-08-27 20:55:56 +00001207 if (Arg *A = Args.getLastArg(options::OPT_G)) {
Richard Smith1d489cf2012-11-01 04:30:05 +00001208 StringRef v = A->getValue();
Simon Atanasyan9804b762012-08-27 20:55:56 +00001209 CmdArgs.push_back("-mllvm");
1210 CmdArgs.push_back(Args.MakeArgString("-mips-ssection-threshold=" + v));
1211 A->claim();
1212 }
Eric Christophered734732010-03-02 02:41:08 +00001213}
1214
Hal Finkel02a84272012-06-11 22:35:19 +00001215/// getPPCTargetCPU - Get the (LLVM) name of the PowerPC cpu we are targeting.
1216static std::string getPPCTargetCPU(const ArgList &Args) {
1217 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ)) {
Richard Smith1d489cf2012-11-01 04:30:05 +00001218 StringRef CPUName = A->getValue();
Hal Finkel02a84272012-06-11 22:35:19 +00001219
1220 if (CPUName == "native") {
1221 std::string CPU = llvm::sys::getHostCPUName();
1222 if (!CPU.empty() && CPU != "generic")
1223 return CPU;
1224 else
1225 return "";
1226 }
1227
1228 return llvm::StringSwitch<const char *>(CPUName)
1229 .Case("common", "generic")
1230 .Case("440", "440")
1231 .Case("440fp", "440")
1232 .Case("450", "450")
1233 .Case("601", "601")
1234 .Case("602", "602")
1235 .Case("603", "603")
1236 .Case("603e", "603e")
1237 .Case("603ev", "603ev")
1238 .Case("604", "604")
1239 .Case("604e", "604e")
1240 .Case("620", "620")
Bill Schmidt2821e182013-02-01 20:23:10 +00001241 .Case("630", "pwr3")
Hal Finkel02a84272012-06-11 22:35:19 +00001242 .Case("G3", "g3")
1243 .Case("7400", "7400")
1244 .Case("G4", "g4")
1245 .Case("7450", "7450")
1246 .Case("G4+", "g4+")
1247 .Case("750", "750")
1248 .Case("970", "970")
1249 .Case("G5", "g5")
1250 .Case("a2", "a2")
Hal Finkel5ccd3d02013-02-01 05:53:33 +00001251 .Case("a2q", "a2q")
Hal Finkel7de32962012-09-18 22:25:03 +00001252 .Case("e500mc", "e500mc")
1253 .Case("e5500", "e5500")
Bill Schmidt2821e182013-02-01 20:23:10 +00001254 .Case("power3", "pwr3")
1255 .Case("power4", "pwr4")
1256 .Case("power5", "pwr5")
1257 .Case("power5x", "pwr5x")
Hal Finkel02a84272012-06-11 22:35:19 +00001258 .Case("power6", "pwr6")
Bill Schmidt2821e182013-02-01 20:23:10 +00001259 .Case("power6x", "pwr6x")
Hal Finkel02a84272012-06-11 22:35:19 +00001260 .Case("power7", "pwr7")
Stephen Hinesef822542014-07-21 00:47:37 -07001261 .Case("power8", "pwr8")
Bill Schmidt2821e182013-02-01 20:23:10 +00001262 .Case("pwr3", "pwr3")
1263 .Case("pwr4", "pwr4")
1264 .Case("pwr5", "pwr5")
1265 .Case("pwr5x", "pwr5x")
1266 .Case("pwr6", "pwr6")
1267 .Case("pwr6x", "pwr6x")
1268 .Case("pwr7", "pwr7")
Stephen Hinesef822542014-07-21 00:47:37 -07001269 .Case("pwr8", "pwr8")
Hal Finkel02a84272012-06-11 22:35:19 +00001270 .Case("powerpc", "ppc")
1271 .Case("powerpc64", "ppc64")
Bill Schmidtea7fb0c2013-07-26 01:36:11 +00001272 .Case("powerpc64le", "ppc64le")
Hal Finkel02a84272012-06-11 22:35:19 +00001273 .Default("");
1274 }
1275
1276 return "";
1277}
1278
Rafael Espindola146dbbf2013-08-21 16:39:20 +00001279static void getPPCTargetFeatures(const ArgList &Args,
1280 std::vector<const char *> &Features) {
Eric Christopherd5e59fc2013-10-16 20:40:08 +00001281 for (arg_iterator it = Args.filtered_begin(options::OPT_m_ppc_Features_Group),
1282 ie = Args.filtered_end();
1283 it != ie; ++it) {
1284 StringRef Name = (*it)->getOption().getName();
1285 (*it)->claim();
1286
1287 // Skip over "-m".
1288 assert(Name.startswith("m") && "Invalid feature name.");
1289 Name = Name.substr(1);
1290
1291 bool IsNegative = Name.startswith("no-");
1292 if (IsNegative)
1293 Name = Name.substr(3);
1294
1295 // Note that gcc calls this mfcrf and LLVM calls this mfocrf so we
1296 // pass the correct option to the backend while calling the frontend
1297 // option the same.
1298 // TODO: Change the LLVM backend option maybe?
1299 if (Name == "mfcrf")
1300 Name = "mfocrf";
1301
1302 Features.push_back(Args.MakeArgString((IsNegative ? "-" : "+") + Name));
1303 }
1304
1305 // Altivec is a bit weird, allow overriding of the Altivec feature here.
Rafael Espindola146dbbf2013-08-21 16:39:20 +00001306 AddTargetFeature(Args, Features, options::OPT_faltivec,
1307 options::OPT_fno_altivec, "altivec");
Hal Finkel02a84272012-06-11 22:35:19 +00001308}
1309
Stephen Hines176edba2014-12-01 14:53:08 -08001310void Clang::AddPPCTargetArgs(const ArgList &Args,
1311 ArgStringList &CmdArgs) const {
1312 // Select the ABI to use.
1313 const char *ABIName = nullptr;
1314 if (Arg *A = Args.getLastArg(options::OPT_mabi_EQ)) {
1315 ABIName = A->getValue();
1316 } else if (getToolChain().getTriple().isOSLinux())
1317 switch(getToolChain().getArch()) {
1318 case llvm::Triple::ppc64:
1319 ABIName = "elfv1";
1320 break;
1321 case llvm::Triple::ppc64le:
1322 ABIName = "elfv2";
1323 break;
1324 default:
1325 break;
1326 }
1327
1328 if (ABIName) {
1329 CmdArgs.push_back("-target-abi");
1330 CmdArgs.push_back(ABIName);
1331 }
1332}
1333
1334bool ppc::hasPPCAbiArg(const ArgList &Args, const char *Value) {
1335 Arg *A = Args.getLastArg(options::OPT_mabi_EQ);
1336 return A && (A->getValue() == StringRef(Value));
1337}
1338
Tom Stellarde25d2f62013-04-01 20:56:53 +00001339/// Get the (LLVM) name of the R600 gpu we are targeting.
1340static std::string getR600TargetGPU(const ArgList &Args) {
1341 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ)) {
Benjamin Kramer39e4b0f2013-10-21 12:33:55 +00001342 const char *GPUName = A->getValue();
Tom Stellarde25d2f62013-04-01 20:56:53 +00001343 return llvm::StringSwitch<const char *>(GPUName)
Tom Stellardfd4aa4b2013-05-06 16:12:05 +00001344 .Cases("rv630", "rv635", "r600")
1345 .Cases("rv610", "rv620", "rs780", "rs880")
Tom Stellarde25d2f62013-04-01 20:56:53 +00001346 .Case("rv740", "rv770")
1347 .Case("palm", "cedar")
Tom Stellardfd4aa4b2013-05-06 16:12:05 +00001348 .Cases("sumo", "sumo2", "sumo")
Tom Stellarde25d2f62013-04-01 20:56:53 +00001349 .Case("hemlock", "cypress")
1350 .Case("aruba", "cayman")
Benjamin Kramer39e4b0f2013-10-21 12:33:55 +00001351 .Default(GPUName);
Tom Stellarde25d2f62013-04-01 20:56:53 +00001352 }
1353 return "";
1354}
1355
Rafael Espindola146dbbf2013-08-21 16:39:20 +00001356static void getSparcTargetFeatures(const ArgList &Args,
Stephen Hines176edba2014-12-01 14:53:08 -08001357 std::vector<const char *> &Features) {
Rafael Espindola146dbbf2013-08-21 16:39:20 +00001358 bool SoftFloatABI = true;
1359 if (Arg *A =
1360 Args.getLastArg(options::OPT_msoft_float, options::OPT_mhard_float)) {
1361 if (A->getOption().matches(options::OPT_mhard_float))
1362 SoftFloatABI = false;
1363 }
1364 if (SoftFloatABI)
1365 Features.push_back("+soft-float");
1366}
1367
Bruno Cardoso Lopes9284d212010-11-09 17:21:19 +00001368void Clang::AddSparcTargetArgs(const ArgList &Args,
1369 ArgStringList &CmdArgs) const {
1370 const Driver &D = getToolChain().getDriver();
1371
Stephen Hines176edba2014-12-01 14:53:08 -08001372 // Select the float ABI as determined by -msoft-float and -mhard-float.
Chris Lattner5f9e2722011-07-23 10:55:15 +00001373 StringRef FloatABI;
Bruno Cardoso Lopes9284d212010-11-09 17:21:19 +00001374 if (Arg *A = Args.getLastArg(options::OPT_msoft_float,
1375 options::OPT_mhard_float)) {
1376 if (A->getOption().matches(options::OPT_msoft_float))
1377 FloatABI = "soft";
1378 else if (A->getOption().matches(options::OPT_mhard_float))
1379 FloatABI = "hard";
1380 }
1381
1382 // If unspecified, choose the default based on the platform.
1383 if (FloatABI.empty()) {
Aaron Ballmand58915e2013-07-15 13:41:33 +00001384 // Assume "soft", but warn the user we are guessing.
1385 FloatABI = "soft";
1386 D.Diag(diag::warn_drv_assuming_mfloat_abi_is) << "soft";
Bruno Cardoso Lopes9284d212010-11-09 17:21:19 +00001387 }
1388
1389 if (FloatABI == "soft") {
1390 // Floating point operations and argument passing are soft.
1391 //
1392 // FIXME: This changes CPP defines, we need -target-soft-float.
1393 CmdArgs.push_back("-msoft-float");
Bruno Cardoso Lopes9284d212010-11-09 17:21:19 +00001394 } else {
1395 assert(FloatABI == "hard" && "Invalid float abi!");
1396 CmdArgs.push_back("-mhard-float");
1397 }
1398}
1399
Richard Sandiford5c92b9a2013-07-19 16:51:51 +00001400static const char *getSystemZTargetCPU(const ArgList &Args) {
1401 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ))
1402 return A->getValue();
1403 return "z10";
1404}
1405
Chandler Carruth700d4e42013-01-13 11:46:33 +00001406static const char *getX86TargetCPU(const ArgList &Args,
1407 const llvm::Triple &Triple) {
1408 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ)) {
Jim Grosbach32ca73e2013-11-16 00:53:35 +00001409 if (StringRef(A->getValue()) != "native") {
1410 if (Triple.isOSDarwin() && Triple.getArchName() == "x86_64h")
1411 return "core-avx2";
1412
Chandler Carruth700d4e42013-01-13 11:46:33 +00001413 return A->getValue();
Jim Grosbach32ca73e2013-11-16 00:53:35 +00001414 }
Chandler Carruth700d4e42013-01-13 11:46:33 +00001415
1416 // FIXME: Reject attempts to use -march=native unless the target matches
1417 // the host.
1418 //
1419 // FIXME: We should also incorporate the detected target features for use
1420 // with -native.
1421 std::string CPU = llvm::sys::getHostCPUName();
1422 if (!CPU.empty() && CPU != "generic")
1423 return Args.MakeArgString(CPU);
1424 }
1425
1426 // Select the default CPU if none was given (or detection failed).
1427
1428 if (Triple.getArch() != llvm::Triple::x86_64 &&
1429 Triple.getArch() != llvm::Triple::x86)
Stephen Hines6bcf27b2014-05-29 04:14:42 -07001430 return nullptr; // This routine is only handling x86 targets.
Chandler Carruth700d4e42013-01-13 11:46:33 +00001431
1432 bool Is64Bit = Triple.getArch() == llvm::Triple::x86_64;
1433
1434 // FIXME: Need target hooks.
Jim Grosbach32ca73e2013-11-16 00:53:35 +00001435 if (Triple.isOSDarwin()) {
1436 if (Triple.getArchName() == "x86_64h")
1437 return "core-avx2";
Chandler Carruth700d4e42013-01-13 11:46:33 +00001438 return Is64Bit ? "core2" : "yonah";
Jim Grosbach32ca73e2013-11-16 00:53:35 +00001439 }
Chandler Carruth700d4e42013-01-13 11:46:33 +00001440
Stephen Hines0e2c34f2015-03-23 12:09:02 -07001441 // Set up default CPU name for PS4 compilers.
1442 if (Triple.isPS4CPU())
1443 return "btver2";
1444
Stephen Hines651f13c2014-04-23 16:59:28 -07001445 // On Android use targets compatible with gcc
Chandler Carruth700d4e42013-01-13 11:46:33 +00001446 if (Triple.getEnvironment() == llvm::Triple::Android)
Stephen Hines651f13c2014-04-23 16:59:28 -07001447 return Is64Bit ? "x86-64" : "i686";
Chandler Carruth700d4e42013-01-13 11:46:33 +00001448
Benjamin Kramer39e4b0f2013-10-21 12:33:55 +00001449 // Everything else goes to x86-64 in 64-bit mode.
1450 if (Is64Bit)
1451 return "x86-64";
1452
1453 switch (Triple.getOS()) {
1454 case llvm::Triple::FreeBSD:
1455 case llvm::Triple::NetBSD:
1456 case llvm::Triple::OpenBSD:
1457 return "i486";
1458 case llvm::Triple::Haiku:
1459 return "i586";
1460 case llvm::Triple::Bitrig:
1461 return "i686";
1462 default:
1463 // Fallback to p4.
1464 return "pentium4";
1465 }
Chandler Carruth700d4e42013-01-13 11:46:33 +00001466}
1467
Rafael Espindolab330e402013-08-20 22:12:08 +00001468static std::string getCPUName(const ArgList &Args, const llvm::Triple &T) {
1469 switch(T.getArch()) {
1470 default:
1471 return "";
1472
Amara Emerson3bb1b5c2013-10-31 09:32:33 +00001473 case llvm::Triple::aarch64:
Stephen Hines651f13c2014-04-23 16:59:28 -07001474 case llvm::Triple::aarch64_be:
Stephen Hines6bcf27b2014-05-29 04:14:42 -07001475 return getAArch64TargetCPU(Args);
Amara Emerson3bb1b5c2013-10-31 09:32:33 +00001476
Rafael Espindolab330e402013-08-20 22:12:08 +00001477 case llvm::Triple::arm:
Stephen Hines651f13c2014-04-23 16:59:28 -07001478 case llvm::Triple::armeb:
Rafael Espindolab330e402013-08-20 22:12:08 +00001479 case llvm::Triple::thumb:
Stephen Hines651f13c2014-04-23 16:59:28 -07001480 case llvm::Triple::thumbeb:
1481 return arm::getARMTargetCPU(Args, T);
Rafael Espindolab330e402013-08-20 22:12:08 +00001482
1483 case llvm::Triple::mips:
1484 case llvm::Triple::mipsel:
1485 case llvm::Triple::mips64:
1486 case llvm::Triple::mips64el: {
1487 StringRef CPUName;
1488 StringRef ABIName;
Stephen Hines176edba2014-12-01 14:53:08 -08001489 mips::getMipsCPUAndABI(Args, T, CPUName, ABIName);
Rafael Espindolab330e402013-08-20 22:12:08 +00001490 return CPUName;
1491 }
1492
1493 case llvm::Triple::ppc:
1494 case llvm::Triple::ppc64:
1495 case llvm::Triple::ppc64le: {
1496 std::string TargetCPUName = getPPCTargetCPU(Args);
1497 // LLVM may default to generating code for the native CPU,
1498 // but, like gcc, we default to a more generic option for
1499 // each architecture. (except on Darwin)
1500 if (TargetCPUName.empty() && !T.isOSDarwin()) {
1501 if (T.getArch() == llvm::Triple::ppc64)
1502 TargetCPUName = "ppc64";
1503 else if (T.getArch() == llvm::Triple::ppc64le)
1504 TargetCPUName = "ppc64le";
1505 else
1506 TargetCPUName = "ppc";
1507 }
1508 return TargetCPUName;
1509 }
1510
1511 case llvm::Triple::sparc:
Stephen Hines651f13c2014-04-23 16:59:28 -07001512 case llvm::Triple::sparcv9:
1513 if (const Arg *A = Args.getLastArg(options::OPT_mcpu_EQ))
Rafael Espindolab330e402013-08-20 22:12:08 +00001514 return A->getValue();
1515 return "";
1516
1517 case llvm::Triple::x86:
1518 case llvm::Triple::x86_64:
1519 return getX86TargetCPU(Args, T);
1520
1521 case llvm::Triple::hexagon:
1522 return "hexagon" + toolchains::Hexagon_TC::GetTargetCPU(Args).str();
1523
1524 case llvm::Triple::systemz:
1525 return getSystemZTargetCPU(Args);
1526
1527 case llvm::Triple::r600:
Stephen Hines0e2c34f2015-03-23 12:09:02 -07001528 case llvm::Triple::amdgcn:
Rafael Espindolab330e402013-08-20 22:12:08 +00001529 return getR600TargetGPU(Args);
1530 }
1531}
1532
Stephen Hines651f13c2014-04-23 16:59:28 -07001533static void AddGoldPlugin(const ToolChain &ToolChain, const ArgList &Args,
1534 ArgStringList &CmdArgs) {
1535 // Tell the linker to load the plugin. This has to come before AddLinkerInputs
1536 // as gold requires -plugin to come before any -plugin-opt that -Wl might
1537 // forward.
1538 CmdArgs.push_back("-plugin");
Stephen Hines0e2c34f2015-03-23 12:09:02 -07001539 std::string Plugin = ToolChain.getDriver().Dir + "/../lib" CLANG_LIBDIR_SUFFIX "/LLVMgold.so";
Stephen Hines651f13c2014-04-23 16:59:28 -07001540 CmdArgs.push_back(Args.MakeArgString(Plugin));
1541
1542 // Try to pass driver level flags relevant to LTO code generation down to
1543 // the plugin.
1544
1545 // Handle flags for selecting CPU variants.
1546 std::string CPU = getCPUName(Args, ToolChain.getTriple());
1547 if (!CPU.empty())
1548 CmdArgs.push_back(Args.MakeArgString(Twine("-plugin-opt=mcpu=") + CPU));
1549}
1550
Stephen Hines176edba2014-12-01 14:53:08 -08001551static void getX86TargetFeatures(const Driver & D,
1552 const llvm::Triple &Triple,
Jim Grosbach32ca73e2013-11-16 00:53:35 +00001553 const ArgList &Args,
Rafael Espindola146dbbf2013-08-21 16:39:20 +00001554 std::vector<const char *> &Features) {
Jim Grosbach32ca73e2013-11-16 00:53:35 +00001555 if (Triple.getArchName() == "x86_64h") {
1556 // x86_64h implies quite a few of the more modern subtarget features
1557 // for Haswell class CPUs, but not all of them. Opt-out of a few.
1558 Features.push_back("-rdrnd");
1559 Features.push_back("-aes");
1560 Features.push_back("-pclmul");
1561 Features.push_back("-rtm");
1562 Features.push_back("-hle");
1563 Features.push_back("-fsgsbase");
1564 }
1565
Stephen Hinesef822542014-07-21 00:47:37 -07001566 // Add features to comply with gcc on Android
Stephen Hines651f13c2014-04-23 16:59:28 -07001567 if (Triple.getEnvironment() == llvm::Triple::Android) {
Stephen Hinesef822542014-07-21 00:47:37 -07001568 if (Triple.getArch() == llvm::Triple::x86_64) {
1569 Features.push_back("+sse4.2");
1570 Features.push_back("+popcnt");
1571 } else
1572 Features.push_back("+ssse3");
Stephen Hines651f13c2014-04-23 16:59:28 -07001573 }
1574
Stephen Hines176edba2014-12-01 14:53:08 -08001575 // Set features according to the -arch flag on MSVC
1576 if (Arg *A = Args.getLastArg(options::OPT__SLASH_arch)) {
1577 StringRef Arch = A->getValue();
1578 bool ArchUsed = false;
1579 // First, look for flags that are shared in x86 and x86-64.
1580 if (Triple.getArch() == llvm::Triple::x86_64 ||
1581 Triple.getArch() == llvm::Triple::x86) {
1582 if (Arch == "AVX" || Arch == "AVX2") {
1583 ArchUsed = true;
1584 Features.push_back(Args.MakeArgString("+" + Arch.lower()));
1585 }
1586 }
1587 // Then, look for x86-specific flags.
1588 if (Triple.getArch() == llvm::Triple::x86) {
1589 if (Arch == "IA32") {
1590 ArchUsed = true;
1591 } else if (Arch == "SSE" || Arch == "SSE2") {
1592 ArchUsed = true;
1593 Features.push_back(Args.MakeArgString("+" + Arch.lower()));
1594 }
1595 }
1596 if (!ArchUsed)
1597 D.Diag(clang::diag::warn_drv_unused_argument) << A->getAsString(Args);
1598 }
1599
Jim Grosbach32ca73e2013-11-16 00:53:35 +00001600 // Now add any that the user explicitly requested on the command line,
1601 // which may override the defaults.
Rafael Espindola146dbbf2013-08-21 16:39:20 +00001602 for (arg_iterator it = Args.filtered_begin(options::OPT_m_x86_Features_Group),
1603 ie = Args.filtered_end();
1604 it != ie; ++it) {
1605 StringRef Name = (*it)->getOption().getName();
1606 (*it)->claim();
1607
1608 // Skip over "-m".
1609 assert(Name.startswith("m") && "Invalid feature name.");
1610 Name = Name.substr(1);
1611
1612 bool IsNegative = Name.startswith("no-");
1613 if (IsNegative)
1614 Name = Name.substr(3);
1615
1616 Features.push_back(Args.MakeArgString((IsNegative ? "-" : "+") + Name));
1617 }
1618}
1619
Daniel Dunbar6acda162009-09-09 22:33:08 +00001620void Clang::AddX86TargetArgs(const ArgList &Args,
1621 ArgStringList &CmdArgs) const {
Daniel Dunbare6ad3f92009-09-10 22:59:57 +00001622 if (!Args.hasFlag(options::OPT_mred_zone,
1623 options::OPT_mno_red_zone,
1624 true) ||
1625 Args.hasArg(options::OPT_mkernel) ||
1626 Args.hasArg(options::OPT_fapple_kext))
Daniel Dunbar66861e02009-11-20 22:21:36 +00001627 CmdArgs.push_back("-disable-red-zone");
Daniel Dunbare6ad3f92009-09-10 22:59:57 +00001628
Bob Wilsonf0c54562013-02-10 16:01:41 +00001629 // Default to avoid implicit floating-point for kernel/kext code, but allow
1630 // that to be overridden with -mno-soft-float.
1631 bool NoImplicitFloat = (Args.hasArg(options::OPT_mkernel) ||
1632 Args.hasArg(options::OPT_fapple_kext));
1633 if (Arg *A = Args.getLastArg(options::OPT_msoft_float,
1634 options::OPT_mno_soft_float,
Bob Wilsonf6f77bd2013-04-11 18:53:25 +00001635 options::OPT_mimplicit_float,
Bob Wilsonf0c54562013-02-10 16:01:41 +00001636 options::OPT_mno_implicit_float)) {
1637 const Option &O = A->getOption();
1638 NoImplicitFloat = (O.matches(options::OPT_mno_implicit_float) ||
1639 O.matches(options::OPT_msoft_float));
1640 }
1641 if (NoImplicitFloat)
Daniel Dunbar66861e02009-11-20 22:21:36 +00001642 CmdArgs.push_back("-no-implicit-float");
Stephen Hines6bcf27b2014-05-29 04:14:42 -07001643
1644 if (Arg *A = Args.getLastArg(options::OPT_masm_EQ)) {
1645 StringRef Value = A->getValue();
1646 if (Value == "intel" || Value == "att") {
1647 CmdArgs.push_back("-mllvm");
1648 CmdArgs.push_back(Args.MakeArgString("-x86-asm-syntax=" + Value));
1649 } else {
1650 getToolChain().getDriver().Diag(diag::err_drv_unsupported_option_argument)
1651 << A->getOption().getName() << Value;
1652 }
1653 }
Daniel Dunbar6acda162009-09-09 22:33:08 +00001654}
1655
Matthew Curtis33c95f12012-12-06 17:49:03 +00001656static inline bool HasPICArg(const ArgList &Args) {
1657 return Args.hasArg(options::OPT_fPIC)
1658 || Args.hasArg(options::OPT_fpic);
1659}
1660
1661static Arg *GetLastSmallDataThresholdArg(const ArgList &Args) {
1662 return Args.getLastArg(options::OPT_G,
1663 options::OPT_G_EQ,
1664 options::OPT_msmall_data_threshold_EQ);
1665}
1666
1667static std::string GetHexagonSmallDataThresholdValue(const ArgList &Args) {
1668 std::string value;
1669 if (HasPICArg(Args))
1670 value = "0";
1671 else if (Arg *A = GetLastSmallDataThresholdArg(Args)) {
1672 value = A->getValue();
1673 A->claim();
1674 }
1675 return value;
1676}
1677
Tony Linthicum96319392011-12-12 21:14:55 +00001678void Clang::AddHexagonTargetArgs(const ArgList &Args,
1679 ArgStringList &CmdArgs) const {
Tony Linthicum96319392011-12-12 21:14:55 +00001680 CmdArgs.push_back("-fno-signed-char");
Matthew Curtis1dbaef52012-12-07 13:52:44 +00001681 CmdArgs.push_back("-mqdsp6-compat");
1682 CmdArgs.push_back("-Wreturn-type");
Tony Linthicum96319392011-12-12 21:14:55 +00001683
Matthew Curtis33c95f12012-12-06 17:49:03 +00001684 std::string SmallDataThreshold = GetHexagonSmallDataThresholdValue(Args);
1685 if (!SmallDataThreshold.empty()) {
Tony Linthicum96319392011-12-12 21:14:55 +00001686 CmdArgs.push_back ("-mllvm");
Matthew Curtis33c95f12012-12-06 17:49:03 +00001687 CmdArgs.push_back(Args.MakeArgString(
1688 "-hexagon-small-data-threshold=" + SmallDataThreshold));
Tony Linthicum96319392011-12-12 21:14:55 +00001689 }
1690
Sirish Pande5f9688b2012-05-10 20:19:54 +00001691 if (!Args.hasArg(options::OPT_fno_short_enums))
1692 CmdArgs.push_back("-fshort-enums");
1693 if (Args.getLastArg(options::OPT_mieee_rnd_near)) {
1694 CmdArgs.push_back ("-mllvm");
1695 CmdArgs.push_back ("-enable-hexagon-ieee-rnd-near");
1696 }
Tony Linthicum96319392011-12-12 21:14:55 +00001697 CmdArgs.push_back ("-mllvm");
1698 CmdArgs.push_back ("-machine-sink-split=0");
1699}
1700
Stephen Hines176edba2014-12-01 14:53:08 -08001701// Decode AArch64 features from string like +[no]featureA+[no]featureB+...
1702static bool DecodeAArch64Features(const Driver &D, StringRef text,
1703 std::vector<const char *> &Features) {
1704 SmallVector<StringRef, 8> Split;
1705 text.split(Split, StringRef("+"), -1, false);
1706
1707 for (unsigned I = 0, E = Split.size(); I != E; ++I) {
1708 const char *result = llvm::StringSwitch<const char *>(Split[I])
1709 .Case("fp", "+fp-armv8")
1710 .Case("simd", "+neon")
1711 .Case("crc", "+crc")
1712 .Case("crypto", "+crypto")
1713 .Case("nofp", "-fp-armv8")
1714 .Case("nosimd", "-neon")
1715 .Case("nocrc", "-crc")
1716 .Case("nocrypto", "-crypto")
1717 .Default(nullptr);
1718 if (result)
1719 Features.push_back(result);
1720 else if (Split[I] == "neon" || Split[I] == "noneon")
1721 D.Diag(diag::err_drv_no_neon_modifier);
1722 else
1723 return false;
1724 }
1725 return true;
1726}
1727
1728// Check if the CPU name and feature modifiers in -mcpu are legal. If yes,
1729// decode CPU and feature.
1730static bool DecodeAArch64Mcpu(const Driver &D, StringRef Mcpu, StringRef &CPU,
1731 std::vector<const char *> &Features) {
1732 std::pair<StringRef, StringRef> Split = Mcpu.split("+");
1733 CPU = Split.first;
Stephen Hines0e2c34f2015-03-23 12:09:02 -07001734 if (CPU == "cyclone" || CPU == "cortex-a53" || CPU == "cortex-a57" || CPU == "cortex-a72") {
Stephen Hines176edba2014-12-01 14:53:08 -08001735 Features.push_back("+neon");
1736 Features.push_back("+crc");
1737 Features.push_back("+crypto");
1738 } else if (CPU == "generic") {
1739 Features.push_back("+neon");
1740 } else {
1741 return false;
1742 }
1743
1744 if (Split.second.size() && !DecodeAArch64Features(D, Split.second, Features))
1745 return false;
1746
1747 return true;
1748}
1749
1750static bool
1751getAArch64ArchFeaturesFromMarch(const Driver &D, StringRef March,
1752 const ArgList &Args,
1753 std::vector<const char *> &Features) {
1754 std::pair<StringRef, StringRef> Split = March.split("+");
1755 if (Split.first != "armv8-a")
1756 return false;
1757
1758 if (Split.second.size() && !DecodeAArch64Features(D, Split.second, Features))
1759 return false;
1760
1761 return true;
1762}
1763
1764static bool
1765getAArch64ArchFeaturesFromMcpu(const Driver &D, StringRef Mcpu,
1766 const ArgList &Args,
1767 std::vector<const char *> &Features) {
1768 StringRef CPU;
1769 if (!DecodeAArch64Mcpu(D, Mcpu, CPU, Features))
1770 return false;
1771
1772 return true;
1773}
1774
1775static bool
1776getAArch64MicroArchFeaturesFromMtune(const Driver &D, StringRef Mtune,
1777 const ArgList &Args,
1778 std::vector<const char *> &Features) {
1779 // Handle CPU name is 'native'.
1780 if (Mtune == "native")
1781 Mtune = llvm::sys::getHostCPUName();
1782 if (Mtune == "cyclone") {
1783 Features.push_back("+zcm");
1784 Features.push_back("+zcz");
1785 }
1786 return true;
1787}
1788
1789static bool
1790getAArch64MicroArchFeaturesFromMcpu(const Driver &D, StringRef Mcpu,
1791 const ArgList &Args,
1792 std::vector<const char *> &Features) {
1793 StringRef CPU;
1794 std::vector<const char *> DecodedFeature;
1795 if (!DecodeAArch64Mcpu(D, Mcpu, CPU, DecodedFeature))
1796 return false;
1797
1798 return getAArch64MicroArchFeaturesFromMtune(D, CPU, Args, Features);
1799}
1800
Rafael Espindola146dbbf2013-08-21 16:39:20 +00001801static void getAArch64TargetFeatures(const Driver &D, const ArgList &Args,
1802 std::vector<const char *> &Features) {
Stephen Hines176edba2014-12-01 14:53:08 -08001803 Arg *A;
1804 bool success = true;
1805 // Enable NEON by default.
1806 Features.push_back("+neon");
1807 if ((A = Args.getLastArg(options::OPT_march_EQ)))
1808 success = getAArch64ArchFeaturesFromMarch(D, A->getValue(), Args, Features);
1809 else if ((A = Args.getLastArg(options::OPT_mcpu_EQ)))
1810 success = getAArch64ArchFeaturesFromMcpu(D, A->getValue(), Args, Features);
1811 else if (Args.hasArg(options::OPT_arch))
1812 success = getAArch64ArchFeaturesFromMcpu(D, getAArch64TargetCPU(Args), Args,
1813 Features);
1814
1815 if (success && (A = Args.getLastArg(options::OPT_mtune_EQ)))
1816 success =
1817 getAArch64MicroArchFeaturesFromMtune(D, A->getValue(), Args, Features);
1818 else if (success && (A = Args.getLastArg(options::OPT_mcpu_EQ)))
1819 success =
1820 getAArch64MicroArchFeaturesFromMcpu(D, A->getValue(), Args, Features);
1821 else if (Args.hasArg(options::OPT_arch))
1822 success = getAArch64MicroArchFeaturesFromMcpu(D, getAArch64TargetCPU(Args),
1823 Args, Features);
1824
1825 if (!success)
1826 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
Stephen Hines651f13c2014-04-23 16:59:28 -07001827
1828 if (Args.getLastArg(options::OPT_mgeneral_regs_only)) {
1829 Features.push_back("-fp-armv8");
1830 Features.push_back("-crypto");
1831 Features.push_back("-neon");
1832 }
Stephen Hines6bcf27b2014-05-29 04:14:42 -07001833
1834 // En/disable crc
1835 if (Arg *A = Args.getLastArg(options::OPT_mcrc,
1836 options::OPT_mnocrc)) {
1837 if (A->getOption().matches(options::OPT_mcrc))
1838 Features.push_back("+crc");
1839 else
1840 Features.push_back("-crc");
1841 }
Rafael Espindola146dbbf2013-08-21 16:39:20 +00001842}
1843
1844static void getTargetFeatures(const Driver &D, const llvm::Triple &Triple,
Stephen Hines651f13c2014-04-23 16:59:28 -07001845 const ArgList &Args, ArgStringList &CmdArgs,
1846 bool ForAS) {
Rafael Espindola146dbbf2013-08-21 16:39:20 +00001847 std::vector<const char *> Features;
1848 switch (Triple.getArch()) {
1849 default:
1850 break;
1851 case llvm::Triple::mips:
1852 case llvm::Triple::mipsel:
1853 case llvm::Triple::mips64:
1854 case llvm::Triple::mips64el:
Stephen Hines176edba2014-12-01 14:53:08 -08001855 getMIPSTargetFeatures(D, Triple, Args, Features);
Rafael Espindola146dbbf2013-08-21 16:39:20 +00001856 break;
1857
1858 case llvm::Triple::arm:
Stephen Hines651f13c2014-04-23 16:59:28 -07001859 case llvm::Triple::armeb:
Rafael Espindola146dbbf2013-08-21 16:39:20 +00001860 case llvm::Triple::thumb:
Stephen Hines651f13c2014-04-23 16:59:28 -07001861 case llvm::Triple::thumbeb:
1862 getARMTargetFeatures(D, Triple, Args, Features, ForAS);
Rafael Espindola146dbbf2013-08-21 16:39:20 +00001863 break;
1864
1865 case llvm::Triple::ppc:
1866 case llvm::Triple::ppc64:
1867 case llvm::Triple::ppc64le:
1868 getPPCTargetFeatures(Args, Features);
1869 break;
1870 case llvm::Triple::sparc:
Stephen Hines176edba2014-12-01 14:53:08 -08001871 case llvm::Triple::sparcv9:
Rafael Espindola146dbbf2013-08-21 16:39:20 +00001872 getSparcTargetFeatures(Args, Features);
1873 break;
1874 case llvm::Triple::aarch64:
Stephen Hines651f13c2014-04-23 16:59:28 -07001875 case llvm::Triple::aarch64_be:
Rafael Espindola146dbbf2013-08-21 16:39:20 +00001876 getAArch64TargetFeatures(D, Args, Features);
1877 break;
1878 case llvm::Triple::x86:
1879 case llvm::Triple::x86_64:
Stephen Hines176edba2014-12-01 14:53:08 -08001880 getX86TargetFeatures(D, Triple, Args, Features);
Rafael Espindola146dbbf2013-08-21 16:39:20 +00001881 break;
1882 }
Rafael Espindolabc1e5452013-08-21 17:34:32 +00001883
1884 // Find the last of each feature.
1885 llvm::StringMap<unsigned> LastOpt;
1886 for (unsigned I = 0, N = Features.size(); I < N; ++I) {
1887 const char *Name = Features[I];
1888 assert(Name[0] == '-' || Name[0] == '+');
1889 LastOpt[Name + 1] = I;
1890 }
1891
1892 for (unsigned I = 0, N = Features.size(); I < N; ++I) {
1893 // If this feature was overridden, ignore it.
1894 const char *Name = Features[I];
1895 llvm::StringMap<unsigned>::iterator LastI = LastOpt.find(Name + 1);
1896 assert(LastI != LastOpt.end());
1897 unsigned Last = LastI->second;
1898 if (Last != I)
1899 continue;
1900
Rafael Espindola146dbbf2013-08-21 16:39:20 +00001901 CmdArgs.push_back("-target-feature");
Rafael Espindolabc1e5452013-08-21 17:34:32 +00001902 CmdArgs.push_back(Name);
Rafael Espindola146dbbf2013-08-21 16:39:20 +00001903 }
Tim Northoverb793f0d2013-08-01 09:23:19 +00001904}
1905
Eric Christopher88b7cf02011-08-19 00:30:14 +00001906static bool
John McCall260611a2012-06-20 06:18:46 +00001907shouldUseExceptionTablesForObjCExceptions(const ObjCRuntime &runtime,
Anders Carlsson525544d2011-02-28 00:44:51 +00001908 const llvm::Triple &Triple) {
1909 // We use the zero-cost exception tables for Objective-C if the non-fragile
1910 // ABI is enabled or when compiling for x86_64 and ARM on Snow Leopard and
1911 // later.
John McCall260611a2012-06-20 06:18:46 +00001912 if (runtime.isNonFragile())
Anders Carlsson525544d2011-02-28 00:44:51 +00001913 return true;
1914
Stephen Hines651f13c2014-04-23 16:59:28 -07001915 if (!Triple.isMacOSX())
Anders Carlsson525544d2011-02-28 00:44:51 +00001916 return false;
1917
Eric Christopheraa7333c2011-07-02 00:20:22 +00001918 return (!Triple.isMacOSXVersionLT(10,5) &&
Anders Carlsson525544d2011-02-28 00:44:51 +00001919 (Triple.getArch() == llvm::Triple::x86_64 ||
Eric Christopher88b7cf02011-08-19 00:30:14 +00001920 Triple.getArch() == llvm::Triple::arm));
Anders Carlsson525544d2011-02-28 00:44:51 +00001921}
1922
Stephen Hines6bcf27b2014-05-29 04:14:42 -07001923// exceptionSettings() exists to share the logic between -cc1 and linker
1924// invocations.
Stephen Hines0e2c34f2015-03-23 12:09:02 -07001925static bool exceptionSettings(const ArgList &Args, const llvm::Triple &Triple) {
Stephen Hines651f13c2014-04-23 16:59:28 -07001926 if (Arg *A = Args.getLastArg(options::OPT_fexceptions,
Stephen Hines0e2c34f2015-03-23 12:09:02 -07001927 options::OPT_fno_exceptions))
Stephen Hines651f13c2014-04-23 16:59:28 -07001928 if (A->getOption().matches(options::OPT_fexceptions))
Stephen Hines0e2c34f2015-03-23 12:09:02 -07001929 return true;
Stephen Hines651f13c2014-04-23 16:59:28 -07001930
Stephen Hines0e2c34f2015-03-23 12:09:02 -07001931 return false;
Stephen Hines651f13c2014-04-23 16:59:28 -07001932}
1933
Stephen Hines0e2c34f2015-03-23 12:09:02 -07001934/// Adds exception related arguments to the driver command arguments. There's a
1935/// master flag, -fexceptions and also language specific flags to enable/disable
1936/// C++ and Objective-C exceptions. This makes it possible to for example
1937/// disable C++ exceptions but enable Objective-C exceptions.
Anders Carlsson15348ae2011-02-28 02:27:16 +00001938static void addExceptionArgs(const ArgList &Args, types::ID InputType,
Stephen Hines0e2c34f2015-03-23 12:09:02 -07001939 const ToolChain &TC, bool KernelOrKext,
John McCall260611a2012-06-20 06:18:46 +00001940 const ObjCRuntime &objcRuntime,
Anders Carlsson15348ae2011-02-28 02:27:16 +00001941 ArgStringList &CmdArgs) {
Stephen Hines0e2c34f2015-03-23 12:09:02 -07001942 const Driver &D = TC.getDriver();
1943 const llvm::Triple &Triple = TC.getTriple();
1944
Chad Rosierafc4baa2012-03-26 22:04:46 +00001945 if (KernelOrKext) {
1946 // -mkernel and -fapple-kext imply no exceptions, so claim exception related
1947 // arguments now to avoid warnings about unused arguments.
1948 Args.ClaimAllArgs(options::OPT_fexceptions);
1949 Args.ClaimAllArgs(options::OPT_fno_exceptions);
1950 Args.ClaimAllArgs(options::OPT_fobjc_exceptions);
1951 Args.ClaimAllArgs(options::OPT_fno_objc_exceptions);
1952 Args.ClaimAllArgs(options::OPT_fcxx_exceptions);
1953 Args.ClaimAllArgs(options::OPT_fno_cxx_exceptions);
Anders Carlsson15348ae2011-02-28 02:27:16 +00001954 return;
Chad Rosierafc4baa2012-03-26 22:04:46 +00001955 }
Anders Carlsson15348ae2011-02-28 02:27:16 +00001956
Stephen Hines0e2c34f2015-03-23 12:09:02 -07001957 // Gather the exception settings from the command line arguments.
1958 bool EH = exceptionSettings(Args, Triple);
Daniel Dunbar1a2cd4f2010-09-14 23:12:31 +00001959
Daniel Dunbard47ea692011-03-17 23:28:31 +00001960 // Obj-C exceptions are enabled by default, regardless of -fexceptions. This
1961 // is not necessarily sensible, but follows GCC.
1962 if (types::isObjC(InputType) &&
Eric Christopher88b7cf02011-08-19 00:30:14 +00001963 Args.hasFlag(options::OPT_fobjc_exceptions,
Daniel Dunbard47ea692011-03-17 23:28:31 +00001964 options::OPT_fno_objc_exceptions,
1965 true)) {
1966 CmdArgs.push_back("-fobjc-exceptions");
Anders Carlsson15348ae2011-02-28 02:27:16 +00001967
Stephen Hines0e2c34f2015-03-23 12:09:02 -07001968 EH |= shouldUseExceptionTablesForObjCExceptions(objcRuntime, Triple);
Anders Carlsson15348ae2011-02-28 02:27:16 +00001969 }
1970
1971 if (types::isCXX(InputType)) {
Stephen Hines0e2c34f2015-03-23 12:09:02 -07001972 bool CXXExceptionsEnabled =
1973 Triple.getArch() != llvm::Triple::xcore && !Triple.isPS4CPU();
1974 Arg *ExceptionArg = Args.getLastArg(
1975 options::OPT_fcxx_exceptions, options::OPT_fno_cxx_exceptions,
1976 options::OPT_fexceptions, options::OPT_fno_exceptions);
1977 if (ExceptionArg)
1978 CXXExceptionsEnabled =
1979 ExceptionArg->getOption().matches(options::OPT_fcxx_exceptions) ||
1980 ExceptionArg->getOption().matches(options::OPT_fexceptions);
Anders Carlsson15348ae2011-02-28 02:27:16 +00001981
1982 if (CXXExceptionsEnabled) {
Stephen Hines0e2c34f2015-03-23 12:09:02 -07001983 if (Triple.isPS4CPU()) {
1984 ToolChain::RTTIMode RTTIMode = TC.getRTTIMode();
1985 assert(ExceptionArg &&
1986 "On the PS4 exceptions should only be enabled if passing "
1987 "an argument");
1988 if (RTTIMode == ToolChain::RM_DisabledExplicitly) {
1989 const Arg *RTTIArg = TC.getRTTIArg();
1990 assert(RTTIArg && "RTTI disabled explicitly but no RTTIArg!");
1991 D.Diag(diag::err_drv_argument_not_allowed_with)
1992 << RTTIArg->getAsString(Args) << ExceptionArg->getAsString(Args);
1993 } else if (RTTIMode == ToolChain::RM_EnabledImplicitly)
1994 D.Diag(diag::warn_drv_enabling_rtti_with_exceptions);
1995 } else
1996 assert(TC.getRTTIMode() != ToolChain::RM_DisabledImplicitly);
1997
Anders Carlsson15348ae2011-02-28 02:27:16 +00001998 CmdArgs.push_back("-fcxx-exceptions");
1999
Stephen Hines0e2c34f2015-03-23 12:09:02 -07002000 EH = true;
Anders Carlsson15348ae2011-02-28 02:27:16 +00002001 }
2002 }
2003
Stephen Hines0e2c34f2015-03-23 12:09:02 -07002004 if (EH)
Anders Carlsson15348ae2011-02-28 02:27:16 +00002005 CmdArgs.push_back("-fexceptions");
Rafael Espindolaf759df02009-10-01 13:33:33 +00002006}
2007
Daniel Dunbarf4910132013-04-16 18:21:19 +00002008static bool ShouldDisableAutolink(const ArgList &Args,
2009 const ToolChain &TC) {
2010 bool Default = true;
2011 if (TC.getTriple().isOSDarwin()) {
2012 // The native darwin assembler doesn't support the linker_option directives,
2013 // so we disable them if we think the .s file will be passed to it.
2014 Default = TC.useIntegratedAs();
2015 }
2016 return !Args.hasFlag(options::OPT_fautolink, options::OPT_fno_autolink,
2017 Default);
2018}
2019
Ted Kremenekc06fcdf2013-03-12 17:02:12 +00002020static bool ShouldDisableDwarfDirectory(const ArgList &Args,
2021 const ToolChain &TC) {
Nick Lewyckyea523d72011-10-17 23:05:52 +00002022 bool UseDwarfDirectory = Args.hasFlag(options::OPT_fdwarf_directory_asm,
2023 options::OPT_fno_dwarf_directory_asm,
Rafael Espindolaaf370e62013-03-18 18:10:27 +00002024 TC.useIntegratedAs());
Nick Lewyckyea523d72011-10-17 23:05:52 +00002025 return !UseDwarfDirectory;
2026}
2027
Joerg Sonnenberger359cf922011-05-06 14:35:16 +00002028/// \brief Check whether the given input tree contains any compilation actions.
2029static bool ContainsCompileAction(const Action *A) {
Stephen Hines0e2c34f2015-03-23 12:09:02 -07002030 if (isa<CompileJobAction>(A) || isa<BackendJobAction>(A))
Joerg Sonnenberger359cf922011-05-06 14:35:16 +00002031 return true;
2032
Stephen Hinesef822542014-07-21 00:47:37 -07002033 for (const auto &Act : *A)
2034 if (ContainsCompileAction(Act))
Joerg Sonnenberger359cf922011-05-06 14:35:16 +00002035 return true;
2036
2037 return false;
2038}
2039
2040/// \brief Check if -relax-all should be passed to the internal assembler.
2041/// This is done by default when compiling non-assembler source with -O0.
2042static bool UseRelaxAll(Compilation &C, const ArgList &Args) {
2043 bool RelaxDefault = true;
2044
2045 if (Arg *A = Args.getLastArg(options::OPT_O_Group))
2046 RelaxDefault = A->getOption().matches(options::OPT_O0);
2047
2048 if (RelaxDefault) {
2049 RelaxDefault = false;
Stephen Hinesef822542014-07-21 00:47:37 -07002050 for (const auto &Act : C.getActions()) {
2051 if (ContainsCompileAction(Act)) {
Joerg Sonnenberger359cf922011-05-06 14:35:16 +00002052 RelaxDefault = true;
2053 break;
2054 }
2055 }
2056 }
2057
2058 return Args.hasFlag(options::OPT_mrelax_all, options::OPT_mno_relax_all,
2059 RelaxDefault);
2060}
2061
David Blaikie73168db2013-07-25 21:19:01 +00002062static void CollectArgsForIntegratedAssembler(Compilation &C,
2063 const ArgList &Args,
2064 ArgStringList &CmdArgs,
2065 const Driver &D) {
2066 if (UseRelaxAll(C, Args))
2067 CmdArgs.push_back("-mrelax-all");
2068
David Peixotto4ca9eae2013-11-14 22:52:58 +00002069 // When passing -I arguments to the assembler we sometimes need to
David Peixotto2317f7b2013-11-14 22:58:17 +00002070 // unconditionally take the next argument. For example, when parsing
David Peixotto4ca9eae2013-11-14 22:52:58 +00002071 // '-Wa,-I -Wa,foo' we need to accept the -Wa,foo arg after seeing the
2072 // -Wa,-I arg and when parsing '-Wa,-I,foo' we need to accept the 'foo'
2073 // arg after parsing the '-I' arg.
2074 bool TakeNextArg = false;
2075
David Blaikie73168db2013-07-25 21:19:01 +00002076 // When using an integrated assembler, translate -Wa, and -Xassembler
2077 // options.
Stephen Hines651f13c2014-04-23 16:59:28 -07002078 bool CompressDebugSections = false;
David Blaikie73168db2013-07-25 21:19:01 +00002079 for (arg_iterator it = Args.filtered_begin(options::OPT_Wa_COMMA,
2080 options::OPT_Xassembler),
2081 ie = Args.filtered_end(); it != ie; ++it) {
2082 const Arg *A = *it;
2083 A->claim();
2084
2085 for (unsigned i = 0, e = A->getNumValues(); i != e; ++i) {
2086 StringRef Value = A->getValue(i);
David Peixotto4ca9eae2013-11-14 22:52:58 +00002087 if (TakeNextArg) {
2088 CmdArgs.push_back(Value.data());
2089 TakeNextArg = false;
2090 continue;
2091 }
David Blaikie73168db2013-07-25 21:19:01 +00002092
2093 if (Value == "-force_cpusubtype_ALL") {
2094 // Do nothing, this is the default and we don't support anything else.
2095 } else if (Value == "-L") {
2096 CmdArgs.push_back("-msave-temp-labels");
2097 } else if (Value == "--fatal-warnings") {
Stephen Hines176edba2014-12-01 14:53:08 -08002098 CmdArgs.push_back("-massembler-fatal-warnings");
David Blaikie73168db2013-07-25 21:19:01 +00002099 } else if (Value == "--noexecstack") {
2100 CmdArgs.push_back("-mnoexecstack");
Stephen Hines651f13c2014-04-23 16:59:28 -07002101 } else if (Value == "-compress-debug-sections" ||
2102 Value == "--compress-debug-sections") {
2103 CompressDebugSections = true;
2104 } else if (Value == "-nocompress-debug-sections" ||
2105 Value == "--nocompress-debug-sections") {
2106 CompressDebugSections = false;
David Peixotto4ca9eae2013-11-14 22:52:58 +00002107 } else if (Value.startswith("-I")) {
2108 CmdArgs.push_back(Value.data());
2109 // We need to consume the next argument if the current arg is a plain
2110 // -I. The next arg will be the include directory.
2111 if (Value == "-I")
2112 TakeNextArg = true;
Stephen Hines6bcf27b2014-05-29 04:14:42 -07002113 } else if (Value.startswith("-gdwarf-")) {
2114 CmdArgs.push_back(Value.data());
David Blaikie73168db2013-07-25 21:19:01 +00002115 } else {
2116 D.Diag(diag::err_drv_unsupported_option_argument)
2117 << A->getOption().getName() << Value;
2118 }
2119 }
2120 }
Stephen Hines651f13c2014-04-23 16:59:28 -07002121 if (CompressDebugSections) {
2122 if (llvm::zlib::isAvailable())
2123 CmdArgs.push_back("-compress-debug-sections");
2124 else
2125 D.Diag(diag::warn_debug_compression_unavailable);
2126 }
David Blaikie73168db2013-07-25 21:19:01 +00002127}
2128
Stephen Hines651f13c2014-04-23 16:59:28 -07002129// Until ARM libraries are build separately, we have them all in one library
2130static StringRef getArchNameForCompilerRTLib(const ToolChain &TC) {
Stephen Hines0e2c34f2015-03-23 12:09:02 -07002131 // FIXME: handle 64-bit
2132 if (TC.getTriple().isOSWindows() &&
2133 !TC.getTriple().isWindowsItaniumEnvironment())
2134 return "i386";
2135 if (TC.getArch() == llvm::Triple::arm || TC.getArch() == llvm::Triple::armeb)
Stephen Hines651f13c2014-04-23 16:59:28 -07002136 return "arm";
Stephen Hines0e2c34f2015-03-23 12:09:02 -07002137 return TC.getArchName();
Stephen Hines651f13c2014-04-23 16:59:28 -07002138}
2139
2140static SmallString<128> getCompilerRTLibDir(const ToolChain &TC) {
2141 // The runtimes are located in the OS-specific resource directory.
2142 SmallString<128> Res(TC.getDriver().ResourceDir);
2143 const llvm::Triple &Triple = TC.getTriple();
2144 // TC.getOS() yield "freebsd10.0" whereas "freebsd" is expected.
Stephen Hines0e2c34f2015-03-23 12:09:02 -07002145 StringRef OSLibName =
2146 (Triple.getOS() == llvm::Triple::FreeBSD) ? "freebsd" : TC.getOS();
Stephen Hines651f13c2014-04-23 16:59:28 -07002147 llvm::sys::path::append(Res, "lib", OSLibName);
2148 return Res;
2149}
2150
Stephen Hines0e2c34f2015-03-23 12:09:02 -07002151static SmallString<128> getCompilerRT(const ToolChain &TC, StringRef Component,
2152 bool Shared = false) {
2153 const char *Env = TC.getTriple().getEnvironment() == llvm::Triple::Android
2154 ? "-android"
2155 : "";
2156
2157 bool IsOSWindows = TC.getTriple().isOSWindows();
2158 StringRef Arch = getArchNameForCompilerRTLib(TC);
2159 const char *Prefix = IsOSWindows ? "" : "lib";
2160 const char *Suffix =
2161 Shared ? (IsOSWindows ? ".dll" : ".so") : (IsOSWindows ? ".lib" : ".a");
2162
2163 SmallString<128> Path = getCompilerRTLibDir(TC);
2164 llvm::sys::path::append(Path, Prefix + Twine("clang_rt.") + Component + "-" +
2165 Arch + Env + Suffix);
2166
2167 return Path;
2168}
2169
Stephen Hines6bcf27b2014-05-29 04:14:42 -07002170// This adds the static libclang_rt.builtins-arch.a directly to the command line
Stephen Hines651f13c2014-04-23 16:59:28 -07002171// FIXME: Make sure we can also emit shared objects if they're requested
2172// and available, check for possible errors, etc.
Stephen Hines0e2c34f2015-03-23 12:09:02 -07002173static void addClangRT(const ToolChain &TC, const ArgList &Args,
2174 ArgStringList &CmdArgs) {
2175 CmdArgs.push_back(Args.MakeArgString(getCompilerRT(TC, "builtins")));
Stephen Hines651f13c2014-04-23 16:59:28 -07002176
Stephen Hines0e2c34f2015-03-23 12:09:02 -07002177 if (!TC.getTriple().isOSWindows()) {
2178 // FIXME: why do we link against gcc when we are using compiler-rt?
2179 CmdArgs.push_back("-lgcc_s");
2180 if (TC.getDriver().CCCIsCXX())
2181 CmdArgs.push_back("-lgcc_eh");
2182 }
Stephen Hines651f13c2014-04-23 16:59:28 -07002183}
2184
Stephen Hines0e2c34f2015-03-23 12:09:02 -07002185static void addProfileRT(const ToolChain &TC, const ArgList &Args,
2186 ArgStringList &CmdArgs) {
Stephen Hines176edba2014-12-01 14:53:08 -08002187 if (!(Args.hasFlag(options::OPT_fprofile_arcs, options::OPT_fno_profile_arcs,
2188 false) ||
Chandler Carruth9db37cd2013-06-23 11:28:48 +00002189 Args.hasArg(options::OPT_fprofile_generate) ||
Stephen Hines651f13c2014-04-23 16:59:28 -07002190 Args.hasArg(options::OPT_fprofile_instr_generate) ||
Chandler Carruth9db37cd2013-06-23 11:28:48 +00002191 Args.hasArg(options::OPT_fcreate_profile) ||
2192 Args.hasArg(options::OPT_coverage)))
2193 return;
2194
Stephen Hines0e2c34f2015-03-23 12:09:02 -07002195 CmdArgs.push_back(Args.MakeArgString(getCompilerRT(TC, "profile")));
Stephen Hines651f13c2014-04-23 16:59:28 -07002196}
2197
Stephen Hines176edba2014-12-01 14:53:08 -08002198static void addSanitizerRuntime(const ToolChain &TC, const ArgList &Args,
2199 ArgStringList &CmdArgs, StringRef Sanitizer,
2200 bool IsShared) {
Stephen Hines176edba2014-12-01 14:53:08 -08002201 // Static runtimes must be forced into executable, so we wrap them in
Peter Collingbournebf548552013-10-20 21:29:13 +00002202 // whole-archive.
Stephen Hines176edba2014-12-01 14:53:08 -08002203 if (!IsShared)
2204 CmdArgs.push_back("-whole-archive");
Stephen Hines0e2c34f2015-03-23 12:09:02 -07002205 CmdArgs.push_back(Args.MakeArgString(getCompilerRT(TC, Sanitizer, IsShared)));
Stephen Hines176edba2014-12-01 14:53:08 -08002206 if (!IsShared)
2207 CmdArgs.push_back("-no-whole-archive");
Alexey Samsonov86143042013-02-27 11:14:55 +00002208}
2209
Stephen Hines176edba2014-12-01 14:53:08 -08002210// Tries to use a file with the list of dynamic symbols that need to be exported
2211// from the runtime library. Returns true if the file was found.
2212static bool addSanitizerDynamicList(const ToolChain &TC, const ArgList &Args,
2213 ArgStringList &CmdArgs,
2214 StringRef Sanitizer) {
Stephen Hines0e2c34f2015-03-23 12:09:02 -07002215 SmallString<128> SanRT = getCompilerRT(TC, Sanitizer);
2216 if (llvm::sys::fs::exists(SanRT + ".syms")) {
2217 CmdArgs.push_back(Args.MakeArgString("--dynamic-list=" + SanRT + ".syms"));
Stephen Hines176edba2014-12-01 14:53:08 -08002218 return true;
2219 }
2220 return false;
2221}
2222
2223static void linkSanitizerRuntimeDeps(const ToolChain &TC,
2224 ArgStringList &CmdArgs) {
2225 // Force linking against the system libraries sanitizers depends on
2226 // (see PR15823 why this is necessary).
2227 CmdArgs.push_back("--no-as-needed");
2228 CmdArgs.push_back("-lpthread");
2229 CmdArgs.push_back("-lrt");
2230 CmdArgs.push_back("-lm");
2231 // There's no libdl on FreeBSD.
2232 if (TC.getTriple().getOS() != llvm::Triple::FreeBSD)
2233 CmdArgs.push_back("-ldl");
2234}
2235
2236static void
2237collectSanitizerRuntimes(const ToolChain &TC, const ArgList &Args,
2238 SmallVectorImpl<StringRef> &SharedRuntimes,
2239 SmallVectorImpl<StringRef> &StaticRuntimes,
2240 SmallVectorImpl<StringRef> &HelperStaticRuntimes) {
2241 const SanitizerArgs &SanArgs = TC.getSanitizerArgs();
2242 // Collect shared runtimes.
2243 if (SanArgs.needsAsanRt() && SanArgs.needsSharedAsanRt()) {
2244 SharedRuntimes.push_back("asan");
Evgeniy Stepanova6ddc022012-04-25 08:59:22 +00002245 }
Stephen Hines651f13c2014-04-23 16:59:28 -07002246
Stephen Hines176edba2014-12-01 14:53:08 -08002247 // Collect static runtimes.
Stephen Hines651f13c2014-04-23 16:59:28 -07002248 if (Args.hasArg(options::OPT_shared) ||
Stephen Hines176edba2014-12-01 14:53:08 -08002249 (TC.getTriple().getEnvironment() == llvm::Triple::Android)) {
2250 // Don't link static runtimes into DSOs or if compiling for Android.
Stephen Hines651f13c2014-04-23 16:59:28 -07002251 return;
Stephen Hines176edba2014-12-01 14:53:08 -08002252 }
2253 if (SanArgs.needsAsanRt()) {
2254 if (SanArgs.needsSharedAsanRt()) {
2255 HelperStaticRuntimes.push_back("asan-preinit");
2256 } else {
2257 StaticRuntimes.push_back("asan");
2258 if (SanArgs.linkCXXRuntimes())
2259 StaticRuntimes.push_back("asan_cxx");
2260 }
2261 }
2262 if (SanArgs.needsDfsanRt())
2263 StaticRuntimes.push_back("dfsan");
2264 if (SanArgs.needsLsanRt())
2265 StaticRuntimes.push_back("lsan");
2266 if (SanArgs.needsMsanRt())
2267 StaticRuntimes.push_back("msan");
2268 if (SanArgs.needsTsanRt())
2269 StaticRuntimes.push_back("tsan");
2270 // WARNING: UBSan should always go last.
2271 if (SanArgs.needsUbsanRt()) {
2272 // If UBSan is not combined with another sanitizer, we need to pull in
2273 // sanitizer_common explicitly.
2274 if (StaticRuntimes.empty())
2275 HelperStaticRuntimes.push_back("san");
2276 StaticRuntimes.push_back("ubsan");
2277 if (SanArgs.linkCXXRuntimes())
2278 StaticRuntimes.push_back("ubsan_cxx");
Stephen Hines6bcf27b2014-05-29 04:14:42 -07002279 }
Kostya Serebryanydff466c2011-11-30 01:39:16 +00002280}
2281
Stephen Hines176edba2014-12-01 14:53:08 -08002282// Should be called before we add system libraries (C++ ABI, libstdc++/libc++,
2283// C runtime, etc). Returns true if sanitizer system deps need to be linked in.
2284static bool addSanitizerRuntimes(const ToolChain &TC, const ArgList &Args,
Stephen Hines651f13c2014-04-23 16:59:28 -07002285 ArgStringList &CmdArgs) {
Stephen Hines176edba2014-12-01 14:53:08 -08002286 SmallVector<StringRef, 4> SharedRuntimes, StaticRuntimes,
2287 HelperStaticRuntimes;
2288 collectSanitizerRuntimes(TC, Args, SharedRuntimes, StaticRuntimes,
2289 HelperStaticRuntimes);
2290 for (auto RT : SharedRuntimes)
2291 addSanitizerRuntime(TC, Args, CmdArgs, RT, true);
2292 for (auto RT : HelperStaticRuntimes)
2293 addSanitizerRuntime(TC, Args, CmdArgs, RT, false);
2294 bool AddExportDynamic = false;
2295 for (auto RT : StaticRuntimes) {
2296 addSanitizerRuntime(TC, Args, CmdArgs, RT, false);
2297 AddExportDynamic |= !addSanitizerDynamicList(TC, Args, CmdArgs, RT);
2298 }
2299 // If there is a static runtime with no dynamic list, force all the symbols
2300 // to be dynamic to be sure we export sanitizer interface functions.
2301 if (AddExportDynamic)
2302 CmdArgs.push_back("-export-dynamic");
2303 return !StaticRuntimes.empty();
Peter Collingbourne2eeed712013-08-07 22:47:34 +00002304}
2305
Stephen Hines0e2c34f2015-03-23 12:09:02 -07002306static bool areOptimizationsEnabled(const ArgList &Args) {
2307 // Find the last -O arg and see if it is non-zero.
2308 if (Arg *A = Args.getLastArg(options::OPT_O_Group))
2309 return !A->getOption().matches(options::OPT_O0);
2310 // Defaults to -O0.
2311 return false;
2312}
2313
Benjamin Kramer5322a552013-10-16 17:42:39 +00002314static bool shouldUseFramePointerForTarget(const ArgList &Args,
2315 const llvm::Triple &Triple) {
Stephen Hines0e2c34f2015-03-23 12:09:02 -07002316 // XCore never wants frame pointers, regardless of OS.
2317 if (Triple.getArch() == llvm::Triple::xcore) {
Benjamin Kramer5322a552013-10-16 17:42:39 +00002318 return false;
Benjamin Kramer5322a552013-10-16 17:42:39 +00002319 }
Stephen Hines0e2c34f2015-03-23 12:09:02 -07002320
2321 if (Triple.isOSLinux()) {
2322 switch (Triple.getArch()) {
2323 // Don't use a frame pointer on linux if optimizing for certain targets.
2324 case llvm::Triple::mips64:
2325 case llvm::Triple::mips64el:
2326 case llvm::Triple::mips:
2327 case llvm::Triple::mipsel:
2328 case llvm::Triple::systemz:
2329 case llvm::Triple::x86:
2330 case llvm::Triple::x86_64:
2331 return !areOptimizationsEnabled(Args);
2332 default:
2333 return true;
2334 }
2335 }
2336
2337 if (Triple.isOSWindows()) {
2338 switch (Triple.getArch()) {
2339 case llvm::Triple::x86:
2340 return !areOptimizationsEnabled(Args);
2341 default:
2342 // All other supported Windows ISAs use xdata unwind information, so frame
2343 // pointers are not generally useful.
2344 return false;
2345 }
2346 }
2347
2348 return true;
Benjamin Kramer5322a552013-10-16 17:42:39 +00002349}
2350
Rafael Espindola6af27ec2011-12-14 21:02:23 +00002351static bool shouldUseFramePointer(const ArgList &Args,
2352 const llvm::Triple &Triple) {
2353 if (Arg *A = Args.getLastArg(options::OPT_fno_omit_frame_pointer,
2354 options::OPT_fomit_frame_pointer))
2355 return A->getOption().matches(options::OPT_fno_omit_frame_pointer);
2356
Benjamin Kramer5322a552013-10-16 17:42:39 +00002357 return shouldUseFramePointerForTarget(Args, Triple);
Rafael Espindola6af27ec2011-12-14 21:02:23 +00002358}
2359
Eric Christopherd3e22df2013-04-03 01:58:53 +00002360static bool shouldUseLeafFramePointer(const ArgList &Args,
2361 const llvm::Triple &Triple) {
2362 if (Arg *A = Args.getLastArg(options::OPT_mno_omit_leaf_frame_pointer,
2363 options::OPT_momit_leaf_frame_pointer))
2364 return A->getOption().matches(options::OPT_mno_omit_leaf_frame_pointer);
2365
Stephen Hines0e2c34f2015-03-23 12:09:02 -07002366 if (Triple.isPS4CPU())
2367 return false;
2368
Benjamin Kramer5322a552013-10-16 17:42:39 +00002369 return shouldUseFramePointerForTarget(Args, Triple);
Eric Christopherd3e22df2013-04-03 01:58:53 +00002370}
2371
Rafael Espindolaa2148242013-08-10 01:40:10 +00002372/// Add a CC1 option to specify the debug compilation directory.
Chandler Carruthd566df62012-12-17 21:40:04 +00002373static void addDebugCompDirArg(const ArgList &Args, ArgStringList &CmdArgs) {
Benjamin Kramer6089adc2013-04-27 08:12:29 +00002374 SmallString<128> cwd;
2375 if (!llvm::sys::fs::current_path(cwd)) {
Chad Rosierb1c81222013-04-26 20:49:50 +00002376 CmdArgs.push_back("-fdebug-compilation-dir");
2377 CmdArgs.push_back(Args.MakeArgString(cwd));
Chandler Carruthd566df62012-12-17 21:40:04 +00002378 }
2379}
2380
Eric Christopher80190392013-02-22 20:12:52 +00002381static const char *SplitDebugName(const ArgList &Args,
2382 const InputInfoList &Inputs) {
2383 Arg *FinalOutput = Args.getLastArg(options::OPT_o);
2384 if (FinalOutput && Args.hasArg(options::OPT_c)) {
2385 SmallString<128> T(FinalOutput->getValue());
2386 llvm::sys::path::replace_extension(T, "dwo");
2387 return Args.MakeArgString(T);
2388 } else {
2389 // Use the compilation dir.
Stephen Hines6bcf27b2014-05-29 04:14:42 -07002390 SmallString<128> T(
2391 Args.getLastArgValue(options::OPT_fdebug_compilation_dir));
Eric Christopher80190392013-02-22 20:12:52 +00002392 SmallString<128> F(llvm::sys::path::stem(Inputs[0].getBaseInput()));
2393 llvm::sys::path::replace_extension(F, "dwo");
2394 T += F;
2395 return Args.MakeArgString(F);
2396 }
2397}
2398
2399static void SplitDebugInfo(const ToolChain &TC, Compilation &C,
2400 const Tool &T, const JobAction &JA,
2401 const ArgList &Args, const InputInfo &Output,
2402 const char *OutFile) {
Eric Christopher59320e72013-02-21 22:35:01 +00002403 ArgStringList ExtractArgs;
2404 ExtractArgs.push_back("--extract-dwo");
2405
2406 ArgStringList StripArgs;
2407 StripArgs.push_back("--strip-dwo");
2408
2409 // Grabbing the output of the earlier compile step.
2410 StripArgs.push_back(Output.getFilename());
2411 ExtractArgs.push_back(Output.getFilename());
Eric Christopher59320e72013-02-21 22:35:01 +00002412 ExtractArgs.push_back(OutFile);
2413
2414 const char *Exec =
Eric Christopher80190392013-02-22 20:12:52 +00002415 Args.MakeArgString(TC.GetProgramPath("objcopy"));
Eric Christopher59320e72013-02-21 22:35:01 +00002416
2417 // First extract the dwo sections.
Stephen Hines176edba2014-12-01 14:53:08 -08002418 C.addCommand(llvm::make_unique<Command>(JA, T, Exec, ExtractArgs));
Eric Christopher59320e72013-02-21 22:35:01 +00002419
2420 // Then remove them from the original .o file.
Stephen Hines176edba2014-12-01 14:53:08 -08002421 C.addCommand(llvm::make_unique<Command>(JA, T, Exec, StripArgs));
Eric Christopher59320e72013-02-21 22:35:01 +00002422}
2423
Arnold Schwaighofer99662a12013-08-13 15:46:23 +00002424/// \brief Vectorize at all optimization levels greater than 1 except for -Oz.
Stephen Hines6bcf27b2014-05-29 04:14:42 -07002425/// For -Oz the loop vectorizer is disable, while the slp vectorizer is enabled.
2426static bool shouldEnableVectorizerAtOLevel(const ArgList &Args, bool isSlpVec) {
Arnold Schwaighofer99662a12013-08-13 15:46:23 +00002427 if (Arg *A = Args.getLastArg(options::OPT_O_Group)) {
Rafael Espindola55ee1eb2013-08-27 16:58:15 +00002428 if (A->getOption().matches(options::OPT_O4) ||
2429 A->getOption().matches(options::OPT_Ofast))
Arnold Schwaighofer99662a12013-08-13 15:46:23 +00002430 return true;
2431
2432 if (A->getOption().matches(options::OPT_O0))
2433 return false;
2434
2435 assert(A->getOption().matches(options::OPT_O) && "Must have a -O flag");
2436
Rafael Espindola168de192013-08-26 14:05:41 +00002437 // Vectorize -Os.
Arnold Schwaighofer99662a12013-08-13 15:46:23 +00002438 StringRef S(A->getValue());
Rafael Espindola168de192013-08-26 14:05:41 +00002439 if (S == "s")
Arnold Schwaighofer99662a12013-08-13 15:46:23 +00002440 return true;
2441
Stephen Hines6bcf27b2014-05-29 04:14:42 -07002442 // Don't vectorize -Oz, unless it's the slp vectorizer.
Arnold Schwaighofer99662a12013-08-13 15:46:23 +00002443 if (S == "z")
Stephen Hines6bcf27b2014-05-29 04:14:42 -07002444 return isSlpVec;
Arnold Schwaighofer99662a12013-08-13 15:46:23 +00002445
2446 unsigned OptLevel = 0;
2447 if (S.getAsInteger(10, OptLevel))
2448 return false;
2449
2450 return OptLevel > 1;
2451 }
2452
2453 return false;
2454}
2455
Stephen Hines651f13c2014-04-23 16:59:28 -07002456/// Add -x lang to \p CmdArgs for \p Input.
2457static void addDashXForInput(const ArgList &Args, const InputInfo &Input,
2458 ArgStringList &CmdArgs) {
2459 // When using -verify-pch, we don't want to provide the type
2460 // 'precompiled-header' if it was inferred from the file extension
2461 if (Args.hasArg(options::OPT_verify_pch) && Input.getType() == types::TY_PCH)
2462 return;
2463
2464 CmdArgs.push_back("-x");
2465 if (Args.hasArg(options::OPT_rewrite_objc))
2466 CmdArgs.push_back(types::getTypeName(types::TY_PP_ObjCXX));
2467 else
2468 CmdArgs.push_back(types::getTypeName(Input.getType()));
2469}
2470
Stephen Hines176edba2014-12-01 14:53:08 -08002471static std::string getMSCompatibilityVersion(const char *VersionStr) {
2472 unsigned Version;
2473 if (StringRef(VersionStr).getAsInteger(10, Version))
2474 return "0";
2475
2476 if (Version < 100)
2477 return llvm::utostr_32(Version) + ".0";
2478
2479 if (Version < 10000)
2480 return llvm::utostr_32(Version / 100) + "." +
2481 llvm::utostr_32(Version % 100);
2482
2483 unsigned Build = 0, Factor = 1;
2484 for ( ; Version > 10000; Version = Version / 10, Factor = Factor * 10)
2485 Build = Build + (Version % 10) * Factor;
2486 return llvm::utostr_32(Version / 100) + "." +
2487 llvm::utostr_32(Version % 100) + "." +
2488 llvm::utostr_32(Build);
2489}
2490
Stephen Hines0e2c34f2015-03-23 12:09:02 -07002491// Claim options we don't want to warn if they are unused. We do this for
2492// options that build systems might add but are unused when assembling or only
2493// running the preprocessor for example.
2494static void claimNoWarnArgs(const ArgList &Args) {
2495 // Don't warn about unused -f(no-)?lto. This can happen when we're
2496 // preprocessing, precompiling or assembling.
2497 Args.ClaimAllArgs(options::OPT_flto);
2498 Args.ClaimAllArgs(options::OPT_fno_lto);
2499}
2500
2501static void appendUserToPath(SmallVectorImpl<char> &Result) {
2502#ifdef LLVM_ON_UNIX
2503 const char *Username = getenv("LOGNAME");
2504#else
2505 const char *Username = getenv("USERNAME");
2506#endif
2507 if (Username) {
2508 // Validate that LoginName can be used in a path, and get its length.
2509 size_t Len = 0;
2510 for (const char *P = Username; *P; ++P, ++Len) {
2511 if (!isAlphanumeric(*P) && *P != '_') {
2512 Username = nullptr;
2513 break;
2514 }
2515 }
2516
2517 if (Username && Len > 0) {
2518 Result.append(Username, Username + Len);
2519 return;
2520 }
2521 }
2522
2523 // Fallback to user id.
2524#ifdef LLVM_ON_UNIX
2525 std::string UID = llvm::utostr(getuid());
2526#else
2527 // FIXME: Windows seems to have an 'SID' that might work.
2528 std::string UID = "9999";
2529#endif
2530 Result.append(UID.begin(), UID.end());
2531}
2532
Daniel Dunbar47ac7d22009-03-18 06:00:36 +00002533void Clang::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar871adcf2009-03-18 07:06:02 +00002534 const InputInfo &Output,
Daniel Dunbar62cf6012009-03-18 06:07:59 +00002535 const InputInfoList &Inputs,
Daniel Dunbar1d460332009-03-18 10:01:51 +00002536 const ArgList &Args,
Daniel Dunbar47ac7d22009-03-18 06:00:36 +00002537 const char *LinkingOutput) const {
Daniel Dunbar0a80ba72010-03-20 04:52:14 +00002538 bool KernelOrKext = Args.hasArg(options::OPT_mkernel,
2539 options::OPT_fapple_kext);
Daniel Dunbaree788e72009-12-21 18:54:17 +00002540 const Driver &D = getToolChain().getDriver();
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00002541 ArgStringList CmdArgs;
2542
Stephen Hines651f13c2014-04-23 16:59:28 -07002543 bool IsWindowsGNU = getToolChain().getTriple().isWindowsGNUEnvironment();
Stephen Hines6bcf27b2014-05-29 04:14:42 -07002544 bool IsWindowsCygnus =
2545 getToolChain().getTriple().isWindowsCygwinEnvironment();
Stephen Hines651f13c2014-04-23 16:59:28 -07002546 bool IsWindowsMSVC = getToolChain().getTriple().isWindowsMSVCEnvironment();
2547
Daniel Dunbar077ba6a2009-03-31 20:53:55 +00002548 assert(Inputs.size() == 1 && "Unable to handle multiple inputs.");
2549
Daniel Dunbar8ff5b282009-12-11 23:00:49 +00002550 // Invoke ourselves in -cc1 mode.
2551 //
2552 // FIXME: Implement custom jobs for internal actions.
2553 CmdArgs.push_back("-cc1");
2554
Daniel Dunbardd4fe002009-10-30 18:12:20 +00002555 // Add the "effective" target triple.
Daniel Dunbaraf07f932009-03-31 17:35:15 +00002556 CmdArgs.push_back("-triple");
Daniel Dunbar00577ad2010-08-23 22:35:37 +00002557 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
Daniel Dunbardd4fe002009-10-30 18:12:20 +00002558 CmdArgs.push_back(Args.MakeArgString(TripleStr));
Daniel Dunbar728a5122009-09-10 06:49:20 +00002559
Stephen Hines6bcf27b2014-05-29 04:14:42 -07002560 const llvm::Triple TT(TripleStr);
2561 if (TT.isOSWindows() && (TT.getArch() == llvm::Triple::arm ||
2562 TT.getArch() == llvm::Triple::thumb)) {
2563 unsigned Offset = TT.getArch() == llvm::Triple::arm ? 4 : 6;
2564 unsigned Version;
2565 TT.getArchName().substr(Offset).getAsInteger(10, Version);
2566 if (Version < 7)
2567 D.Diag(diag::err_target_unsupported_arch) << TT.getArchName()
2568 << TripleStr;
2569 }
2570
Stephen Hines651f13c2014-04-23 16:59:28 -07002571 // Push all default warning arguments that are specific to
2572 // the given target. These come before user provided warning options
2573 // are provided.
2574 getToolChain().addClangWarningOptions(CmdArgs);
2575
Daniel Dunbardd4fe002009-10-30 18:12:20 +00002576 // Select the appropriate action.
John McCall260611a2012-06-20 06:18:46 +00002577 RewriteKind rewriteKind = RK_None;
Fariborz Jahaniane982cc02012-04-04 18:50:28 +00002578
Daniel Dunbar1d460332009-03-18 10:01:51 +00002579 if (isa<AnalyzeJobAction>(JA)) {
2580 assert(JA.getType() == types::TY_Plist && "Invalid output type.");
2581 CmdArgs.push_back("-analyze");
Ted Kremenek30660a82012-03-06 20:06:33 +00002582 } else if (isa<MigrateJobAction>(JA)) {
2583 CmdArgs.push_back("-migrate");
Daniel Dunbar1d460332009-03-18 10:01:51 +00002584 } else if (isa<PreprocessJobAction>(JA)) {
Daniel Dunbarcd8e4c42009-03-30 06:36:42 +00002585 if (Output.getType() == types::TY_Dependencies)
2586 CmdArgs.push_back("-Eonly");
Fariborz Jahanian51be73d2013-03-18 19:41:18 +00002587 else {
Daniel Dunbarcd8e4c42009-03-30 06:36:42 +00002588 CmdArgs.push_back("-E");
Fariborz Jahanian51be73d2013-03-18 19:41:18 +00002589 if (Args.hasArg(options::OPT_rewrite_objc) &&
2590 !Args.hasArg(options::OPT_g_Group))
2591 CmdArgs.push_back("-P");
2592 }
Daniel Dunbar8767cbc2010-02-03 03:07:56 +00002593 } else if (isa<AssembleJobAction>(JA)) {
2594 CmdArgs.push_back("-emit-obj");
Daniel Dunbar99298002010-05-27 06:18:05 +00002595
David Blaikie73168db2013-07-25 21:19:01 +00002596 CollectArgsForIntegratedAssembler(C, Args, CmdArgs, D);
Daniel Dunbard02bba82010-11-19 16:23:35 +00002597
2598 // Also ignore explicit -force_cpusubtype_ALL option.
2599 (void) Args.hasArg(options::OPT_force__cpusubtype__ALL);
Daniel Dunbar1d460332009-03-18 10:01:51 +00002600 } else if (isa<PrecompileJobAction>(JA)) {
Argyrios Kyrtzidise5c35372010-08-11 23:27:58 +00002601 // Use PCH if the user requested it.
Daniel Dunbar0ebd9322009-10-15 20:02:44 +00002602 bool UsePCH = D.CCCUsePCH;
Daniel Dunbar0ebd9322009-10-15 20:02:44 +00002603
Aaron Ballman761322b2012-07-31 01:21:00 +00002604 if (JA.getType() == types::TY_Nothing)
2605 CmdArgs.push_back("-fsyntax-only");
2606 else if (UsePCH)
Douglas Gregordf91ef32009-04-18 00:34:01 +00002607 CmdArgs.push_back("-emit-pch");
2608 else
2609 CmdArgs.push_back("-emit-pth");
Stephen Hines651f13c2014-04-23 16:59:28 -07002610 } else if (isa<VerifyPCHJobAction>(JA)) {
2611 CmdArgs.push_back("-verify-pch");
Daniel Dunbar1d460332009-03-18 10:01:51 +00002612 } else {
Stephen Hines0e2c34f2015-03-23 12:09:02 -07002613 assert((isa<CompileJobAction>(JA) || isa<BackendJobAction>(JA)) &&
2614 "Invalid action for clang tool.");
Daniel Dunbarc21c4852009-04-08 23:54:23 +00002615
Daniel Dunbar1d460332009-03-18 10:01:51 +00002616 if (JA.getType() == types::TY_Nothing) {
2617 CmdArgs.push_back("-fsyntax-only");
Daniel Dunbar6c6424b2010-06-07 23:28:45 +00002618 } else if (JA.getType() == types::TY_LLVM_IR ||
2619 JA.getType() == types::TY_LTO_IR) {
Daniel Dunbar1d460332009-03-18 10:01:51 +00002620 CmdArgs.push_back("-emit-llvm");
Daniel Dunbar6c6424b2010-06-07 23:28:45 +00002621 } else if (JA.getType() == types::TY_LLVM_BC ||
2622 JA.getType() == types::TY_LTO_BC) {
Daniel Dunbar1d460332009-03-18 10:01:51 +00002623 CmdArgs.push_back("-emit-llvm-bc");
2624 } else if (JA.getType() == types::TY_PP_Asm) {
Daniel Dunbare3b8d072009-09-17 00:47:53 +00002625 CmdArgs.push_back("-S");
Daniel Dunbar5915fbf2009-09-01 16:57:46 +00002626 } else if (JA.getType() == types::TY_AST) {
2627 CmdArgs.push_back("-emit-pch");
Douglas Gregorc544ba02013-03-27 16:47:18 +00002628 } else if (JA.getType() == types::TY_ModuleFile) {
2629 CmdArgs.push_back("-module-file-info");
Daniel Dunbar64952502010-02-11 03:16:21 +00002630 } else if (JA.getType() == types::TY_RewrittenObjC) {
2631 CmdArgs.push_back("-rewrite-objc");
John McCall260611a2012-06-20 06:18:46 +00002632 rewriteKind = RK_NonFragile;
Fariborz Jahanian582b3952012-04-02 15:59:19 +00002633 } else if (JA.getType() == types::TY_RewrittenLegacyObjC) {
2634 CmdArgs.push_back("-rewrite-objc");
John McCall260611a2012-06-20 06:18:46 +00002635 rewriteKind = RK_Fragile;
Daniel Dunbar64952502010-02-11 03:16:21 +00002636 } else {
2637 assert(JA.getType() == types::TY_PP_Asm &&
2638 "Unexpected output type!");
Daniel Dunbar1d460332009-03-18 10:01:51 +00002639 }
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00002640 }
2641
Stephen Hinesef822542014-07-21 00:47:37 -07002642 // We normally speed up the clang process a bit by skipping destructors at
2643 // exit, but when we're generating diagnostics we can rely on some of the
2644 // cleanup.
2645 if (!C.isForDiagnostics())
2646 CmdArgs.push_back("-disable-free");
Daniel Dunbar1d460332009-03-18 10:01:51 +00002647
John McCallb689afb2010-02-13 03:50:24 +00002648 // Disable the verification pass in -asserts builds.
2649#ifdef NDEBUG
2650 CmdArgs.push_back("-disable-llvm-verifier");
2651#endif
2652
Daniel Dunbarc9abc042009-04-08 05:11:16 +00002653 // Set the main file name, so that debug info works even with
2654 // -save-temps.
2655 CmdArgs.push_back("-main-file-name");
Bob Wilson66b8a662012-11-23 06:14:39 +00002656 CmdArgs.push_back(getBaseInputName(Args, Inputs));
Daniel Dunbarc9abc042009-04-08 05:11:16 +00002657
Daniel Dunbar3bbc7532009-04-08 18:03:55 +00002658 // Some flags which affect the language (via preprocessor
Bob Wilson66b8a662012-11-23 06:14:39 +00002659 // defines).
Daniel Dunbar3bbc7532009-04-08 18:03:55 +00002660 if (Args.hasArg(options::OPT_static))
2661 CmdArgs.push_back("-static-define");
2662
Daniel Dunbar1d460332009-03-18 10:01:51 +00002663 if (isa<AnalyzeJobAction>(JA)) {
Ted Kremenekb8bb3e72009-09-25 05:55:59 +00002664 // Enable region store model by default.
2665 CmdArgs.push_back("-analyzer-store=region");
2666
Ted Kremenekb40d06d2009-12-07 22:26:14 +00002667 // Treat blocks as analysis entry points.
2668 CmdArgs.push_back("-analyzer-opt-analyze-nested-blocks");
2669
Ted Kremenek51885072011-03-24 00:28:47 +00002670 CmdArgs.push_back("-analyzer-eagerly-assume");
2671
Daniel Dunbar1d460332009-03-18 10:01:51 +00002672 // Add default argument set.
Daniel Dunbard8fc0f22009-05-22 00:38:15 +00002673 if (!Args.hasArg(options::OPT__analyzer_no_default_checks)) {
Argyrios Kyrtzidis027a6ab2011-02-15 07:42:33 +00002674 CmdArgs.push_back("-analyzer-checker=core");
Ted Kremenek51885072011-03-24 00:28:47 +00002675
Stephen Hines651f13c2014-04-23 16:59:28 -07002676 if (!IsWindowsMSVC)
Argyrios Kyrtzidis027a6ab2011-02-15 07:42:33 +00002677 CmdArgs.push_back("-analyzer-checker=unix");
Ted Kremenek51885072011-03-24 00:28:47 +00002678
Argyrios Kyrtzidis027a6ab2011-02-15 07:42:33 +00002679 if (getToolChain().getTriple().getVendor() == llvm::Triple::Apple)
Ted Kremenek51885072011-03-24 00:28:47 +00002680 CmdArgs.push_back("-analyzer-checker=osx");
Ted Kremeneka8180e52012-01-20 06:00:17 +00002681
2682 CmdArgs.push_back("-analyzer-checker=deadcode");
Ted Kremenek8dc05062012-01-26 02:27:38 +00002683
Jordan Rosee449edc2013-04-05 17:55:07 +00002684 if (types::isCXX(Inputs[0].getType()))
2685 CmdArgs.push_back("-analyzer-checker=cplusplus");
2686
Stephen Hines6bcf27b2014-05-29 04:14:42 -07002687 // Enable the following experimental checkers for testing.
2688 CmdArgs.push_back(
2689 "-analyzer-checker=security.insecureAPI.UncheckedReturn");
Ted Kremenek8dc05062012-01-26 02:27:38 +00002690 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.getpw");
2691 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.gets");
2692 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.mktemp");
2693 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.mkstemp");
2694 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.vfork");
Daniel Dunbard8fc0f22009-05-22 00:38:15 +00002695 }
Daniel Dunbarc21c4852009-04-08 23:54:23 +00002696
Daniel Dunbard8fc0f22009-05-22 00:38:15 +00002697 // Set the output format. The default is plist, for (lame) historical
2698 // reasons.
2699 CmdArgs.push_back("-analyzer-output");
2700 if (Arg *A = Args.getLastArg(options::OPT__analyzer_output))
Richard Smith1d489cf2012-11-01 04:30:05 +00002701 CmdArgs.push_back(A->getValue());
Daniel Dunbard8fc0f22009-05-22 00:38:15 +00002702 else
2703 CmdArgs.push_back("plist");
Daniel Dunbar1d460332009-03-18 10:01:51 +00002704
Ted Kremenek0647a7b2010-03-22 22:32:05 +00002705 // Disable the presentation of standard compiler warnings when
2706 // using --analyze. We only want to show static analyzer diagnostics
2707 // or frontend errors.
2708 CmdArgs.push_back("-w");
2709
Daniel Dunbar1d460332009-03-18 10:01:51 +00002710 // Add -Xanalyzer arguments when running as analyzer.
2711 Args.AddAllArgValues(CmdArgs, options::OPT_Xanalyzer);
Mike Stump1eb44332009-09-09 15:08:12 +00002712 }
2713
Daniel Dunbare2fd6642009-09-10 01:21:12 +00002714 CheckCodeGenerationOptions(D, Args);
2715
Peter Collingbourne52ca70d2013-04-09 04:35:11 +00002716 bool PIE = getToolChain().isPIEDefault();
2717 bool PIC = PIE || getToolChain().isPICDefault();
Chandler Carruth7ce816a2012-11-19 03:52:03 +00002718 bool IsPICLevelTwo = PIC;
Peter Collingbourne52ca70d2013-04-09 04:35:11 +00002719
Stephen Hines651f13c2014-04-23 16:59:28 -07002720 // Android-specific defaults for PIC/PIE
2721 if (getToolChain().getTriple().getEnvironment() == llvm::Triple::Android) {
2722 switch (getToolChain().getTriple().getArch()) {
2723 case llvm::Triple::arm:
2724 case llvm::Triple::armeb:
2725 case llvm::Triple::thumb:
2726 case llvm::Triple::thumbeb:
Stephen Hines6bcf27b2014-05-29 04:14:42 -07002727 case llvm::Triple::aarch64:
Stephen Hines651f13c2014-04-23 16:59:28 -07002728 case llvm::Triple::mips:
2729 case llvm::Triple::mipsel:
2730 case llvm::Triple::mips64:
2731 case llvm::Triple::mips64el:
2732 PIC = true; // "-fpic"
2733 break;
2734
2735 case llvm::Triple::x86:
2736 case llvm::Triple::x86_64:
2737 PIC = true; // "-fPIC"
2738 IsPICLevelTwo = true;
2739 break;
2740
2741 default:
2742 break;
2743 }
2744 }
2745
Stephen Hinesef822542014-07-21 00:47:37 -07002746 // OpenBSD-specific defaults for PIE
2747 if (getToolChain().getTriple().getOS() == llvm::Triple::OpenBSD) {
2748 switch (getToolChain().getTriple().getArch()) {
2749 case llvm::Triple::mips64:
2750 case llvm::Triple::mips64el:
2751 case llvm::Triple::sparc:
2752 case llvm::Triple::x86:
2753 case llvm::Triple::x86_64:
2754 IsPICLevelTwo = false; // "-fpie"
2755 break;
2756
2757 case llvm::Triple::ppc:
2758 case llvm::Triple::sparcv9:
2759 IsPICLevelTwo = true; // "-fPIE"
2760 break;
2761
2762 default:
2763 break;
2764 }
2765 }
2766
Alexey Samsonovdb68e5a2013-04-09 12:28:19 +00002767 // For the PIC and PIE flag options, this logic is different from the
2768 // legacy logic in very old versions of GCC, as that logic was just
2769 // a bug no one had ever fixed. This logic is both more rational and
2770 // consistent with GCC's new logic now that the bugs are fixed. The last
2771 // argument relating to either PIC or PIE wins, and no other argument is
2772 // used. If the last argument is any flavor of the '-fno-...' arguments,
2773 // both PIC and PIE are disabled. Any PIE option implicitly enables PIC
2774 // at the same level.
2775 Arg *LastPICArg =Args.getLastArg(options::OPT_fPIC, options::OPT_fno_PIC,
2776 options::OPT_fpic, options::OPT_fno_pic,
2777 options::OPT_fPIE, options::OPT_fno_PIE,
2778 options::OPT_fpie, options::OPT_fno_pie);
Chandler Carruth7ce816a2012-11-19 03:52:03 +00002779 // Check whether the tool chain trumps the PIC-ness decision. If the PIC-ness
2780 // is forced, then neither PIC nor PIE flags will have no effect.
Peter Collingbourne52ca70d2013-04-09 04:35:11 +00002781 if (!getToolChain().isPICDefaultForced()) {
Alexey Samsonovdb68e5a2013-04-09 12:28:19 +00002782 if (LastPICArg) {
2783 Option O = LastPICArg->getOption();
Peter Collingbourne52ca70d2013-04-09 04:35:11 +00002784 if (O.matches(options::OPT_fPIC) || O.matches(options::OPT_fpic) ||
2785 O.matches(options::OPT_fPIE) || O.matches(options::OPT_fpie)) {
2786 PIE = O.matches(options::OPT_fPIE) || O.matches(options::OPT_fpie);
2787 PIC = PIE || O.matches(options::OPT_fPIC) ||
2788 O.matches(options::OPT_fpic);
2789 IsPICLevelTwo = O.matches(options::OPT_fPIE) ||
2790 O.matches(options::OPT_fPIC);
2791 } else {
2792 PIE = PIC = false;
2793 }
2794 }
Chandler Carruth5e219cf2012-04-08 16:40:35 +00002795 }
Chandler Carruth7ce816a2012-11-19 03:52:03 +00002796
Nick Lewyckyd4705682013-10-11 03:33:53 +00002797 // Introduce a Darwin-specific hack. If the default is PIC but the flags
Chandler Carruth7ce816a2012-11-19 03:52:03 +00002798 // specified while enabling PIC enabled level 1 PIC, just force it back to
2799 // level 2 PIC instead. This matches the behavior of Darwin GCC (based on my
2800 // informal testing).
2801 if (PIC && getToolChain().getTriple().isOSDarwin())
2802 IsPICLevelTwo |= getToolChain().isPICDefault();
2803
Chandler Carruth5e219cf2012-04-08 16:40:35 +00002804 // Note that these flags are trump-cards. Regardless of the order w.r.t. the
2805 // PIC or PIE options above, if these show up, PIC is disabled.
Daniel Dunbar7a0c0642012-10-15 22:23:53 +00002806 llvm::Triple Triple(TripleStr);
Stephen Hines0e2c34f2015-03-23 12:09:02 -07002807 if (KernelOrKext && (!Triple.isiOS() || Triple.isOSVersionLT(6)))
Chandler Carruth7ce816a2012-11-19 03:52:03 +00002808 PIC = PIE = false;
Simon Atanasyanc0e83642013-10-04 11:46:54 +00002809 if (Args.hasArg(options::OPT_static))
Chandler Carruth7ce816a2012-11-19 03:52:03 +00002810 PIC = PIE = false;
Chandler Carruth5e219cf2012-04-08 16:40:35 +00002811
Chandler Carruth7ce816a2012-11-19 03:52:03 +00002812 if (Arg *A = Args.getLastArg(options::OPT_mdynamic_no_pic)) {
2813 // This is a very special mode. It trumps the other modes, almost no one
2814 // uses it, and it isn't even valid on any OS but Darwin.
2815 if (!getToolChain().getTriple().isOSDarwin())
2816 D.Diag(diag::err_drv_unsupported_opt_for_target)
2817 << A->getSpelling() << getToolChain().getTriple().str();
2818
2819 // FIXME: Warn when this flag trumps some other PIC or PIE flag.
2820
Daniel Dunbarf219e7c2009-11-29 07:18:39 +00002821 CmdArgs.push_back("-mrelocation-model");
Chandler Carruth7ce816a2012-11-19 03:52:03 +00002822 CmdArgs.push_back("dynamic-no-pic");
Daniel Dunbarbc85be82009-04-29 18:32:25 +00002823
Chandler Carruth7ce816a2012-11-19 03:52:03 +00002824 // Only a forced PIC mode can cause the actual compile to have PIC defines
2825 // etc., no flags are sufficient. This behavior was selected to closely
2826 // match that of llvm-gcc and Apple GCC before that.
2827 if (getToolChain().isPICDefault() && getToolChain().isPICDefaultForced()) {
2828 CmdArgs.push_back("-pic-level");
2829 CmdArgs.push_back("2");
2830 }
2831 } else {
2832 // Currently, LLVM only knows about PIC vs. static; the PIE differences are
2833 // handled in Clang's IRGen by the -pie-level flag.
2834 CmdArgs.push_back("-mrelocation-model");
2835 CmdArgs.push_back(PIC ? "pic" : "static");
2836
2837 if (PIC) {
2838 CmdArgs.push_back("-pic-level");
2839 CmdArgs.push_back(IsPICLevelTwo ? "2" : "1");
2840 if (PIE) {
2841 CmdArgs.push_back("-pie-level");
2842 CmdArgs.push_back(IsPICLevelTwo ? "2" : "1");
2843 }
2844 }
Daniel Dunbarbc85be82009-04-29 18:32:25 +00002845 }
Chandler Carruth5e219cf2012-04-08 16:40:35 +00002846
Stephen Hines176edba2014-12-01 14:53:08 -08002847 CmdArgs.push_back("-mthread-model");
2848 if (Arg *A = Args.getLastArg(options::OPT_mthread_model))
2849 CmdArgs.push_back(A->getValue());
2850 else
2851 CmdArgs.push_back(Args.MakeArgString(getToolChain().getThreadModel()));
2852
Tanya Lattner59876c22009-11-04 01:18:09 +00002853 if (!Args.hasFlag(options::OPT_fmerge_all_constants,
2854 options::OPT_fno_merge_all_constants))
Chris Lattnerf44a1a02011-04-08 18:06:54 +00002855 CmdArgs.push_back("-fno-merge-all-constants");
Daniel Dunbar6bea73b2009-09-16 06:17:29 +00002856
Daniel Dunbarf219e7c2009-11-29 07:18:39 +00002857 // LLVM Code Generator Options.
2858
Stephen Hines0e2c34f2015-03-23 12:09:02 -07002859 if (Args.hasArg(options::OPT_frewrite_map_file) ||
2860 Args.hasArg(options::OPT_frewrite_map_file_EQ)) {
2861 for (arg_iterator
2862 MFI = Args.filtered_begin(options::OPT_frewrite_map_file,
2863 options::OPT_frewrite_map_file_EQ),
2864 MFE = Args.filtered_end();
2865 MFI != MFE; ++MFI) {
2866 CmdArgs.push_back("-frewrite-map-file");
2867 CmdArgs.push_back((*MFI)->getValue());
2868 (*MFI)->claim();
2869 }
2870 }
2871
Stephen Hinesef822542014-07-21 00:47:37 -07002872 if (Arg *A = Args.getLastArg(options::OPT_Wframe_larger_than_EQ)) {
2873 StringRef v = A->getValue();
2874 CmdArgs.push_back("-mllvm");
2875 CmdArgs.push_back(Args.MakeArgString("-warn-stack-size=" + v));
2876 A->claim();
2877 }
2878
Daniel Dunbar17d3fea2011-02-09 17:54:19 +00002879 if (Arg *A = Args.getLastArg(options::OPT_mregparm_EQ)) {
2880 CmdArgs.push_back("-mregparm");
Richard Smith1d489cf2012-11-01 04:30:05 +00002881 CmdArgs.push_back(A->getValue());
Daniel Dunbar17d3fea2011-02-09 17:54:19 +00002882 }
2883
Nick Lewyckyfdf137b2013-06-25 01:49:44 +00002884 if (Arg *A = Args.getLastArg(options::OPT_fpcc_struct_return,
2885 options::OPT_freg_struct_return)) {
Eli Bendersky8f4269a2013-07-24 22:20:49 +00002886 if (getToolChain().getArch() != llvm::Triple::x86) {
John McCallb8b52972013-06-18 02:46:29 +00002887 D.Diag(diag::err_drv_unsupported_opt_for_target)
2888 << A->getSpelling() << getToolChain().getTriple().str();
2889 } else if (A->getOption().matches(options::OPT_fpcc_struct_return)) {
2890 CmdArgs.push_back("-fpcc-struct-return");
2891 } else {
2892 assert(A->getOption().matches(options::OPT_freg_struct_return));
2893 CmdArgs.push_back("-freg-struct-return");
2894 }
2895 }
2896
Roman Divackycfe9af22011-03-01 17:40:53 +00002897 if (Args.hasFlag(options::OPT_mrtd, options::OPT_mno_rtd, false))
2898 CmdArgs.push_back("-mrtd");
2899
Rafael Espindola6af27ec2011-12-14 21:02:23 +00002900 if (shouldUseFramePointer(Args, getToolChain().getTriple()))
Daniel Dunbarf219e7c2009-11-29 07:18:39 +00002901 CmdArgs.push_back("-mdisable-fp-elim");
2902 if (!Args.hasFlag(options::OPT_fzero_initialized_in_bss,
2903 options::OPT_fno_zero_initialized_in_bss))
2904 CmdArgs.push_back("-mno-zero-initialized-in-bss");
Chad Rosierb82e1172013-04-24 18:09:54 +00002905
2906 bool OFastEnabled = isOptimizationLevelFast(Args);
2907 // If -Ofast is the optimization level, then -fstrict-aliasing should be
2908 // enabled. This alias option is being used to simplify the hasFlag logic.
2909 OptSpecifier StrictAliasingAliasOption = OFastEnabled ? options::OPT_Ofast :
2910 options::OPT_fstrict_aliasing;
Stephen Hines6bcf27b2014-05-29 04:14:42 -07002911 // We turn strict aliasing off by default if we're in CL mode, since MSVC
2912 // doesn't do any TBAA.
2913 bool TBAAOnByDefault = !getToolChain().getDriver().IsCLMode();
Chad Rosierb82e1172013-04-24 18:09:54 +00002914 if (!Args.hasFlag(options::OPT_fstrict_aliasing, StrictAliasingAliasOption,
Stephen Hines6bcf27b2014-05-29 04:14:42 -07002915 options::OPT_fno_strict_aliasing, TBAAOnByDefault))
Dan Gohman4d5625e2010-10-14 22:36:56 +00002916 CmdArgs.push_back("-relaxed-aliasing");
Manman Ren96d6c452013-10-11 20:48:38 +00002917 if (!Args.hasFlag(options::OPT_fstruct_path_tbaa,
2918 options::OPT_fno_struct_path_tbaa))
2919 CmdArgs.push_back("-no-struct-path-tbaa");
Chandler Carruth82fe6ae2012-03-27 23:58:37 +00002920 if (Args.hasFlag(options::OPT_fstrict_enums, options::OPT_fno_strict_enums,
2921 false))
2922 CmdArgs.push_back("-fstrict-enums");
Nick Lewycky1db772b2012-01-23 08:29:12 +00002923 if (!Args.hasFlag(options::OPT_foptimize_sibling_calls,
2924 options::OPT_fno_optimize_sibling_calls))
2925 CmdArgs.push_back("-mdisable-tail-calls");
Daniel Dunbar1b718482010-05-14 22:00:22 +00002926
Eric Christopher31056272013-04-04 06:29:47 +00002927 // Handle segmented stacks.
2928 if (Args.hasArg(options::OPT_fsplit_stack))
2929 CmdArgs.push_back("-split-stacks");
Chad Rosierb82e1172013-04-24 18:09:54 +00002930
2931 // If -Ofast is the optimization level, then -ffast-math should be enabled.
2932 // This alias option is being used to simplify the getLastArg logic.
2933 OptSpecifier FastMathAliasOption = OFastEnabled ? options::OPT_Ofast :
2934 options::OPT_ffast_math;
Eric Christopher31056272013-04-04 06:29:47 +00002935
Chandler Carruthabf07a72012-01-02 14:19:45 +00002936 // Handle various floating point optimization flags, mapping them to the
2937 // appropriate LLVM code generation flags. The pattern for all of these is to
2938 // default off the codegen optimizations, and if any flag enables them and no
2939 // flag disables them after the flag enabling them, enable the codegen
2940 // optimization. This is complicated by several "umbrella" flags.
Chad Rosierb82e1172013-04-24 18:09:54 +00002941 if (Arg *A = Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
Chad Rosier80ecf5e2012-09-25 22:03:25 +00002942 options::OPT_fno_fast_math,
Chandler Carruthabf07a72012-01-02 14:19:45 +00002943 options::OPT_ffinite_math_only,
2944 options::OPT_fno_finite_math_only,
2945 options::OPT_fhonor_infinities,
2946 options::OPT_fno_honor_infinities))
Chad Rosier80ecf5e2012-09-25 22:03:25 +00002947 if (A->getOption().getID() != options::OPT_fno_fast_math &&
2948 A->getOption().getID() != options::OPT_fno_finite_math_only &&
Chandler Carruthabf07a72012-01-02 14:19:45 +00002949 A->getOption().getID() != options::OPT_fhonor_infinities)
2950 CmdArgs.push_back("-menable-no-infs");
Chad Rosierb82e1172013-04-24 18:09:54 +00002951 if (Arg *A = Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
Chad Rosier80ecf5e2012-09-25 22:03:25 +00002952 options::OPT_fno_fast_math,
Chandler Carruthabf07a72012-01-02 14:19:45 +00002953 options::OPT_ffinite_math_only,
2954 options::OPT_fno_finite_math_only,
2955 options::OPT_fhonor_nans,
2956 options::OPT_fno_honor_nans))
Chad Rosier80ecf5e2012-09-25 22:03:25 +00002957 if (A->getOption().getID() != options::OPT_fno_fast_math &&
2958 A->getOption().getID() != options::OPT_fno_finite_math_only &&
Chandler Carruthabf07a72012-01-02 14:19:45 +00002959 A->getOption().getID() != options::OPT_fhonor_nans)
2960 CmdArgs.push_back("-menable-no-nans");
2961
Benjamin Kramer769aa2d2012-05-02 14:55:48 +00002962 // -fmath-errno is the default on some platforms, e.g. BSD-derived OSes.
2963 bool MathErrno = getToolChain().IsMathErrnoDefault();
Chad Rosierb82e1172013-04-24 18:09:54 +00002964 if (Arg *A = Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
Chad Rosier80ecf5e2012-09-25 22:03:25 +00002965 options::OPT_fno_fast_math,
Chandler Carruthabf07a72012-01-02 14:19:45 +00002966 options::OPT_fmath_errno,
Chandler Carruthb69557e2013-05-18 20:47:36 +00002967 options::OPT_fno_math_errno)) {
2968 // Turning on -ffast_math (with either flag) removes the need for MathErrno.
2969 // However, turning *off* -ffast_math merely restores the toolchain default
2970 // (which may be false).
2971 if (A->getOption().getID() == options::OPT_fno_math_errno ||
2972 A->getOption().getID() == options::OPT_ffast_math ||
2973 A->getOption().getID() == options::OPT_Ofast)
2974 MathErrno = false;
2975 else if (A->getOption().getID() == options::OPT_fmath_errno)
2976 MathErrno = true;
2977 }
Chandler Carruth4f50c502012-04-26 02:10:51 +00002978 if (MathErrno)
2979 CmdArgs.push_back("-fmath-errno");
Chandler Carruthabf07a72012-01-02 14:19:45 +00002980
2981 // There are several flags which require disabling very specific
2982 // optimizations. Any of these being disabled forces us to turn off the
2983 // entire set of LLVM optimizations, so collect them through all the flag
2984 // madness.
2985 bool AssociativeMath = false;
Chad Rosierb82e1172013-04-24 18:09:54 +00002986 if (Arg *A = Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
Chad Rosier80ecf5e2012-09-25 22:03:25 +00002987 options::OPT_fno_fast_math,
Chandler Carruthabf07a72012-01-02 14:19:45 +00002988 options::OPT_funsafe_math_optimizations,
2989 options::OPT_fno_unsafe_math_optimizations,
2990 options::OPT_fassociative_math,
2991 options::OPT_fno_associative_math))
Chad Rosier80ecf5e2012-09-25 22:03:25 +00002992 if (A->getOption().getID() != options::OPT_fno_fast_math &&
2993 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruthabf07a72012-01-02 14:19:45 +00002994 A->getOption().getID() != options::OPT_fno_associative_math)
2995 AssociativeMath = true;
2996 bool ReciprocalMath = false;
Chad Rosierb82e1172013-04-24 18:09:54 +00002997 if (Arg *A = Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
Chad Rosier80ecf5e2012-09-25 22:03:25 +00002998 options::OPT_fno_fast_math,
Chandler Carruthabf07a72012-01-02 14:19:45 +00002999 options::OPT_funsafe_math_optimizations,
3000 options::OPT_fno_unsafe_math_optimizations,
3001 options::OPT_freciprocal_math,
3002 options::OPT_fno_reciprocal_math))
Chad Rosier80ecf5e2012-09-25 22:03:25 +00003003 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3004 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruthabf07a72012-01-02 14:19:45 +00003005 A->getOption().getID() != options::OPT_fno_reciprocal_math)
3006 ReciprocalMath = true;
3007 bool SignedZeros = true;
Chad Rosierb82e1172013-04-24 18:09:54 +00003008 if (Arg *A = Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
Chad Rosier80ecf5e2012-09-25 22:03:25 +00003009 options::OPT_fno_fast_math,
Chandler Carruthabf07a72012-01-02 14:19:45 +00003010 options::OPT_funsafe_math_optimizations,
3011 options::OPT_fno_unsafe_math_optimizations,
3012 options::OPT_fsigned_zeros,
3013 options::OPT_fno_signed_zeros))
Chad Rosier80ecf5e2012-09-25 22:03:25 +00003014 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3015 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruthabf07a72012-01-02 14:19:45 +00003016 A->getOption().getID() != options::OPT_fsigned_zeros)
3017 SignedZeros = false;
3018 bool TrappingMath = true;
Chad Rosierb82e1172013-04-24 18:09:54 +00003019 if (Arg *A = Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
Chad Rosier80ecf5e2012-09-25 22:03:25 +00003020 options::OPT_fno_fast_math,
Chandler Carruthabf07a72012-01-02 14:19:45 +00003021 options::OPT_funsafe_math_optimizations,
3022 options::OPT_fno_unsafe_math_optimizations,
3023 options::OPT_ftrapping_math,
3024 options::OPT_fno_trapping_math))
Chad Rosier80ecf5e2012-09-25 22:03:25 +00003025 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3026 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruthabf07a72012-01-02 14:19:45 +00003027 A->getOption().getID() != options::OPT_ftrapping_math)
3028 TrappingMath = false;
3029 if (!MathErrno && AssociativeMath && ReciprocalMath && !SignedZeros &&
3030 !TrappingMath)
3031 CmdArgs.push_back("-menable-unsafe-fp-math");
3032
Stephen Hines0e2c34f2015-03-23 12:09:02 -07003033 if (!SignedZeros)
3034 CmdArgs.push_back("-fno-signed-zeros");
Lang Hamesc9686712012-07-06 00:59:19 +00003035
3036 // Validate and pass through -fp-contract option.
Chad Rosierb82e1172013-04-24 18:09:54 +00003037 if (Arg *A = Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
Chad Rosier80ecf5e2012-09-25 22:03:25 +00003038 options::OPT_fno_fast_math,
Lang Hamesc9686712012-07-06 00:59:19 +00003039 options::OPT_ffp_contract)) {
3040 if (A->getOption().getID() == options::OPT_ffp_contract) {
Richard Smith1d489cf2012-11-01 04:30:05 +00003041 StringRef Val = A->getValue();
Lang Hamesc9686712012-07-06 00:59:19 +00003042 if (Val == "fast" || Val == "on" || Val == "off") {
3043 CmdArgs.push_back(Args.MakeArgString("-ffp-contract=" + Val));
3044 } else {
3045 D.Diag(diag::err_drv_unsupported_option_argument)
3046 << A->getOption().getName() << Val;
3047 }
Chad Rosierb82e1172013-04-24 18:09:54 +00003048 } else if (A->getOption().matches(options::OPT_ffast_math) ||
3049 (OFastEnabled && A->getOption().matches(options::OPT_Ofast))) {
Lang Hamesc9686712012-07-06 00:59:19 +00003050 // If fast-math is set then set the fp-contract mode to fast.
3051 CmdArgs.push_back(Args.MakeArgString("-ffp-contract=fast"));
3052 }
3053 }
3054
Bob Wilson455e72e2012-07-19 03:52:53 +00003055 // We separately look for the '-ffast-math' and '-ffinite-math-only' flags,
3056 // and if we find them, tell the frontend to provide the appropriate
3057 // preprocessor macros. This is distinct from enabling any optimizations as
3058 // these options induce language changes which must survive serialization
3059 // and deserialization, etc.
Chad Rosierb82e1172013-04-24 18:09:54 +00003060 if (Arg *A = Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
3061 options::OPT_fno_fast_math))
3062 if (!A->getOption().matches(options::OPT_fno_fast_math))
3063 CmdArgs.push_back("-ffast-math");
Stephen Hines6bcf27b2014-05-29 04:14:42 -07003064 if (Arg *A = Args.getLastArg(options::OPT_ffinite_math_only,
3065 options::OPT_fno_fast_math))
Chad Rosier80ecf5e2012-09-25 22:03:25 +00003066 if (A->getOption().matches(options::OPT_ffinite_math_only))
3067 CmdArgs.push_back("-ffinite-math-only");
Chandler Carruthabf07a72012-01-02 14:19:45 +00003068
Daniel Dunbar1b718482010-05-14 22:00:22 +00003069 // Decide whether to use verbose asm. Verbose assembly is the default on
3070 // toolchains which have the integrated assembler on by default.
Stephen Hines651f13c2014-04-23 16:59:28 -07003071 bool IsIntegratedAssemblerDefault =
3072 getToolChain().IsIntegratedAssemblerDefault();
Daniel Dunbar1b718482010-05-14 22:00:22 +00003073 if (Args.hasFlag(options::OPT_fverbose_asm, options::OPT_fno_verbose_asm,
Stephen Hines651f13c2014-04-23 16:59:28 -07003074 IsIntegratedAssemblerDefault) ||
Daniel Dunbar1b718482010-05-14 22:00:22 +00003075 Args.hasArg(options::OPT_dA))
Daniel Dunbarf219e7c2009-11-29 07:18:39 +00003076 CmdArgs.push_back("-masm-verbose");
Daniel Dunbar1b718482010-05-14 22:00:22 +00003077
Stephen Hines651f13c2014-04-23 16:59:28 -07003078 if (!Args.hasFlag(options::OPT_fintegrated_as, options::OPT_fno_integrated_as,
3079 IsIntegratedAssemblerDefault))
3080 CmdArgs.push_back("-no-integrated-as");
3081
Daniel Dunbarf219e7c2009-11-29 07:18:39 +00003082 if (Args.hasArg(options::OPT_fdebug_pass_structure)) {
3083 CmdArgs.push_back("-mdebug-pass");
3084 CmdArgs.push_back("Structure");
3085 }
3086 if (Args.hasArg(options::OPT_fdebug_pass_arguments)) {
3087 CmdArgs.push_back("-mdebug-pass");
3088 CmdArgs.push_back("Arguments");
3089 }
3090
John McCalld0c2ec42010-02-19 02:45:38 +00003091 // Enable -mconstructor-aliases except on darwin, where we have to
3092 // work around a linker bug; see <rdar://problem/7651567>.
Bob Wilson905c45f2011-10-14 05:03:44 +00003093 if (!getToolChain().getTriple().isOSDarwin())
John McCalld0c2ec42010-02-19 02:45:38 +00003094 CmdArgs.push_back("-mconstructor-aliases");
NAKAMURA Takumi125b4cb2011-02-17 08:50:50 +00003095
John McCall32096692011-03-18 02:56:14 +00003096 // Darwin's kernel doesn't support guard variables; just die if we
3097 // try to use them.
Bob Wilson905c45f2011-10-14 05:03:44 +00003098 if (KernelOrKext && getToolChain().getTriple().isOSDarwin())
John McCall32096692011-03-18 02:56:14 +00003099 CmdArgs.push_back("-fforbid-guard-variables");
3100
Douglas Gregor6f755502011-02-01 15:15:22 +00003101 if (Args.hasArg(options::OPT_mms_bitfields)) {
3102 CmdArgs.push_back("-mms-bitfields");
3103 }
John McCalld0c2ec42010-02-19 02:45:38 +00003104
Daniel Dunbar6bea73b2009-09-16 06:17:29 +00003105 // This is a coarse approximation of what llvm-gcc actually does, both
3106 // -fasynchronous-unwind-tables and -fnon-call-exceptions interact in more
3107 // complicated ways.
3108 bool AsynchronousUnwindTables =
Stephen Hines651f13c2014-04-23 16:59:28 -07003109 Args.hasFlag(options::OPT_fasynchronous_unwind_tables,
3110 options::OPT_fno_asynchronous_unwind_tables,
3111 (getToolChain().IsUnwindTablesDefault() ||
3112 getToolChain().getSanitizerArgs().needsUnwindTables()) &&
3113 !KernelOrKext);
Daniel Dunbar6bea73b2009-09-16 06:17:29 +00003114 if (Args.hasFlag(options::OPT_funwind_tables, options::OPT_fno_unwind_tables,
3115 AsynchronousUnwindTables))
Daniel Dunbarf219e7c2009-11-29 07:18:39 +00003116 CmdArgs.push_back("-munwind-tables");
3117
Chandler Carrutha6b25812012-11-21 23:40:23 +00003118 getToolChain().addClangTargetOptions(Args, CmdArgs);
Rafael Espindola8af669f2012-06-19 01:26:10 +00003119
Daniel Dunbarf219e7c2009-11-29 07:18:39 +00003120 if (Arg *A = Args.getLastArg(options::OPT_flimited_precision_EQ)) {
3121 CmdArgs.push_back("-mlimit-float-precision");
Richard Smith1d489cf2012-11-01 04:30:05 +00003122 CmdArgs.push_back(A->getValue());
Daniel Dunbarf219e7c2009-11-29 07:18:39 +00003123 }
Daniel Dunbarbc85be82009-04-29 18:32:25 +00003124
Daniel Dunbar868bd0a2009-05-06 03:16:41 +00003125 // FIXME: Handle -mtune=.
3126 (void) Args.hasArg(options::OPT_mtune_EQ);
Daniel Dunbarbc85be82009-04-29 18:32:25 +00003127
Benjamin Kramer8e9ef0d2009-08-05 14:30:52 +00003128 if (Arg *A = Args.getLastArg(options::OPT_mcmodel_EQ)) {
Daniel Dunbarf219e7c2009-11-29 07:18:39 +00003129 CmdArgs.push_back("-mcode-model");
Richard Smith1d489cf2012-11-01 04:30:05 +00003130 CmdArgs.push_back(A->getValue());
Benjamin Kramer8e9ef0d2009-08-05 14:30:52 +00003131 }
3132
Rafael Espindolab330e402013-08-20 22:12:08 +00003133 // Add the target cpu
3134 std::string ETripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
3135 llvm::Triple ETriple(ETripleStr);
3136 std::string CPU = getCPUName(Args, ETriple);
3137 if (!CPU.empty()) {
3138 CmdArgs.push_back("-target-cpu");
3139 CmdArgs.push_back(Args.MakeArgString(CPU));
3140 }
3141
Rafael Espindola5389b842013-08-21 21:59:03 +00003142 if (const Arg *A = Args.getLastArg(options::OPT_mfpmath_EQ)) {
3143 CmdArgs.push_back("-mfpmath");
3144 CmdArgs.push_back(A->getValue());
3145 }
3146
Rafael Espindola146dbbf2013-08-21 16:39:20 +00003147 // Add the target features
Stephen Hines651f13c2014-04-23 16:59:28 -07003148 getTargetFeatures(D, ETriple, Args, CmdArgs, false);
Rafael Espindola146dbbf2013-08-21 16:39:20 +00003149
Rafael Espindolab330e402013-08-20 22:12:08 +00003150 // Add target specific flags.
Eli Bendersky8f4269a2013-07-24 22:20:49 +00003151 switch(getToolChain().getArch()) {
Daniel Dunbar6acda162009-09-09 22:33:08 +00003152 default:
3153 break;
Daniel Dunbar868bd0a2009-05-06 03:16:41 +00003154
Daniel Dunbarb163ef72009-09-10 04:57:17 +00003155 case llvm::Triple::arm:
Stephen Hines651f13c2014-04-23 16:59:28 -07003156 case llvm::Triple::armeb:
Daniel Dunbarb163ef72009-09-10 04:57:17 +00003157 case llvm::Triple::thumb:
Stephen Hines651f13c2014-04-23 16:59:28 -07003158 case llvm::Triple::thumbeb:
Daniel Dunbarfa41d692011-03-17 17:10:06 +00003159 AddARMTargetArgs(Args, CmdArgs, KernelOrKext);
Daniel Dunbarb163ef72009-09-10 04:57:17 +00003160 break;
3161
Stephen Hines6bcf27b2014-05-29 04:14:42 -07003162 case llvm::Triple::aarch64:
3163 case llvm::Triple::aarch64_be:
Stephen Hines6bcf27b2014-05-29 04:14:42 -07003164 AddAArch64TargetArgs(Args, CmdArgs);
Stephen Hines651f13c2014-04-23 16:59:28 -07003165 break;
3166
Eric Christophered734732010-03-02 02:41:08 +00003167 case llvm::Triple::mips:
3168 case llvm::Triple::mipsel:
Akira Hatanaka7ec02582011-09-21 02:13:07 +00003169 case llvm::Triple::mips64:
3170 case llvm::Triple::mips64el:
Eric Christophered734732010-03-02 02:41:08 +00003171 AddMIPSTargetArgs(Args, CmdArgs);
3172 break;
3173
Stephen Hines176edba2014-12-01 14:53:08 -08003174 case llvm::Triple::ppc:
3175 case llvm::Triple::ppc64:
3176 case llvm::Triple::ppc64le:
3177 AddPPCTargetArgs(Args, CmdArgs);
3178 break;
3179
Bruno Cardoso Lopes9284d212010-11-09 17:21:19 +00003180 case llvm::Triple::sparc:
Stephen Hines176edba2014-12-01 14:53:08 -08003181 case llvm::Triple::sparcv9:
Bruno Cardoso Lopes9284d212010-11-09 17:21:19 +00003182 AddSparcTargetArgs(Args, CmdArgs);
3183 break;
3184
Daniel Dunbar6acda162009-09-09 22:33:08 +00003185 case llvm::Triple::x86:
3186 case llvm::Triple::x86_64:
3187 AddX86TargetArgs(Args, CmdArgs);
3188 break;
Tony Linthicum96319392011-12-12 21:14:55 +00003189
3190 case llvm::Triple::hexagon:
3191 AddHexagonTargetArgs(Args, CmdArgs);
3192 break;
Daniel Dunbarbc85be82009-04-29 18:32:25 +00003193 }
3194
Hans Wennborgb3574792013-08-08 00:17:41 +00003195 // Add clang-cl arguments.
3196 if (getToolChain().getDriver().IsCLMode())
3197 AddClangCLArgs(Args, CmdArgs);
3198
Daniel Dunbarc176bc62010-08-11 23:07:47 +00003199 // Pass the linker version in use.
3200 if (Arg *A = Args.getLastArg(options::OPT_mlinker_version_EQ)) {
3201 CmdArgs.push_back("-target-linker-version");
Richard Smith1d489cf2012-11-01 04:30:05 +00003202 CmdArgs.push_back(A->getValue());
Daniel Dunbarc176bc62010-08-11 23:07:47 +00003203 }
3204
Eric Christopherd3e22df2013-04-03 01:58:53 +00003205 if (!shouldUseLeafFramePointer(Args, getToolChain().getTriple()))
Daniel Dunbar1ad66482010-07-01 01:31:45 +00003206 CmdArgs.push_back("-momit-leaf-frame-pointer");
3207
Daniel Dunbarb30575c2010-05-12 18:19:58 +00003208 // Explicitly error on some things we know we don't support and can't just
3209 // ignore.
3210 types::ID InputType = Inputs[0].getType();
Daniel Dunbare94db472010-09-24 19:39:37 +00003211 if (!Args.hasArg(options::OPT_fallow_unsupported)) {
3212 Arg *Unsupported;
Daniel Dunbare94db472010-09-24 19:39:37 +00003213 if (types::isCXX(InputType) &&
Bob Wilson905c45f2011-10-14 05:03:44 +00003214 getToolChain().getTriple().isOSDarwin() &&
Eli Bendersky8f4269a2013-07-24 22:20:49 +00003215 getToolChain().getArch() == llvm::Triple::x86) {
Bob Wilsona544aee2011-08-13 23:48:55 +00003216 if ((Unsupported = Args.getLastArg(options::OPT_fapple_kext)) ||
3217 (Unsupported = Args.getLastArg(options::OPT_mkernel)))
Chris Lattner5f9e2722011-07-23 10:55:15 +00003218 D.Diag(diag::err_drv_clang_unsupported_opt_cxx_darwin_i386)
Daniel Dunbare94db472010-09-24 19:39:37 +00003219 << Unsupported->getOption().getName();
3220 }
Daniel Dunbarb30575c2010-05-12 18:19:58 +00003221 }
3222
Daniel Dunbar1d460332009-03-18 10:01:51 +00003223 Args.AddAllArgs(CmdArgs, options::OPT_v);
Daniel Dunbarf7c16d92010-08-24 22:44:13 +00003224 Args.AddLastArg(CmdArgs, options::OPT_H);
Chad Rosier2b819102011-08-02 17:58:04 +00003225 if (D.CCPrintHeaders && !D.CCGenDiagnostics) {
Daniel Dunbar322c29f2011-02-02 21:11:35 +00003226 CmdArgs.push_back("-header-include-file");
3227 CmdArgs.push_back(D.CCPrintHeadersFilename ?
3228 D.CCPrintHeadersFilename : "-");
3229 }
Daniel Dunbar1d460332009-03-18 10:01:51 +00003230 Args.AddLastArg(CmdArgs, options::OPT_P);
Mike Stump1eb44332009-09-09 15:08:12 +00003231 Args.AddLastArg(CmdArgs, options::OPT_print_ivar_layout);
Daniel Dunbar1d460332009-03-18 10:01:51 +00003232
Chad Rosier2b819102011-08-02 17:58:04 +00003233 if (D.CCLogDiagnostics && !D.CCGenDiagnostics) {
Daniel Dunbarc8a22b02011-04-07 18:01:20 +00003234 CmdArgs.push_back("-diagnostic-log-file");
3235 CmdArgs.push_back(D.CCLogDiagnosticsFilename ?
3236 D.CCLogDiagnosticsFilename : "-");
3237 }
3238
Stephen Hines651f13c2014-04-23 16:59:28 -07003239 // Use the last option from "-g" group. "-gline-tables-only" and "-gdwarf-x"
3240 // are preserved, all other debug options are substituted with "-g".
Rafael Espindola18f36d92010-03-07 04:46:18 +00003241 Args.ClaimAllArgs(options::OPT_g_Group);
Alexey Samsonova9cd83b2012-05-29 08:10:34 +00003242 if (Arg *A = Args.getLastArg(options::OPT_g_Group)) {
Stephen Hines176edba2014-12-01 14:53:08 -08003243 if (A->getOption().matches(options::OPT_gline_tables_only) ||
3244 A->getOption().matches(options::OPT_g1)) {
Stephen Hines651f13c2014-04-23 16:59:28 -07003245 // FIXME: we should support specifying dwarf version with
3246 // -gline-tables-only.
Alexey Samsonova9cd83b2012-05-29 08:10:34 +00003247 CmdArgs.push_back("-gline-tables-only");
Stephen Hines176edba2014-12-01 14:53:08 -08003248 // Default is dwarf-2 for Darwin, OpenBSD, FreeBSD and Solaris.
Stephen Hinesef822542014-07-21 00:47:37 -07003249 const llvm::Triple &Triple = getToolChain().getTriple();
3250 if (Triple.isOSDarwin() || Triple.getOS() == llvm::Triple::OpenBSD ||
Stephen Hines176edba2014-12-01 14:53:08 -08003251 Triple.getOS() == llvm::Triple::FreeBSD ||
3252 Triple.getOS() == llvm::Triple::Solaris)
Stephen Hines651f13c2014-04-23 16:59:28 -07003253 CmdArgs.push_back("-gdwarf-2");
3254 } else if (A->getOption().matches(options::OPT_gdwarf_2))
Manman Renfc0f91c2013-06-19 01:46:49 +00003255 CmdArgs.push_back("-gdwarf-2");
3256 else if (A->getOption().matches(options::OPT_gdwarf_3))
3257 CmdArgs.push_back("-gdwarf-3");
3258 else if (A->getOption().matches(options::OPT_gdwarf_4))
3259 CmdArgs.push_back("-gdwarf-4");
Eric Christopherc706c8e2013-02-05 07:29:57 +00003260 else if (!A->getOption().matches(options::OPT_g0) &&
Manman Ren8ed38d82013-07-02 23:15:25 +00003261 !A->getOption().matches(options::OPT_ggdb0)) {
Stephen Hines176edba2014-12-01 14:53:08 -08003262 // Default is dwarf-2 for Darwin, OpenBSD, FreeBSD and Solaris.
Stephen Hinesef822542014-07-21 00:47:37 -07003263 const llvm::Triple &Triple = getToolChain().getTriple();
3264 if (Triple.isOSDarwin() || Triple.getOS() == llvm::Triple::OpenBSD ||
Stephen Hines176edba2014-12-01 14:53:08 -08003265 Triple.getOS() == llvm::Triple::FreeBSD ||
3266 Triple.getOS() == llvm::Triple::Solaris)
Manman Ren8ed38d82013-07-02 23:15:25 +00003267 CmdArgs.push_back("-gdwarf-2");
3268 else
3269 CmdArgs.push_back("-g");
3270 }
Alexey Samsonova9cd83b2012-05-29 08:10:34 +00003271 }
Daniel Dunbar1d460332009-03-18 10:01:51 +00003272
Alexey Samsonov7f326072012-06-21 08:22:39 +00003273 // We ignore flags -gstrict-dwarf and -grecord-gcc-switches for now.
3274 Args.ClaimAllArgs(options::OPT_g_flags_Group);
Stephen Hines176edba2014-12-01 14:53:08 -08003275 if (Args.hasFlag(options::OPT_gcolumn_info, options::OPT_gno_column_info,
3276 /*Default*/ true))
Eric Christopherda3301e2012-10-18 21:52:18 +00003277 CmdArgs.push_back("-dwarf-column-info");
Alexey Samsonov7f326072012-06-21 08:22:39 +00003278
Eric Christopher0f43a6d2013-09-13 22:37:55 +00003279 // FIXME: Move backend command line options to the module.
Eric Christopherc706c8e2013-02-05 07:29:57 +00003280 // -gsplit-dwarf should turn on -g and enable the backend dwarf
3281 // splitting and extraction.
Eric Christopherf870e122013-02-21 22:35:05 +00003282 // FIXME: Currently only works on Linux.
Cameron Esfahani57b1da12013-09-14 01:09:11 +00003283 if (getToolChain().getTriple().isOSLinux() &&
Eric Christopherf870e122013-02-21 22:35:05 +00003284 Args.hasArg(options::OPT_gsplit_dwarf)) {
Eric Christopherc706c8e2013-02-05 07:29:57 +00003285 CmdArgs.push_back("-g");
3286 CmdArgs.push_back("-backend-option");
3287 CmdArgs.push_back("-split-dwarf=Enable");
3288 }
3289
Eric Christopher0f43a6d2013-09-13 22:37:55 +00003290 // -ggnu-pubnames turns on gnu style pubnames in the backend.
3291 if (Args.hasArg(options::OPT_ggnu_pubnames)) {
3292 CmdArgs.push_back("-backend-option");
3293 CmdArgs.push_back("-generate-gnu-dwarf-pub-sections");
3294 }
Eric Christopher3e8ac1b2013-06-18 00:03:50 +00003295
Stephen Hines651f13c2014-04-23 16:59:28 -07003296 // -gdwarf-aranges turns on the emission of the aranges section in the
3297 // backend.
3298 if (Args.hasArg(options::OPT_gdwarf_aranges)) {
3299 CmdArgs.push_back("-backend-option");
3300 CmdArgs.push_back("-generate-arange-section");
3301 }
Eric Christopher3e8ac1b2013-06-18 00:03:50 +00003302
Stephen Hines651f13c2014-04-23 16:59:28 -07003303 if (Args.hasFlag(options::OPT_fdebug_types_section,
3304 options::OPT_fno_debug_types_section, false)) {
3305 CmdArgs.push_back("-backend-option");
3306 CmdArgs.push_back("-generate-type-units");
3307 }
3308
3309 if (Args.hasFlag(options::OPT_ffunction_sections,
3310 options::OPT_fno_function_sections, false)) {
3311 CmdArgs.push_back("-ffunction-sections");
3312 }
3313
3314 if (Args.hasFlag(options::OPT_fdata_sections,
3315 options::OPT_fno_data_sections, false)) {
3316 CmdArgs.push_back("-fdata-sections");
3317 }
Rafael Espindola9cf933a2010-05-06 21:06:04 +00003318
Stephen Hines0e2c34f2015-03-23 12:09:02 -07003319 if (!Args.hasFlag(options::OPT_funique_section_names,
3320 options::OPT_fno_unique_section_names, true))
3321 CmdArgs.push_back("-fno-unique-section-names");
3322
Chris Lattner7255a2d2010-06-22 00:03:40 +00003323 Args.AddAllArgs(CmdArgs, options::OPT_finstrument_functions);
3324
Stephen Hines651f13c2014-04-23 16:59:28 -07003325 if (Args.hasArg(options::OPT_fprofile_instr_generate) &&
3326 (Args.hasArg(options::OPT_fprofile_instr_use) ||
3327 Args.hasArg(options::OPT_fprofile_instr_use_EQ)))
3328 D.Diag(diag::err_drv_argument_not_allowed_with)
3329 << "-fprofile-instr-generate" << "-fprofile-instr-use";
3330
3331 Args.AddAllArgs(CmdArgs, options::OPT_fprofile_instr_generate);
3332
3333 if (Arg *A = Args.getLastArg(options::OPT_fprofile_instr_use_EQ))
3334 A->render(Args, CmdArgs);
3335 else if (Args.hasArg(options::OPT_fprofile_instr_use))
3336 CmdArgs.push_back("-fprofile-instr-use=pgo-data");
3337
Nick Lewyckye8ba8d72011-04-21 23:44:07 +00003338 if (Args.hasArg(options::OPT_ftest_coverage) ||
3339 Args.hasArg(options::OPT_coverage))
3340 CmdArgs.push_back("-femit-coverage-notes");
Stephen Hines176edba2014-12-01 14:53:08 -08003341 if (Args.hasFlag(options::OPT_fprofile_arcs, options::OPT_fno_profile_arcs,
3342 false) ||
Nick Lewyckye8ba8d72011-04-21 23:44:07 +00003343 Args.hasArg(options::OPT_coverage))
3344 CmdArgs.push_back("-femit-coverage-data");
3345
Stephen Hines176edba2014-12-01 14:53:08 -08003346 if (Args.hasArg(options::OPT_fcoverage_mapping) &&
3347 !Args.hasArg(options::OPT_fprofile_instr_generate))
3348 D.Diag(diag::err_drv_argument_only_allowed_with)
3349 << "-fcoverage-mapping" << "-fprofile-instr-generate";
3350
3351 if (Args.hasArg(options::OPT_fcoverage_mapping))
3352 CmdArgs.push_back("-fcoverage-mapping");
3353
Nick Lewycky5ea4f442011-05-04 20:46:58 +00003354 if (C.getArgs().hasArg(options::OPT_c) ||
3355 C.getArgs().hasArg(options::OPT_S)) {
3356 if (Output.isFilename()) {
Nick Lewycky3dc05412011-05-05 00:08:20 +00003357 CmdArgs.push_back("-coverage-file");
Stephen Hines176edba2014-12-01 14:53:08 -08003358 SmallString<128> CoverageFilename;
3359 if (Arg *FinalOutput = C.getArgs().getLastArg(options::OPT_o)) {
3360 CoverageFilename = FinalOutput->getValue();
3361 } else {
3362 CoverageFilename = llvm::sys::path::filename(Output.getBaseInput());
3363 }
Nick Lewycky0f815f12013-03-07 08:28:53 +00003364 if (llvm::sys::path::is_relative(CoverageFilename.str())) {
Rafael Espindolaa2148242013-08-10 01:40:10 +00003365 SmallString<128> Pwd;
3366 if (!llvm::sys::fs::current_path(Pwd)) {
3367 llvm::sys::path::append(Pwd, CoverageFilename.str());
3368 CoverageFilename.swap(Pwd);
Nick Lewycky0f815f12013-03-07 08:28:53 +00003369 }
3370 }
Eric Christopher025b3d42013-02-22 00:24:40 +00003371 CmdArgs.push_back(Args.MakeArgString(CoverageFilename));
Nick Lewycky5ea4f442011-05-04 20:46:58 +00003372 }
3373 }
3374
Daniel Dunbara268fc02011-10-11 18:20:10 +00003375 // Pass options for controlling the default header search paths.
3376 if (Args.hasArg(options::OPT_nostdinc)) {
3377 CmdArgs.push_back("-nostdsysteminc");
3378 CmdArgs.push_back("-nobuiltininc");
3379 } else {
Daniel Dunbar92d6d402011-10-11 18:20:16 +00003380 if (Args.hasArg(options::OPT_nostdlibinc))
3381 CmdArgs.push_back("-nostdsysteminc");
Daniel Dunbara268fc02011-10-11 18:20:10 +00003382 Args.AddLastArg(CmdArgs, options::OPT_nostdincxx);
3383 Args.AddLastArg(CmdArgs, options::OPT_nobuiltininc);
3384 }
Daniel Dunbar1d460332009-03-18 10:01:51 +00003385
Daniel Dunbar5f122322009-12-15 01:02:52 +00003386 // Pass the path to compiler resource files.
Daniel Dunbar5f122322009-12-15 01:02:52 +00003387 CmdArgs.push_back("-resource-dir");
Daniel Dunbar225c4172010-01-20 02:35:16 +00003388 CmdArgs.push_back(D.ResourceDir.c_str());
Daniel Dunbar2ac9fc22009-04-07 21:42:00 +00003389
Argyrios Kyrtzidis389db162010-11-03 22:45:23 +00003390 Args.AddLastArg(CmdArgs, options::OPT_working_directory);
3391
Ted Kremenek30660a82012-03-06 20:06:33 +00003392 bool ARCMTEnabled = false;
Argyrios Kyrtzidisdce3ce32013-09-17 19:14:29 +00003393 if (!Args.hasArg(options::OPT_fno_objc_arc, options::OPT_fobjc_arc)) {
Argyrios Kyrtzidis72ac1202011-07-07 04:00:39 +00003394 if (const Arg *A = Args.getLastArg(options::OPT_ccc_arcmt_check,
Argyrios Kyrtzidis69325d52011-07-09 20:00:58 +00003395 options::OPT_ccc_arcmt_modify,
3396 options::OPT_ccc_arcmt_migrate)) {
Ted Kremenek30660a82012-03-06 20:06:33 +00003397 ARCMTEnabled = true;
John McCall8f0e8d22011-06-15 23:25:17 +00003398 switch (A->getOption().getID()) {
3399 default:
3400 llvm_unreachable("missed a case");
Argyrios Kyrtzidis72ac1202011-07-07 04:00:39 +00003401 case options::OPT_ccc_arcmt_check:
John McCall8f0e8d22011-06-15 23:25:17 +00003402 CmdArgs.push_back("-arcmt-check");
3403 break;
Argyrios Kyrtzidis72ac1202011-07-07 04:00:39 +00003404 case options::OPT_ccc_arcmt_modify:
John McCall8f0e8d22011-06-15 23:25:17 +00003405 CmdArgs.push_back("-arcmt-modify");
3406 break;
Argyrios Kyrtzidis69325d52011-07-09 20:00:58 +00003407 case options::OPT_ccc_arcmt_migrate:
3408 CmdArgs.push_back("-arcmt-migrate");
Ted Kremenek30660a82012-03-06 20:06:33 +00003409 CmdArgs.push_back("-mt-migrate-directory");
Richard Smith1d489cf2012-11-01 04:30:05 +00003410 CmdArgs.push_back(A->getValue());
Argyrios Kyrtzidis7ee20492011-07-19 17:20:03 +00003411
3412 Args.AddLastArg(CmdArgs, options::OPT_arcmt_migrate_report_output);
3413 Args.AddLastArg(CmdArgs, options::OPT_arcmt_migrate_emit_arc_errors);
Argyrios Kyrtzidis69325d52011-07-09 20:00:58 +00003414 break;
John McCall8f0e8d22011-06-15 23:25:17 +00003415 }
3416 }
Argyrios Kyrtzidisf75ece42013-06-24 19:01:18 +00003417 } else {
3418 Args.ClaimAllArgs(options::OPT_ccc_arcmt_check);
3419 Args.ClaimAllArgs(options::OPT_ccc_arcmt_modify);
3420 Args.ClaimAllArgs(options::OPT_ccc_arcmt_migrate);
John McCall8f0e8d22011-06-15 23:25:17 +00003421 }
Eric Christopher88b7cf02011-08-19 00:30:14 +00003422
Ted Kremenek30660a82012-03-06 20:06:33 +00003423 if (const Arg *A = Args.getLastArg(options::OPT_ccc_objcmt_migrate)) {
3424 if (ARCMTEnabled) {
3425 D.Diag(diag::err_drv_argument_not_allowed_with)
3426 << A->getAsString(Args) << "-ccc-arcmt-migrate";
3427 }
3428 CmdArgs.push_back("-mt-migrate-directory");
Richard Smith1d489cf2012-11-01 04:30:05 +00003429 CmdArgs.push_back(A->getValue());
Ted Kremenek30660a82012-03-06 20:06:33 +00003430
3431 if (!Args.hasArg(options::OPT_objcmt_migrate_literals,
Fariborz Jahaniand4129992013-07-09 16:59:14 +00003432 options::OPT_objcmt_migrate_subscripting,
3433 options::OPT_objcmt_migrate_property)) {
Ted Kremenek30660a82012-03-06 20:06:33 +00003434 // None specified, means enable them all.
3435 CmdArgs.push_back("-objcmt-migrate-literals");
3436 CmdArgs.push_back("-objcmt-migrate-subscripting");
Fariborz Jahaniand4129992013-07-09 16:59:14 +00003437 CmdArgs.push_back("-objcmt-migrate-property");
Ted Kremenek30660a82012-03-06 20:06:33 +00003438 } else {
3439 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_literals);
3440 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_subscripting);
Fariborz Jahaniand4129992013-07-09 16:59:14 +00003441 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_property);
Ted Kremenek30660a82012-03-06 20:06:33 +00003442 }
Argyrios Kyrtzidis17c384c2013-11-13 23:38:20 +00003443 } else {
3444 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_literals);
3445 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_subscripting);
3446 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_property);
3447 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_all);
3448 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_readonly_property);
3449 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_readwrite_property);
3450 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_annotation);
3451 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_instancetype);
3452 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_nsmacros);
3453 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_protocol_conformance);
3454 Args.AddLastArg(CmdArgs, options::OPT_objcmt_atomic_property);
3455 Args.AddLastArg(CmdArgs, options::OPT_objcmt_returns_innerpointer_property);
3456 Args.AddLastArg(CmdArgs, options::OPT_objcmt_ns_nonatomic_iosonly);
Stephen Hines651f13c2014-04-23 16:59:28 -07003457 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_designated_init);
3458 Args.AddLastArg(CmdArgs, options::OPT_objcmt_whitelist_dir_path);
Ted Kremenek30660a82012-03-06 20:06:33 +00003459 }
3460
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003461 // Add preprocessing options like -I, -D, etc. if we are using the
3462 // preprocessor.
3463 //
3464 // FIXME: Support -fpreprocessed
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003465 if (types::getPreprocessedType(InputType) != types::TY_INVALID)
Chad Rosier9d718632013-01-24 19:14:47 +00003466 AddPreprocessingOptions(C, JA, D, Args, CmdArgs, Output, Inputs);
Daniel Dunbar1d460332009-03-18 10:01:51 +00003467
Rafael Espindola19d9d2e2011-07-21 23:40:37 +00003468 // Don't warn about "clang -c -DPIC -fPIC test.i" because libtool.m4 assumes
3469 // that "The compiler can only warn and ignore the option if not recognized".
3470 // When building with ccache, it will pass -D options to clang even on
3471 // preprocessed inputs and configure concludes that -fPIC is not supported.
3472 Args.ClaimAllArgs(options::OPT_D);
3473
Alp Tokere22017e2013-11-15 20:40:58 +00003474 // Manually translate -O4 to -O3; let clang reject others.
Rafael Espindola55ee1eb2013-08-27 16:58:15 +00003475 if (Arg *A = Args.getLastArg(options::OPT_O_Group)) {
3476 if (A->getOption().matches(options::OPT_O4)) {
3477 CmdArgs.push_back("-O3");
3478 D.Diag(diag::warn_O4_is_O3);
3479 } else {
3480 A->render(Args, CmdArgs);
3481 }
3482 }
Daniel Dunbar1d460332009-03-18 10:01:51 +00003483
Stephen Hines176edba2014-12-01 14:53:08 -08003484 // Warn about ignored options to clang.
3485 for (arg_iterator it = Args.filtered_begin(
3486 options::OPT_clang_ignored_gcc_optimization_f_Group),
3487 ie = Args.filtered_end(); it != ie; ++it) {
3488 D.Diag(diag::warn_ignored_gcc_optimization) << (*it)->getAsString(Args);
3489 }
3490
Stephen Hines0e2c34f2015-03-23 12:09:02 -07003491 claimNoWarnArgs(Args);
Chad Rosierb2c08872012-12-12 20:06:31 +00003492
Stephen Hines176edba2014-12-01 14:53:08 -08003493 Args.AddAllArgs(CmdArgs, options::OPT_R_Group);
Daniel Dunbar6e8371e2009-10-29 02:24:45 +00003494 Args.AddAllArgs(CmdArgs, options::OPT_W_Group);
Ted Kremeneke8cf7d12012-07-07 05:53:30 +00003495 if (Args.hasFlag(options::OPT_pedantic, options::OPT_no_pedantic, false))
3496 CmdArgs.push_back("-pedantic");
Daniel Dunbar6e8371e2009-10-29 02:24:45 +00003497 Args.AddLastArg(CmdArgs, options::OPT_pedantic_errors);
Daniel Dunbar1d460332009-03-18 10:01:51 +00003498 Args.AddLastArg(CmdArgs, options::OPT_w);
Daniel Dunbard573d262009-04-07 22:13:21 +00003499
3500 // Handle -{std, ansi, trigraphs} -- take the last of -{std, ansi}
Hans Wennborgadbb4552013-07-31 16:57:56 +00003501 // (-ansi is equivalent to -std=c89 or -std=c++98).
Daniel Dunbard573d262009-04-07 22:13:21 +00003502 //
3503 // If a std is supplied, only add -trigraphs if it follows the
3504 // option.
3505 if (Arg *Std = Args.getLastArg(options::OPT_std_EQ, options::OPT_ansi)) {
3506 if (Std->getOption().matches(options::OPT_ansi))
Nuno Lopes528365d2009-10-16 14:28:06 +00003507 if (types::isCXX(InputType))
Daniel Dunbar294691e2009-11-04 06:24:38 +00003508 CmdArgs.push_back("-std=c++98");
Nuno Lopes528365d2009-10-16 14:28:06 +00003509 else
Daniel Dunbar294691e2009-11-04 06:24:38 +00003510 CmdArgs.push_back("-std=c89");
Daniel Dunbard573d262009-04-07 22:13:21 +00003511 else
3512 Std->render(Args, CmdArgs);
3513
Stephen Hines0e2c34f2015-03-23 12:09:02 -07003514 // If -f(no-)trigraphs appears after the language standard flag, honor it.
Daniel Dunbar0e100312010-06-14 21:23:08 +00003515 if (Arg *A = Args.getLastArg(options::OPT_std_EQ, options::OPT_ansi,
Stephen Hines0e2c34f2015-03-23 12:09:02 -07003516 options::OPT_ftrigraphs,
3517 options::OPT_fno_trigraphs))
Daniel Dunbar0e100312010-06-14 21:23:08 +00003518 if (A != Std)
Daniel Dunbard573d262009-04-07 22:13:21 +00003519 A->render(Args, CmdArgs);
Daniel Dunbara3ff2022009-04-26 01:10:38 +00003520 } else {
3521 // Honor -std-default.
Daniel Dunbar4a5290e2010-01-29 21:03:02 +00003522 //
3523 // FIXME: Clang doesn't correctly handle -std= when the input language
3524 // doesn't match. For the time being just ignore this for C++ inputs;
3525 // eventually we want to do all the standard defaulting here instead of
3526 // splitting it between the driver and clang -cc1.
3527 if (!types::isCXX(InputType))
Nico Weber50f88b92012-08-30 02:08:31 +00003528 Args.AddAllArgsTranslated(CmdArgs, options::OPT_std_default_EQ,
3529 "-std=", /*Joined=*/true);
Stephen Hines651f13c2014-04-23 16:59:28 -07003530 else if (IsWindowsMSVC)
Nico Weber50f88b92012-08-30 02:08:31 +00003531 CmdArgs.push_back("-std=c++11");
3532
Stephen Hines0e2c34f2015-03-23 12:09:02 -07003533 Args.AddLastArg(CmdArgs, options::OPT_ftrigraphs,
3534 options::OPT_fno_trigraphs);
Daniel Dunbara3ff2022009-04-26 01:10:38 +00003535 }
Daniel Dunbarc21c4852009-04-08 23:54:23 +00003536
Richard Smithe9813b32013-09-04 22:50:31 +00003537 // GCC's behavior for -Wwrite-strings is a bit strange:
3538 // * In C, this "warning flag" changes the types of string literals from
3539 // 'char[N]' to 'const char[N]', and thus triggers an unrelated warning
3540 // for the discarded qualifier.
3541 // * In C++, this is just a normal warning flag.
3542 //
3543 // Implementing this warning correctly in C is hard, so we follow GCC's
3544 // behavior for now. FIXME: Directly diagnose uses of a string literal as
3545 // a non-const char* in C, rather than using this crude hack.
3546 if (!types::isCXX(InputType)) {
Stephen Hines651f13c2014-04-23 16:59:28 -07003547 // FIXME: This should behave just like a warning flag, and thus should also
3548 // respect -Weverything, -Wno-everything, -Werror=write-strings, and so on.
3549 Arg *WriteStrings =
3550 Args.getLastArg(options::OPT_Wwrite_strings,
3551 options::OPT_Wno_write_strings, options::OPT_w);
3552 if (WriteStrings &&
3553 WriteStrings->getOption().matches(options::OPT_Wwrite_strings))
Richard Smithe9813b32013-09-04 22:50:31 +00003554 CmdArgs.push_back("-fconst-strings");
Chandler Carruth50465d12011-04-23 06:30:43 +00003555 }
3556
Chandler Carruth1cfe3c32011-04-23 09:27:53 +00003557 // GCC provides a macro definition '__DEPRECATED' when -Wdeprecated is active
Chandler Carruthf8c247d2011-04-23 19:48:40 +00003558 // during C++ compilation, which it is by default. GCC keeps this define even
3559 // in the presence of '-w', match this behavior bug-for-bug.
3560 if (types::isCXX(InputType) &&
3561 Args.hasFlag(options::OPT_Wdeprecated, options::OPT_Wno_deprecated,
3562 true)) {
3563 CmdArgs.push_back("-fdeprecated-macro");
Chandler Carruth1cfe3c32011-04-23 09:27:53 +00003564 }
3565
Chandler Carruthc304ba32010-05-22 02:21:53 +00003566 // Translate GCC's misnamer '-fasm' arguments to '-fgnu-keywords'.
3567 if (Arg *Asm = Args.getLastArg(options::OPT_fasm, options::OPT_fno_asm)) {
3568 if (Asm->getOption().matches(options::OPT_fasm))
3569 CmdArgs.push_back("-fgnu-keywords");
3570 else
3571 CmdArgs.push_back("-fno-gnu-keywords");
3572 }
3573
Nick Lewyckyea523d72011-10-17 23:05:52 +00003574 if (ShouldDisableDwarfDirectory(Args, getToolChain()))
3575 CmdArgs.push_back("-fno-dwarf-directory-asm");
3576
Daniel Dunbarf4910132013-04-16 18:21:19 +00003577 if (ShouldDisableAutolink(Args, getToolChain()))
3578 CmdArgs.push_back("-fno-autolink");
3579
Chandler Carruthd566df62012-12-17 21:40:04 +00003580 // Add in -fdebug-compilation-dir if necessary.
3581 addDebugCompDirArg(Args, CmdArgs);
Nick Lewycky7c4fd912011-10-21 02:32:14 +00003582
Richard Smithc18c4232011-11-21 19:36:32 +00003583 if (Arg *A = Args.getLastArg(options::OPT_ftemplate_depth_,
3584 options::OPT_ftemplate_depth_EQ)) {
Daniel Dunbar1d460332009-03-18 10:01:51 +00003585 CmdArgs.push_back("-ftemplate-depth");
Richard Smith1d489cf2012-11-01 04:30:05 +00003586 CmdArgs.push_back(A->getValue());
Daniel Dunbar1d460332009-03-18 10:01:51 +00003587 }
3588
Richard Smith195dd7c2013-11-06 19:31:51 +00003589 if (Arg *A = Args.getLastArg(options::OPT_foperator_arrow_depth_EQ)) {
3590 CmdArgs.push_back("-foperator-arrow-depth");
3591 CmdArgs.push_back(A->getValue());
3592 }
3593
Richard Smithc18c4232011-11-21 19:36:32 +00003594 if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_depth_EQ)) {
3595 CmdArgs.push_back("-fconstexpr-depth");
Richard Smith1d489cf2012-11-01 04:30:05 +00003596 CmdArgs.push_back(A->getValue());
Richard Smithc18c4232011-11-21 19:36:32 +00003597 }
3598
Richard Smithe7565632013-05-08 02:12:03 +00003599 if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_steps_EQ)) {
3600 CmdArgs.push_back("-fconstexpr-steps");
3601 CmdArgs.push_back(A->getValue());
3602 }
3603
Richard Smith9e738cc2013-02-22 01:59:51 +00003604 if (Arg *A = Args.getLastArg(options::OPT_fbracket_depth_EQ)) {
3605 CmdArgs.push_back("-fbracket-depth");
3606 CmdArgs.push_back(A->getValue());
3607 }
3608
Argyrios Kyrtzidis1380a142010-11-18 00:20:36 +00003609 if (Arg *A = Args.getLastArg(options::OPT_Wlarge_by_value_copy_EQ,
3610 options::OPT_Wlarge_by_value_copy_def)) {
Jean-Daniel Dupas2e4fd6d2012-05-04 08:08:37 +00003611 if (A->getNumValues()) {
Richard Smith1d489cf2012-11-01 04:30:05 +00003612 StringRef bytes = A->getValue();
Jean-Daniel Dupas2e4fd6d2012-05-04 08:08:37 +00003613 CmdArgs.push_back(Args.MakeArgString("-Wlarge-by-value-copy=" + bytes));
3614 } else
3615 CmdArgs.push_back("-Wlarge-by-value-copy=64"); // default value
Argyrios Kyrtzidis3532fdd2010-11-17 23:11:54 +00003616 }
3617
Nuno Lopesb3198a82012-05-08 22:10:46 +00003618
Michael J. Spencerc6357102012-10-22 22:13:48 +00003619 if (Args.hasArg(options::OPT_relocatable_pch))
Daniel Dunbar66861e02009-11-20 22:21:36 +00003620 CmdArgs.push_back("-relocatable-pch");
Mike Stump1eb44332009-09-09 15:08:12 +00003621
Daniel Dunbar294691e2009-11-04 06:24:38 +00003622 if (Arg *A = Args.getLastArg(options::OPT_fconstant_string_class_EQ)) {
3623 CmdArgs.push_back("-fconstant-string-class");
Richard Smith1d489cf2012-11-01 04:30:05 +00003624 CmdArgs.push_back(A->getValue());
Daniel Dunbar294691e2009-11-04 06:24:38 +00003625 }
David Chisnall8a5a9aa2009-08-31 16:41:57 +00003626
Chris Lattner124fca52010-01-09 21:54:33 +00003627 if (Arg *A = Args.getLastArg(options::OPT_ftabstop_EQ)) {
3628 CmdArgs.push_back("-ftabstop");
Richard Smith1d489cf2012-11-01 04:30:05 +00003629 CmdArgs.push_back(A->getValue());
Chris Lattner124fca52010-01-09 21:54:33 +00003630 }
3631
Chris Lattner0f0c9632010-04-07 20:49:23 +00003632 CmdArgs.push_back("-ferror-limit");
3633 if (Arg *A = Args.getLastArg(options::OPT_ferror_limit_EQ))
Richard Smith1d489cf2012-11-01 04:30:05 +00003634 CmdArgs.push_back(A->getValue());
Chris Lattner0f0c9632010-04-07 20:49:23 +00003635 else
3636 CmdArgs.push_back("19");
Douglas Gregor575cf372010-04-20 07:18:24 +00003637
Chandler Carruthc40f73c2010-05-06 04:55:18 +00003638 if (Arg *A = Args.getLastArg(options::OPT_fmacro_backtrace_limit_EQ)) {
3639 CmdArgs.push_back("-fmacro-backtrace-limit");
Richard Smith1d489cf2012-11-01 04:30:05 +00003640 CmdArgs.push_back(A->getValue());
Chandler Carruthc40f73c2010-05-06 04:55:18 +00003641 }
3642
3643 if (Arg *A = Args.getLastArg(options::OPT_ftemplate_backtrace_limit_EQ)) {
3644 CmdArgs.push_back("-ftemplate-backtrace-limit");
Richard Smith1d489cf2012-11-01 04:30:05 +00003645 CmdArgs.push_back(A->getValue());
Chandler Carruthc40f73c2010-05-06 04:55:18 +00003646 }
3647
Richard Smith08d6e032011-12-16 19:06:07 +00003648 if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_backtrace_limit_EQ)) {
3649 CmdArgs.push_back("-fconstexpr-backtrace-limit");
Richard Smith1d489cf2012-11-01 04:30:05 +00003650 CmdArgs.push_back(A->getValue());
Richard Smith08d6e032011-12-16 19:06:07 +00003651 }
3652
Stephen Hines0e2c34f2015-03-23 12:09:02 -07003653 if (Arg *A = Args.getLastArg(options::OPT_fspell_checking_limit_EQ)) {
3654 CmdArgs.push_back("-fspell-checking-limit");
3655 CmdArgs.push_back(A->getValue());
3656 }
3657
Daniel Dunbar55efe142009-11-04 06:24:47 +00003658 // Pass -fmessage-length=.
Daniel Dunbara28690e2009-11-30 08:40:54 +00003659 CmdArgs.push_back("-fmessage-length");
Daniel Dunbar55efe142009-11-04 06:24:47 +00003660 if (Arg *A = Args.getLastArg(options::OPT_fmessage_length_EQ)) {
Richard Smith1d489cf2012-11-01 04:30:05 +00003661 CmdArgs.push_back(A->getValue());
Daniel Dunbar55efe142009-11-04 06:24:47 +00003662 } else {
3663 // If -fmessage-length=N was not specified, determine whether this is a
3664 // terminal and, if so, implicitly define -fmessage-length appropriately.
3665 unsigned N = llvm::sys::Process::StandardErrColumns();
Chris Lattner5f9e2722011-07-23 10:55:15 +00003666 CmdArgs.push_back(Args.MakeArgString(Twine(N)));
Daniel Dunbar55efe142009-11-04 06:24:47 +00003667 }
3668
John McCalla880b192013-02-19 01:57:35 +00003669 // -fvisibility= and -fvisibility-ms-compat are of a piece.
3670 if (const Arg *A = Args.getLastArg(options::OPT_fvisibility_EQ,
3671 options::OPT_fvisibility_ms_compat)) {
3672 if (A->getOption().matches(options::OPT_fvisibility_EQ)) {
3673 CmdArgs.push_back("-fvisibility");
3674 CmdArgs.push_back(A->getValue());
3675 } else {
3676 assert(A->getOption().matches(options::OPT_fvisibility_ms_compat));
3677 CmdArgs.push_back("-fvisibility");
3678 CmdArgs.push_back("hidden");
3679 CmdArgs.push_back("-ftype-visibility");
3680 CmdArgs.push_back("default");
3681 }
Daniel Dunbarba8d8612009-12-03 18:42:11 +00003682 }
3683
Douglas Gregor7cf84d62010-06-15 17:05:35 +00003684 Args.AddLastArg(CmdArgs, options::OPT_fvisibility_inlines_hidden);
Michael J. Spencer20249a12010-10-21 03:16:25 +00003685
Hans Wennborgde981f32012-06-28 08:01:44 +00003686 Args.AddLastArg(CmdArgs, options::OPT_ftlsmodel_EQ);
3687
Daniel Dunbar0a80ba72010-03-20 04:52:14 +00003688 // -fhosted is default.
Chad Rosierafc4baa2012-03-26 22:04:46 +00003689 if (Args.hasFlag(options::OPT_ffreestanding, options::OPT_fhosted, false) ||
3690 KernelOrKext)
Daniel Dunbar0a80ba72010-03-20 04:52:14 +00003691 CmdArgs.push_back("-ffreestanding");
3692
Daniel Dunbarba8d8612009-12-03 18:42:11 +00003693 // Forward -f (flag) options which we can pass directly.
Daniel Dunbar3aaf0822009-04-07 21:51:40 +00003694 Args.AddLastArg(CmdArgs, options::OPT_femit_all_decls);
Daniel Dunbar3aaf0822009-04-07 21:51:40 +00003695 Args.AddLastArg(CmdArgs, options::OPT_fheinous_gnu_extensions);
Stephen Hines651f13c2014-04-23 16:59:28 -07003696 Args.AddLastArg(CmdArgs, options::OPT_fstandalone_debug);
3697 Args.AddLastArg(CmdArgs, options::OPT_fno_standalone_debug);
Eric Christophere88c4512011-10-25 07:13:06 +00003698 Args.AddLastArg(CmdArgs, options::OPT_fno_operator_names);
Bill Schmidt9e0b6472013-07-03 15:36:02 +00003699 // AltiVec language extensions aren't relevant for assembling.
3700 if (!isa<PreprocessJobAction>(JA) ||
3701 Output.getType() != types::TY_PP_Asm)
3702 Args.AddLastArg(CmdArgs, options::OPT_faltivec);
Richard Trieu246b6aa2012-06-26 18:18:47 +00003703 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_show_template_tree);
3704 Args.AddLastArg(CmdArgs, options::OPT_fno_elide_type);
Chad Rosier4574c3d2012-03-13 23:45:51 +00003705
Peter Collingbournec6911a22013-11-01 18:16:25 +00003706 const SanitizerArgs &Sanitize = getToolChain().getSanitizerArgs();
3707 Sanitize.addArgs(Args, CmdArgs);
Richard Smithc4dabad2012-11-05 22:04:41 +00003708
Eric Christopher98654c92013-02-19 06:16:53 +00003709 // Report an error for -faltivec on anything other than PowerPC.
Chad Rosier4574c3d2012-03-13 23:45:51 +00003710 if (const Arg *A = Args.getLastArg(options::OPT_faltivec))
Eli Bendersky8f4269a2013-07-24 22:20:49 +00003711 if (!(getToolChain().getArch() == llvm::Triple::ppc ||
Bill Schmidtea7fb0c2013-07-26 01:36:11 +00003712 getToolChain().getArch() == llvm::Triple::ppc64 ||
3713 getToolChain().getArch() == llvm::Triple::ppc64le))
Chad Rosier4574c3d2012-03-13 23:45:51 +00003714 D.Diag(diag::err_drv_argument_only_allowed_with)
Bill Schmidtea7fb0c2013-07-26 01:36:11 +00003715 << A->getAsString(Args) << "ppc/ppc64/ppc64le";
Chad Rosier4574c3d2012-03-13 23:45:51 +00003716
Daniel Dunbarbbe8e3e2011-03-01 18:49:30 +00003717 if (getToolChain().SupportsProfiling())
3718 Args.AddLastArg(CmdArgs, options::OPT_pg);
Daniel Dunbar8c6fa842010-03-16 16:57:46 +00003719
3720 // -flax-vector-conversions is default.
3721 if (!Args.hasFlag(options::OPT_flax_vector_conversions,
3722 options::OPT_fno_lax_vector_conversions))
3723 CmdArgs.push_back("-fno-lax-vector-conversions");
3724
Fariborz Jahanianb466d012011-01-07 01:05:02 +00003725 if (Args.getLastArg(options::OPT_fapple_kext))
3726 CmdArgs.push_back("-fapple-kext");
3727
Fariborz Jahanian34e65772009-05-22 20:17:16 +00003728 Args.AddLastArg(CmdArgs, options::OPT_fobjc_sender_dependent_dispatch);
Chris Lattner182e0922009-04-21 05:34:31 +00003729 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_print_source_range_info);
Douglas Gregor4786c152010-08-19 20:24:43 +00003730 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_parseable_fixits);
Daniel Dunbar3aaf0822009-04-07 21:51:40 +00003731 Args.AddLastArg(CmdArgs, options::OPT_ftime_report);
3732 Args.AddLastArg(CmdArgs, options::OPT_ftrapv);
David Chisnall7f18e672010-09-17 18:29:54 +00003733
3734 if (Arg *A = Args.getLastArg(options::OPT_ftrapv_handler_EQ)) {
3735 CmdArgs.push_back("-ftrapv-handler");
Richard Smith1d489cf2012-11-01 04:30:05 +00003736 CmdArgs.push_back(A->getValue());
David Chisnall7f18e672010-09-17 18:29:54 +00003737 }
3738
Bob Wilson71fd6cc2012-02-03 06:27:22 +00003739 Args.AddLastArg(CmdArgs, options::OPT_ftrap_function_EQ);
Evan Cheng49af1f32011-04-08 21:37:45 +00003740
Chandler Carruth5adb5a82011-03-27 00:04:55 +00003741 // -fno-strict-overflow implies -fwrapv if it isn't disabled, but
3742 // -fstrict-overflow won't turn off an explicitly enabled -fwrapv.
3743 if (Arg *A = Args.getLastArg(options::OPT_fwrapv,
3744 options::OPT_fno_wrapv)) {
3745 if (A->getOption().matches(options::OPT_fwrapv))
3746 CmdArgs.push_back("-fwrapv");
3747 } else if (Arg *A = Args.getLastArg(options::OPT_fstrict_overflow,
3748 options::OPT_fno_strict_overflow)) {
3749 if (A->getOption().matches(options::OPT_fno_strict_overflow))
3750 CmdArgs.push_back("-fwrapv");
3751 }
Hal Finkelce5b5f12013-11-17 16:03:29 +00003752
3753 if (Arg *A = Args.getLastArg(options::OPT_freroll_loops,
3754 options::OPT_fno_reroll_loops))
3755 if (A->getOption().matches(options::OPT_freroll_loops))
3756 CmdArgs.push_back("-freroll-loops");
3757
Daniel Dunbar3aaf0822009-04-07 21:51:40 +00003758 Args.AddLastArg(CmdArgs, options::OPT_fwritable_strings);
Chandler Carruthb26404a2013-08-08 08:34:35 +00003759 Args.AddLastArg(CmdArgs, options::OPT_funroll_loops,
3760 options::OPT_fno_unroll_loops);
Daniel Dunbar1d460332009-03-18 10:01:51 +00003761
Daniel Dunbar5345c392009-09-03 04:54:28 +00003762 Args.AddLastArg(CmdArgs, options::OPT_pthread);
3763
Mahesha Sf3b52312012-10-27 07:47:56 +00003764
Daniel Dunbar9e5cc6b2009-11-17 08:07:36 +00003765 // -stack-protector=0 is default.
3766 unsigned StackProtectorLevel = 0;
Bill Wendling45483f72009-06-28 07:36:13 +00003767 if (Arg *A = Args.getLastArg(options::OPT_fno_stack_protector,
3768 options::OPT_fstack_protector_all,
Stephen Hines651f13c2014-04-23 16:59:28 -07003769 options::OPT_fstack_protector_strong,
Bill Wendling45483f72009-06-28 07:36:13 +00003770 options::OPT_fstack_protector)) {
Stephen Hines6bcf27b2014-05-29 04:14:42 -07003771 if (A->getOption().matches(options::OPT_fstack_protector)) {
3772 StackProtectorLevel = std::max<unsigned>(LangOptions::SSPOn,
3773 getToolChain().GetDefaultStackProtectorLevel(KernelOrKext));
3774 } else if (A->getOption().matches(options::OPT_fstack_protector_strong))
Stephen Hines651f13c2014-04-23 16:59:28 -07003775 StackProtectorLevel = LangOptions::SSPStrong;
Daniel Dunbar9e5cc6b2009-11-17 08:07:36 +00003776 else if (A->getOption().matches(options::OPT_fstack_protector_all))
Stephen Hines651f13c2014-04-23 16:59:28 -07003777 StackProtectorLevel = LangOptions::SSPReq;
Nico Weber2fef1112011-08-23 07:38:27 +00003778 } else {
3779 StackProtectorLevel =
3780 getToolChain().GetDefaultStackProtectorLevel(KernelOrKext);
3781 }
Daniel Dunbar9e5cc6b2009-11-17 08:07:36 +00003782 if (StackProtectorLevel) {
3783 CmdArgs.push_back("-stack-protector");
Chris Lattner5f9e2722011-07-23 10:55:15 +00003784 CmdArgs.push_back(Args.MakeArgString(Twine(StackProtectorLevel)));
Joerg Sonnenberger53b43a72012-09-12 13:51:14 +00003785 }
Chad Rosiera7afeb02012-08-21 16:16:06 +00003786
Joerg Sonnenberger53b43a72012-09-12 13:51:14 +00003787 // --param ssp-buffer-size=
3788 for (arg_iterator it = Args.filtered_begin(options::OPT__param),
3789 ie = Args.filtered_end(); it != ie; ++it) {
Richard Smith1d489cf2012-11-01 04:30:05 +00003790 StringRef Str((*it)->getValue());
Joerg Sonnenberger53b43a72012-09-12 13:51:14 +00003791 if (Str.startswith("ssp-buffer-size=")) {
3792 if (StackProtectorLevel) {
Chad Rosiera7afeb02012-08-21 16:16:06 +00003793 CmdArgs.push_back("-stack-protector-buffer-size");
3794 // FIXME: Verify the argument is a valid integer.
3795 CmdArgs.push_back(Args.MakeArgString(Str.drop_front(16)));
Chad Rosiera7afeb02012-08-21 16:16:06 +00003796 }
Joerg Sonnenberger53b43a72012-09-12 13:51:14 +00003797 (*it)->claim();
Chad Rosiera7afeb02012-08-21 16:16:06 +00003798 }
Bill Wendling45483f72009-06-28 07:36:13 +00003799 }
3800
Nick Lewycky4e785c92011-12-06 03:33:03 +00003801 // Translate -mstackrealign
3802 if (Args.hasFlag(options::OPT_mstackrealign, options::OPT_mno_stackrealign,
3803 false)) {
3804 CmdArgs.push_back("-backend-option");
3805 CmdArgs.push_back("-force-align-stack");
3806 }
3807 if (!Args.hasFlag(options::OPT_mno_stackrealign, options::OPT_mstackrealign,
3808 false)) {
3809 CmdArgs.push_back(Args.MakeArgString("-mstackrealign"));
3810 }
3811
Joerg Sonnenbergere9d11db2011-12-05 23:05:23 +00003812 if (Args.hasArg(options::OPT_mstack_alignment)) {
3813 StringRef alignment = Args.getLastArgValue(options::OPT_mstack_alignment);
3814 CmdArgs.push_back(Args.MakeArgString("-mstack-alignment=" + alignment));
Eric Christopher1a584022011-05-02 21:18:22 +00003815 }
Stephen Hines176edba2014-12-01 14:53:08 -08003816
Stephen Hines0e2c34f2015-03-23 12:09:02 -07003817 if (Args.hasArg(options::OPT_mstack_probe_size)) {
3818 StringRef Size = Args.getLastArgValue(options::OPT_mstack_probe_size);
3819
3820 if (!Size.empty())
3821 CmdArgs.push_back(Args.MakeArgString("-mstack-probe-size=" + Size));
3822 else
3823 CmdArgs.push_back("-mstack-probe-size=0");
3824 }
3825
Stephen Hines176edba2014-12-01 14:53:08 -08003826 if (getToolChain().getTriple().getArch() == llvm::Triple::aarch64 ||
3827 getToolChain().getTriple().getArch() == llvm::Triple::aarch64_be)
3828 CmdArgs.push_back("-fallow-half-arguments-and-returns");
Eric Christopher88b7cf02011-08-19 00:30:14 +00003829
Weiming Zhao7792fde2013-11-13 18:31:23 +00003830 if (Arg *A = Args.getLastArg(options::OPT_mrestrict_it,
3831 options::OPT_mno_restrict_it)) {
3832 if (A->getOption().matches(options::OPT_mrestrict_it)) {
3833 CmdArgs.push_back("-backend-option");
3834 CmdArgs.push_back("-arm-restrict-it");
3835 } else {
3836 CmdArgs.push_back("-backend-option");
3837 CmdArgs.push_back("-arm-no-restrict-it");
3838 }
Stephen Hines6bcf27b2014-05-29 04:14:42 -07003839 } else if (TT.isOSWindows() && (TT.getArch() == llvm::Triple::arm ||
3840 TT.getArch() == llvm::Triple::thumb)) {
3841 // Windows on ARM expects restricted IT blocks
3842 CmdArgs.push_back("-backend-option");
3843 CmdArgs.push_back("-arm-restrict-it");
Weiming Zhao7792fde2013-11-13 18:31:23 +00003844 }
3845
Stephen Hinesef822542014-07-21 00:47:37 -07003846 if (TT.getArch() == llvm::Triple::arm ||
3847 TT.getArch() == llvm::Triple::thumb) {
3848 if (Arg *A = Args.getLastArg(options::OPT_mlong_calls,
3849 options::OPT_mno_long_calls)) {
3850 if (A->getOption().matches(options::OPT_mlong_calls)) {
3851 CmdArgs.push_back("-backend-option");
3852 CmdArgs.push_back("-arm-long-calls");
3853 }
3854 }
3855 }
3856
Daniel Dunbar48d1ef72009-04-07 21:16:11 +00003857 // Forward -f options with positive and negative forms; we translate
3858 // these by hand.
Diego Novillob85a9ec2013-11-13 12:22:39 +00003859 if (Arg *A = Args.getLastArg(options::OPT_fprofile_sample_use_EQ)) {
3860 StringRef fname = A->getValue();
3861 if (!llvm::sys::fs::exists(fname))
3862 D.Diag(diag::err_drv_no_such_file) << fname;
3863 else
3864 A->render(Args, CmdArgs);
3865 }
Daniel Dunbar48d1ef72009-04-07 21:16:11 +00003866
Fariborz Jahanianb466d012011-01-07 01:05:02 +00003867 if (Args.hasArg(options::OPT_mkernel)) {
Daniel Dunbar2843c192011-02-04 17:24:47 +00003868 if (!Args.hasArg(options::OPT_fapple_kext) && types::isCXX(InputType))
Fariborz Jahanianb466d012011-01-07 01:05:02 +00003869 CmdArgs.push_back("-fapple-kext");
3870 if (!Args.hasArg(options::OPT_fbuiltin))
3871 CmdArgs.push_back("-fno-builtin");
Chad Rosier3d265502012-03-26 21:29:17 +00003872 Args.ClaimAllArgs(options::OPT_fno_builtin);
Fariborz Jahanianb466d012011-01-07 01:05:02 +00003873 }
Daniel Dunbar9e5cc6b2009-11-17 08:07:36 +00003874 // -fbuiltin is default.
Fariborz Jahanianb466d012011-01-07 01:05:02 +00003875 else if (!Args.hasFlag(options::OPT_fbuiltin, options::OPT_fno_builtin))
Daniel Dunbar53e84842009-11-19 04:55:23 +00003876 CmdArgs.push_back("-fno-builtin");
Daniel Dunbar48d1ef72009-04-07 21:16:11 +00003877
Nuno Lopesfc284482009-12-16 16:59:22 +00003878 if (!Args.hasFlag(options::OPT_fassume_sane_operator_new,
3879 options::OPT_fno_assume_sane_operator_new))
3880 CmdArgs.push_back("-fno-assume-sane-operator-new");
3881
Daniel Dunbar9e5cc6b2009-11-17 08:07:36 +00003882 // -fblocks=0 is default.
3883 if (Args.hasFlag(options::OPT_fblocks, options::OPT_fno_blocks,
David Chisnalle6533ff2011-02-28 17:11:43 +00003884 getToolChain().IsBlocksDefault()) ||
3885 (Args.hasArg(options::OPT_fgnu_runtime) &&
3886 Args.hasArg(options::OPT_fobjc_nonfragile_abi) &&
3887 !Args.hasArg(options::OPT_fno_blocks))) {
Daniel Dunbar9e5cc6b2009-11-17 08:07:36 +00003888 CmdArgs.push_back("-fblocks");
John McCall13db5cf2011-09-09 20:41:01 +00003889
3890 if (!Args.hasArg(options::OPT_fgnu_runtime) &&
3891 !getToolChain().hasBlocksRuntime())
3892 CmdArgs.push_back("-fblocks-runtime-optional");
David Chisnall5e530af2009-11-17 19:33:30 +00003893 }
Daniel Dunbar48d1ef72009-04-07 21:16:11 +00003894
Stephen Hines176edba2014-12-01 14:53:08 -08003895 // -fmodules enables modules (off by default).
3896 // Users can pass -fno-cxx-modules to turn off modules support for
3897 // C++/Objective-C++ programs, which is a little less mature.
Douglas Gregorf43b7212013-01-16 01:23:41 +00003898 bool HaveModules = false;
Douglas Gregor64554ba2012-01-18 15:19:58 +00003899 if (Args.hasFlag(options::OPT_fmodules, options::OPT_fno_modules, false)) {
3900 bool AllowedInCXX = Args.hasFlag(options::OPT_fcxx_modules,
3901 options::OPT_fno_cxx_modules,
Stephen Hines176edba2014-12-01 14:53:08 -08003902 true);
Douglas Gregorf43b7212013-01-16 01:23:41 +00003903 if (AllowedInCXX || !types::isCXX(InputType)) {
Douglas Gregor64554ba2012-01-18 15:19:58 +00003904 CmdArgs.push_back("-fmodules");
Douglas Gregorf43b7212013-01-16 01:23:41 +00003905 HaveModules = true;
3906 }
3907 }
3908
Daniel Jasper056ec122013-08-05 20:26:17 +00003909 // -fmodule-maps enables module map processing (off by default) for header
3910 // checking. It is implied by -fmodules.
3911 if (Args.hasFlag(options::OPT_fmodule_maps, options::OPT_fno_module_maps,
3912 false)) {
3913 CmdArgs.push_back("-fmodule-maps");
3914 }
3915
Daniel Jasper95411412013-10-21 06:34:34 +00003916 // -fmodules-decluse checks that modules used are declared so (off by
3917 // default).
Daniel Jasperddd2dfc2013-09-24 09:14:14 +00003918 if (Args.hasFlag(options::OPT_fmodules_decluse,
3919 options::OPT_fno_modules_decluse,
3920 false)) {
Daniel Jasper097595a2013-09-29 12:40:54 +00003921 CmdArgs.push_back("-fmodules-decluse");
Daniel Jasperddd2dfc2013-09-24 09:14:14 +00003922 }
3923
Stephen Hines6bcf27b2014-05-29 04:14:42 -07003924 // -fmodules-strict-decluse is like -fmodule-decluse, but also checks that
3925 // all #included headers are part of modules.
3926 if (Args.hasFlag(options::OPT_fmodules_strict_decluse,
3927 options::OPT_fno_modules_strict_decluse,
3928 false)) {
3929 CmdArgs.push_back("-fmodules-strict-decluse");
3930 }
3931
Stephen Hines0e2c34f2015-03-23 12:09:02 -07003932 // -fno-implicit-modules turns off implicitly compiling modules on demand.
3933 if (!Args.hasFlag(options::OPT_fimplicit_modules,
3934 options::OPT_fno_implicit_modules)) {
3935 CmdArgs.push_back("-fno-implicit-modules");
3936 }
3937
Daniel Jasper95411412013-10-21 06:34:34 +00003938 // -fmodule-name specifies the module that is currently being built (or
3939 // used for header checking by -fmodule-maps).
Stephen Hines176edba2014-12-01 14:53:08 -08003940 Args.AddLastArg(CmdArgs, options::OPT_fmodule_name);
Daniel Jasper95411412013-10-21 06:34:34 +00003941
Stephen Hines176edba2014-12-01 14:53:08 -08003942 // -fmodule-map-file can be used to specify files containing module
Daniel Jasper95411412013-10-21 06:34:34 +00003943 // definitions.
Stephen Hines176edba2014-12-01 14:53:08 -08003944 Args.AddAllArgs(CmdArgs, options::OPT_fmodule_map_file);
Daniel Jasper95411412013-10-21 06:34:34 +00003945
Stephen Hines176edba2014-12-01 14:53:08 -08003946 // -fmodule-file can be used to specify files containing precompiled modules.
3947 Args.AddAllArgs(CmdArgs, options::OPT_fmodule_file);
3948
3949 // -fmodule-cache-path specifies where our implicitly-built module files
3950 // should be written.
Stephen Hinesef822542014-07-21 00:47:37 -07003951 SmallString<128> ModuleCachePath;
3952 if (Arg *A = Args.getLastArg(options::OPT_fmodules_cache_path))
3953 ModuleCachePath = A->getValue();
3954 if (HaveModules) {
3955 if (C.isForDiagnostics()) {
3956 // When generating crash reports, we want to emit the modules along with
3957 // the reproduction sources, so we ignore any provided module path.
3958 ModuleCachePath = Output.getFilename();
3959 llvm::sys::path::replace_extension(ModuleCachePath, ".cache");
3960 llvm::sys::path::append(ModuleCachePath, "modules");
3961 } else if (ModuleCachePath.empty()) {
3962 // No module path was provided: use the default.
3963 llvm::sys::path::system_temp_directory(/*erasedOnReboot=*/false,
3964 ModuleCachePath);
Stephen Hines0e2c34f2015-03-23 12:09:02 -07003965 llvm::sys::path::append(ModuleCachePath, "org.llvm.clang.");
3966 appendUserToPath(ModuleCachePath);
Stephen Hinesef822542014-07-21 00:47:37 -07003967 llvm::sys::path::append(ModuleCachePath, "ModuleCache");
Douglas Gregor953a61f2013-02-07 19:01:24 +00003968 }
Douglas Gregor250172a2013-02-07 22:59:12 +00003969 const char Arg[] = "-fmodules-cache-path=";
Stephen Hinesef822542014-07-21 00:47:37 -07003970 ModuleCachePath.insert(ModuleCachePath.begin(), Arg, Arg + strlen(Arg));
3971 CmdArgs.push_back(Args.MakeArgString(ModuleCachePath));
Douglas Gregor953a61f2013-02-07 19:01:24 +00003972 }
3973
Stephen Hinesef822542014-07-21 00:47:37 -07003974 // When building modules and generating crashdumps, we need to dump a module
3975 // dependency VFS alongside the output.
3976 if (HaveModules && C.isForDiagnostics()) {
3977 SmallString<128> VFSDir(Output.getFilename());
3978 llvm::sys::path::replace_extension(VFSDir, ".cache");
Stephen Hines176edba2014-12-01 14:53:08 -08003979 // Add the cache directory as a temp so the crash diagnostics pick it up.
3980 C.addTempFile(Args.MakeArgString(VFSDir));
3981
Stephen Hinesef822542014-07-21 00:47:37 -07003982 llvm::sys::path::append(VFSDir, "vfs");
3983 CmdArgs.push_back("-module-dependency-dir");
3984 CmdArgs.push_back(Args.MakeArgString(VFSDir));
Stephen Hines651f13c2014-04-23 16:59:28 -07003985 }
3986
Stephen Hines176edba2014-12-01 14:53:08 -08003987 if (HaveModules)
3988 Args.AddLastArg(CmdArgs, options::OPT_fmodules_user_build_path);
Stephen Hinesef822542014-07-21 00:47:37 -07003989
Douglas Gregor953a61f2013-02-07 19:01:24 +00003990 // Pass through all -fmodules-ignore-macro arguments.
3991 Args.AddAllArgs(CmdArgs, options::OPT_fmodules_ignore_macro);
Douglas Gregord44d2872013-03-25 21:19:16 +00003992 Args.AddLastArg(CmdArgs, options::OPT_fmodules_prune_interval);
3993 Args.AddLastArg(CmdArgs, options::OPT_fmodules_prune_after);
Douglas Gregor953a61f2013-02-07 19:01:24 +00003994
Stephen Hines651f13c2014-04-23 16:59:28 -07003995 Args.AddLastArg(CmdArgs, options::OPT_fbuild_session_timestamp);
3996
Stephen Hines176edba2014-12-01 14:53:08 -08003997 if (Arg *A = Args.getLastArg(options::OPT_fbuild_session_file)) {
3998 if (Args.hasArg(options::OPT_fbuild_session_timestamp))
3999 D.Diag(diag::err_drv_argument_not_allowed_with)
4000 << A->getAsString(Args) << "-fbuild-session-timestamp";
4001
4002 llvm::sys::fs::file_status Status;
4003 if (llvm::sys::fs::status(A->getValue(), Status))
4004 D.Diag(diag::err_drv_no_such_file) << A->getValue();
Stephen Hines0e2c34f2015-03-23 12:09:02 -07004005 CmdArgs.push_back(Args.MakeArgString(
4006 "-fbuild-session-timestamp=" +
4007 Twine((uint64_t)Status.getLastModificationTime().toEpochTime())));
Stephen Hines176edba2014-12-01 14:53:08 -08004008 }
4009
Stephen Hines651f13c2014-04-23 16:59:28 -07004010 if (Args.getLastArg(options::OPT_fmodules_validate_once_per_build_session)) {
Stephen Hines176edba2014-12-01 14:53:08 -08004011 if (!Args.getLastArg(options::OPT_fbuild_session_timestamp,
4012 options::OPT_fbuild_session_file))
Stephen Hines651f13c2014-04-23 16:59:28 -07004013 D.Diag(diag::err_drv_modules_validate_once_requires_timestamp);
4014
4015 Args.AddLastArg(CmdArgs,
4016 options::OPT_fmodules_validate_once_per_build_session);
4017 }
4018
4019 Args.AddLastArg(CmdArgs, options::OPT_fmodules_validate_system_headers);
4020
John McCall32579cf2010-04-09 19:12:06 +00004021 // -faccess-control is default.
John McCall7002f4c2010-04-09 19:03:51 +00004022 if (Args.hasFlag(options::OPT_fno_access_control,
4023 options::OPT_faccess_control,
John McCall32579cf2010-04-09 19:12:06 +00004024 false))
John McCall7002f4c2010-04-09 19:03:51 +00004025 CmdArgs.push_back("-fno-access-control");
John McCall3ddd6e02010-03-17 01:32:13 +00004026
Anders Carlssona4c24752010-11-21 00:09:52 +00004027 // -felide-constructors is the default.
4028 if (Args.hasFlag(options::OPT_fno_elide_constructors,
4029 options::OPT_felide_constructors,
4030 false))
4031 CmdArgs.push_back("-fno-elide-constructors");
4032
Stephen Hines0e2c34f2015-03-23 12:09:02 -07004033 ToolChain::RTTIMode RTTIMode = getToolChain().getRTTIMode();
Mike Stump738f8c22009-07-31 23:15:31 +00004034
Stephen Hines0e2c34f2015-03-23 12:09:02 -07004035 if (RTTIMode == ToolChain::RM_DisabledExplicitly ||
4036 RTTIMode == ToolChain::RM_DisabledImplicitly)
4037 CmdArgs.push_back("-fno-rtti");
Richard Smithc4dabad2012-11-05 22:04:41 +00004038
Tony Linthicum96319392011-12-12 21:14:55 +00004039 // -fshort-enums=0 is default for all architectures except Hexagon.
Argyrios Kyrtzidis9a2b9d72010-10-08 00:25:19 +00004040 if (Args.hasFlag(options::OPT_fshort_enums,
Tony Linthicum96319392011-12-12 21:14:55 +00004041 options::OPT_fno_short_enums,
Eli Bendersky8f4269a2013-07-24 22:20:49 +00004042 getToolChain().getArch() ==
Tony Linthicum96319392011-12-12 21:14:55 +00004043 llvm::Triple::hexagon))
Argyrios Kyrtzidis9a2b9d72010-10-08 00:25:19 +00004044 CmdArgs.push_back("-fshort-enums");
4045
Daniel Dunbar1f95e652009-11-17 06:37:03 +00004046 // -fsigned-char is default.
Daniel Dunbar6d2eb4d2009-11-25 10:14:30 +00004047 if (!Args.hasFlag(options::OPT_fsigned_char, options::OPT_funsigned_char,
Daniel Dunbar1f95e652009-11-17 06:37:03 +00004048 isSignedCharDefault(getToolChain().getTriple())))
Daniel Dunbar76743522009-11-29 02:39:08 +00004049 CmdArgs.push_back("-fno-signed-char");
Eli Friedman5a779732009-06-05 07:21:14 +00004050
Anders Carlssona508b7d2010-02-06 23:23:06 +00004051 // -fthreadsafe-static is default.
Michael J. Spencer20249a12010-10-21 03:16:25 +00004052 if (!Args.hasFlag(options::OPT_fthreadsafe_statics,
Anders Carlssona508b7d2010-02-06 23:23:06 +00004053 options::OPT_fno_threadsafe_statics))
4054 CmdArgs.push_back("-fno-threadsafe-statics");
4055
Daniel Dunbarefb0fa92010-03-20 04:15:41 +00004056 // -fuse-cxa-atexit is default.
Stephen Hines651f13c2014-04-23 16:59:28 -07004057 if (!Args.hasFlag(options::OPT_fuse_cxa_atexit,
4058 options::OPT_fno_use_cxa_atexit,
4059 !IsWindowsCygnus && !IsWindowsGNU &&
4060 getToolChain().getArch() != llvm::Triple::hexagon &&
4061 getToolChain().getArch() != llvm::Triple::xcore) ||
Chad Rosierafc4baa2012-03-26 22:04:46 +00004062 KernelOrKext)
Daniel Dunbarefb0fa92010-03-20 04:15:41 +00004063 CmdArgs.push_back("-fno-use-cxa-atexit");
4064
Daniel Dunbar0be42c42009-11-17 07:06:20 +00004065 // -fms-extensions=0 is default.
Daniel Dunbar6d2eb4d2009-11-25 10:14:30 +00004066 if (Args.hasFlag(options::OPT_fms_extensions, options::OPT_fno_ms_extensions,
Stephen Hines651f13c2014-04-23 16:59:28 -07004067 IsWindowsMSVC))
Daniel Dunbar0be42c42009-11-17 07:06:20 +00004068 CmdArgs.push_back("-fms-extensions");
4069
Stephen Hines0e2c34f2015-03-23 12:09:02 -07004070 // -fno-use-line-directives is default.
4071 if (Args.hasFlag(options::OPT_fuse_line_directives,
4072 options::OPT_fno_use_line_directives, false))
4073 CmdArgs.push_back("-fuse-line-directives");
4074
Francois Pichetae556082011-09-17 04:32:15 +00004075 // -fms-compatibility=0 is default.
Douglas Gregorba97b6e2011-10-24 15:49:38 +00004076 if (Args.hasFlag(options::OPT_fms_compatibility,
4077 options::OPT_fno_ms_compatibility,
Stephen Hines651f13c2014-04-23 16:59:28 -07004078 (IsWindowsMSVC && Args.hasFlag(options::OPT_fms_extensions,
4079 options::OPT_fno_ms_extensions,
4080 true))))
Francois Pichetae556082011-09-17 04:32:15 +00004081 CmdArgs.push_back("-fms-compatibility");
4082
Stephen Hines176edba2014-12-01 14:53:08 -08004083 // -fms-compatibility-version=17.00 is default.
Michael J. Spencerdae4ac42010-10-21 05:21:48 +00004084 if (Args.hasFlag(options::OPT_fms_extensions, options::OPT_fno_ms_extensions,
Stephen Hines176edba2014-12-01 14:53:08 -08004085 IsWindowsMSVC) || Args.hasArg(options::OPT_fmsc_version) ||
4086 Args.hasArg(options::OPT_fms_compatibility_version)) {
4087 const Arg *MSCVersion = Args.getLastArg(options::OPT_fmsc_version);
4088 const Arg *MSCompatibilityVersion =
4089 Args.getLastArg(options::OPT_fms_compatibility_version);
Michael J. Spencerdae4ac42010-10-21 05:21:48 +00004090
Stephen Hines176edba2014-12-01 14:53:08 -08004091 if (MSCVersion && MSCompatibilityVersion)
4092 D.Diag(diag::err_drv_argument_not_allowed_with)
4093 << MSCVersion->getAsString(Args)
4094 << MSCompatibilityVersion->getAsString(Args);
4095
4096 std::string Ver;
4097 if (MSCompatibilityVersion)
4098 Ver = Args.getLastArgValue(options::OPT_fms_compatibility_version);
4099 else if (MSCVersion)
4100 Ver = getMSCompatibilityVersion(MSCVersion->getValue());
4101
4102 if (Ver.empty())
Stephen Hines0e2c34f2015-03-23 12:09:02 -07004103 CmdArgs.push_back("-fms-compatibility-version=18.00");
Stephen Hines176edba2014-12-01 14:53:08 -08004104 else
4105 CmdArgs.push_back(Args.MakeArgString("-fms-compatibility-version=" + Ver));
4106 }
Michael J. Spencerdae4ac42010-10-21 05:21:48 +00004107
Eric Christophercfc01e42013-02-18 00:38:31 +00004108 // -fno-borland-extensions is default.
Dawn Perchik400b6072010-09-02 23:59:25 +00004109 if (Args.hasFlag(options::OPT_fborland_extensions,
4110 options::OPT_fno_borland_extensions, false))
4111 CmdArgs.push_back("-fborland-extensions");
4112
Francois Pichet8efcc012011-09-01 16:38:08 +00004113 // -fno-delayed-template-parsing is default, except for Windows where MSVC STL
4114 // needs it.
Francois Pichet8387e2a2011-04-22 22:18:13 +00004115 if (Args.hasFlag(options::OPT_fdelayed_template_parsing,
Stephen Hines651f13c2014-04-23 16:59:28 -07004116 options::OPT_fno_delayed_template_parsing, IsWindowsMSVC))
Francois Pichet805bc1f2011-08-26 00:22:34 +00004117 CmdArgs.push_back("-fdelayed-template-parsing");
Francois Pichet8387e2a2011-04-22 22:18:13 +00004118
Chandler Carrutheb5d7b72010-04-17 20:17:31 +00004119 // -fgnu-keywords default varies depending on language; only pass if
4120 // specified.
4121 if (Arg *A = Args.getLastArg(options::OPT_fgnu_keywords,
Daniel Dunbar40788d92010-04-24 17:56:39 +00004122 options::OPT_fno_gnu_keywords))
4123 A->render(Args, CmdArgs);
Chandler Carrutheb5d7b72010-04-17 20:17:31 +00004124
Rafael Espindola01ba8542011-06-02 17:30:53 +00004125 if (Args.hasFlag(options::OPT_fgnu89_inline,
4126 options::OPT_fno_gnu89_inline,
4127 false))
Rafael Espindolafb3f4aa2011-06-02 16:13:27 +00004128 CmdArgs.push_back("-fgnu89-inline");
4129
Chad Rosierfc055f92012-03-15 22:31:42 +00004130 if (Args.hasArg(options::OPT_fno_inline))
4131 CmdArgs.push_back("-fno-inline");
4132
Chad Rosier634a4b12012-03-06 21:17:19 +00004133 if (Args.hasArg(options::OPT_fno_inline_functions))
4134 CmdArgs.push_back("-fno-inline-functions");
Chad Rosier250008b2012-03-06 18:49:20 +00004135
John McCall260611a2012-06-20 06:18:46 +00004136 ObjCRuntime objcRuntime = AddObjCRuntimeArgs(Args, CmdArgs, rewriteKind);
John McCall9f084a32011-07-06 00:26:06 +00004137
John McCall260611a2012-06-20 06:18:46 +00004138 // -fobjc-dispatch-method is only relevant with the nonfragile-abi, and
Stephen Hines651f13c2014-04-23 16:59:28 -07004139 // legacy is the default. Except for deployment taget of 10.5,
4140 // next runtime is always legacy dispatch and -fno-objc-legacy-dispatch
4141 // gets ignored silently.
4142 if (objcRuntime.isNonFragile()) {
David Chisnall3c3ccd22011-09-30 13:32:35 +00004143 if (!Args.hasFlag(options::OPT_fobjc_legacy_dispatch,
4144 options::OPT_fno_objc_legacy_dispatch,
David Chisnall2c7886d2012-07-04 11:52:24 +00004145 objcRuntime.isLegacyDispatchDefaultForArch(
Eli Bendersky8f4269a2013-07-24 22:20:49 +00004146 getToolChain().getArch()))) {
David Chisnall3c3ccd22011-09-30 13:32:35 +00004147 if (getToolChain().UseObjCMixedDispatch())
4148 CmdArgs.push_back("-fobjc-dispatch-method=mixed");
4149 else
4150 CmdArgs.push_back("-fobjc-dispatch-method=non-legacy");
4151 }
4152 }
Rafael Espindola669496b2013-11-12 04:33:56 +00004153
Fariborz Jahanian5d5058c2013-11-12 17:08:46 +00004154 // When ObjectiveC legacy runtime is in effect on MacOSX,
4155 // turn on the option to do Array/Dictionary subscripting
4156 // by default.
Fariborz Jahanian08d86e92013-11-12 20:50:26 +00004157 if (getToolChain().getTriple().getArch() == llvm::Triple::x86 &&
4158 getToolChain().getTriple().isMacOSX() &&
4159 !getToolChain().getTriple().isMacOSXVersionLT(10, 7) &&
4160 objcRuntime.getKind() == ObjCRuntime::FragileMacOSX &&
Fariborz Jahanian5d5058c2013-11-12 17:08:46 +00004161 objcRuntime.isNeXTFamily())
4162 CmdArgs.push_back("-fobjc-subscripting-legacy-runtime");
4163
Fariborz Jahanian3d145f62012-11-15 19:02:45 +00004164 // -fencode-extended-block-signature=1 is default.
4165 if (getToolChain().IsEncodeExtendedBlockSignatureDefault()) {
4166 CmdArgs.push_back("-fencode-extended-block-signature");
4167 }
4168
John McCall9f084a32011-07-06 00:26:06 +00004169 // Allow -fno-objc-arr to trump -fobjc-arr/-fobjc-arc.
4170 // NOTE: This logic is duplicated in ToolChains.cpp.
4171 bool ARC = isObjCAutoRefCount(Args);
4172 if (ARC) {
John McCall0a7dd782012-08-21 02:47:43 +00004173 getToolChain().CheckObjCARC();
Argyrios Kyrtzidis5840dd92012-02-29 03:43:52 +00004174
John McCall9f084a32011-07-06 00:26:06 +00004175 CmdArgs.push_back("-fobjc-arc");
4176
Chandler Carruth7ffa0322011-11-04 07:34:47 +00004177 // FIXME: It seems like this entire block, and several around it should be
4178 // wrapped in isObjC, but for now we just use it here as this is where it
4179 // was being used previously.
4180 if (types::isCXX(InputType) && types::isObjC(InputType)) {
4181 if (getToolChain().GetCXXStdlibType(Args) == ToolChain::CST_Libcxx)
4182 CmdArgs.push_back("-fobjc-arc-cxxlib=libc++");
4183 else
4184 CmdArgs.push_back("-fobjc-arc-cxxlib=libstdc++");
4185 }
4186
John McCall9f084a32011-07-06 00:26:06 +00004187 // Allow the user to enable full exceptions code emission.
4188 // We define off for Objective-CC, on for Objective-C++.
4189 if (Args.hasFlag(options::OPT_fobjc_arc_exceptions,
4190 options::OPT_fno_objc_arc_exceptions,
4191 /*default*/ types::isCXX(InputType)))
4192 CmdArgs.push_back("-fobjc-arc-exceptions");
4193 }
4194
4195 // -fobjc-infer-related-result-type is the default, except in the Objective-C
4196 // rewriter.
John McCall260611a2012-06-20 06:18:46 +00004197 if (rewriteKind != RK_None)
John McCall9f084a32011-07-06 00:26:06 +00004198 CmdArgs.push_back("-fno-objc-infer-related-result-type");
Eric Christopher88b7cf02011-08-19 00:30:14 +00004199
John McCall9f084a32011-07-06 00:26:06 +00004200 // Handle -fobjc-gc and -fobjc-gc-only. They are exclusive, and -fobjc-gc-only
4201 // takes precedence.
4202 const Arg *GCArg = Args.getLastArg(options::OPT_fobjc_gc_only);
4203 if (!GCArg)
4204 GCArg = Args.getLastArg(options::OPT_fobjc_gc);
4205 if (GCArg) {
4206 if (ARC) {
Chris Lattner5f9e2722011-07-23 10:55:15 +00004207 D.Diag(diag::err_drv_objc_gc_arr)
John McCall9f084a32011-07-06 00:26:06 +00004208 << GCArg->getAsString(Args);
4209 } else if (getToolChain().SupportsObjCGC()) {
4210 GCArg->render(Args, CmdArgs);
4211 } else {
4212 // FIXME: We should move this to a hard error.
Chris Lattner5f9e2722011-07-23 10:55:15 +00004213 D.Diag(diag::warn_drv_objc_gc_unsupported)
John McCall9f084a32011-07-06 00:26:06 +00004214 << GCArg->getAsString(Args);
4215 }
4216 }
4217
Stephen Hinesef822542014-07-21 00:47:37 -07004218 // Handle GCC-style exception args.
4219 if (!C.getDriver().IsCLMode())
Stephen Hines0e2c34f2015-03-23 12:09:02 -07004220 addExceptionArgs(Args, InputType, getToolChain(), KernelOrKext,
Stephen Hinesef822542014-07-21 00:47:37 -07004221 objcRuntime, CmdArgs);
John McCalld71315c2011-06-22 00:53:57 +00004222
4223 if (getToolChain().UseSjLjExceptions())
4224 CmdArgs.push_back("-fsjlj-exceptions");
4225
4226 // C++ "sane" operator new.
Daniel Dunbar984eb862010-02-01 21:07:25 +00004227 if (!Args.hasFlag(options::OPT_fassume_sane_operator_new,
4228 options::OPT_fno_assume_sane_operator_new))
4229 CmdArgs.push_back("-fno-assume-sane-operator-new");
4230
Daniel Dunbarf35f14d2010-04-27 15:34:57 +00004231 // -fconstant-cfstrings is default, and may be subject to argument translation
4232 // on Darwin.
4233 if (!Args.hasFlag(options::OPT_fconstant_cfstrings,
4234 options::OPT_fno_constant_cfstrings) ||
4235 !Args.hasFlag(options::OPT_mconstant_cfstrings,
4236 options::OPT_mno_constant_cfstrings))
4237 CmdArgs.push_back("-fno-constant-cfstrings");
4238
John Thompsona6fda122009-11-05 20:14:16 +00004239 // -fshort-wchar default varies depending on platform; only
4240 // pass if specified.
Stephen Hines651f13c2014-04-23 16:59:28 -07004241 if (Arg *A = Args.getLastArg(options::OPT_fshort_wchar,
4242 options::OPT_fno_short_wchar))
Daniel Dunbar1744a352010-04-27 15:35:03 +00004243 A->render(Args, CmdArgs);
John Thompsona6fda122009-11-05 20:14:16 +00004244
Hans Wennborgb087a5d2013-07-31 23:39:13 +00004245 // -fno-pascal-strings is default, only pass non-default.
Daniel Dunbarc21c4852009-04-08 23:54:23 +00004246 if (Args.hasFlag(options::OPT_fpascal_strings,
Daniel Dunbar82d00682009-04-07 23:51:44 +00004247 options::OPT_fno_pascal_strings,
Daniel Dunbar82d00682009-04-07 23:51:44 +00004248 false))
Daniel Dunbar48d1ef72009-04-07 21:16:11 +00004249 CmdArgs.push_back("-fpascal-strings");
NAKAMURA Takumi125b4cb2011-02-17 08:50:50 +00004250
Daniel Dunbar88934e82011-10-05 21:04:55 +00004251 // Honor -fpack-struct= and -fpack-struct, if given. Note that
4252 // -fno-pack-struct doesn't apply to -fpack-struct=.
4253 if (Arg *A = Args.getLastArg(options::OPT_fpack_struct_EQ)) {
James Molloy8049c442012-05-02 07:56:14 +00004254 std::string PackStructStr = "-fpack-struct=";
Richard Smith1d489cf2012-11-01 04:30:05 +00004255 PackStructStr += A->getValue();
James Molloy8049c442012-05-02 07:56:14 +00004256 CmdArgs.push_back(Args.MakeArgString(PackStructStr));
Daniel Dunbar88934e82011-10-05 21:04:55 +00004257 } else if (Args.hasFlag(options::OPT_fpack_struct,
4258 options::OPT_fno_pack_struct, false)) {
James Molloy8049c442012-05-02 07:56:14 +00004259 CmdArgs.push_back("-fpack-struct=1");
Daniel Dunbar88934e82011-10-05 21:04:55 +00004260 }
4261
Stephen Hines176edba2014-12-01 14:53:08 -08004262 // Handle -fmax-type-align=N and -fno-type-align
4263 bool SkipMaxTypeAlign = Args.hasArg(options::OPT_fno_max_type_align);
4264 if (Arg *A = Args.getLastArg(options::OPT_fmax_type_align_EQ)) {
4265 if (!SkipMaxTypeAlign) {
4266 std::string MaxTypeAlignStr = "-fmax-type-align=";
4267 MaxTypeAlignStr += A->getValue();
4268 CmdArgs.push_back(Args.MakeArgString(MaxTypeAlignStr));
4269 }
4270 } else if (getToolChain().getTriple().isOSDarwin()) {
4271 if (!SkipMaxTypeAlign) {
4272 std::string MaxTypeAlignStr = "-fmax-type-align=16";
4273 CmdArgs.push_back(Args.MakeArgString(MaxTypeAlignStr));
4274 }
4275 }
4276
Robert Lytton5f15f4d2013-08-13 09:43:10 +00004277 if (KernelOrKext || isNoCommonDefault(getToolChain().getTriple())) {
Fariborz Jahanianb466d012011-01-07 01:05:02 +00004278 if (!Args.hasArg(options::OPT_fcommon))
4279 CmdArgs.push_back("-fno-common");
Chad Rosierec09b3e2012-03-26 21:35:40 +00004280 Args.ClaimAllArgs(options::OPT_fno_common);
Fariborz Jahanianb466d012011-01-07 01:05:02 +00004281 }
Daniel Dunbar88934e82011-10-05 21:04:55 +00004282
Daniel Dunbar48d1ef72009-04-07 21:16:11 +00004283 // -fcommon is default, only pass non-default.
Fariborz Jahanianb466d012011-01-07 01:05:02 +00004284 else if (!Args.hasFlag(options::OPT_fcommon, options::OPT_fno_common))
Daniel Dunbar48d1ef72009-04-07 21:16:11 +00004285 CmdArgs.push_back("-fno-common");
4286
Daniel Dunbar70d3c922009-04-15 02:37:43 +00004287 // -fsigned-bitfields is default, and clang doesn't yet support
Daniel Dunbar06205ca2010-10-15 22:30:42 +00004288 // -funsigned-bitfields.
Mike Stump1eb44332009-09-09 15:08:12 +00004289 if (!Args.hasFlag(options::OPT_fsigned_bitfields,
Daniel Dunbar70d3c922009-04-15 02:37:43 +00004290 options::OPT_funsigned_bitfields))
Chris Lattner5f9e2722011-07-23 10:55:15 +00004291 D.Diag(diag::warn_drv_clang_unsupported)
Daniel Dunbar70d3c922009-04-15 02:37:43 +00004292 << Args.getLastArg(options::OPT_funsigned_bitfields)->getAsString(Args);
4293
Daniel Dunbar06205ca2010-10-15 22:30:42 +00004294 // -fsigned-bitfields is default, and clang doesn't support -fno-for-scope.
4295 if (!Args.hasFlag(options::OPT_ffor_scope,
4296 options::OPT_fno_for_scope))
Chris Lattner5f9e2722011-07-23 10:55:15 +00004297 D.Diag(diag::err_drv_clang_unsupported)
Daniel Dunbar06205ca2010-10-15 22:30:42 +00004298 << Args.getLastArg(options::OPT_fno_for_scope)->getAsString(Args);
4299
Stephen Hinesef822542014-07-21 00:47:37 -07004300 // -finput_charset=UTF-8 is default. Reject others
4301 if (Arg *inputCharset = Args.getLastArg(
4302 options::OPT_finput_charset_EQ)) {
4303 StringRef value = inputCharset->getValue();
4304 if (value != "UTF-8")
4305 D.Diag(diag::err_drv_invalid_value) << inputCharset->getAsString(Args) << value;
4306 }
4307
Stephen Hines176edba2014-12-01 14:53:08 -08004308 // -fexec_charset=UTF-8 is default. Reject others
4309 if (Arg *execCharset = Args.getLastArg(
4310 options::OPT_fexec_charset_EQ)) {
4311 StringRef value = execCharset->getValue();
4312 if (value != "UTF-8")
4313 D.Diag(diag::err_drv_invalid_value) << execCharset->getAsString(Args) << value;
4314 }
4315
Jeffrey Yasskin0ea22fd2010-06-08 04:56:20 +00004316 // -fcaret-diagnostics is default.
4317 if (!Args.hasFlag(options::OPT_fcaret_diagnostics,
4318 options::OPT_fno_caret_diagnostics, true))
4319 CmdArgs.push_back("-fno-caret-diagnostics");
4320
Daniel Dunbar49138fc2009-04-19 21:09:34 +00004321 // -fdiagnostics-fixit-info is default, only pass non-default.
Mike Stump1eb44332009-09-09 15:08:12 +00004322 if (!Args.hasFlag(options::OPT_fdiagnostics_fixit_info,
Daniel Dunbar49138fc2009-04-19 21:09:34 +00004323 options::OPT_fno_diagnostics_fixit_info))
4324 CmdArgs.push_back("-fno-diagnostics-fixit-info");
Eric Christopher88b7cf02011-08-19 00:30:14 +00004325
Daniel Dunbar9e820ee2009-04-16 06:32:38 +00004326 // Enable -fdiagnostics-show-option by default.
Mike Stump1eb44332009-09-09 15:08:12 +00004327 if (Args.hasFlag(options::OPT_fdiagnostics_show_option,
Daniel Dunbar9e820ee2009-04-16 06:32:38 +00004328 options::OPT_fno_diagnostics_show_option))
4329 CmdArgs.push_back("-fdiagnostics-show-option");
Daniel Dunbar838be482009-11-04 06:24:57 +00004330
Chris Lattner6fbe8392010-05-04 21:55:25 +00004331 if (const Arg *A =
4332 Args.getLastArg(options::OPT_fdiagnostics_show_category_EQ)) {
4333 CmdArgs.push_back("-fdiagnostics-show-category");
Richard Smith1d489cf2012-11-01 04:30:05 +00004334 CmdArgs.push_back(A->getValue());
Chris Lattner6fbe8392010-05-04 21:55:25 +00004335 }
Daniel Dunbarca0e0542010-08-24 16:47:49 +00004336
Douglas Gregorc9471b02011-05-21 17:07:29 +00004337 if (const Arg *A =
4338 Args.getLastArg(options::OPT_fdiagnostics_format_EQ)) {
4339 CmdArgs.push_back("-fdiagnostics-format");
Richard Smith1d489cf2012-11-01 04:30:05 +00004340 CmdArgs.push_back(A->getValue());
Douglas Gregorc9471b02011-05-21 17:07:29 +00004341 }
4342
Chandler Carruthabaca7a2011-03-27 01:50:55 +00004343 if (Arg *A = Args.getLastArg(
4344 options::OPT_fdiagnostics_show_note_include_stack,
4345 options::OPT_fno_diagnostics_show_note_include_stack)) {
4346 if (A->getOption().matches(
4347 options::OPT_fdiagnostics_show_note_include_stack))
4348 CmdArgs.push_back("-fdiagnostics-show-note-include-stack");
4349 else
4350 CmdArgs.push_back("-fno-diagnostics-show-note-include-stack");
4351 }
4352
Daniel Dunbar838be482009-11-04 06:24:57 +00004353 // Color diagnostics are the default, unless the terminal doesn't support
4354 // them.
Nico Weber9753d462013-04-17 21:52:44 +00004355 // Support both clang's -f[no-]color-diagnostics and gcc's
4356 // -f[no-]diagnostics-colors[=never|always|auto].
4357 enum { Colors_On, Colors_Off, Colors_Auto } ShowColors = Colors_Auto;
Stephen Hinesef822542014-07-21 00:47:37 -07004358 for (const auto &Arg : Args) {
4359 const Option &O = Arg->getOption();
Nico Weber9753d462013-04-17 21:52:44 +00004360 if (!O.matches(options::OPT_fcolor_diagnostics) &&
4361 !O.matches(options::OPT_fdiagnostics_color) &&
4362 !O.matches(options::OPT_fno_color_diagnostics) &&
4363 !O.matches(options::OPT_fno_diagnostics_color) &&
4364 !O.matches(options::OPT_fdiagnostics_color_EQ))
4365 continue;
4366
Stephen Hinesef822542014-07-21 00:47:37 -07004367 Arg->claim();
Nico Weber9753d462013-04-17 21:52:44 +00004368 if (O.matches(options::OPT_fcolor_diagnostics) ||
4369 O.matches(options::OPT_fdiagnostics_color)) {
4370 ShowColors = Colors_On;
4371 } else if (O.matches(options::OPT_fno_color_diagnostics) ||
4372 O.matches(options::OPT_fno_diagnostics_color)) {
4373 ShowColors = Colors_Off;
4374 } else {
4375 assert(O.matches(options::OPT_fdiagnostics_color_EQ));
Stephen Hinesef822542014-07-21 00:47:37 -07004376 StringRef value(Arg->getValue());
Nico Weber9753d462013-04-17 21:52:44 +00004377 if (value == "always")
4378 ShowColors = Colors_On;
4379 else if (value == "never")
4380 ShowColors = Colors_Off;
4381 else if (value == "auto")
4382 ShowColors = Colors_Auto;
4383 else
4384 getToolChain().getDriver().Diag(diag::err_drv_clang_unsupported)
4385 << ("-fdiagnostics-color=" + value).str();
4386 }
4387 }
4388 if (ShowColors == Colors_On ||
4389 (ShowColors == Colors_Auto && llvm::sys::Process::StandardErrHasColors()))
Daniel Dunbar838be482009-11-04 06:24:57 +00004390 CmdArgs.push_back("-fcolor-diagnostics");
4391
Nico Rieck2956ef42013-09-11 00:38:02 +00004392 if (Args.hasArg(options::OPT_fansi_escape_codes))
4393 CmdArgs.push_back("-fansi-escape-codes");
4394
Daniel Dunbar75eb1d62009-06-08 21:13:54 +00004395 if (!Args.hasFlag(options::OPT_fshow_source_location,
4396 options::OPT_fno_show_source_location))
4397 CmdArgs.push_back("-fno-show-source-location");
Daniel Dunbar9e820ee2009-04-16 06:32:38 +00004398
Douglas Gregorc9471b02011-05-21 17:07:29 +00004399 if (!Args.hasFlag(options::OPT_fshow_column,
4400 options::OPT_fno_show_column,
4401 true))
4402 CmdArgs.push_back("-fno-show-column");
4403
Douglas Gregora0068fc2010-07-09 17:35:33 +00004404 if (!Args.hasFlag(options::OPT_fspell_checking,
4405 options::OPT_fno_spell_checking))
4406 CmdArgs.push_back("-fno-spell-checking");
Daniel Dunbarca0e0542010-08-24 16:47:49 +00004407
Daniel Dunbar25b26eb2010-10-18 22:49:46 +00004408
Chad Rosier15490fd2012-12-05 21:08:21 +00004409 // -fno-asm-blocks is default.
4410 if (Args.hasFlag(options::OPT_fasm_blocks, options::OPT_fno_asm_blocks,
4411 false))
4412 CmdArgs.push_back("-fasm-blocks");
Daniel Dunbar25b26eb2010-10-18 22:49:46 +00004413
Stephen Hines0e2c34f2015-03-23 12:09:02 -07004414 // -fgnu-inline-asm is default.
4415 if (!Args.hasFlag(options::OPT_fgnu_inline_asm,
4416 options::OPT_fno_gnu_inline_asm, true))
4417 CmdArgs.push_back("-fno-gnu-inline-asm");
4418
Arnold Schwaighofer99662a12013-08-13 15:46:23 +00004419 // Enable vectorization per default according to the optimization level
4420 // selected. For optimization levels that want vectorization we use the alias
4421 // option to simplify the hasFlag logic.
Stephen Hines6bcf27b2014-05-29 04:14:42 -07004422 bool EnableVec = shouldEnableVectorizerAtOLevel(Args, false);
Arnold Schwaighofer99662a12013-08-13 15:46:23 +00004423 OptSpecifier VectorizeAliasOption = EnableVec ? options::OPT_O_Group :
Chad Rosier31422792013-04-24 18:29:59 +00004424 options::OPT_fvectorize;
Chad Rosier31422792013-04-24 18:29:59 +00004425 if (Args.hasFlag(options::OPT_fvectorize, VectorizeAliasOption,
Hal Finkelcf5691e2013-08-28 05:21:45 +00004426 options::OPT_fno_vectorize, EnableVec))
Chad Rosierc04d0932012-12-11 17:12:28 +00004427 CmdArgs.push_back("-vectorize-loops");
Chad Rosierc04d0932012-12-11 17:12:28 +00004428
Stephen Hines6bcf27b2014-05-29 04:14:42 -07004429 // -fslp-vectorize is enabled based on the optimization level selected.
4430 bool EnableSLPVec = shouldEnableVectorizerAtOLevel(Args, true);
4431 OptSpecifier SLPVectAliasOption = EnableSLPVec ? options::OPT_O_Group :
4432 options::OPT_fslp_vectorize;
4433 if (Args.hasFlag(options::OPT_fslp_vectorize, SLPVectAliasOption,
4434 options::OPT_fno_slp_vectorize, EnableSLPVec))
Nadav Rotem50ea9632013-04-15 04:57:18 +00004435 CmdArgs.push_back("-vectorize-slp");
Hal Finkel443c9992012-12-11 19:59:32 +00004436
Nadav Rotem3c6a9b02013-04-15 05:38:41 +00004437 // -fno-slp-vectorize-aggressive is default.
4438 if (Args.hasFlag(options::OPT_fslp_vectorize_aggressive,
Nick Lewyckyfdf137b2013-06-25 01:49:44 +00004439 options::OPT_fno_slp_vectorize_aggressive, false))
Nadav Rotem3c6a9b02013-04-15 05:38:41 +00004440 CmdArgs.push_back("-vectorize-slp-aggressive");
Nadav Rotem3c6a9b02013-04-15 05:38:41 +00004441
Jeffrey Yasskin5edbdcc2010-06-11 05:57:47 +00004442 if (Arg *A = Args.getLastArg(options::OPT_fshow_overloads_EQ))
4443 A->render(Args, CmdArgs);
4444
Daniel Dunbar7695fba2009-04-19 21:20:32 +00004445 // -fdollars-in-identifiers default varies depending on platform and
4446 // language; only pass if specified.
Mike Stump1eb44332009-09-09 15:08:12 +00004447 if (Arg *A = Args.getLastArg(options::OPT_fdollars_in_identifiers,
Daniel Dunbar7695fba2009-04-19 21:20:32 +00004448 options::OPT_fno_dollars_in_identifiers)) {
4449 if (A->getOption().matches(options::OPT_fdollars_in_identifiers))
Daniel Dunbar8663b182009-12-16 20:10:18 +00004450 CmdArgs.push_back("-fdollars-in-identifiers");
Daniel Dunbar7695fba2009-04-19 21:20:32 +00004451 else
Daniel Dunbar8663b182009-12-16 20:10:18 +00004452 CmdArgs.push_back("-fno-dollars-in-identifiers");
Daniel Dunbar7695fba2009-04-19 21:20:32 +00004453 }
4454
Daniel Dunbare027a4b2009-05-22 19:02:20 +00004455 // -funit-at-a-time is default, and we don't support -fno-unit-at-a-time for
4456 // practical purposes.
Mike Stump1eb44332009-09-09 15:08:12 +00004457 if (Arg *A = Args.getLastArg(options::OPT_funit_at_a_time,
Daniel Dunbare027a4b2009-05-22 19:02:20 +00004458 options::OPT_fno_unit_at_a_time)) {
4459 if (A->getOption().matches(options::OPT_fno_unit_at_a_time))
Chris Lattner5f9e2722011-07-23 10:55:15 +00004460 D.Diag(diag::warn_drv_clang_unsupported) << A->getAsString(Args);
Daniel Dunbare027a4b2009-05-22 19:02:20 +00004461 }
Eli Friedmanceb5c5b2009-07-14 21:58:17 +00004462
Eli Friedman19bda3a2011-11-02 01:53:16 +00004463 if (Args.hasFlag(options::OPT_fapple_pragma_pack,
4464 options::OPT_fno_apple_pragma_pack, false))
4465 CmdArgs.push_back("-fapple-pragma-pack");
4466
Eli Benderskyf3ecf892013-07-24 18:20:14 +00004467 // le32-specific flags:
4468 // -fno-math-builtin: clang should not convert math builtins to intrinsics
4469 // by default.
4470 if (getToolChain().getArch() == llvm::Triple::le32) {
4471 CmdArgs.push_back("-fno-math-builtin");
4472 }
4473
Daniel Dunbar2ba91572009-09-10 03:37:02 +00004474 // Default to -fno-builtin-str{cat,cpy} on Darwin for ARM.
Daniel Dunbarf84a4a42009-09-10 04:57:27 +00004475 //
Daniel Dunbar8ff5b282009-12-11 23:00:49 +00004476 // FIXME: This is disabled until clang -cc1 supports -fno-builtin-foo. PR4941.
Daniel Dunbarf84a4a42009-09-10 04:57:27 +00004477#if 0
Bob Wilson905c45f2011-10-14 05:03:44 +00004478 if (getToolChain().getTriple().isOSDarwin() &&
Eli Bendersky8f4269a2013-07-24 22:20:49 +00004479 (getToolChain().getArch() == llvm::Triple::arm ||
4480 getToolChain().getArch() == llvm::Triple::thumb)) {
Daniel Dunbar2ba91572009-09-10 03:37:02 +00004481 if (!Args.hasArg(options::OPT_fbuiltin_strcat))
4482 CmdArgs.push_back("-fno-builtin-strcat");
4483 if (!Args.hasArg(options::OPT_fbuiltin_strcpy))
4484 CmdArgs.push_back("-fno-builtin-strcpy");
4485 }
Daniel Dunbarf84a4a42009-09-10 04:57:27 +00004486#endif
Daniel Dunbar2ba91572009-09-10 03:37:02 +00004487
Stephen Hinesef822542014-07-21 00:47:37 -07004488 // Enable rewrite includes if the user's asked for it or if we're generating
4489 // diagnostics.
4490 // TODO: Once -module-dependency-dir works with -frewrite-includes it'd be
4491 // nice to enable this when doing a crashdump for modules as well.
4492 if (Args.hasFlag(options::OPT_frewrite_includes,
4493 options::OPT_fno_rewrite_includes, false) ||
4494 (C.isForDiagnostics() && !HaveModules))
4495 CmdArgs.push_back("-frewrite-includes");
4496
Daniel Dunbard98750f2011-03-18 21:23:40 +00004497 // Only allow -traditional or -traditional-cpp outside in preprocessing modes.
Mike Stump1eb44332009-09-09 15:08:12 +00004498 if (Arg *A = Args.getLastArg(options::OPT_traditional,
Daniel Dunbard98750f2011-03-18 21:23:40 +00004499 options::OPT_traditional_cpp)) {
4500 if (isa<PreprocessJobAction>(JA))
4501 CmdArgs.push_back("-traditional-cpp");
Eric Christopher88b7cf02011-08-19 00:30:14 +00004502 else
Chris Lattner5f9e2722011-07-23 10:55:15 +00004503 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
Daniel Dunbard98750f2011-03-18 21:23:40 +00004504 }
Eli Friedmanceb5c5b2009-07-14 21:58:17 +00004505
Daniel Dunbar1d460332009-03-18 10:01:51 +00004506 Args.AddLastArg(CmdArgs, options::OPT_dM);
Chris Lattnerd82df3a2009-04-12 01:56:53 +00004507 Args.AddLastArg(CmdArgs, options::OPT_dD);
Ted Kremenek36f6e302011-11-11 00:07:43 +00004508
4509 // Handle serialized diagnostics.
4510 if (Arg *A = Args.getLastArg(options::OPT__serialize_diags)) {
4511 CmdArgs.push_back("-serialize-diagnostic-file");
Richard Smith1d489cf2012-11-01 04:30:05 +00004512 CmdArgs.push_back(Args.MakeArgString(A->getValue()));
Ted Kremenek36f6e302011-11-11 00:07:43 +00004513 }
Daniel Dunbar1d460332009-03-18 10:01:51 +00004514
Ted Kremenek127ff2e2012-09-13 06:41:18 +00004515 if (Args.hasArg(options::OPT_fretain_comments_from_system_headers))
4516 CmdArgs.push_back("-fretain-comments-from-system-headers");
4517
Dmitri Gribenko6ebf0912013-02-22 14:21:27 +00004518 // Forward -fcomment-block-commands to -cc1.
4519 Args.AddAllArgs(CmdArgs, options::OPT_fcomment_block_commands);
Dmitri Gribenko6fd7d302013-04-10 15:35:17 +00004520 // Forward -fparse-all-comments to -cc1.
4521 Args.AddAllArgs(CmdArgs, options::OPT_fparse_all_comments);
Dmitri Gribenko6ebf0912013-02-22 14:21:27 +00004522
Daniel Dunbar3f87fb02010-04-15 06:09:03 +00004523 // Forward -Xclang arguments to -cc1, and -mllvm arguments to the LLVM option
4524 // parser.
Daniel Dunbar1d460332009-03-18 10:01:51 +00004525 Args.AddAllArgValues(CmdArgs, options::OPT_Xclang);
Stephen Hines0e2c34f2015-03-23 12:09:02 -07004526 bool OptDisabled = false;
Daniel Dunbar3f87fb02010-04-15 06:09:03 +00004527 for (arg_iterator it = Args.filtered_begin(options::OPT_mllvm),
4528 ie = Args.filtered_end(); it != ie; ++it) {
Daniel Dunbar7e4953e2010-06-11 22:00:13 +00004529 (*it)->claim();
Daniel Dunbarfb36d212010-04-17 06:10:00 +00004530
Daniel Dunbar3f87fb02010-04-15 06:09:03 +00004531 // We translate this by hand to the -cc1 argument, since nightly test uses
4532 // it and developers have been trained to spell it with -mllvm.
Stephen Hines0e2c34f2015-03-23 12:09:02 -07004533 if (StringRef((*it)->getValue(0)) == "-disable-llvm-optzns") {
Daniel Dunbar3f87fb02010-04-15 06:09:03 +00004534 CmdArgs.push_back("-disable-llvm-optzns");
Stephen Hines0e2c34f2015-03-23 12:09:02 -07004535 OptDisabled = true;
4536 } else
Daniel Dunbar7e4953e2010-06-11 22:00:13 +00004537 (*it)->render(Args, CmdArgs);
Daniel Dunbar3f87fb02010-04-15 06:09:03 +00004538 }
Daniel Dunbar1d460332009-03-18 10:01:51 +00004539
Stephen Hines0e2c34f2015-03-23 12:09:02 -07004540 // With -save-temps, we want to save the unoptimized bitcode output from the
4541 // CompileJobAction, so disable optimizations if they are not already
4542 // disabled.
4543 if (C.getDriver().isSaveTempsEnabled() && !OptDisabled &&
4544 isa<CompileJobAction>(JA))
4545 CmdArgs.push_back("-disable-llvm-optzns");
4546
Daniel Dunbarcd8e4c42009-03-30 06:36:42 +00004547 if (Output.getType() == types::TY_Dependencies) {
4548 // Handled with other dependency code.
Daniel Dunbar115a7922009-03-19 07:29:38 +00004549 } else if (Output.isFilename()) {
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00004550 CmdArgs.push_back("-o");
Daniel Dunbar115a7922009-03-19 07:29:38 +00004551 CmdArgs.push_back(Output.getFilename());
4552 } else {
4553 assert(Output.isNothing() && "Invalid output.");
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00004554 }
4555
Stephen Hinesef822542014-07-21 00:47:37 -07004556 for (const auto &II : Inputs) {
Stephen Hines651f13c2014-04-23 16:59:28 -07004557 addDashXForInput(Args, II, CmdArgs);
4558
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00004559 if (II.isFilename())
Daniel Dunbar115a7922009-03-19 07:29:38 +00004560 CmdArgs.push_back(II.getFilename());
Daniel Dunbar1d460332009-03-18 10:01:51 +00004561 else
Daniel Dunbar115a7922009-03-19 07:29:38 +00004562 II.getInputArg().renderAsInput(Args, CmdArgs);
Daniel Dunbar1d460332009-03-18 10:01:51 +00004563 }
Daniel Dunbarc21c4852009-04-08 23:54:23 +00004564
Chris Lattnere6113de2009-11-03 19:50:27 +00004565 Args.AddAllArgs(CmdArgs, options::OPT_undef);
4566
Daniel Dunbara001c1c2010-07-18 21:16:15 +00004567 const char *Exec = getToolChain().getDriver().getClangProgramPath();
Daniel Dunbarf2d8b9f2009-12-18 02:43:17 +00004568
4569 // Optionally embed the -cc1 level arguments into the debug info, for build
4570 // analysis.
4571 if (getToolChain().UseDwarfDebugFlags()) {
Daniel Dunbar6e900472010-06-04 18:47:06 +00004572 ArgStringList OriginalArgs;
Stephen Hinesef822542014-07-21 00:47:37 -07004573 for (const auto &Arg : Args)
4574 Arg->render(Args, OriginalArgs);
Daniel Dunbarca0e0542010-08-24 16:47:49 +00004575
Dylan Noblesmithf7ccbad2012-02-05 02:13:05 +00004576 SmallString<256> Flags;
Daniel Dunbarf2d8b9f2009-12-18 02:43:17 +00004577 Flags += Exec;
Daniel Dunbar6e900472010-06-04 18:47:06 +00004578 for (unsigned i = 0, e = OriginalArgs.size(); i != e; ++i) {
Stephen Hines176edba2014-12-01 14:53:08 -08004579 SmallString<128> EscapedArg;
4580 EscapeSpacesAndBackslashes(OriginalArgs[i], EscapedArg);
Daniel Dunbarf2d8b9f2009-12-18 02:43:17 +00004581 Flags += " ";
Stephen Hines176edba2014-12-01 14:53:08 -08004582 Flags += EscapedArg;
Daniel Dunbarf2d8b9f2009-12-18 02:43:17 +00004583 }
4584 CmdArgs.push_back("-dwarf-debug-flags");
4585 CmdArgs.push_back(Args.MakeArgString(Flags.str()));
4586 }
4587
Eric Christopher80190392013-02-22 20:12:52 +00004588 // Add the split debug info name to the command lines here so we
4589 // can propagate it to the backend.
4590 bool SplitDwarf = Args.hasArg(options::OPT_gsplit_dwarf) &&
Cameron Esfahani57b1da12013-09-14 01:09:11 +00004591 getToolChain().getTriple().isOSLinux() &&
Stephen Hines0e2c34f2015-03-23 12:09:02 -07004592 (isa<AssembleJobAction>(JA) || isa<CompileJobAction>(JA) ||
4593 isa<BackendJobAction>(JA));
Eric Christopher80190392013-02-22 20:12:52 +00004594 const char *SplitDwarfOut;
4595 if (SplitDwarf) {
4596 CmdArgs.push_back("-split-dwarf-file");
4597 SplitDwarfOut = SplitDebugName(Args, Inputs);
4598 CmdArgs.push_back(SplitDwarfOut);
4599 }
4600
4601 // Finally add the compile command to the compilation.
Stephen Hines651f13c2014-04-23 16:59:28 -07004602 if (Args.hasArg(options::OPT__SLASH_fallback) &&
Stephen Hines6bcf27b2014-05-29 04:14:42 -07004603 Output.getType() == types::TY_Object &&
4604 (InputType == types::TY_C || InputType == types::TY_CXX)) {
Stephen Hines176edba2014-12-01 14:53:08 -08004605 auto CLCommand =
4606 getCLFallback()->GetCommand(C, JA, Output, Inputs, Args, LinkingOutput);
4607 C.addCommand(llvm::make_unique<FallbackCommand>(JA, *this, Exec, CmdArgs,
4608 std::move(CLCommand)));
Hans Wennborgc8ba0a02013-09-19 20:32:16 +00004609 } else {
Stephen Hines176edba2014-12-01 14:53:08 -08004610 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Hans Wennborgc8ba0a02013-09-19 20:32:16 +00004611 }
4612
Daniel Dunbara880db02009-03-23 19:03:36 +00004613
Eric Christopherff971d72013-02-22 23:50:16 +00004614 // Handle the debug info splitting at object creation time if we're
4615 // creating an object.
Eric Christopher59320e72013-02-21 22:35:01 +00004616 // TODO: Currently only works on linux with newer objcopy.
Stephen Hines0e2c34f2015-03-23 12:09:02 -07004617 if (SplitDwarf && !isa<CompileJobAction>(JA) && !isa<BackendJobAction>(JA))
Eric Christopher80190392013-02-22 20:12:52 +00004618 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output, SplitDwarfOut);
Eric Christopher59320e72013-02-21 22:35:01 +00004619
Roman Divackybe4c8702011-02-10 16:52:03 +00004620 if (Arg *A = Args.getLastArg(options::OPT_pg))
4621 if (Args.hasArg(options::OPT_fomit_frame_pointer))
Chris Lattner5f9e2722011-07-23 10:55:15 +00004622 D.Diag(diag::err_drv_argument_not_allowed_with)
Roman Divackybe4c8702011-02-10 16:52:03 +00004623 << "-fomit-frame-pointer" << A->getAsString(Args);
Michael J. Spencer20249a12010-10-21 03:16:25 +00004624
Daniel Dunbar68fb4692009-04-03 20:51:31 +00004625 // Claim some arguments which clang supports automatically.
4626
Daniel Dunbarf4046862010-04-15 06:18:42 +00004627 // -fpch-preprocess is used with gcc to add a special marker in the output to
4628 // include the PCH file. Clang's PTH solution is completely transparent, so we
4629 // do not need to deal with it at all.
Daniel Dunbar68fb4692009-04-03 20:51:31 +00004630 Args.ClaimAllArgs(options::OPT_fpch_preprocess);
Daniel Dunbarc21c4852009-04-08 23:54:23 +00004631
Daniel Dunbara880db02009-03-23 19:03:36 +00004632 // Claim some arguments which clang doesn't support, but we don't
4633 // care to warn the user about.
Daniel Dunbarcdd96862009-11-25 11:53:23 +00004634 Args.ClaimAllArgs(options::OPT_clang_ignored_f_Group);
4635 Args.ClaimAllArgs(options::OPT_clang_ignored_m_Group);
Rafael Espindola035ff0c2011-02-28 23:29:45 +00004636
Rafael Espindola6155fbe2013-09-04 19:37:35 +00004637 // Disable warnings for clang -E -emit-llvm foo.c
Rafael Espindola9c094fb2011-03-01 05:25:27 +00004638 Args.ClaimAllArgs(options::OPT_emit_llvm);
Daniel Dunbar47ac7d22009-03-18 06:00:36 +00004639}
4640
John McCall260611a2012-06-20 06:18:46 +00004641/// Add options related to the Objective-C runtime/ABI.
4642///
4643/// Returns true if the runtime is non-fragile.
4644ObjCRuntime Clang::AddObjCRuntimeArgs(const ArgList &args,
4645 ArgStringList &cmdArgs,
4646 RewriteKind rewriteKind) const {
4647 // Look for the controlling runtime option.
4648 Arg *runtimeArg = args.getLastArg(options::OPT_fnext_runtime,
4649 options::OPT_fgnu_runtime,
4650 options::OPT_fobjc_runtime_EQ);
4651
4652 // Just forward -fobjc-runtime= to the frontend. This supercedes
4653 // options about fragility.
4654 if (runtimeArg &&
4655 runtimeArg->getOption().matches(options::OPT_fobjc_runtime_EQ)) {
4656 ObjCRuntime runtime;
Richard Smith1d489cf2012-11-01 04:30:05 +00004657 StringRef value = runtimeArg->getValue();
John McCall260611a2012-06-20 06:18:46 +00004658 if (runtime.tryParse(value)) {
4659 getToolChain().getDriver().Diag(diag::err_drv_unknown_objc_runtime)
4660 << value;
4661 }
4662
4663 runtimeArg->render(args, cmdArgs);
4664 return runtime;
4665 }
4666
4667 // Otherwise, we'll need the ABI "version". Version numbers are
4668 // slightly confusing for historical reasons:
4669 // 1 - Traditional "fragile" ABI
4670 // 2 - Non-fragile ABI, version 1
4671 // 3 - Non-fragile ABI, version 2
4672 unsigned objcABIVersion = 1;
4673 // If -fobjc-abi-version= is present, use that to set the version.
4674 if (Arg *abiArg = args.getLastArg(options::OPT_fobjc_abi_version_EQ)) {
Richard Smith1d489cf2012-11-01 04:30:05 +00004675 StringRef value = abiArg->getValue();
John McCall260611a2012-06-20 06:18:46 +00004676 if (value == "1")
4677 objcABIVersion = 1;
4678 else if (value == "2")
4679 objcABIVersion = 2;
4680 else if (value == "3")
4681 objcABIVersion = 3;
4682 else
4683 getToolChain().getDriver().Diag(diag::err_drv_clang_unsupported)
4684 << value;
4685 } else {
4686 // Otherwise, determine if we are using the non-fragile ABI.
4687 bool nonFragileABIIsDefault =
4688 (rewriteKind == RK_NonFragile ||
4689 (rewriteKind == RK_None &&
4690 getToolChain().IsObjCNonFragileABIDefault()));
4691 if (args.hasFlag(options::OPT_fobjc_nonfragile_abi,
4692 options::OPT_fno_objc_nonfragile_abi,
4693 nonFragileABIIsDefault)) {
4694 // Determine the non-fragile ABI version to use.
4695#ifdef DISABLE_DEFAULT_NONFRAGILEABI_TWO
4696 unsigned nonFragileABIVersion = 1;
4697#else
4698 unsigned nonFragileABIVersion = 2;
4699#endif
4700
4701 if (Arg *abiArg = args.getLastArg(
4702 options::OPT_fobjc_nonfragile_abi_version_EQ)) {
Richard Smith1d489cf2012-11-01 04:30:05 +00004703 StringRef value = abiArg->getValue();
John McCall260611a2012-06-20 06:18:46 +00004704 if (value == "1")
4705 nonFragileABIVersion = 1;
4706 else if (value == "2")
4707 nonFragileABIVersion = 2;
4708 else
4709 getToolChain().getDriver().Diag(diag::err_drv_clang_unsupported)
4710 << value;
4711 }
4712
4713 objcABIVersion = 1 + nonFragileABIVersion;
4714 } else {
4715 objcABIVersion = 1;
4716 }
4717 }
4718
4719 // We don't actually care about the ABI version other than whether
4720 // it's non-fragile.
4721 bool isNonFragile = objcABIVersion != 1;
4722
4723 // If we have no runtime argument, ask the toolchain for its default runtime.
4724 // However, the rewriter only really supports the Mac runtime, so assume that.
4725 ObjCRuntime runtime;
4726 if (!runtimeArg) {
4727 switch (rewriteKind) {
4728 case RK_None:
4729 runtime = getToolChain().getDefaultObjCRuntime(isNonFragile);
4730 break;
4731 case RK_Fragile:
4732 runtime = ObjCRuntime(ObjCRuntime::FragileMacOSX, VersionTuple());
4733 break;
4734 case RK_NonFragile:
4735 runtime = ObjCRuntime(ObjCRuntime::MacOSX, VersionTuple());
4736 break;
4737 }
4738
4739 // -fnext-runtime
4740 } else if (runtimeArg->getOption().matches(options::OPT_fnext_runtime)) {
4741 // On Darwin, make this use the default behavior for the toolchain.
4742 if (getToolChain().getTriple().isOSDarwin()) {
4743 runtime = getToolChain().getDefaultObjCRuntime(isNonFragile);
4744
4745 // Otherwise, build for a generic macosx port.
4746 } else {
4747 runtime = ObjCRuntime(ObjCRuntime::MacOSX, VersionTuple());
4748 }
4749
4750 // -fgnu-runtime
4751 } else {
4752 assert(runtimeArg->getOption().matches(options::OPT_fgnu_runtime));
David Chisnalla422cd02012-07-04 10:37:03 +00004753 // Legacy behaviour is to target the gnustep runtime if we are i
4754 // non-fragile mode or the GCC runtime in fragile mode.
4755 if (isNonFragile)
David Chisnall891dac72012-10-16 15:11:55 +00004756 runtime = ObjCRuntime(ObjCRuntime::GNUstep, VersionTuple(1,6));
David Chisnalla422cd02012-07-04 10:37:03 +00004757 else
4758 runtime = ObjCRuntime(ObjCRuntime::GCC, VersionTuple());
John McCall260611a2012-06-20 06:18:46 +00004759 }
4760
4761 cmdArgs.push_back(args.MakeArgString(
4762 "-fobjc-runtime=" + runtime.getAsString()));
4763 return runtime;
4764}
4765
Stephen Hinesef822542014-07-21 00:47:37 -07004766static bool maybeConsumeDash(const std::string &EH, size_t &I) {
4767 bool HaveDash = (I + 1 < EH.size() && EH[I + 1] == '-');
4768 I += HaveDash;
4769 return !HaveDash;
4770}
4771
4772struct EHFlags {
4773 EHFlags() : Synch(false), Asynch(false), NoExceptC(false) {}
4774 bool Synch;
4775 bool Asynch;
4776 bool NoExceptC;
4777};
4778
4779/// /EH controls whether to run destructor cleanups when exceptions are
4780/// thrown. There are three modifiers:
4781/// - s: Cleanup after "synchronous" exceptions, aka C++ exceptions.
4782/// - a: Cleanup after "asynchronous" exceptions, aka structured exceptions.
4783/// The 'a' modifier is unimplemented and fundamentally hard in LLVM IR.
4784/// - c: Assume that extern "C" functions are implicitly noexcept. This
4785/// modifier is an optimization, so we ignore it for now.
4786/// The default is /EHs-c-, meaning cleanups are disabled.
4787static EHFlags parseClangCLEHFlags(const Driver &D, const ArgList &Args) {
4788 EHFlags EH;
4789 std::vector<std::string> EHArgs = Args.getAllArgValues(options::OPT__SLASH_EH);
4790 for (auto EHVal : EHArgs) {
4791 for (size_t I = 0, E = EHVal.size(); I != E; ++I) {
4792 switch (EHVal[I]) {
4793 case 'a': EH.Asynch = maybeConsumeDash(EHVal, I); continue;
4794 case 'c': EH.NoExceptC = maybeConsumeDash(EHVal, I); continue;
4795 case 's': EH.Synch = maybeConsumeDash(EHVal, I); continue;
4796 default: break;
4797 }
4798 D.Diag(clang::diag::err_drv_invalid_value) << "/EH" << EHVal;
4799 break;
4800 }
4801 }
4802 return EH;
4803}
4804
Hans Wennborgb3574792013-08-08 00:17:41 +00004805void Clang::AddClangCLArgs(const ArgList &Args, ArgStringList &CmdArgs) const {
4806 unsigned RTOptionID = options::OPT__SLASH_MT;
4807
Hans Wennborg6d0a8d52013-09-10 20:18:04 +00004808 if (Args.hasArg(options::OPT__SLASH_LDd))
4809 // The /LDd option implies /MTd. The dependent lib part can be overridden,
4810 // but defining _DEBUG is sticky.
4811 RTOptionID = options::OPT__SLASH_MTd;
4812
Hans Wennborg76da1782013-09-18 22:26:39 +00004813 if (Arg *A = Args.getLastArg(options::OPT__SLASH_M_Group))
Hans Wennborgb3574792013-08-08 00:17:41 +00004814 RTOptionID = A->getOption().getID();
Hans Wennborg42ade492013-09-11 16:38:41 +00004815
Hans Wennborgb3574792013-08-08 00:17:41 +00004816 switch(RTOptionID) {
4817 case options::OPT__SLASH_MD:
Hans Wennborg6d0a8d52013-09-10 20:18:04 +00004818 if (Args.hasArg(options::OPT__SLASH_LDd))
4819 CmdArgs.push_back("-D_DEBUG");
Hans Wennborgb3574792013-08-08 00:17:41 +00004820 CmdArgs.push_back("-D_MT");
4821 CmdArgs.push_back("-D_DLL");
4822 CmdArgs.push_back("--dependent-lib=msvcrt");
4823 break;
4824 case options::OPT__SLASH_MDd:
4825 CmdArgs.push_back("-D_DEBUG");
4826 CmdArgs.push_back("-D_MT");
4827 CmdArgs.push_back("-D_DLL");
4828 CmdArgs.push_back("--dependent-lib=msvcrtd");
4829 break;
4830 case options::OPT__SLASH_MT:
Hans Wennborg6d0a8d52013-09-10 20:18:04 +00004831 if (Args.hasArg(options::OPT__SLASH_LDd))
4832 CmdArgs.push_back("-D_DEBUG");
Hans Wennborgb3574792013-08-08 00:17:41 +00004833 CmdArgs.push_back("-D_MT");
4834 CmdArgs.push_back("--dependent-lib=libcmt");
4835 break;
4836 case options::OPT__SLASH_MTd:
4837 CmdArgs.push_back("-D_DEBUG");
4838 CmdArgs.push_back("-D_MT");
4839 CmdArgs.push_back("--dependent-lib=libcmtd");
4840 break;
4841 default:
4842 llvm_unreachable("Unexpected option ID.");
4843 }
4844
Reid Klecknera32c5232013-08-08 19:33:10 +00004845 // This provides POSIX compatibility (maps 'open' to '_open'), which most
4846 // users want. The /Za flag to cl.exe turns this off, but it's not
4847 // implemented in clang.
4848 CmdArgs.push_back("--dependent-lib=oldnames");
Hans Wennborgf0f98912013-08-08 19:54:30 +00004849
Stephen Hines176edba2014-12-01 14:53:08 -08004850 // Both /showIncludes and /E (and /EP) write to stdout. Allowing both
4851 // would produce interleaved output, so ignore /showIncludes in such cases.
4852 if (!Args.hasArg(options::OPT_E) && !Args.hasArg(options::OPT__SLASH_EP))
4853 if (Arg *A = Args.getLastArg(options::OPT_show_includes))
4854 A->render(Args, CmdArgs);
Hans Wennborgb6475522013-09-10 01:07:07 +00004855
Stephen Hinesef822542014-07-21 00:47:37 -07004856 // This controls whether or not we emit RTTI data for polymorphic types.
4857 if (Args.hasFlag(options::OPT__SLASH_GR_, options::OPT__SLASH_GR,
4858 /*default=*/false))
4859 CmdArgs.push_back("-fno-rtti-data");
Stephen Hines651f13c2014-04-23 16:59:28 -07004860
Stephen Hines651f13c2014-04-23 16:59:28 -07004861 const Driver &D = getToolChain().getDriver();
Stephen Hinesef822542014-07-21 00:47:37 -07004862 EHFlags EH = parseClangCLEHFlags(D, Args);
4863 // FIXME: Do something with NoExceptC.
4864 if (EH.Synch || EH.Asynch) {
Stephen Hinesef822542014-07-21 00:47:37 -07004865 CmdArgs.push_back("-fcxx-exceptions");
Stephen Hines0e2c34f2015-03-23 12:09:02 -07004866 CmdArgs.push_back("-fexceptions");
Stephen Hinesef822542014-07-21 00:47:37 -07004867 }
4868
4869 // /EP should expand to -E -P.
4870 if (Args.hasArg(options::OPT__SLASH_EP)) {
4871 CmdArgs.push_back("-E");
4872 CmdArgs.push_back("-P");
4873 }
4874
Stephen Hines0e2c34f2015-03-23 12:09:02 -07004875 unsigned VolatileOptionID;
4876 if (getToolChain().getTriple().getArch() == llvm::Triple::x86_64 ||
4877 getToolChain().getTriple().getArch() == llvm::Triple::x86)
4878 VolatileOptionID = options::OPT__SLASH_volatile_ms;
4879 else
4880 VolatileOptionID = options::OPT__SLASH_volatile_iso;
4881
4882 if (Arg *A = Args.getLastArg(options::OPT__SLASH_volatile_Group))
4883 VolatileOptionID = A->getOption().getID();
4884
4885 if (VolatileOptionID == options::OPT__SLASH_volatile_ms)
4886 CmdArgs.push_back("-fms-volatile");
4887
Stephen Hines651f13c2014-04-23 16:59:28 -07004888 Arg *MostGeneralArg = Args.getLastArg(options::OPT__SLASH_vmg);
4889 Arg *BestCaseArg = Args.getLastArg(options::OPT__SLASH_vmb);
4890 if (MostGeneralArg && BestCaseArg)
4891 D.Diag(clang::diag::err_drv_argument_not_allowed_with)
4892 << MostGeneralArg->getAsString(Args) << BestCaseArg->getAsString(Args);
4893
4894 if (MostGeneralArg) {
4895 Arg *SingleArg = Args.getLastArg(options::OPT__SLASH_vms);
4896 Arg *MultipleArg = Args.getLastArg(options::OPT__SLASH_vmm);
4897 Arg *VirtualArg = Args.getLastArg(options::OPT__SLASH_vmv);
4898
4899 Arg *FirstConflict = SingleArg ? SingleArg : MultipleArg;
4900 Arg *SecondConflict = VirtualArg ? VirtualArg : MultipleArg;
4901 if (FirstConflict && SecondConflict && FirstConflict != SecondConflict)
4902 D.Diag(clang::diag::err_drv_argument_not_allowed_with)
4903 << FirstConflict->getAsString(Args)
4904 << SecondConflict->getAsString(Args);
4905
4906 if (SingleArg)
4907 CmdArgs.push_back("-fms-memptr-rep=single");
4908 else if (MultipleArg)
4909 CmdArgs.push_back("-fms-memptr-rep=multiple");
4910 else
4911 CmdArgs.push_back("-fms-memptr-rep=virtual");
4912 }
4913
4914 if (Arg *A = Args.getLastArg(options::OPT_vtordisp_mode_EQ))
4915 A->render(Args, CmdArgs);
4916
Hans Wennborgb6475522013-09-10 01:07:07 +00004917 if (!Args.hasArg(options::OPT_fdiagnostics_format_EQ)) {
4918 CmdArgs.push_back("-fdiagnostics-format");
Hans Wennborg89e32742013-09-24 00:08:55 +00004919 if (Args.hasArg(options::OPT__SLASH_fallback))
4920 CmdArgs.push_back("msvc-fallback");
4921 else
4922 CmdArgs.push_back("msvc");
Hans Wennborgb6475522013-09-10 01:07:07 +00004923 }
Hans Wennborgb3574792013-08-08 00:17:41 +00004924}
4925
Stephen Hinesef822542014-07-21 00:47:37 -07004926visualstudio::Compile *Clang::getCLFallback() const {
4927 if (!CLFallback)
4928 CLFallback.reset(new visualstudio::Compile(getToolChain()));
4929 return CLFallback.get();
4930}
4931
Stephen Hines0e2c34f2015-03-23 12:09:02 -07004932void ClangAs::AddMIPSTargetArgs(const ArgList &Args,
4933 ArgStringList &CmdArgs) const {
4934 StringRef CPUName;
4935 StringRef ABIName;
4936 const llvm::Triple &Triple = getToolChain().getTriple();
4937 mips::getMipsCPUAndABI(Args, Triple, CPUName, ABIName);
4938
4939 CmdArgs.push_back("-target-abi");
4940 CmdArgs.push_back(ABIName.data());
4941}
4942
Daniel Dunbar20a9aa52010-05-20 21:30:13 +00004943void ClangAs::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar20a9aa52010-05-20 21:30:13 +00004944 const InputInfo &Output,
4945 const InputInfoList &Inputs,
4946 const ArgList &Args,
4947 const char *LinkingOutput) const {
Daniel Dunbar20a9aa52010-05-20 21:30:13 +00004948 ArgStringList CmdArgs;
4949
4950 assert(Inputs.size() == 1 && "Unexpected number of inputs.");
4951 const InputInfo &Input = Inputs[0];
4952
Rafael Espindoladbe80d92010-11-17 22:13:25 +00004953 // Don't warn about "clang -w -c foo.s"
4954 Args.ClaimAllArgs(options::OPT_w);
Rafael Espindola9c094fb2011-03-01 05:25:27 +00004955 // and "clang -emit-llvm -c foo.s"
4956 Args.ClaimAllArgs(options::OPT_emit_llvm);
Rafael Espindoladbe80d92010-11-17 22:13:25 +00004957
Stephen Hines0e2c34f2015-03-23 12:09:02 -07004958 claimNoWarnArgs(Args);
4959
Daniel Dunbar20a9aa52010-05-20 21:30:13 +00004960 // Invoke ourselves in -cc1as mode.
4961 //
4962 // FIXME: Implement custom jobs for internal actions.
4963 CmdArgs.push_back("-cc1as");
4964
4965 // Add the "effective" target triple.
4966 CmdArgs.push_back("-triple");
Chad Rosier61ab80a2011-09-20 20:44:06 +00004967 std::string TripleStr =
4968 getToolChain().ComputeEffectiveClangTriple(Args, Input.getType());
Daniel Dunbar20a9aa52010-05-20 21:30:13 +00004969 CmdArgs.push_back(Args.MakeArgString(TripleStr));
4970
4971 // Set the output mode, we currently only expect to be used as a real
4972 // assembler.
4973 CmdArgs.push_back("-filetype");
4974 CmdArgs.push_back("obj");
4975
Eric Christopher27e2b982012-12-18 00:31:10 +00004976 // Set the main file name, so that debug info works even with
4977 // -save-temps or preprocessed assembly.
4978 CmdArgs.push_back("-main-file-name");
4979 CmdArgs.push_back(Clang::getBaseInputName(Args, Inputs));
4980
Rafael Espindolab330e402013-08-20 22:12:08 +00004981 // Add the target cpu
Rafael Espindola146dbbf2013-08-21 16:39:20 +00004982 const llvm::Triple &Triple = getToolChain().getTriple();
4983 std::string CPU = getCPUName(Args, Triple);
Rafael Espindolab330e402013-08-20 22:12:08 +00004984 if (!CPU.empty()) {
4985 CmdArgs.push_back("-target-cpu");
4986 CmdArgs.push_back(Args.MakeArgString(CPU));
4987 }
4988
Rafael Espindola146dbbf2013-08-21 16:39:20 +00004989 // Add the target features
4990 const Driver &D = getToolChain().getDriver();
Stephen Hines651f13c2014-04-23 16:59:28 -07004991 getTargetFeatures(D, Triple, Args, CmdArgs, true);
Jim Grosbachfc308292012-02-10 20:37:10 +00004992
Daniel Dunbar7f6f8c82011-03-17 17:37:29 +00004993 // Ignore explicit -force_cpusubtype_ALL option.
4994 (void) Args.hasArg(options::OPT_force__cpusubtype__ALL);
Daniel Dunbar20a9aa52010-05-20 21:30:13 +00004995
Eric Christopher8f0a4032012-01-10 00:38:01 +00004996 // Determine the original source input.
4997 const Action *SourceAction = &JA;
4998 while (SourceAction->getKind() != Action::InputClass) {
4999 assert(!SourceAction->getInputs().empty() && "unexpected root action!");
5000 SourceAction = SourceAction->getInputs()[0];
5001 }
5002
Chandler Carruthd566df62012-12-17 21:40:04 +00005003 // Forward -g and handle debug info related flags, assuming we are dealing
5004 // with an actual assembly file.
Eric Christopher8f0a4032012-01-10 00:38:01 +00005005 if (SourceAction->getType() == types::TY_Asm ||
5006 SourceAction->getType() == types::TY_PP_Asm) {
5007 Args.ClaimAllArgs(options::OPT_g_Group);
5008 if (Arg *A = Args.getLastArg(options::OPT_g_Group))
5009 if (!A->getOption().matches(options::OPT_g0))
5010 CmdArgs.push_back("-g");
Chandler Carruthd566df62012-12-17 21:40:04 +00005011
Stephen Hines6bcf27b2014-05-29 04:14:42 -07005012 if (Args.hasArg(options::OPT_gdwarf_2))
5013 CmdArgs.push_back("-gdwarf-2");
5014 if (Args.hasArg(options::OPT_gdwarf_3))
5015 CmdArgs.push_back("-gdwarf-3");
5016 if (Args.hasArg(options::OPT_gdwarf_4))
5017 CmdArgs.push_back("-gdwarf-4");
5018
Chandler Carruthd566df62012-12-17 21:40:04 +00005019 // Add the -fdebug-compilation-dir flag if needed.
5020 addDebugCompDirArg(Args, CmdArgs);
Kevin Enderby02341792013-01-17 21:38:06 +00005021
5022 // Set the AT_producer to the clang version when using the integrated
5023 // assembler on assembly source files.
5024 CmdArgs.push_back("-dwarf-debug-producer");
5025 CmdArgs.push_back(Args.MakeArgString(getClangFullVersion()));
Eric Christopher8f0a4032012-01-10 00:38:01 +00005026 }
Kevin Enderby567003e2011-12-22 19:31:58 +00005027
5028 // Optionally embed the -cc1as level arguments into the debug info, for build
5029 // analysis.
5030 if (getToolChain().UseDwarfDebugFlags()) {
5031 ArgStringList OriginalArgs;
Stephen Hinesef822542014-07-21 00:47:37 -07005032 for (const auto &Arg : Args)
5033 Arg->render(Args, OriginalArgs);
Kevin Enderby567003e2011-12-22 19:31:58 +00005034
Dylan Noblesmithf7ccbad2012-02-05 02:13:05 +00005035 SmallString<256> Flags;
Kevin Enderby567003e2011-12-22 19:31:58 +00005036 const char *Exec = getToolChain().getDriver().getClangProgramPath();
5037 Flags += Exec;
5038 for (unsigned i = 0, e = OriginalArgs.size(); i != e; ++i) {
Stephen Hines176edba2014-12-01 14:53:08 -08005039 SmallString<128> EscapedArg;
5040 EscapeSpacesAndBackslashes(OriginalArgs[i], EscapedArg);
Kevin Enderby567003e2011-12-22 19:31:58 +00005041 Flags += " ";
Stephen Hines176edba2014-12-01 14:53:08 -08005042 Flags += EscapedArg;
Kevin Enderby567003e2011-12-22 19:31:58 +00005043 }
5044 CmdArgs.push_back("-dwarf-debug-flags");
5045 CmdArgs.push_back(Args.MakeArgString(Flags.str()));
5046 }
Daniel Dunbar20a9aa52010-05-20 21:30:13 +00005047
5048 // FIXME: Add -static support, once we have it.
5049
Stephen Hines0e2c34f2015-03-23 12:09:02 -07005050 // Add target specific flags.
5051 switch(getToolChain().getArch()) {
5052 default:
5053 break;
5054
5055 case llvm::Triple::mips:
5056 case llvm::Triple::mipsel:
5057 case llvm::Triple::mips64:
5058 case llvm::Triple::mips64el:
5059 AddMIPSTargetArgs(Args, CmdArgs);
5060 break;
5061 }
5062
Stephen Hines651f13c2014-04-23 16:59:28 -07005063 // Consume all the warning flags. Usually this would be handled more
5064 // gracefully by -cc1 (warning about unknown warning flags, etc) but -cc1as
5065 // doesn't handle that so rather than warning about unused flags that are
5066 // actually used, we'll lie by omission instead.
5067 // FIXME: Stop lying and consume only the appropriate driver flags
5068 for (arg_iterator it = Args.filtered_begin(options::OPT_W_Group),
5069 ie = Args.filtered_end();
5070 it != ie; ++it)
5071 (*it)->claim();
5072
David Blaikie73168db2013-07-25 21:19:01 +00005073 CollectArgsForIntegratedAssembler(C, Args, CmdArgs,
5074 getToolChain().getDriver());
5075
Daniel Dunbar3df23252011-04-29 17:53:18 +00005076 Args.AddAllArgs(CmdArgs, options::OPT_mllvm);
Daniel Dunbar20a9aa52010-05-20 21:30:13 +00005077
5078 assert(Output.isFilename() && "Unexpected lipo output.");
5079 CmdArgs.push_back("-o");
5080 CmdArgs.push_back(Output.getFilename());
5081
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00005082 assert(Input.isFilename() && "Invalid input.");
5083 CmdArgs.push_back(Input.getFilename());
Daniel Dunbar20a9aa52010-05-20 21:30:13 +00005084
Daniel Dunbara001c1c2010-07-18 21:16:15 +00005085 const char *Exec = getToolChain().getDriver().getClangProgramPath();
Stephen Hines176edba2014-12-01 14:53:08 -08005086 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Eric Christopher708d72a2013-04-10 21:30:40 +00005087
5088 // Handle the debug info splitting at object creation time if we're
5089 // creating an object.
5090 // TODO: Currently only works on linux with newer objcopy.
5091 if (Args.hasArg(options::OPT_gsplit_dwarf) &&
Cameron Esfahani57b1da12013-09-14 01:09:11 +00005092 getToolChain().getTriple().isOSLinux())
Eric Christopher708d72a2013-04-10 21:30:40 +00005093 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output,
5094 SplitDebugName(Args, Inputs));
Daniel Dunbar20a9aa52010-05-20 21:30:13 +00005095}
5096
Stephen Hines176edba2014-12-01 14:53:08 -08005097void GnuTool::anchor() {}
5098
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00005099void gcc::Common::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00005100 const InputInfo &Output,
5101 const InputInfoList &Inputs,
Daniel Dunbar1d460332009-03-18 10:01:51 +00005102 const ArgList &Args,
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00005103 const char *LinkingOutput) const {
Daniel Dunbaree788e72009-12-21 18:54:17 +00005104 const Driver &D = getToolChain().getDriver();
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00005105 ArgStringList CmdArgs;
Daniel Dunbar47ac7d22009-03-18 06:00:36 +00005106
Stephen Hinesef822542014-07-21 00:47:37 -07005107 for (const auto &A : Args) {
Michael J. Spencer91e06da2012-10-19 22:37:06 +00005108 if (forwardToGCC(A->getOption())) {
Daniel Dunbar2dffe2d2010-08-03 16:14:14 +00005109 // Don't forward any -g arguments to assembly steps.
5110 if (isa<AssembleJobAction>(JA) &&
5111 A->getOption().matches(options::OPT_g_Group))
5112 continue;
5113
NAKAMURA Takumi3c6c8222013-08-19 11:51:51 +00005114 // Don't forward any -W arguments to assembly and link steps.
5115 if ((isa<AssembleJobAction>(JA) || isa<LinkJobAction>(JA)) &&
5116 A->getOption().matches(options::OPT_W_Group))
5117 continue;
5118
Daniel Dunbar75877192009-03-19 07:55:12 +00005119 // It is unfortunate that we have to claim here, as this means
5120 // we will basically never report anything interesting for
Daniel Dunbar6ecc7a92009-05-02 21:41:52 +00005121 // platforms using a generic gcc, even if we are just using gcc
5122 // to get to the assembler.
Daniel Dunbar75877192009-03-19 07:55:12 +00005123 A->claim();
Daniel Dunbar1d460332009-03-18 10:01:51 +00005124 A->render(Args, CmdArgs);
Daniel Dunbar75877192009-03-19 07:55:12 +00005125 }
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00005126 }
Daniel Dunbarc21c4852009-04-08 23:54:23 +00005127
Daniel Dunbar82b51cc2010-01-25 22:35:08 +00005128 RenderExtraToolArgs(JA, CmdArgs);
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00005129
5130 // If using a driver driver, force the arch.
Bob Wilson905c45f2011-10-14 05:03:44 +00005131 if (getToolChain().getTriple().isOSDarwin()) {
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00005132 CmdArgs.push_back("-arch");
Stephen Hines176edba2014-12-01 14:53:08 -08005133 CmdArgs.push_back(
5134 Args.MakeArgString(getToolChain().getDefaultUniversalArchName()));
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00005135 }
5136
Daniel Dunbar6ecc7a92009-05-02 21:41:52 +00005137 // Try to force gcc to match the tool chain we want, if we recognize
5138 // the arch.
Daniel Dunbar7cfe31a2009-05-22 02:21:04 +00005139 //
5140 // FIXME: The triple class should directly provide the information we want
5141 // here.
Stephen Hines176edba2014-12-01 14:53:08 -08005142 llvm::Triple::ArchType Arch = getToolChain().getArch();
Rafael Espindola64f7ad92012-10-07 04:44:33 +00005143 if (Arch == llvm::Triple::x86 || Arch == llvm::Triple::ppc)
Daniel Dunbar6ecc7a92009-05-02 21:41:52 +00005144 CmdArgs.push_back("-m32");
Bill Schmidtea7fb0c2013-07-26 01:36:11 +00005145 else if (Arch == llvm::Triple::x86_64 || Arch == llvm::Triple::ppc64 ||
5146 Arch == llvm::Triple::ppc64le)
Daniel Dunbar6ecc7a92009-05-02 21:41:52 +00005147 CmdArgs.push_back("-m64");
5148
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00005149 if (Output.isFilename()) {
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00005150 CmdArgs.push_back("-o");
Daniel Dunbar115a7922009-03-19 07:29:38 +00005151 CmdArgs.push_back(Output.getFilename());
5152 } else {
5153 assert(Output.isNothing() && "Unexpected output");
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00005154 CmdArgs.push_back("-fsyntax-only");
Daniel Dunbar115a7922009-03-19 07:29:38 +00005155 }
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00005156
Tony Linthicum96319392011-12-12 21:14:55 +00005157 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
5158 options::OPT_Xassembler);
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00005159
5160 // Only pass -x if gcc will understand it; otherwise hope gcc
5161 // understands the suffix correctly. The main use case this would go
5162 // wrong in is for linker inputs if they happened to have an odd
5163 // suffix; really the only way to get this to happen is a command
5164 // like '-x foobar a.c' which will treat a.c like a linker input.
5165 //
5166 // FIXME: For the linker case specifically, can we safely convert
5167 // inputs into '-Wl,' options?
Stephen Hinesef822542014-07-21 00:47:37 -07005168 for (const auto &II : Inputs) {
Daniel Dunbar5915fbf2009-09-01 16:57:46 +00005169 // Don't try to pass LLVM or AST inputs to a generic gcc.
Daniel Dunbar6c6424b2010-06-07 23:28:45 +00005170 if (II.getType() == types::TY_LLVM_IR || II.getType() == types::TY_LTO_IR ||
5171 II.getType() == types::TY_LLVM_BC || II.getType() == types::TY_LTO_BC)
Chris Lattner5f9e2722011-07-23 10:55:15 +00005172 D.Diag(diag::err_drv_no_linker_llvm_support)
Daniel Dunbar88137642009-09-09 22:32:48 +00005173 << getToolChain().getTripleString();
Daniel Dunbar5915fbf2009-09-01 16:57:46 +00005174 else if (II.getType() == types::TY_AST)
Chris Lattner5f9e2722011-07-23 10:55:15 +00005175 D.Diag(diag::err_drv_no_ast_support)
Daniel Dunbar88137642009-09-09 22:32:48 +00005176 << getToolChain().getTripleString();
Douglas Gregorc544ba02013-03-27 16:47:18 +00005177 else if (II.getType() == types::TY_ModuleFile)
5178 D.Diag(diag::err_drv_no_module_support)
5179 << getToolChain().getTripleString();
Daniel Dunbara8304f62009-05-02 20:14:53 +00005180
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00005181 if (types::canTypeBeUserSpecified(II.getType())) {
5182 CmdArgs.push_back("-x");
5183 CmdArgs.push_back(types::getTypeName(II.getType()));
5184 }
5185
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00005186 if (II.isFilename())
Daniel Dunbar115a7922009-03-19 07:29:38 +00005187 CmdArgs.push_back(II.getFilename());
Daniel Dunbar48f99942010-09-25 18:10:05 +00005188 else {
5189 const Arg &A = II.getInputArg();
5190
5191 // Reverse translate some rewritten options.
5192 if (A.getOption().matches(options::OPT_Z_reserved_lib_stdcxx)) {
5193 CmdArgs.push_back("-lstdc++");
5194 continue;
5195 }
5196
Daniel Dunbar115a7922009-03-19 07:29:38 +00005197 // Don't render as input, we need gcc to do the translations.
Daniel Dunbar48f99942010-09-25 18:10:05 +00005198 A.render(Args, CmdArgs);
5199 }
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00005200 }
5201
Dylan Noblesmithb8a3e812011-04-09 13:31:59 +00005202 const std::string customGCCName = D.getCCCGenericGCCName();
5203 const char *GCCName;
5204 if (!customGCCName.empty())
5205 GCCName = customGCCName.c_str();
Hans Wennborg76b86c22013-07-18 20:29:38 +00005206 else if (D.CCCIsCXX()) {
Dylan Noblesmithb8a3e812011-04-09 13:31:59 +00005207 GCCName = "g++";
Dylan Noblesmithb8a3e812011-04-09 13:31:59 +00005208 } else
5209 GCCName = "gcc";
5210
Daniel Dunbarc21c4852009-04-08 23:54:23 +00005211 const char *Exec =
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00005212 Args.MakeArgString(getToolChain().GetProgramPath(GCCName));
Stephen Hines176edba2014-12-01 14:53:08 -08005213 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Daniel Dunbar47ac7d22009-03-18 06:00:36 +00005214}
5215
Daniel Dunbar82b51cc2010-01-25 22:35:08 +00005216void gcc::Preprocess::RenderExtraToolArgs(const JobAction &JA,
5217 ArgStringList &CmdArgs) const {
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00005218 CmdArgs.push_back("-E");
Daniel Dunbar47ac7d22009-03-18 06:00:36 +00005219}
5220
Daniel Dunbar82b51cc2010-01-25 22:35:08 +00005221void gcc::Compile::RenderExtraToolArgs(const JobAction &JA,
5222 ArgStringList &CmdArgs) const {
Daniel Dunbar64952502010-02-11 03:16:21 +00005223 const Driver &D = getToolChain().getDriver();
5224
Stephen Hines0e2c34f2015-03-23 12:09:02 -07005225 switch (JA.getType()) {
Daniel Dunbar82b51cc2010-01-25 22:35:08 +00005226 // If -flto, etc. are present then make sure not to force assembly output.
Stephen Hines0e2c34f2015-03-23 12:09:02 -07005227 case types::TY_LLVM_IR:
5228 case types::TY_LTO_IR:
5229 case types::TY_LLVM_BC:
5230 case types::TY_LTO_BC:
Daniel Dunbar82b51cc2010-01-25 22:35:08 +00005231 CmdArgs.push_back("-c");
Stephen Hines0e2c34f2015-03-23 12:09:02 -07005232 break;
5233 case types::TY_PP_Asm:
Daniel Dunbar82b51cc2010-01-25 22:35:08 +00005234 CmdArgs.push_back("-S");
Stephen Hines0e2c34f2015-03-23 12:09:02 -07005235 break;
5236 case types::TY_Nothing:
5237 CmdArgs.push_back("-fsyntax-only");
5238 break;
5239 default:
5240 D.Diag(diag::err_drv_invalid_gcc_output_type) << getTypeName(JA.getType());
Daniel Dunbar64952502010-02-11 03:16:21 +00005241 }
Daniel Dunbar47ac7d22009-03-18 06:00:36 +00005242}
5243
Daniel Dunbar82b51cc2010-01-25 22:35:08 +00005244void gcc::Link::RenderExtraToolArgs(const JobAction &JA,
5245 ArgStringList &CmdArgs) const {
Daniel Dunbarb488c1d2009-03-18 08:07:30 +00005246 // The types are (hopefully) good enough.
5247}
5248
Tony Linthicum96319392011-12-12 21:14:55 +00005249// Hexagon tools start.
5250void hexagon::Assemble::RenderExtraToolArgs(const JobAction &JA,
5251 ArgStringList &CmdArgs) const {
5252
5253}
5254void hexagon::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
5255 const InputInfo &Output,
5256 const InputInfoList &Inputs,
5257 const ArgList &Args,
5258 const char *LinkingOutput) const {
Stephen Hines0e2c34f2015-03-23 12:09:02 -07005259 claimNoWarnArgs(Args);
Tony Linthicum96319392011-12-12 21:14:55 +00005260
5261 const Driver &D = getToolChain().getDriver();
5262 ArgStringList CmdArgs;
5263
5264 std::string MarchString = "-march=";
Matthew Curtis67814152012-12-06 14:16:43 +00005265 MarchString += toolchains::Hexagon_TC::GetTargetCPU(Args);
Tony Linthicum96319392011-12-12 21:14:55 +00005266 CmdArgs.push_back(Args.MakeArgString(MarchString));
5267
5268 RenderExtraToolArgs(JA, CmdArgs);
5269
5270 if (Output.isFilename()) {
5271 CmdArgs.push_back("-o");
5272 CmdArgs.push_back(Output.getFilename());
5273 } else {
5274 assert(Output.isNothing() && "Unexpected output");
5275 CmdArgs.push_back("-fsyntax-only");
5276 }
5277
Matthew Curtis33c95f12012-12-06 17:49:03 +00005278 std::string SmallDataThreshold = GetHexagonSmallDataThresholdValue(Args);
5279 if (!SmallDataThreshold.empty())
5280 CmdArgs.push_back(
5281 Args.MakeArgString(std::string("-G") + SmallDataThreshold));
Tony Linthicum96319392011-12-12 21:14:55 +00005282
Matthew Curtis3d8d4222012-12-07 17:23:04 +00005283 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
5284 options::OPT_Xassembler);
5285
Tony Linthicum96319392011-12-12 21:14:55 +00005286 // Only pass -x if gcc will understand it; otherwise hope gcc
5287 // understands the suffix correctly. The main use case this would go
5288 // wrong in is for linker inputs if they happened to have an odd
5289 // suffix; really the only way to get this to happen is a command
5290 // like '-x foobar a.c' which will treat a.c like a linker input.
5291 //
5292 // FIXME: For the linker case specifically, can we safely convert
5293 // inputs into '-Wl,' options?
Stephen Hinesef822542014-07-21 00:47:37 -07005294 for (const auto &II : Inputs) {
Tony Linthicum96319392011-12-12 21:14:55 +00005295 // Don't try to pass LLVM or AST inputs to a generic gcc.
5296 if (II.getType() == types::TY_LLVM_IR || II.getType() == types::TY_LTO_IR ||
5297 II.getType() == types::TY_LLVM_BC || II.getType() == types::TY_LTO_BC)
5298 D.Diag(clang::diag::err_drv_no_linker_llvm_support)
5299 << getToolChain().getTripleString();
5300 else if (II.getType() == types::TY_AST)
5301 D.Diag(clang::diag::err_drv_no_ast_support)
5302 << getToolChain().getTripleString();
Douglas Gregorc544ba02013-03-27 16:47:18 +00005303 else if (II.getType() == types::TY_ModuleFile)
5304 D.Diag(diag::err_drv_no_module_support)
5305 << getToolChain().getTripleString();
Tony Linthicum96319392011-12-12 21:14:55 +00005306
5307 if (II.isFilename())
5308 CmdArgs.push_back(II.getFilename());
5309 else
5310 // Don't render as input, we need gcc to do the translations. FIXME: Pranav: What is this ?
5311 II.getInputArg().render(Args, CmdArgs);
5312 }
5313
5314 const char *GCCName = "hexagon-as";
Stephen Hinesef822542014-07-21 00:47:37 -07005315 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath(GCCName));
Stephen Hines176edba2014-12-01 14:53:08 -08005316 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Tony Linthicum96319392011-12-12 21:14:55 +00005317}
Stephen Hinesef822542014-07-21 00:47:37 -07005318
Tony Linthicum96319392011-12-12 21:14:55 +00005319void hexagon::Link::RenderExtraToolArgs(const JobAction &JA,
5320 ArgStringList &CmdArgs) const {
5321 // The types are (hopefully) good enough.
5322}
5323
5324void hexagon::Link::ConstructJob(Compilation &C, const JobAction &JA,
5325 const InputInfo &Output,
5326 const InputInfoList &Inputs,
5327 const ArgList &Args,
5328 const char *LinkingOutput) const {
5329
Matthew Curtis5fdf3502012-12-06 15:46:07 +00005330 const toolchains::Hexagon_TC& ToolChain =
5331 static_cast<const toolchains::Hexagon_TC&>(getToolChain());
5332 const Driver &D = ToolChain.getDriver();
5333
Tony Linthicum96319392011-12-12 21:14:55 +00005334 ArgStringList CmdArgs;
5335
Matthew Curtis5fdf3502012-12-06 15:46:07 +00005336 //----------------------------------------------------------------------------
5337 //
5338 //----------------------------------------------------------------------------
5339 bool hasStaticArg = Args.hasArg(options::OPT_static);
5340 bool buildingLib = Args.hasArg(options::OPT_shared);
Matthew Curtis33c95f12012-12-06 17:49:03 +00005341 bool buildPIE = Args.hasArg(options::OPT_pie);
Matthew Curtis5fdf3502012-12-06 15:46:07 +00005342 bool incStdLib = !Args.hasArg(options::OPT_nostdlib);
5343 bool incStartFiles = !Args.hasArg(options::OPT_nostartfiles);
5344 bool incDefLibs = !Args.hasArg(options::OPT_nodefaultlibs);
5345 bool useShared = buildingLib && !hasStaticArg;
Tony Linthicum96319392011-12-12 21:14:55 +00005346
Matthew Curtis5fdf3502012-12-06 15:46:07 +00005347 //----------------------------------------------------------------------------
5348 // Silence warnings for various options
5349 //----------------------------------------------------------------------------
Tony Linthicum96319392011-12-12 21:14:55 +00005350
Matthew Curtis5fdf3502012-12-06 15:46:07 +00005351 Args.ClaimAllArgs(options::OPT_g_Group);
5352 Args.ClaimAllArgs(options::OPT_emit_llvm);
5353 Args.ClaimAllArgs(options::OPT_w); // Other warning options are already
5354 // handled somewhere else.
5355 Args.ClaimAllArgs(options::OPT_static_libgcc);
5356
5357 //----------------------------------------------------------------------------
5358 //
5359 //----------------------------------------------------------------------------
Stephen Hinesef822542014-07-21 00:47:37 -07005360 for (const auto &Opt : ToolChain.ExtraOpts)
5361 CmdArgs.push_back(Opt.c_str());
Tony Linthicum96319392011-12-12 21:14:55 +00005362
Matthew Curtis67814152012-12-06 14:16:43 +00005363 std::string MarchString = toolchains::Hexagon_TC::GetTargetCPU(Args);
5364 CmdArgs.push_back(Args.MakeArgString("-m" + MarchString));
Sebastian Pop43115d42012-01-13 20:37:10 +00005365
Matthew Curtis5fdf3502012-12-06 15:46:07 +00005366 if (buildingLib) {
5367 CmdArgs.push_back("-shared");
5368 CmdArgs.push_back("-call_shared"); // should be the default, but doing as
5369 // hexagon-gcc does
Tony Linthicum96319392011-12-12 21:14:55 +00005370 }
5371
Matthew Curtis5fdf3502012-12-06 15:46:07 +00005372 if (hasStaticArg)
5373 CmdArgs.push_back("-static");
Tony Linthicum96319392011-12-12 21:14:55 +00005374
Matthew Curtis33c95f12012-12-06 17:49:03 +00005375 if (buildPIE && !buildingLib)
5376 CmdArgs.push_back("-pie");
5377
5378 std::string SmallDataThreshold = GetHexagonSmallDataThresholdValue(Args);
5379 if (!SmallDataThreshold.empty()) {
5380 CmdArgs.push_back(
5381 Args.MakeArgString(std::string("-G") + SmallDataThreshold));
5382 }
5383
Matthew Curtis5fdf3502012-12-06 15:46:07 +00005384 //----------------------------------------------------------------------------
5385 //
5386 //----------------------------------------------------------------------------
5387 CmdArgs.push_back("-o");
5388 CmdArgs.push_back(Output.getFilename());
Tony Linthicum96319392011-12-12 21:14:55 +00005389
Matthew Curtis5fdf3502012-12-06 15:46:07 +00005390 const std::string MarchSuffix = "/" + MarchString;
5391 const std::string G0Suffix = "/G0";
5392 const std::string MarchG0Suffix = MarchSuffix + G0Suffix;
Stephen Hines176edba2014-12-01 14:53:08 -08005393 const std::string RootDir =
5394 toolchains::Hexagon_TC::GetGnuDir(D.InstalledDir, Args) + "/";
Matthew Curtis5fdf3502012-12-06 15:46:07 +00005395 const std::string StartFilesDir = RootDir
5396 + "hexagon/lib"
5397 + (buildingLib
5398 ? MarchG0Suffix : MarchSuffix);
5399
5400 //----------------------------------------------------------------------------
5401 // moslib
5402 //----------------------------------------------------------------------------
5403 std::vector<std::string> oslibs;
5404 bool hasStandalone= false;
5405
5406 for (arg_iterator it = Args.filtered_begin(options::OPT_moslib_EQ),
5407 ie = Args.filtered_end(); it != ie; ++it) {
5408 (*it)->claim();
5409 oslibs.push_back((*it)->getValue());
5410 hasStandalone = hasStandalone || (oslibs.back() == "standalone");
Tony Linthicum96319392011-12-12 21:14:55 +00005411 }
Matthew Curtis5fdf3502012-12-06 15:46:07 +00005412 if (oslibs.empty()) {
5413 oslibs.push_back("standalone");
5414 hasStandalone = true;
5415 }
Tony Linthicum96319392011-12-12 21:14:55 +00005416
Matthew Curtis5fdf3502012-12-06 15:46:07 +00005417 //----------------------------------------------------------------------------
5418 // Start Files
5419 //----------------------------------------------------------------------------
5420 if (incStdLib && incStartFiles) {
5421
5422 if (!buildingLib) {
5423 if (hasStandalone) {
5424 CmdArgs.push_back(
5425 Args.MakeArgString(StartFilesDir + "/crt0_standalone.o"));
5426 }
5427 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crt0.o"));
5428 }
5429 std::string initObj = useShared ? "/initS.o" : "/init.o";
5430 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + initObj));
5431 }
5432
5433 //----------------------------------------------------------------------------
5434 // Library Search Paths
5435 //----------------------------------------------------------------------------
5436 const ToolChain::path_list &LibPaths = ToolChain.getFilePaths();
Stephen Hinesef822542014-07-21 00:47:37 -07005437 for (const auto &LibPath : LibPaths)
5438 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + LibPath));
Matthew Curtis5fdf3502012-12-06 15:46:07 +00005439
5440 //----------------------------------------------------------------------------
5441 //
5442 //----------------------------------------------------------------------------
5443 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
5444 Args.AddAllArgs(CmdArgs, options::OPT_e);
5445 Args.AddAllArgs(CmdArgs, options::OPT_s);
5446 Args.AddAllArgs(CmdArgs, options::OPT_t);
5447 Args.AddAllArgs(CmdArgs, options::OPT_u_Group);
5448
5449 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
5450
5451 //----------------------------------------------------------------------------
5452 // Libraries
5453 //----------------------------------------------------------------------------
5454 if (incStdLib && incDefLibs) {
Hans Wennborg76b86c22013-07-18 20:29:38 +00005455 if (D.CCCIsCXX()) {
Matthew Curtis5fdf3502012-12-06 15:46:07 +00005456 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
5457 CmdArgs.push_back("-lm");
5458 }
5459
5460 CmdArgs.push_back("--start-group");
5461
5462 if (!buildingLib) {
5463 for(std::vector<std::string>::iterator i = oslibs.begin(),
5464 e = oslibs.end(); i != e; ++i)
5465 CmdArgs.push_back(Args.MakeArgString("-l" + *i));
5466 CmdArgs.push_back("-lc");
5467 }
5468 CmdArgs.push_back("-lgcc");
5469
5470 CmdArgs.push_back("--end-group");
5471 }
5472
5473 //----------------------------------------------------------------------------
5474 // End files
5475 //----------------------------------------------------------------------------
5476 if (incStdLib && incStartFiles) {
5477 std::string finiObj = useShared ? "/finiS.o" : "/fini.o";
5478 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + finiObj));
5479 }
5480
5481 std::string Linker = ToolChain.GetProgramPath("hexagon-ld");
Stephen Hines176edba2014-12-01 14:53:08 -08005482 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Linker),
5483 CmdArgs));
Tony Linthicum96319392011-12-12 21:14:55 +00005484}
5485// Hexagon tools end.
5486
Stephen Hines176edba2014-12-01 14:53:08 -08005487/// Get the (LLVM) name of the minimum ARM CPU for the arch we are targeting.
Stephen Hines651f13c2014-04-23 16:59:28 -07005488const char *arm::getARMCPUForMArch(const ArgList &Args,
5489 const llvm::Triple &Triple) {
5490 StringRef MArch;
5491 if (Arg *A = Args.getLastArg(options::OPT_march_EQ)) {
5492 // Otherwise, if we have -march= choose the base CPU for that arch.
5493 MArch = A->getValue();
5494 } else {
5495 // Otherwise, use the Arch from the triple.
5496 MArch = Triple.getArchName();
5497 }
5498
5499 // Handle -march=native.
5500 if (MArch == "native") {
5501 std::string CPU = llvm::sys::getHostCPUName();
5502 if (CPU != "generic") {
5503 // Translate the native cpu into the architecture. The switch below will
5504 // then chose the minimum cpu for that arch.
5505 MArch = std::string("arm") + arm::getLLVMArchSuffixForARM(CPU);
5506 }
5507 }
5508
Stephen Hines176edba2014-12-01 14:53:08 -08005509 return Triple.getARMCPUForArch(MArch);
Stephen Hines651f13c2014-04-23 16:59:28 -07005510}
5511
5512/// getARMTargetCPU - Get the (LLVM) name of the ARM cpu we are targeting.
5513StringRef arm::getARMTargetCPU(const ArgList &Args,
5514 const llvm::Triple &Triple) {
5515 // FIXME: Warn on inconsistent use of -mcpu and -march.
5516 // If we have -mcpu=, use that.
5517 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ)) {
5518 StringRef MCPU = A->getValue();
5519 // Handle -mcpu=native.
5520 if (MCPU == "native")
5521 return llvm::sys::getHostCPUName();
5522 else
5523 return MCPU;
5524 }
5525
5526 return getARMCPUForMArch(Args, Triple);
5527}
5528
5529/// getLLVMArchSuffixForARM - Get the LLVM arch name to use for a particular
5530/// CPU.
5531//
5532// FIXME: This is redundant with -mcpu, why does LLVM use this.
5533// FIXME: tblgen this, or kill it!
5534const char *arm::getLLVMArchSuffixForARM(StringRef CPU) {
5535 return llvm::StringSwitch<const char *>(CPU)
5536 .Case("strongarm", "v4")
5537 .Cases("arm7tdmi", "arm7tdmi-s", "arm710t", "v4t")
5538 .Cases("arm720t", "arm9", "arm9tdmi", "v4t")
5539 .Cases("arm920", "arm920t", "arm922t", "v4t")
5540 .Cases("arm940t", "ep9312","v4t")
5541 .Cases("arm10tdmi", "arm1020t", "v5")
5542 .Cases("arm9e", "arm926ej-s", "arm946e-s", "v5e")
5543 .Cases("arm966e-s", "arm968e-s", "arm10e", "v5e")
5544 .Cases("arm1020e", "arm1022e", "xscale", "iwmmxt", "v5e")
5545 .Cases("arm1136j-s", "arm1136jf-s", "arm1176jz-s", "v6")
5546 .Cases("arm1176jzf-s", "mpcorenovfp", "mpcore", "v6")
5547 .Cases("arm1156t2-s", "arm1156t2f-s", "v6t2")
Stephen Hines176edba2014-12-01 14:53:08 -08005548 .Cases("cortex-a5", "cortex-a7", "cortex-a8", "v7")
5549 .Cases("cortex-a9", "cortex-a12", "cortex-a15", "cortex-a17", "krait", "v7")
Stephen Hines0e2c34f2015-03-23 12:09:02 -07005550 .Cases("cortex-r4", "cortex-r5", "cortex-r7", "v7r")
5551 .Cases("sc000", "cortex-m0", "cortex-m0plus", "cortex-m1", "v6m")
5552 .Cases("sc300", "cortex-m3", "v7m")
Stephen Hines176edba2014-12-01 14:53:08 -08005553 .Cases("cortex-m4", "cortex-m7", "v7em")
Stephen Hines651f13c2014-04-23 16:59:28 -07005554 .Case("swift", "v7s")
5555 .Case("cyclone", "v8")
Stephen Hines0e2c34f2015-03-23 12:09:02 -07005556 .Cases("cortex-a53", "cortex-a57", "cortex-a72", "v8")
Stephen Hines651f13c2014-04-23 16:59:28 -07005557 .Default("");
5558}
5559
Stephen Hines0e2c34f2015-03-23 12:09:02 -07005560void arm::appendEBLinkFlags(const ArgList &Args, ArgStringList &CmdArgs, const llvm::Triple &Triple) {
5561 if (Args.hasArg(options::OPT_r))
5562 return;
5563
5564 StringRef Suffix = getLLVMArchSuffixForARM(getARMCPUForMArch(Args, Triple));
5565 const char *LinkFlag = llvm::StringSwitch<const char *>(Suffix)
5566 .Cases("v4", "v4t", "v5", "v5e", nullptr)
5567 .Cases("v6", "v6t2", nullptr)
5568 .Default("--be8");
5569
5570 if (LinkFlag)
5571 CmdArgs.push_back(LinkFlag);
5572}
5573
Stephen Hines651f13c2014-04-23 16:59:28 -07005574bool mips::hasMipsAbiArg(const ArgList &Args, const char *Value) {
5575 Arg *A = Args.getLastArg(options::OPT_mabi_EQ);
5576 return A && (A->getValue() == StringRef(Value));
5577}
5578
Stephen Hines176edba2014-12-01 14:53:08 -08005579bool mips::isUCLibc(const ArgList &Args) {
5580 Arg *A = Args.getLastArg(options::OPT_m_libc_Group);
5581 return A && A->getOption().matches(options::OPT_muclibc);
5582}
5583
Stephen Hinesef822542014-07-21 00:47:37 -07005584bool mips::isNaN2008(const ArgList &Args, const llvm::Triple &Triple) {
5585 if (Arg *NaNArg = Args.getLastArg(options::OPT_mnan_EQ))
5586 return llvm::StringSwitch<bool>(NaNArg->getValue())
5587 .Case("2008", true)
5588 .Case("legacy", false)
5589 .Default(false);
5590
5591 // NaN2008 is the default for MIPS32r6/MIPS64r6.
5592 return llvm::StringSwitch<bool>(getCPUName(Args, Triple))
5593 .Cases("mips32r6", "mips64r6", true)
5594 .Default(false);
5595
5596 return false;
5597}
5598
Stephen Hines176edba2014-12-01 14:53:08 -08005599bool mips::isFPXXDefault(const llvm::Triple &Triple, StringRef CPUName,
5600 StringRef ABIName) {
5601 if (Triple.getVendor() != llvm::Triple::ImaginationTechnologies &&
5602 Triple.getVendor() != llvm::Triple::MipsTechnologies)
5603 return false;
5604
5605 if (ABIName != "32")
5606 return false;
5607
5608 return llvm::StringSwitch<bool>(CPUName)
5609 .Cases("mips2", "mips3", "mips4", "mips5", true)
Stephen Hines0e2c34f2015-03-23 12:09:02 -07005610 .Cases("mips32", "mips32r2", "mips32r3", "mips32r5", true)
5611 .Cases("mips64", "mips64r2", "mips64r3", "mips64r5", true)
Stephen Hines176edba2014-12-01 14:53:08 -08005612 .Default(false);
5613}
5614
Stephen Hines651f13c2014-04-23 16:59:28 -07005615llvm::Triple::ArchType darwin::getArchTypeForMachOArchName(StringRef Str) {
Rafael Espindolacfed8282012-10-31 18:51:07 +00005616 // See arch(3) and llvm-gcc's driver-driver.c. We don't implement support for
5617 // archs which Darwin doesn't use.
5618
5619 // The matching this routine does is fairly pointless, since it is neither the
5620 // complete architecture list, nor a reasonable subset. The problem is that
5621 // historically the driver driver accepts this and also ties its -march=
5622 // handling to the architecture name, so we need to be careful before removing
5623 // support for it.
5624
5625 // This code must be kept in sync with Clang's Darwin specific argument
5626 // translation.
5627
5628 return llvm::StringSwitch<llvm::Triple::ArchType>(Str)
5629 .Cases("ppc", "ppc601", "ppc603", "ppc604", "ppc604e", llvm::Triple::ppc)
5630 .Cases("ppc750", "ppc7400", "ppc7450", "ppc970", llvm::Triple::ppc)
5631 .Case("ppc64", llvm::Triple::ppc64)
5632 .Cases("i386", "i486", "i486SX", "i586", "i686", llvm::Triple::x86)
5633 .Cases("pentium", "pentpro", "pentIIm3", "pentIIm5", "pentium4",
5634 llvm::Triple::x86)
Jim Grosbach32ca73e2013-11-16 00:53:35 +00005635 .Cases("x86_64", "x86_64h", llvm::Triple::x86_64)
Rafael Espindolacfed8282012-10-31 18:51:07 +00005636 // This is derived from the driver driver.
Bob Wilson2503ebd2013-03-04 22:37:49 +00005637 .Cases("arm", "armv4t", "armv5", "armv6", "armv6m", llvm::Triple::arm)
Stephen Hines651f13c2014-04-23 16:59:28 -07005638 .Cases("armv7", "armv7em", "armv7k", "armv7m", llvm::Triple::arm)
Bob Wilson2503ebd2013-03-04 22:37:49 +00005639 .Cases("armv7s", "xscale", llvm::Triple::arm)
Stephen Hines176edba2014-12-01 14:53:08 -08005640 .Case("arm64", llvm::Triple::aarch64)
Rafael Espindolacfed8282012-10-31 18:51:07 +00005641 .Case("r600", llvm::Triple::r600)
Stephen Hines0e2c34f2015-03-23 12:09:02 -07005642 .Case("amdgcn", llvm::Triple::amdgcn)
Rafael Espindolacfed8282012-10-31 18:51:07 +00005643 .Case("nvptx", llvm::Triple::nvptx)
5644 .Case("nvptx64", llvm::Triple::nvptx64)
5645 .Case("amdil", llvm::Triple::amdil)
5646 .Case("spir", llvm::Triple::spir)
5647 .Default(llvm::Triple::UnknownArch);
5648}
Tony Linthicum96319392011-12-12 21:14:55 +00005649
Stephen Hines651f13c2014-04-23 16:59:28 -07005650void darwin::setTripleTypeForMachOArchName(llvm::Triple &T, StringRef Str) {
5651 llvm::Triple::ArchType Arch = getArchTypeForMachOArchName(Str);
5652 T.setArch(Arch);
5653
5654 if (Str == "x86_64h")
5655 T.setArchName(Str);
5656 else if (Str == "armv6m" || Str == "armv7m" || Str == "armv7em") {
5657 T.setOS(llvm::Triple::UnknownOS);
5658 T.setObjectFormat(llvm::Triple::MachO);
5659 }
5660}
5661
Bob Wilson66b8a662012-11-23 06:14:39 +00005662const char *Clang::getBaseInputName(const ArgList &Args,
5663 const InputInfoList &Inputs) {
Michael J. Spencer472ccff2010-12-18 00:19:12 +00005664 return Args.MakeArgString(
5665 llvm::sys::path::filename(Inputs[0].getBaseInput()));
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00005666}
5667
Bob Wilson66b8a662012-11-23 06:14:39 +00005668const char *Clang::getBaseInputStem(const ArgList &Args,
5669 const InputInfoList &Inputs) {
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00005670 const char *Str = getBaseInputName(Args, Inputs);
5671
Chris Lattner657ca662011-01-16 08:14:11 +00005672 if (const char *End = strrchr(Str, '.'))
Daniel Dunbar88137642009-09-09 22:32:48 +00005673 return Args.MakeArgString(std::string(Str, End));
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00005674
5675 return Str;
5676}
5677
Bob Wilson66b8a662012-11-23 06:14:39 +00005678const char *Clang::getDependencyFileName(const ArgList &Args,
5679 const InputInfoList &Inputs) {
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00005680 // FIXME: Think about this more.
5681 std::string Res;
5682
5683 if (Arg *OutputOpt = Args.getLastArg(options::OPT_o)) {
Richard Smith1d489cf2012-11-01 04:30:05 +00005684 std::string Str(OutputOpt->getValue());
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00005685 Res = Str.substr(0, Str.rfind('.'));
Chad Rosier30601782011-08-17 23:08:45 +00005686 } else {
Bob Wilson66b8a662012-11-23 06:14:39 +00005687 Res = getBaseInputStem(Args, Inputs);
Chad Rosier30601782011-08-17 23:08:45 +00005688 }
Daniel Dunbar88137642009-09-09 22:32:48 +00005689 return Args.MakeArgString(Res + ".d");
Daniel Dunbara3ec60e2009-03-29 18:40:18 +00005690}
5691
Daniel Dunbar8cac5f72009-03-20 16:06:39 +00005692void darwin::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00005693 const InputInfo &Output,
Daniel Dunbarc21c4852009-04-08 23:54:23 +00005694 const InputInfoList &Inputs,
5695 const ArgList &Args,
Daniel Dunbar8cac5f72009-03-20 16:06:39 +00005696 const char *LinkingOutput) const {
5697 ArgStringList CmdArgs;
5698
5699 assert(Inputs.size() == 1 && "Unexpected number of inputs.");
5700 const InputInfo &Input = Inputs[0];
5701
Daniel Dunbar34bac1f2011-04-12 23:59:20 +00005702 // Determine the original source input.
5703 const Action *SourceAction = &JA;
5704 while (SourceAction->getKind() != Action::InputClass) {
5705 assert(!SourceAction->getInputs().empty() && "unexpected root action!");
5706 SourceAction = SourceAction->getInputs()[0];
5707 }
5708
Stephen Hines651f13c2014-04-23 16:59:28 -07005709 // If -fno_integrated_as is used add -Q to the darwin assember driver to make
Kevin Enderby6efcf6f2013-11-18 23:30:29 +00005710 // sure it runs its system assembler not clang's integrated assembler.
Stephen Hines651f13c2014-04-23 16:59:28 -07005711 // Applicable to darwin11+ and Xcode 4+. darwin<10 lacked integrated-as.
5712 // FIXME: at run-time detect assembler capabilities or rely on version
5713 // information forwarded by -target-assembler-version (future)
5714 if (Args.hasArg(options::OPT_fno_integrated_as)) {
5715 const llvm::Triple &T(getToolChain().getTriple());
5716 if (!(T.isMacOSX() && T.isMacOSXVersionLT(10, 7)))
5717 CmdArgs.push_back("-Q");
5718 }
Kevin Enderby6efcf6f2013-11-18 23:30:29 +00005719
Daniel Dunbar34bac1f2011-04-12 23:59:20 +00005720 // Forward -g, assuming we are dealing with an actual assembly file.
Eric Christopher88b7cf02011-08-19 00:30:14 +00005721 if (SourceAction->getType() == types::TY_Asm ||
Daniel Dunbar34bac1f2011-04-12 23:59:20 +00005722 SourceAction->getType() == types::TY_PP_Asm) {
Daniel Dunbar8e4fea62009-04-01 00:27:44 +00005723 if (Args.hasArg(options::OPT_gstabs))
5724 CmdArgs.push_back("--gstabs");
5725 else if (Args.hasArg(options::OPT_g_Group))
Bob Wilson591ff152011-11-02 05:10:45 +00005726 CmdArgs.push_back("-g");
Daniel Dunbar8e4fea62009-04-01 00:27:44 +00005727 }
Daniel Dunbarc21c4852009-04-08 23:54:23 +00005728
Daniel Dunbar8cac5f72009-03-20 16:06:39 +00005729 // Derived from asm spec.
Stephen Hines651f13c2014-04-23 16:59:28 -07005730 AddMachOArch(Args, CmdArgs);
Daniel Dunbar8cac5f72009-03-20 16:06:39 +00005731
Daniel Dunbarf5438e32010-07-22 01:47:22 +00005732 // Use -force_cpusubtype_ALL on x86 by default.
Eli Bendersky8f4269a2013-07-24 22:20:49 +00005733 if (getToolChain().getArch() == llvm::Triple::x86 ||
5734 getToolChain().getArch() == llvm::Triple::x86_64 ||
Daniel Dunbarcc6f8032009-09-09 18:36:27 +00005735 Args.hasArg(options::OPT_force__cpusubtype__ALL))
5736 CmdArgs.push_back("-force_cpusubtype_ALL");
5737
Eli Bendersky8f4269a2013-07-24 22:20:49 +00005738 if (getToolChain().getArch() != llvm::Triple::x86_64 &&
Daniel Dunbar7a0c0642012-10-15 22:23:53 +00005739 (((Args.hasArg(options::OPT_mkernel) ||
Eric Christopher59320e72013-02-21 22:35:01 +00005740 Args.hasArg(options::OPT_fapple_kext)) &&
Stephen Hines651f13c2014-04-23 16:59:28 -07005741 getMachOToolChain().isKernelStatic()) ||
Daniel Dunbar7a0c0642012-10-15 22:23:53 +00005742 Args.hasArg(options::OPT_static)))
Daniel Dunbarc21c4852009-04-08 23:54:23 +00005743 CmdArgs.push_back("-static");
5744
Daniel Dunbar8cac5f72009-03-20 16:06:39 +00005745 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
5746 options::OPT_Xassembler);
5747
5748 assert(Output.isFilename() && "Unexpected lipo output.");
5749 CmdArgs.push_back("-o");
5750 CmdArgs.push_back(Output.getFilename());
5751
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00005752 assert(Input.isFilename() && "Invalid input.");
5753 CmdArgs.push_back(Input.getFilename());
Daniel Dunbar8cac5f72009-03-20 16:06:39 +00005754
5755 // asm_final spec is empty.
5756
Daniel Dunbarc21c4852009-04-08 23:54:23 +00005757 const char *Exec =
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00005758 Args.MakeArgString(getToolChain().GetProgramPath("as"));
Stephen Hines176edba2014-12-01 14:53:08 -08005759 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Daniel Dunbar8cac5f72009-03-20 16:06:39 +00005760}
Daniel Dunbarff7488d2009-03-20 00:52:38 +00005761
Stephen Hines651f13c2014-04-23 16:59:28 -07005762void darwin::MachOTool::anchor() {}
David Blaikie99ba9e32011-12-20 02:48:34 +00005763
Stephen Hines651f13c2014-04-23 16:59:28 -07005764void darwin::MachOTool::AddMachOArch(const ArgList &Args,
5765 ArgStringList &CmdArgs) const {
5766 StringRef ArchName = getMachOToolChain().getMachOArchName(Args);
Daniel Dunbareeff4062010-01-22 02:04:58 +00005767
Daniel Dunbar02633b52009-03-26 16:23:12 +00005768 // Derived from darwin_arch spec.
5769 CmdArgs.push_back("-arch");
Daniel Dunbareeff4062010-01-22 02:04:58 +00005770 CmdArgs.push_back(Args.MakeArgString(ArchName));
Daniel Dunbar78dbd582009-09-04 18:35:31 +00005771
Daniel Dunbareeff4062010-01-22 02:04:58 +00005772 // FIXME: Is this needed anymore?
5773 if (ArchName == "arm")
Daniel Dunbar78dbd582009-09-04 18:35:31 +00005774 CmdArgs.push_back("-force_cpusubtype_ALL");
Daniel Dunbar02633b52009-03-26 16:23:12 +00005775}
5776
Bill Wendling6acf8b42012-10-02 18:02:50 +00005777bool darwin::Link::NeedsTempPath(const InputInfoList &Inputs) const {
5778 // We only need to generate a temp path for LTO if we aren't compiling object
5779 // files. When compiling source files, we run 'dsymutil' after linking. We
5780 // don't run 'dsymutil' when compiling object files.
Stephen Hinesef822542014-07-21 00:47:37 -07005781 for (const auto &Input : Inputs)
5782 if (Input.getType() != types::TY_Object)
Bill Wendling6acf8b42012-10-02 18:02:50 +00005783 return true;
5784
5785 return false;
5786}
5787
Daniel Dunbar748de8e2010-09-09 21:51:05 +00005788void darwin::Link::AddLinkArgs(Compilation &C,
5789 const ArgList &Args,
Bill Wendling6acf8b42012-10-02 18:02:50 +00005790 ArgStringList &CmdArgs,
5791 const InputInfoList &Inputs) const {
Daniel Dunbaree788e72009-12-21 18:54:17 +00005792 const Driver &D = getToolChain().getDriver();
Stephen Hines651f13c2014-04-23 16:59:28 -07005793 const toolchains::MachO &MachOTC = getMachOToolChain();
Daniel Dunbar02633b52009-03-26 16:23:12 +00005794
Daniel Dunbarb18dc5b2010-08-11 23:07:50 +00005795 unsigned Version[3] = { 0, 0, 0 };
5796 if (Arg *A = Args.getLastArg(options::OPT_mlinker_version_EQ)) {
5797 bool HadExtra;
Richard Smith1d489cf2012-11-01 04:30:05 +00005798 if (!Driver::GetReleaseVersion(A->getValue(), Version[0],
Daniel Dunbarb18dc5b2010-08-11 23:07:50 +00005799 Version[1], Version[2], HadExtra) ||
5800 HadExtra)
Chris Lattner5f9e2722011-07-23 10:55:15 +00005801 D.Diag(diag::err_drv_invalid_version_number)
Daniel Dunbarb18dc5b2010-08-11 23:07:50 +00005802 << A->getAsString(Args);
5803 }
5804
Stephen Hines651f13c2014-04-23 16:59:28 -07005805 // Newer linkers support -demangle. Pass it if supported and not disabled by
Daniel Dunbarb18dc5b2010-08-11 23:07:50 +00005806 // the user.
Stephen Hines651f13c2014-04-23 16:59:28 -07005807 if (Version[0] >= 100 && !Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
5808 CmdArgs.push_back("-demangle");
Daniel Dunbarb18dc5b2010-08-11 23:07:50 +00005809
Bob Wilsonbd77c592013-08-02 22:25:34 +00005810 if (Args.hasArg(options::OPT_rdynamic) && Version[0] >= 137)
5811 CmdArgs.push_back("-export_dynamic");
5812
Bill Wendlingc35f9082012-11-16 23:03:00 +00005813 // If we are using LTO, then automatically create a temporary file path for
5814 // the linker to use, so that it's lifetime will extend past a possible
5815 // dsymutil step.
Stephen Hines0e2c34f2015-03-23 12:09:02 -07005816 if (Version[0] >= 116 && D.IsUsingLTO(getToolChain(), Args) &&
5817 NeedsTempPath(Inputs)) {
Bill Wendlingc35f9082012-11-16 23:03:00 +00005818 const char *TmpPath = C.getArgs().MakeArgString(
5819 D.GetTemporaryPath("cc", types::getTypeTempSuffix(types::TY_Object)));
5820 C.addTempFile(TmpPath);
5821 CmdArgs.push_back("-object_path_lto");
5822 CmdArgs.push_back(TmpPath);
Daniel Dunbar5bfa6562011-06-21 20:55:11 +00005823 }
5824
Daniel Dunbar02633b52009-03-26 16:23:12 +00005825 // Derived from the "link" spec.
5826 Args.AddAllArgs(CmdArgs, options::OPT_static);
5827 if (!Args.hasArg(options::OPT_static))
5828 CmdArgs.push_back("-dynamic");
5829 if (Args.hasArg(options::OPT_fgnu_runtime)) {
5830 // FIXME: gcc replaces -lobjc in forward args with -lobjc-gnu
5831 // here. How do we wish to handle such things?
5832 }
Daniel Dunbarc21c4852009-04-08 23:54:23 +00005833
Daniel Dunbar02633b52009-03-26 16:23:12 +00005834 if (!Args.hasArg(options::OPT_dynamiclib)) {
Stephen Hines651f13c2014-04-23 16:59:28 -07005835 AddMachOArch(Args, CmdArgs);
Daniel Dunbara6d38492010-01-22 02:04:52 +00005836 // FIXME: Why do this only on this path?
Daniel Dunbar8917dd42010-01-22 03:37:33 +00005837 Args.AddLastArg(CmdArgs, options::OPT_force__cpusubtype__ALL);
Daniel Dunbar02633b52009-03-26 16:23:12 +00005838
5839 Args.AddLastArg(CmdArgs, options::OPT_bundle);
5840 Args.AddAllArgs(CmdArgs, options::OPT_bundle__loader);
5841 Args.AddAllArgs(CmdArgs, options::OPT_client__name);
5842
5843 Arg *A;
5844 if ((A = Args.getLastArg(options::OPT_compatibility__version)) ||
5845 (A = Args.getLastArg(options::OPT_current__version)) ||
5846 (A = Args.getLastArg(options::OPT_install__name)))
Chris Lattner5f9e2722011-07-23 10:55:15 +00005847 D.Diag(diag::err_drv_argument_only_allowed_with)
Daniel Dunbar02633b52009-03-26 16:23:12 +00005848 << A->getAsString(Args) << "-dynamiclib";
5849
5850 Args.AddLastArg(CmdArgs, options::OPT_force__flat__namespace);
5851 Args.AddLastArg(CmdArgs, options::OPT_keep__private__externs);
5852 Args.AddLastArg(CmdArgs, options::OPT_private__bundle);
5853 } else {
5854 CmdArgs.push_back("-dylib");
5855
5856 Arg *A;
5857 if ((A = Args.getLastArg(options::OPT_bundle)) ||
5858 (A = Args.getLastArg(options::OPT_bundle__loader)) ||
5859 (A = Args.getLastArg(options::OPT_client__name)) ||
5860 (A = Args.getLastArg(options::OPT_force__flat__namespace)) ||
5861 (A = Args.getLastArg(options::OPT_keep__private__externs)) ||
5862 (A = Args.getLastArg(options::OPT_private__bundle)))
Chris Lattner5f9e2722011-07-23 10:55:15 +00005863 D.Diag(diag::err_drv_argument_not_allowed_with)
Daniel Dunbar02633b52009-03-26 16:23:12 +00005864 << A->getAsString(Args) << "-dynamiclib";
Daniel Dunbarc21c4852009-04-08 23:54:23 +00005865
Daniel Dunbar02633b52009-03-26 16:23:12 +00005866 Args.AddAllArgsTranslated(CmdArgs, options::OPT_compatibility__version,
5867 "-dylib_compatibility_version");
5868 Args.AddAllArgsTranslated(CmdArgs, options::OPT_current__version,
5869 "-dylib_current_version");
5870
Stephen Hines651f13c2014-04-23 16:59:28 -07005871 AddMachOArch(Args, CmdArgs);
Daniel Dunbar02633b52009-03-26 16:23:12 +00005872
5873 Args.AddAllArgsTranslated(CmdArgs, options::OPT_install__name,
5874 "-dylib_install_name");
5875 }
5876
5877 Args.AddLastArg(CmdArgs, options::OPT_all__load);
5878 Args.AddAllArgs(CmdArgs, options::OPT_allowable__client);
5879 Args.AddLastArg(CmdArgs, options::OPT_bind__at__load);
Stephen Hines651f13c2014-04-23 16:59:28 -07005880 if (MachOTC.isTargetIOSBased())
Daniel Dunbard82f8fa2009-09-04 18:35:41 +00005881 Args.AddLastArg(CmdArgs, options::OPT_arch__errors__fatal);
Daniel Dunbar02633b52009-03-26 16:23:12 +00005882 Args.AddLastArg(CmdArgs, options::OPT_dead__strip);
5883 Args.AddLastArg(CmdArgs, options::OPT_no__dead__strip__inits__and__terms);
5884 Args.AddAllArgs(CmdArgs, options::OPT_dylib__file);
5885 Args.AddLastArg(CmdArgs, options::OPT_dynamic);
5886 Args.AddAllArgs(CmdArgs, options::OPT_exported__symbols__list);
5887 Args.AddLastArg(CmdArgs, options::OPT_flat__namespace);
Daniel Dunbar99ca47b2011-06-28 20:16:02 +00005888 Args.AddAllArgs(CmdArgs, options::OPT_force__load);
Daniel Dunbar02633b52009-03-26 16:23:12 +00005889 Args.AddAllArgs(CmdArgs, options::OPT_headerpad__max__install__names);
5890 Args.AddAllArgs(CmdArgs, options::OPT_image__base);
5891 Args.AddAllArgs(CmdArgs, options::OPT_init);
5892
Daniel Dunbarce911f52011-04-28 21:23:41 +00005893 // Add the deployment target.
Stephen Hines651f13c2014-04-23 16:59:28 -07005894 MachOTC.addMinVersionArgs(Args, CmdArgs);
Daniel Dunbarce911f52011-04-28 21:23:41 +00005895
Daniel Dunbar02633b52009-03-26 16:23:12 +00005896 Args.AddLastArg(CmdArgs, options::OPT_nomultidefs);
5897 Args.AddLastArg(CmdArgs, options::OPT_multi__module);
5898 Args.AddLastArg(CmdArgs, options::OPT_single__module);
5899 Args.AddAllArgs(CmdArgs, options::OPT_multiply__defined);
5900 Args.AddAllArgs(CmdArgs, options::OPT_multiply__defined__unused);
Daniel Dunbarc21c4852009-04-08 23:54:23 +00005901
Daniel Dunbar47e879d2010-07-13 23:31:40 +00005902 if (const Arg *A = Args.getLastArg(options::OPT_fpie, options::OPT_fPIE,
5903 options::OPT_fno_pie,
5904 options::OPT_fno_PIE)) {
5905 if (A->getOption().matches(options::OPT_fpie) ||
5906 A->getOption().matches(options::OPT_fPIE))
5907 CmdArgs.push_back("-pie");
5908 else
5909 CmdArgs.push_back("-no_pie");
5910 }
Daniel Dunbar02633b52009-03-26 16:23:12 +00005911
5912 Args.AddLastArg(CmdArgs, options::OPT_prebind);
5913 Args.AddLastArg(CmdArgs, options::OPT_noprebind);
5914 Args.AddLastArg(CmdArgs, options::OPT_nofixprebinding);
5915 Args.AddLastArg(CmdArgs, options::OPT_prebind__all__twolevel__modules);
5916 Args.AddLastArg(CmdArgs, options::OPT_read__only__relocs);
5917 Args.AddAllArgs(CmdArgs, options::OPT_sectcreate);
5918 Args.AddAllArgs(CmdArgs, options::OPT_sectorder);
5919 Args.AddAllArgs(CmdArgs, options::OPT_seg1addr);
5920 Args.AddAllArgs(CmdArgs, options::OPT_segprot);
5921 Args.AddAllArgs(CmdArgs, options::OPT_segaddr);
5922 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__only__addr);
5923 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__write__addr);
5924 Args.AddAllArgs(CmdArgs, options::OPT_seg__addr__table);
5925 Args.AddAllArgs(CmdArgs, options::OPT_seg__addr__table__filename);
5926 Args.AddAllArgs(CmdArgs, options::OPT_sub__library);
5927 Args.AddAllArgs(CmdArgs, options::OPT_sub__umbrella);
Daniel Dunbard82f8fa2009-09-04 18:35:41 +00005928
Daniel Dunbarcc957192011-05-02 21:03:47 +00005929 // Give --sysroot= preference, over the Apple specific behavior to also use
5930 // --isysroot as the syslibroot.
Sebastian Pop4762a2d2012-04-16 04:16:43 +00005931 StringRef sysroot = C.getSysRoot();
5932 if (sysroot != "") {
Daniel Dunbarcc957192011-05-02 21:03:47 +00005933 CmdArgs.push_back("-syslibroot");
Sebastian Pop4762a2d2012-04-16 04:16:43 +00005934 CmdArgs.push_back(C.getArgs().MakeArgString(sysroot));
Daniel Dunbarcc957192011-05-02 21:03:47 +00005935 } else if (const Arg *A = Args.getLastArg(options::OPT_isysroot)) {
5936 CmdArgs.push_back("-syslibroot");
Richard Smith1d489cf2012-11-01 04:30:05 +00005937 CmdArgs.push_back(A->getValue());
Daniel Dunbard82f8fa2009-09-04 18:35:41 +00005938 }
5939
Daniel Dunbar02633b52009-03-26 16:23:12 +00005940 Args.AddLastArg(CmdArgs, options::OPT_twolevel__namespace);
5941 Args.AddLastArg(CmdArgs, options::OPT_twolevel__namespace__hints);
5942 Args.AddAllArgs(CmdArgs, options::OPT_umbrella);
5943 Args.AddAllArgs(CmdArgs, options::OPT_undefined);
5944 Args.AddAllArgs(CmdArgs, options::OPT_unexported__symbols__list);
Daniel Dunbard82f8fa2009-09-04 18:35:41 +00005945 Args.AddAllArgs(CmdArgs, options::OPT_weak__reference__mismatches);
Daniel Dunbar02633b52009-03-26 16:23:12 +00005946 Args.AddLastArg(CmdArgs, options::OPT_X_Flag);
5947 Args.AddAllArgs(CmdArgs, options::OPT_y);
5948 Args.AddLastArg(CmdArgs, options::OPT_w);
5949 Args.AddAllArgs(CmdArgs, options::OPT_pagezero__size);
5950 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__);
5951 Args.AddLastArg(CmdArgs, options::OPT_seglinkedit);
5952 Args.AddLastArg(CmdArgs, options::OPT_noseglinkedit);
5953 Args.AddAllArgs(CmdArgs, options::OPT_sectalign);
5954 Args.AddAllArgs(CmdArgs, options::OPT_sectobjectsymbols);
5955 Args.AddAllArgs(CmdArgs, options::OPT_segcreate);
5956 Args.AddLastArg(CmdArgs, options::OPT_whyload);
5957 Args.AddLastArg(CmdArgs, options::OPT_whatsloaded);
5958 Args.AddAllArgs(CmdArgs, options::OPT_dylinker__install__name);
5959 Args.AddLastArg(CmdArgs, options::OPT_dylinker);
5960 Args.AddLastArg(CmdArgs, options::OPT_Mach);
5961}
5962
Stephen Hines651f13c2014-04-23 16:59:28 -07005963enum LibOpenMP {
5964 LibUnknown,
5965 LibGOMP,
5966 LibIOMP5
5967};
5968
Daniel Dunbar02633b52009-03-26 16:23:12 +00005969void darwin::Link::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00005970 const InputInfo &Output,
Daniel Dunbarc21c4852009-04-08 23:54:23 +00005971 const InputInfoList &Inputs,
5972 const ArgList &Args,
Daniel Dunbar02633b52009-03-26 16:23:12 +00005973 const char *LinkingOutput) const {
5974 assert(Output.getType() == types::TY_Image && "Invalid linker output type.");
Daniel Dunbare0be8b12009-09-08 16:39:16 +00005975
Stephen Hines176edba2014-12-01 14:53:08 -08005976 // If the number of arguments surpasses the system limits, we will encode the
5977 // input files in a separate file, shortening the command line. To this end,
5978 // build a list of input file names that can be passed via a file with the
5979 // -filelist linker option.
5980 llvm::opt::ArgStringList InputFileList;
5981
Daniel Dunbar02633b52009-03-26 16:23:12 +00005982 // The logic here is derived from gcc's behavior; most of which
5983 // comes from specs (starting with link_command). Consult gcc for
5984 // more information.
Daniel Dunbar02633b52009-03-26 16:23:12 +00005985 ArgStringList CmdArgs;
5986
Argyrios Kyrtzidis22897172011-10-07 22:58:08 +00005987 /// Hack(tm) to ignore linking errors when we are doing ARC migration.
5988 if (Args.hasArg(options::OPT_ccc_arcmt_check,
5989 options::OPT_ccc_arcmt_migrate)) {
Stephen Hinesef822542014-07-21 00:47:37 -07005990 for (const auto &Arg : Args)
5991 Arg->claim();
Argyrios Kyrtzidis22897172011-10-07 22:58:08 +00005992 const char *Exec =
5993 Args.MakeArgString(getToolChain().GetProgramPath("touch"));
5994 CmdArgs.push_back(Output.getFilename());
Stephen Hines176edba2014-12-01 14:53:08 -08005995 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Argyrios Kyrtzidis22897172011-10-07 22:58:08 +00005996 return;
5997 }
5998
Daniel Dunbar02633b52009-03-26 16:23:12 +00005999 // I'm not sure why this particular decomposition exists in gcc, but
6000 // we follow suite for ease of comparison.
Bill Wendling6acf8b42012-10-02 18:02:50 +00006001 AddLinkArgs(C, Args, CmdArgs, Inputs);
Daniel Dunbar02633b52009-03-26 16:23:12 +00006002
Daniel Dunbar02633b52009-03-26 16:23:12 +00006003 Args.AddAllArgs(CmdArgs, options::OPT_d_Flag);
6004 Args.AddAllArgs(CmdArgs, options::OPT_s);
6005 Args.AddAllArgs(CmdArgs, options::OPT_t);
6006 Args.AddAllArgs(CmdArgs, options::OPT_Z_Flag);
6007 Args.AddAllArgs(CmdArgs, options::OPT_u_Group);
Daniel Dunbar02633b52009-03-26 16:23:12 +00006008 Args.AddLastArg(CmdArgs, options::OPT_e);
Daniel Dunbar02633b52009-03-26 16:23:12 +00006009 Args.AddAllArgs(CmdArgs, options::OPT_r);
6010
Daniel Dunbar270073c2010-10-18 22:08:36 +00006011 // Forward -ObjC when either -ObjC or -ObjC++ is used, to force loading
6012 // members of static archive libraries which implement Objective-C classes or
6013 // categories.
6014 if (Args.hasArg(options::OPT_ObjC) || Args.hasArg(options::OPT_ObjCXX))
6015 CmdArgs.push_back("-ObjC");
Michael J. Spencer20249a12010-10-21 03:16:25 +00006016
Daniel Dunbar02633b52009-03-26 16:23:12 +00006017 CmdArgs.push_back("-o");
6018 CmdArgs.push_back(Output.getFilename());
6019
Chad Rosier18937312012-05-16 23:45:12 +00006020 if (!Args.hasArg(options::OPT_nostdlib) &&
Stephen Hines651f13c2014-04-23 16:59:28 -07006021 !Args.hasArg(options::OPT_nostartfiles))
6022 getMachOToolChain().addStartObjectFileArgs(Args, CmdArgs);
Daniel Dunbar02633b52009-03-26 16:23:12 +00006023
6024 Args.AddAllArgs(CmdArgs, options::OPT_L);
Daniel Dunbarc21c4852009-04-08 23:54:23 +00006025
Stephen Hines651f13c2014-04-23 16:59:28 -07006026 LibOpenMP UsedOpenMPLib = LibUnknown;
6027 if (Args.hasArg(options::OPT_fopenmp)) {
6028 UsedOpenMPLib = LibGOMP;
6029 } else if (const Arg *A = Args.getLastArg(options::OPT_fopenmp_EQ)) {
6030 UsedOpenMPLib = llvm::StringSwitch<LibOpenMP>(A->getValue())
6031 .Case("libgomp", LibGOMP)
6032 .Case("libiomp5", LibIOMP5)
6033 .Default(LibUnknown);
6034 if (UsedOpenMPLib == LibUnknown)
6035 getToolChain().getDriver().Diag(diag::err_drv_unsupported_option_argument)
6036 << A->getOption().getName() << A->getValue();
6037 }
6038 switch (UsedOpenMPLib) {
6039 case LibGOMP:
Daniel Dunbar02633b52009-03-26 16:23:12 +00006040 CmdArgs.push_back("-lgomp");
Stephen Hines651f13c2014-04-23 16:59:28 -07006041 break;
6042 case LibIOMP5:
6043 CmdArgs.push_back("-liomp5");
6044 break;
6045 case LibUnknown:
6046 break;
6047 }
Daniel Dunbar02633b52009-03-26 16:23:12 +00006048
Douglas Gregor04e326b2012-05-15 21:00:27 +00006049 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Stephen Hines176edba2014-12-01 14:53:08 -08006050 // Build the input file for -filelist (list of linker input files) in case we
6051 // need it later
6052 for (const auto &II : Inputs) {
6053 if (!II.isFilename()) {
6054 // This is a linker input argument.
6055 // We cannot mix input arguments and file names in a -filelist input, thus
6056 // we prematurely stop our list (remaining files shall be passed as
6057 // arguments).
6058 if (InputFileList.size() > 0)
6059 break;
6060
6061 continue;
6062 }
6063
6064 InputFileList.push_back(II.getFilename());
6065 }
6066
Bob Wilson63d9f3c2012-05-15 18:57:39 +00006067 if (isObjCRuntimeLinked(Args) &&
6068 !Args.hasArg(options::OPT_nostdlib) &&
6069 !Args.hasArg(options::OPT_nodefaultlibs)) {
Stephen Hines651f13c2014-04-23 16:59:28 -07006070 // We use arclite library for both ARC and subscripting support.
6071 getMachOToolChain().AddLinkARCArgs(Args, CmdArgs);
6072
Bob Wilson0b1c7152012-04-21 00:21:42 +00006073 CmdArgs.push_back("-framework");
6074 CmdArgs.push_back("Foundation");
Ted Kremenekebcb57a2012-03-06 20:05:56 +00006075 // Link libobj.
6076 CmdArgs.push_back("-lobjc");
John McCall9f084a32011-07-06 00:26:06 +00006077 }
John McCallf85e1932011-06-15 23:02:42 +00006078
Daniel Dunbar02633b52009-03-26 16:23:12 +00006079 if (LinkingOutput) {
6080 CmdArgs.push_back("-arch_multiple");
6081 CmdArgs.push_back("-final_output");
6082 CmdArgs.push_back(LinkingOutput);
6083 }
6084
Daniel Dunbar02633b52009-03-26 16:23:12 +00006085 if (Args.hasArg(options::OPT_fnested_functions))
6086 CmdArgs.push_back("-allow_stack_execute");
Daniel Dunbarc21c4852009-04-08 23:54:23 +00006087
Daniel Dunbar02633b52009-03-26 16:23:12 +00006088 if (!Args.hasArg(options::OPT_nostdlib) &&
6089 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg76b86c22013-07-18 20:29:38 +00006090 if (getToolChain().getDriver().CCCIsCXX())
Daniel Dunbar132e35d2010-09-17 01:20:05 +00006091 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Daniel Dunbaredfa02b2009-04-08 06:06:21 +00006092
Daniel Dunbar02633b52009-03-26 16:23:12 +00006093 // link_ssp spec is empty.
6094
Daniel Dunbar6cd41542009-09-18 08:15:03 +00006095 // Let the tool chain choose which runtime library to link.
Stephen Hines651f13c2014-04-23 16:59:28 -07006096 getMachOToolChain().AddLinkRuntimeLibArgs(Args, CmdArgs);
Daniel Dunbar02633b52009-03-26 16:23:12 +00006097 }
6098
Chad Rosier18937312012-05-16 23:45:12 +00006099 if (!Args.hasArg(options::OPT_nostdlib) &&
Daniel Dunbar02633b52009-03-26 16:23:12 +00006100 !Args.hasArg(options::OPT_nostartfiles)) {
6101 // endfile_spec is empty.
6102 }
6103
6104 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
6105 Args.AddAllArgs(CmdArgs, options::OPT_F);
6106
Stephen Hines0e2c34f2015-03-23 12:09:02 -07006107 // -iframework should be forwarded as -F.
6108 for (auto it = Args.filtered_begin(options::OPT_iframework),
6109 ie = Args.filtered_end(); it != ie; ++it)
6110 CmdArgs.push_back(Args.MakeArgString(std::string("-F") +
6111 (*it)->getValue()));
6112
Daniel Dunbarc21c4852009-04-08 23:54:23 +00006113 const char *Exec =
Stephen Hinesef822542014-07-21 00:47:37 -07006114 Args.MakeArgString(getToolChain().GetLinkerPath());
Stephen Hines176edba2014-12-01 14:53:08 -08006115 std::unique_ptr<Command> Cmd =
6116 llvm::make_unique<Command>(JA, *this, Exec, CmdArgs);
6117 Cmd->setInputFileList(std::move(InputFileList));
6118 C.addCommand(std::move(Cmd));
Daniel Dunbar02633b52009-03-26 16:23:12 +00006119}
6120
Daniel Dunbarff7488d2009-03-20 00:52:38 +00006121void darwin::Lipo::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00006122 const InputInfo &Output,
Daniel Dunbarc21c4852009-04-08 23:54:23 +00006123 const InputInfoList &Inputs,
6124 const ArgList &Args,
Daniel Dunbarff7488d2009-03-20 00:52:38 +00006125 const char *LinkingOutput) const {
6126 ArgStringList CmdArgs;
6127
6128 CmdArgs.push_back("-create");
6129 assert(Output.isFilename() && "Unexpected lipo output.");
Daniel Dunbara428df82009-03-24 00:24:37 +00006130
6131 CmdArgs.push_back("-output");
Daniel Dunbarff7488d2009-03-20 00:52:38 +00006132 CmdArgs.push_back(Output.getFilename());
Daniel Dunbara428df82009-03-24 00:24:37 +00006133
Stephen Hinesef822542014-07-21 00:47:37 -07006134 for (const auto &II : Inputs) {
Daniel Dunbarff7488d2009-03-20 00:52:38 +00006135 assert(II.isFilename() && "Unexpected lipo input.");
6136 CmdArgs.push_back(II.getFilename());
6137 }
Stephen Hinesef822542014-07-21 00:47:37 -07006138
6139 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("lipo"));
Stephen Hines176edba2014-12-01 14:53:08 -08006140 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Daniel Dunbarff7488d2009-03-20 00:52:38 +00006141}
Daniel Dunbar68a31d42009-03-31 17:45:15 +00006142
Daniel Dunbar6e0f2542010-06-04 18:28:36 +00006143void darwin::Dsymutil::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00006144 const InputInfo &Output,
Daniel Dunbar6e0f2542010-06-04 18:28:36 +00006145 const InputInfoList &Inputs,
6146 const ArgList &Args,
6147 const char *LinkingOutput) const {
6148 ArgStringList CmdArgs;
6149
Daniel Dunbar03e92302011-05-09 17:23:16 +00006150 CmdArgs.push_back("-o");
6151 CmdArgs.push_back(Output.getFilename());
6152
Daniel Dunbar6e0f2542010-06-04 18:28:36 +00006153 assert(Inputs.size() == 1 && "Unable to handle multiple inputs.");
6154 const InputInfo &Input = Inputs[0];
6155 assert(Input.isFilename() && "Unexpected dsymutil input.");
6156 CmdArgs.push_back(Input.getFilename());
6157
Daniel Dunbar6e0f2542010-06-04 18:28:36 +00006158 const char *Exec =
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00006159 Args.MakeArgString(getToolChain().GetProgramPath("dsymutil"));
Stephen Hines176edba2014-12-01 14:53:08 -08006160 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Daniel Dunbar6e0f2542010-06-04 18:28:36 +00006161}
6162
Eric Christopherf8571862011-08-23 17:56:55 +00006163void darwin::VerifyDebug::ConstructJob(Compilation &C, const JobAction &JA,
Eric Christopher27e2b982012-12-18 00:31:10 +00006164 const InputInfo &Output,
6165 const InputInfoList &Inputs,
6166 const ArgList &Args,
6167 const char *LinkingOutput) const {
Eric Christopherf8571862011-08-23 17:56:55 +00006168 ArgStringList CmdArgs;
6169 CmdArgs.push_back("--verify");
Eric Christopher1c79dc42012-02-06 19:13:09 +00006170 CmdArgs.push_back("--debug-info");
6171 CmdArgs.push_back("--eh-frame");
Eric Christopherb822f722012-02-06 19:43:51 +00006172 CmdArgs.push_back("--quiet");
Eric Christopherf8571862011-08-23 17:56:55 +00006173
6174 assert(Inputs.size() == 1 && "Unable to handle multiple inputs.");
6175 const InputInfo &Input = Inputs[0];
6176 assert(Input.isFilename() && "Unexpected verify input");
6177
6178 // Grabbing the output of the earlier dsymutil run.
6179 CmdArgs.push_back(Input.getFilename());
6180
6181 const char *Exec =
6182 Args.MakeArgString(getToolChain().GetProgramPath("dwarfdump"));
Stephen Hines176edba2014-12-01 14:53:08 -08006183 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Eric Christopherf8571862011-08-23 17:56:55 +00006184}
6185
David Chisnall31c46902012-02-15 13:39:01 +00006186void solaris::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
6187 const InputInfo &Output,
6188 const InputInfoList &Inputs,
6189 const ArgList &Args,
6190 const char *LinkingOutput) const {
Stephen Hines0e2c34f2015-03-23 12:09:02 -07006191 claimNoWarnArgs(Args);
David Chisnall31c46902012-02-15 13:39:01 +00006192 ArgStringList CmdArgs;
6193
6194 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
6195 options::OPT_Xassembler);
6196
6197 CmdArgs.push_back("-o");
6198 CmdArgs.push_back(Output.getFilename());
6199
Stephen Hinesef822542014-07-21 00:47:37 -07006200 for (const auto &II : Inputs)
David Chisnall31c46902012-02-15 13:39:01 +00006201 CmdArgs.push_back(II.getFilename());
David Chisnall31c46902012-02-15 13:39:01 +00006202
Stephen Hinesef822542014-07-21 00:47:37 -07006203 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Stephen Hines176edba2014-12-01 14:53:08 -08006204 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
David Chisnall31c46902012-02-15 13:39:01 +00006205}
6206
David Chisnall31c46902012-02-15 13:39:01 +00006207void solaris::Link::ConstructJob(Compilation &C, const JobAction &JA,
6208 const InputInfo &Output,
6209 const InputInfoList &Inputs,
6210 const ArgList &Args,
6211 const char *LinkingOutput) const {
6212 // FIXME: Find a real GCC, don't hard-code versions here
6213 std::string GCCLibPath = "/usr/gcc/4.5/lib/gcc/";
6214 const llvm::Triple &T = getToolChain().getTriple();
6215 std::string LibPath = "/usr/lib/";
6216 llvm::Triple::ArchType Arch = T.getArch();
6217 switch (Arch) {
Benjamin Kramer39e4b0f2013-10-21 12:33:55 +00006218 case llvm::Triple::x86:
6219 GCCLibPath +=
6220 ("i386-" + T.getVendorName() + "-" + T.getOSName()).str() + "/4.5.2/";
6221 break;
6222 case llvm::Triple::x86_64:
6223 GCCLibPath += ("i386-" + T.getVendorName() + "-" + T.getOSName()).str();
6224 GCCLibPath += "/4.5.2/amd64/";
6225 LibPath += "amd64/";
6226 break;
6227 default:
6228 llvm_unreachable("Unsupported architecture");
David Chisnall31c46902012-02-15 13:39:01 +00006229 }
6230
6231 ArgStringList CmdArgs;
6232
David Chisnall41d476d2012-02-29 15:06:12 +00006233 // Demangle C++ names in errors
6234 CmdArgs.push_back("-C");
6235
David Chisnall31c46902012-02-15 13:39:01 +00006236 if ((!Args.hasArg(options::OPT_nostdlib)) &&
6237 (!Args.hasArg(options::OPT_shared))) {
6238 CmdArgs.push_back("-e");
6239 CmdArgs.push_back("_start");
6240 }
6241
6242 if (Args.hasArg(options::OPT_static)) {
6243 CmdArgs.push_back("-Bstatic");
6244 CmdArgs.push_back("-dn");
6245 } else {
6246 CmdArgs.push_back("-Bdynamic");
6247 if (Args.hasArg(options::OPT_shared)) {
6248 CmdArgs.push_back("-shared");
6249 } else {
6250 CmdArgs.push_back("--dynamic-linker");
6251 CmdArgs.push_back(Args.MakeArgString(LibPath + "ld.so.1"));
6252 }
6253 }
6254
6255 if (Output.isFilename()) {
6256 CmdArgs.push_back("-o");
6257 CmdArgs.push_back(Output.getFilename());
6258 } else {
6259 assert(Output.isNothing() && "Invalid output.");
6260 }
6261
6262 if (!Args.hasArg(options::OPT_nostdlib) &&
6263 !Args.hasArg(options::OPT_nostartfiles)) {
6264 if (!Args.hasArg(options::OPT_shared)) {
6265 CmdArgs.push_back(Args.MakeArgString(LibPath + "crt1.o"));
6266 CmdArgs.push_back(Args.MakeArgString(LibPath + "crti.o"));
David Chisnall165329c2012-02-28 17:10:04 +00006267 CmdArgs.push_back(Args.MakeArgString(LibPath + "values-Xa.o"));
David Chisnall31c46902012-02-15 13:39:01 +00006268 CmdArgs.push_back(Args.MakeArgString(GCCLibPath + "crtbegin.o"));
6269 } else {
6270 CmdArgs.push_back(Args.MakeArgString(LibPath + "crti.o"));
David Chisnall165329c2012-02-28 17:10:04 +00006271 CmdArgs.push_back(Args.MakeArgString(LibPath + "values-Xa.o"));
6272 CmdArgs.push_back(Args.MakeArgString(GCCLibPath + "crtbegin.o"));
David Chisnall31c46902012-02-15 13:39:01 +00006273 }
Hans Wennborg76b86c22013-07-18 20:29:38 +00006274 if (getToolChain().getDriver().CCCIsCXX())
David Chisnalle6dd6832012-03-13 14:14:54 +00006275 CmdArgs.push_back(Args.MakeArgString(LibPath + "cxa_finalize.o"));
David Chisnall31c46902012-02-15 13:39:01 +00006276 }
6277
6278 CmdArgs.push_back(Args.MakeArgString("-L" + GCCLibPath));
6279
6280 Args.AddAllArgs(CmdArgs, options::OPT_L);
6281 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
6282 Args.AddAllArgs(CmdArgs, options::OPT_e);
David Chisnall165329c2012-02-28 17:10:04 +00006283 Args.AddAllArgs(CmdArgs, options::OPT_r);
David Chisnall31c46902012-02-15 13:39:01 +00006284
6285 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
6286
6287 if (!Args.hasArg(options::OPT_nostdlib) &&
6288 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg76b86c22013-07-18 20:29:38 +00006289 if (getToolChain().getDriver().CCCIsCXX())
David Chisnalle58e6f92012-04-10 11:49:50 +00006290 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
David Chisnallb6229592012-02-15 18:24:31 +00006291 CmdArgs.push_back("-lgcc_s");
David Chisnall165329c2012-02-28 17:10:04 +00006292 if (!Args.hasArg(options::OPT_shared)) {
6293 CmdArgs.push_back("-lgcc");
David Chisnall31c46902012-02-15 13:39:01 +00006294 CmdArgs.push_back("-lc");
David Chisnall7dbefe12012-02-28 20:06:45 +00006295 CmdArgs.push_back("-lm");
David Chisnall165329c2012-02-28 17:10:04 +00006296 }
David Chisnall31c46902012-02-15 13:39:01 +00006297 }
6298
6299 if (!Args.hasArg(options::OPT_nostdlib) &&
6300 !Args.hasArg(options::OPT_nostartfiles)) {
David Chisnall165329c2012-02-28 17:10:04 +00006301 CmdArgs.push_back(Args.MakeArgString(GCCLibPath + "crtend.o"));
David Chisnall31c46902012-02-15 13:39:01 +00006302 }
David Chisnalld1ac03e2012-02-16 16:00:47 +00006303 CmdArgs.push_back(Args.MakeArgString(LibPath + "crtn.o"));
David Chisnall31c46902012-02-15 13:39:01 +00006304
Stephen Hines651f13c2014-04-23 16:59:28 -07006305 addProfileRT(getToolChain(), Args, CmdArgs);
David Chisnall31c46902012-02-15 13:39:01 +00006306
6307 const char *Exec =
Stephen Hinesef822542014-07-21 00:47:37 -07006308 Args.MakeArgString(getToolChain().GetLinkerPath());
Stephen Hines176edba2014-12-01 14:53:08 -08006309 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Edward O'Callaghane7925a02009-08-22 01:06:46 +00006310}
6311
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00006312void openbsd::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00006313 const InputInfo &Output,
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00006314 const InputInfoList &Inputs,
6315 const ArgList &Args,
Mike Stump1eb44332009-09-09 15:08:12 +00006316 const char *LinkingOutput) const {
Stephen Hines0e2c34f2015-03-23 12:09:02 -07006317 claimNoWarnArgs(Args);
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00006318 ArgStringList CmdArgs;
Stephen Hines651f13c2014-04-23 16:59:28 -07006319 bool NeedsKPIC = false;
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00006320
Stephen Hines651f13c2014-04-23 16:59:28 -07006321 switch (getToolChain().getArch()) {
6322 case llvm::Triple::x86:
6323 // When building 32-bit code on OpenBSD/amd64, we have to explicitly
6324 // instruct as in the base system to assemble 32-bit code.
Bill Wendlingac66cb82013-12-08 00:21:01 +00006325 CmdArgs.push_back("--32");
Stephen Hines651f13c2014-04-23 16:59:28 -07006326 break;
6327
6328 case llvm::Triple::ppc:
Bill Wendlingac66cb82013-12-08 00:21:01 +00006329 CmdArgs.push_back("-mppc");
6330 CmdArgs.push_back("-many");
Stephen Hines651f13c2014-04-23 16:59:28 -07006331 break;
6332
6333 case llvm::Triple::sparc:
6334 CmdArgs.push_back("-32");
6335 NeedsKPIC = true;
6336 break;
6337
6338 case llvm::Triple::sparcv9:
6339 CmdArgs.push_back("-64");
6340 CmdArgs.push_back("-Av9a");
6341 NeedsKPIC = true;
6342 break;
6343
6344 case llvm::Triple::mips64:
6345 case llvm::Triple::mips64el: {
Bill Wendlingac66cb82013-12-08 00:21:01 +00006346 StringRef CPUName;
6347 StringRef ABIName;
Stephen Hines176edba2014-12-01 14:53:08 -08006348 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Bill Wendlingac66cb82013-12-08 00:21:01 +00006349
6350 CmdArgs.push_back("-mabi");
6351 CmdArgs.push_back(getGnuCompatibleMipsABIName(ABIName).data());
6352
6353 if (getToolChain().getArch() == llvm::Triple::mips64)
6354 CmdArgs.push_back("-EB");
6355 else
6356 CmdArgs.push_back("-EL");
6357
Stephen Hines651f13c2014-04-23 16:59:28 -07006358 NeedsKPIC = true;
6359 break;
Bill Wendlingac66cb82013-12-08 00:21:01 +00006360 }
6361
Stephen Hines651f13c2014-04-23 16:59:28 -07006362 default:
6363 break;
6364 }
6365
6366 if (NeedsKPIC)
6367 addAssemblerKPIC(Args, CmdArgs);
6368
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00006369 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
6370 options::OPT_Xassembler);
6371
6372 CmdArgs.push_back("-o");
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00006373 CmdArgs.push_back(Output.getFilename());
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00006374
Stephen Hinesef822542014-07-21 00:47:37 -07006375 for (const auto &II : Inputs)
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00006376 CmdArgs.push_back(II.getFilename());
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00006377
6378 const char *Exec =
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00006379 Args.MakeArgString(getToolChain().GetProgramPath("as"));
Stephen Hines176edba2014-12-01 14:53:08 -08006380 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00006381}
6382
6383void openbsd::Link::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00006384 const InputInfo &Output,
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00006385 const InputInfoList &Inputs,
6386 const ArgList &Args,
6387 const char *LinkingOutput) const {
Daniel Dunbaree788e72009-12-21 18:54:17 +00006388 const Driver &D = getToolChain().getDriver();
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00006389 ArgStringList CmdArgs;
6390
Rafael Espindola6cc2a682012-12-31 22:41:36 +00006391 // Silence warning for "clang -g foo.o -o foo"
6392 Args.ClaimAllArgs(options::OPT_g_Group);
6393 // and "clang -emit-llvm foo.o -o foo"
6394 Args.ClaimAllArgs(options::OPT_emit_llvm);
6395 // and for "clang -w foo.o -o foo". Other warning options are already
6396 // handled somewhere else.
6397 Args.ClaimAllArgs(options::OPT_w);
6398
Bill Wendlingac66cb82013-12-08 00:21:01 +00006399 if (getToolChain().getArch() == llvm::Triple::mips64)
6400 CmdArgs.push_back("-EB");
6401 else if (getToolChain().getArch() == llvm::Triple::mips64el)
6402 CmdArgs.push_back("-EL");
6403
Daniel Dunbar2bbcf662009-08-03 01:28:59 +00006404 if ((!Args.hasArg(options::OPT_nostdlib)) &&
Daniel Dunbar294691e2009-11-04 06:24:38 +00006405 (!Args.hasArg(options::OPT_shared))) {
Daniel Dunbar2bbcf662009-08-03 01:28:59 +00006406 CmdArgs.push_back("-e");
6407 CmdArgs.push_back("__start");
6408 }
6409
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00006410 if (Args.hasArg(options::OPT_static)) {
6411 CmdArgs.push_back("-Bstatic");
6412 } else {
Rafael Espindola65ba55d2010-11-11 02:17:51 +00006413 if (Args.hasArg(options::OPT_rdynamic))
6414 CmdArgs.push_back("-export-dynamic");
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00006415 CmdArgs.push_back("--eh-frame-hdr");
Daniel Dunbar2bbcf662009-08-03 01:28:59 +00006416 CmdArgs.push_back("-Bdynamic");
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00006417 if (Args.hasArg(options::OPT_shared)) {
Daniel Dunbar2bbcf662009-08-03 01:28:59 +00006418 CmdArgs.push_back("-shared");
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00006419 } else {
6420 CmdArgs.push_back("-dynamic-linker");
6421 CmdArgs.push_back("/usr/libexec/ld.so");
6422 }
6423 }
6424
Rafael Espindola9adba392013-06-05 04:28:55 +00006425 if (Args.hasArg(options::OPT_nopie))
6426 CmdArgs.push_back("-nopie");
6427
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00006428 if (Output.isFilename()) {
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00006429 CmdArgs.push_back("-o");
6430 CmdArgs.push_back(Output.getFilename());
6431 } else {
6432 assert(Output.isNothing() && "Invalid output.");
6433 }
6434
6435 if (!Args.hasArg(options::OPT_nostdlib) &&
6436 !Args.hasArg(options::OPT_nostartfiles)) {
6437 if (!Args.hasArg(options::OPT_shared)) {
Eli Friedman62d829a2011-12-15 02:15:56 +00006438 if (Args.hasArg(options::OPT_pg))
6439 CmdArgs.push_back(Args.MakeArgString(
6440 getToolChain().GetFilePath("gcrt0.o")));
6441 else
6442 CmdArgs.push_back(Args.MakeArgString(
6443 getToolChain().GetFilePath("crt0.o")));
Chris Lattner38e317d2010-07-07 16:01:42 +00006444 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00006445 getToolChain().GetFilePath("crtbegin.o")));
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00006446 } else {
Chris Lattner38e317d2010-07-07 16:01:42 +00006447 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00006448 getToolChain().GetFilePath("crtbeginS.o")));
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00006449 }
6450 }
6451
Edward O'Callaghane7e18202009-10-28 15:13:08 +00006452 std::string Triple = getToolChain().getTripleString();
6453 if (Triple.substr(0, 6) == "x86_64")
Daniel Dunbar294691e2009-11-04 06:24:38 +00006454 Triple.replace(0, 6, "amd64");
Daniel Dunbarf7fb31f2009-10-29 02:24:37 +00006455 CmdArgs.push_back(Args.MakeArgString("-L/usr/lib/gcc-lib/" + Triple +
Daniel Dunbar95c04572010-08-01 23:13:54 +00006456 "/4.2.1"));
Daniel Dunbar2bbcf662009-08-03 01:28:59 +00006457
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00006458 Args.AddAllArgs(CmdArgs, options::OPT_L);
6459 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
6460 Args.AddAllArgs(CmdArgs, options::OPT_e);
Rafael Espindola6cc2a682012-12-31 22:41:36 +00006461 Args.AddAllArgs(CmdArgs, options::OPT_s);
6462 Args.AddAllArgs(CmdArgs, options::OPT_t);
6463 Args.AddAllArgs(CmdArgs, options::OPT_Z_Flag);
6464 Args.AddAllArgs(CmdArgs, options::OPT_r);
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00006465
Daniel Dunbar2008fee2010-09-17 00:24:54 +00006466 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00006467
6468 if (!Args.hasArg(options::OPT_nostdlib) &&
6469 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg76b86c22013-07-18 20:29:38 +00006470 if (D.CCCIsCXX()) {
Daniel Dunbar132e35d2010-09-17 01:20:05 +00006471 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Eli Friedman62d829a2011-12-15 02:15:56 +00006472 if (Args.hasArg(options::OPT_pg))
6473 CmdArgs.push_back("-lm_p");
6474 else
6475 CmdArgs.push_back("-lm");
Daniel Dunbar95c04572010-08-01 23:13:54 +00006476 }
6477
Daniel Dunbar2bbcf662009-08-03 01:28:59 +00006478 // FIXME: For some reason GCC passes -lgcc before adding
6479 // the default system libraries. Just mimic this for now.
6480 CmdArgs.push_back("-lgcc");
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00006481
Eric Christopherdc6cc872012-09-13 06:32:34 +00006482 if (Args.hasArg(options::OPT_pthread)) {
6483 if (!Args.hasArg(options::OPT_shared) &&
6484 Args.hasArg(options::OPT_pg))
6485 CmdArgs.push_back("-lpthread_p");
6486 else
6487 CmdArgs.push_back("-lpthread");
6488 }
6489
Chandler Carruth657849c2011-12-17 22:32:42 +00006490 if (!Args.hasArg(options::OPT_shared)) {
Eric Christopherdc6cc872012-09-13 06:32:34 +00006491 if (Args.hasArg(options::OPT_pg))
Eli Friedman62d829a2011-12-15 02:15:56 +00006492 CmdArgs.push_back("-lc_p");
6493 else
6494 CmdArgs.push_back("-lc");
Chandler Carruth657849c2011-12-17 22:32:42 +00006495 }
Eric Christopherdc6cc872012-09-13 06:32:34 +00006496
Daniel Dunbar2bbcf662009-08-03 01:28:59 +00006497 CmdArgs.push_back("-lgcc");
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00006498 }
6499
6500 if (!Args.hasArg(options::OPT_nostdlib) &&
6501 !Args.hasArg(options::OPT_nostartfiles)) {
6502 if (!Args.hasArg(options::OPT_shared))
Chris Lattner38e317d2010-07-07 16:01:42 +00006503 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00006504 getToolChain().GetFilePath("crtend.o")));
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00006505 else
Chris Lattner38e317d2010-07-07 16:01:42 +00006506 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00006507 getToolChain().GetFilePath("crtendS.o")));
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00006508 }
6509
6510 const char *Exec =
Stephen Hinesef822542014-07-21 00:47:37 -07006511 Args.MakeArgString(getToolChain().GetLinkerPath());
Stephen Hines176edba2014-12-01 14:53:08 -08006512 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Daniel Dunbarf7b8eec2009-06-29 20:52:51 +00006513}
Ed Schoutenc66a5a32009-04-02 19:13:12 +00006514
Eli Friedman42f74f22012-08-08 23:57:20 +00006515void bitrig::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
6516 const InputInfo &Output,
6517 const InputInfoList &Inputs,
6518 const ArgList &Args,
6519 const char *LinkingOutput) const {
Stephen Hines0e2c34f2015-03-23 12:09:02 -07006520 claimNoWarnArgs(Args);
Eli Friedman42f74f22012-08-08 23:57:20 +00006521 ArgStringList CmdArgs;
6522
6523 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
6524 options::OPT_Xassembler);
6525
6526 CmdArgs.push_back("-o");
6527 CmdArgs.push_back(Output.getFilename());
6528
Stephen Hinesef822542014-07-21 00:47:37 -07006529 for (const auto &II : Inputs)
Eli Friedman42f74f22012-08-08 23:57:20 +00006530 CmdArgs.push_back(II.getFilename());
Eli Friedman42f74f22012-08-08 23:57:20 +00006531
Stephen Hinesef822542014-07-21 00:47:37 -07006532 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Stephen Hines176edba2014-12-01 14:53:08 -08006533 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Eli Friedman42f74f22012-08-08 23:57:20 +00006534}
6535
6536void bitrig::Link::ConstructJob(Compilation &C, const JobAction &JA,
6537 const InputInfo &Output,
6538 const InputInfoList &Inputs,
6539 const ArgList &Args,
6540 const char *LinkingOutput) const {
6541 const Driver &D = getToolChain().getDriver();
6542 ArgStringList CmdArgs;
6543
6544 if ((!Args.hasArg(options::OPT_nostdlib)) &&
6545 (!Args.hasArg(options::OPT_shared))) {
6546 CmdArgs.push_back("-e");
6547 CmdArgs.push_back("__start");
6548 }
6549
6550 if (Args.hasArg(options::OPT_static)) {
6551 CmdArgs.push_back("-Bstatic");
6552 } else {
6553 if (Args.hasArg(options::OPT_rdynamic))
6554 CmdArgs.push_back("-export-dynamic");
6555 CmdArgs.push_back("--eh-frame-hdr");
6556 CmdArgs.push_back("-Bdynamic");
6557 if (Args.hasArg(options::OPT_shared)) {
6558 CmdArgs.push_back("-shared");
6559 } else {
6560 CmdArgs.push_back("-dynamic-linker");
6561 CmdArgs.push_back("/usr/libexec/ld.so");
6562 }
6563 }
6564
6565 if (Output.isFilename()) {
6566 CmdArgs.push_back("-o");
6567 CmdArgs.push_back(Output.getFilename());
6568 } else {
6569 assert(Output.isNothing() && "Invalid output.");
6570 }
6571
6572 if (!Args.hasArg(options::OPT_nostdlib) &&
6573 !Args.hasArg(options::OPT_nostartfiles)) {
6574 if (!Args.hasArg(options::OPT_shared)) {
6575 if (Args.hasArg(options::OPT_pg))
6576 CmdArgs.push_back(Args.MakeArgString(
6577 getToolChain().GetFilePath("gcrt0.o")));
6578 else
6579 CmdArgs.push_back(Args.MakeArgString(
6580 getToolChain().GetFilePath("crt0.o")));
6581 CmdArgs.push_back(Args.MakeArgString(
6582 getToolChain().GetFilePath("crtbegin.o")));
6583 } else {
6584 CmdArgs.push_back(Args.MakeArgString(
6585 getToolChain().GetFilePath("crtbeginS.o")));
6586 }
6587 }
6588
6589 Args.AddAllArgs(CmdArgs, options::OPT_L);
6590 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
6591 Args.AddAllArgs(CmdArgs, options::OPT_e);
6592
6593 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
6594
6595 if (!Args.hasArg(options::OPT_nostdlib) &&
6596 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg76b86c22013-07-18 20:29:38 +00006597 if (D.CCCIsCXX()) {
Eli Friedman42f74f22012-08-08 23:57:20 +00006598 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
6599 if (Args.hasArg(options::OPT_pg))
6600 CmdArgs.push_back("-lm_p");
6601 else
6602 CmdArgs.push_back("-lm");
6603 }
6604
Rafael Espindola3667bbe2012-10-23 17:07:31 +00006605 if (Args.hasArg(options::OPT_pthread)) {
6606 if (!Args.hasArg(options::OPT_shared) &&
6607 Args.hasArg(options::OPT_pg))
6608 CmdArgs.push_back("-lpthread_p");
6609 else
6610 CmdArgs.push_back("-lpthread");
6611 }
6612
Eli Friedman42f74f22012-08-08 23:57:20 +00006613 if (!Args.hasArg(options::OPT_shared)) {
6614 if (Args.hasArg(options::OPT_pg))
6615 CmdArgs.push_back("-lc_p");
6616 else
6617 CmdArgs.push_back("-lc");
6618 }
6619
Benjamin Kramer39e4b0f2013-10-21 12:33:55 +00006620 StringRef MyArch;
6621 switch (getToolChain().getTriple().getArch()) {
6622 case llvm::Triple::arm:
6623 MyArch = "arm";
6624 break;
6625 case llvm::Triple::x86:
6626 MyArch = "i386";
6627 break;
6628 case llvm::Triple::x86_64:
6629 MyArch = "amd64";
6630 break;
6631 default:
6632 llvm_unreachable("Unsupported architecture");
6633 }
6634 CmdArgs.push_back(Args.MakeArgString("-lclang_rt." + MyArch));
Eli Friedman42f74f22012-08-08 23:57:20 +00006635 }
6636
6637 if (!Args.hasArg(options::OPT_nostdlib) &&
6638 !Args.hasArg(options::OPT_nostartfiles)) {
6639 if (!Args.hasArg(options::OPT_shared))
6640 CmdArgs.push_back(Args.MakeArgString(
6641 getToolChain().GetFilePath("crtend.o")));
6642 else
6643 CmdArgs.push_back(Args.MakeArgString(
6644 getToolChain().GetFilePath("crtendS.o")));
6645 }
Eli Friedmanc9c48db2012-08-09 22:42:04 +00006646
6647 const char *Exec =
Stephen Hinesef822542014-07-21 00:47:37 -07006648 Args.MakeArgString(getToolChain().GetLinkerPath());
Stephen Hines176edba2014-12-01 14:53:08 -08006649 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Eli Friedman42f74f22012-08-08 23:57:20 +00006650}
6651
Daniel Dunbar68a31d42009-03-31 17:45:15 +00006652void freebsd::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00006653 const InputInfo &Output,
Daniel Dunbarc21c4852009-04-08 23:54:23 +00006654 const InputInfoList &Inputs,
6655 const ArgList &Args,
Mike Stump1eb44332009-09-09 15:08:12 +00006656 const char *LinkingOutput) const {
Stephen Hines0e2c34f2015-03-23 12:09:02 -07006657 claimNoWarnArgs(Args);
Daniel Dunbar68a31d42009-03-31 17:45:15 +00006658 ArgStringList CmdArgs;
6659
Daniel Dunbar008f54a2009-04-01 19:36:32 +00006660 // When building 32-bit code on FreeBSD/amd64, we have to explicitly
6661 // instruct as in the base system to assemble 32-bit code.
Eric Christopherc55da4b2012-09-05 21:32:44 +00006662 if (getToolChain().getArch() == llvm::Triple::x86)
Daniel Dunbar68a31d42009-03-31 17:45:15 +00006663 CmdArgs.push_back("--32");
Eric Christopherc55da4b2012-09-05 21:32:44 +00006664 else if (getToolChain().getArch() == llvm::Triple::ppc)
Roman Divacky3393cef2011-06-04 07:37:31 +00006665 CmdArgs.push_back("-a32");
Eric Christopherc55da4b2012-09-05 21:32:44 +00006666 else if (getToolChain().getArch() == llvm::Triple::mips ||
6667 getToolChain().getArch() == llvm::Triple::mipsel ||
6668 getToolChain().getArch() == llvm::Triple::mips64 ||
6669 getToolChain().getArch() == llvm::Triple::mips64el) {
6670 StringRef CPUName;
6671 StringRef ABIName;
Stephen Hines176edba2014-12-01 14:53:08 -08006672 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Michael J. Spencer20249a12010-10-21 03:16:25 +00006673
Eric Christopherc55da4b2012-09-05 21:32:44 +00006674 CmdArgs.push_back("-march");
6675 CmdArgs.push_back(CPUName.data());
6676
Eric Christopherc55da4b2012-09-05 21:32:44 +00006677 CmdArgs.push_back("-mabi");
Simon Atanasyane9616a42013-02-27 14:55:49 +00006678 CmdArgs.push_back(getGnuCompatibleMipsABIName(ABIName).data());
Eric Christopherc55da4b2012-09-05 21:32:44 +00006679
6680 if (getToolChain().getArch() == llvm::Triple::mips ||
6681 getToolChain().getArch() == llvm::Triple::mips64)
6682 CmdArgs.push_back("-EB");
6683 else
6684 CmdArgs.push_back("-EL");
6685
Stephen Hines651f13c2014-04-23 16:59:28 -07006686 addAssemblerKPIC(Args, CmdArgs);
Rafael Espindola27fa2362012-12-13 04:17:14 +00006687 } else if (getToolChain().getArch() == llvm::Triple::arm ||
Stephen Hines651f13c2014-04-23 16:59:28 -07006688 getToolChain().getArch() == llvm::Triple::armeb ||
6689 getToolChain().getArch() == llvm::Triple::thumb ||
6690 getToolChain().getArch() == llvm::Triple::thumbeb) {
6691 const Driver &D = getToolChain().getDriver();
6692 const llvm::Triple &Triple = getToolChain().getTriple();
6693 StringRef FloatABI = arm::getARMFloatABI(D, Args, Triple);
6694
6695 if (FloatABI == "hard") {
6696 CmdArgs.push_back("-mfpu=vfp");
6697 } else {
6698 CmdArgs.push_back("-mfpu=softvfp");
6699 }
6700
Rafael Espindola27fa2362012-12-13 04:17:14 +00006701 switch(getToolChain().getTriple().getEnvironment()) {
Stephen Hines651f13c2014-04-23 16:59:28 -07006702 case llvm::Triple::GNUEABIHF:
Rafael Espindola27fa2362012-12-13 04:17:14 +00006703 case llvm::Triple::GNUEABI:
6704 case llvm::Triple::EABI:
Anton Korobeynikovb234e742013-03-18 07:59:20 +00006705 CmdArgs.push_back("-meabi=5");
Rafael Espindola27fa2362012-12-13 04:17:14 +00006706 break;
6707
6708 default:
6709 CmdArgs.push_back("-matpcs");
6710 }
Stephen Hines651f13c2014-04-23 16:59:28 -07006711 } else if (getToolChain().getArch() == llvm::Triple::sparc ||
6712 getToolChain().getArch() == llvm::Triple::sparcv9) {
6713 if (getToolChain().getArch() == llvm::Triple::sparc)
6714 CmdArgs.push_back("-Av8plusa");
6715 else
6716 CmdArgs.push_back("-Av9a");
6717
6718 addAssemblerKPIC(Args, CmdArgs);
Eric Christopherc55da4b2012-09-05 21:32:44 +00006719 }
Eric Christophered734732010-03-02 02:41:08 +00006720
Daniel Dunbar68a31d42009-03-31 17:45:15 +00006721 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
6722 options::OPT_Xassembler);
6723
6724 CmdArgs.push_back("-o");
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00006725 CmdArgs.push_back(Output.getFilename());
Daniel Dunbar68a31d42009-03-31 17:45:15 +00006726
Stephen Hinesef822542014-07-21 00:47:37 -07006727 for (const auto &II : Inputs)
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00006728 CmdArgs.push_back(II.getFilename());
Daniel Dunbar68a31d42009-03-31 17:45:15 +00006729
Stephen Hinesef822542014-07-21 00:47:37 -07006730 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Stephen Hines176edba2014-12-01 14:53:08 -08006731 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Daniel Dunbar68a31d42009-03-31 17:45:15 +00006732}
Daniel Dunbar008f54a2009-04-01 19:36:32 +00006733
6734void freebsd::Link::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00006735 const InputInfo &Output,
Daniel Dunbarc21c4852009-04-08 23:54:23 +00006736 const InputInfoList &Inputs,
6737 const ArgList &Args,
Daniel Dunbara8304f62009-05-02 20:14:53 +00006738 const char *LinkingOutput) const {
Roman Divacky94380162012-08-28 15:09:03 +00006739 const toolchains::FreeBSD& ToolChain =
6740 static_cast<const toolchains::FreeBSD&>(getToolChain());
6741 const Driver &D = ToolChain.getDriver();
Stephen Hines651f13c2014-04-23 16:59:28 -07006742 const bool IsPIE =
6743 !Args.hasArg(options::OPT_shared) &&
6744 (Args.hasArg(options::OPT_pie) || ToolChain.isPIEDefault());
Daniel Dunbar008f54a2009-04-01 19:36:32 +00006745 ArgStringList CmdArgs;
David Chisnalldfa210b2012-07-29 15:24:44 +00006746
6747 // Silence warning for "clang -g foo.o -o foo"
6748 Args.ClaimAllArgs(options::OPT_g_Group);
6749 // and "clang -emit-llvm foo.o -o foo"
6750 Args.ClaimAllArgs(options::OPT_emit_llvm);
6751 // and for "clang -w foo.o -o foo". Other warning options are already
6752 // handled somewhere else.
6753 Args.ClaimAllArgs(options::OPT_w);
Daniel Dunbar008f54a2009-04-01 19:36:32 +00006754
Joerg Sonnenberger8ab2bdc2011-03-21 13:51:29 +00006755 if (!D.SysRoot.empty())
6756 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
6757
Stephen Hines651f13c2014-04-23 16:59:28 -07006758 if (IsPIE)
Roman Divacky94380162012-08-28 15:09:03 +00006759 CmdArgs.push_back("-pie");
6760
Daniel Dunbar008f54a2009-04-01 19:36:32 +00006761 if (Args.hasArg(options::OPT_static)) {
6762 CmdArgs.push_back("-Bstatic");
6763 } else {
Rafael Espindola65ba55d2010-11-11 02:17:51 +00006764 if (Args.hasArg(options::OPT_rdynamic))
6765 CmdArgs.push_back("-export-dynamic");
Daniel Dunbar008f54a2009-04-01 19:36:32 +00006766 CmdArgs.push_back("--eh-frame-hdr");
6767 if (Args.hasArg(options::OPT_shared)) {
6768 CmdArgs.push_back("-Bshareable");
6769 } else {
6770 CmdArgs.push_back("-dynamic-linker");
6771 CmdArgs.push_back("/libexec/ld-elf.so.1");
6772 }
Roman Divacky94380162012-08-28 15:09:03 +00006773 if (ToolChain.getTriple().getOSMajorVersion() >= 9) {
6774 llvm::Triple::ArchType Arch = ToolChain.getArch();
David Chisnalldfa210b2012-07-29 15:24:44 +00006775 if (Arch == llvm::Triple::arm || Arch == llvm::Triple::sparc ||
6776 Arch == llvm::Triple::x86 || Arch == llvm::Triple::x86_64) {
6777 CmdArgs.push_back("--hash-style=both");
6778 }
6779 }
6780 CmdArgs.push_back("--enable-new-dtags");
Daniel Dunbar008f54a2009-04-01 19:36:32 +00006781 }
6782
6783 // When building 32-bit code on FreeBSD/amd64, we have to explicitly
6784 // instruct ld in the base system to link 32-bit code.
Rafael Espindola64f7ad92012-10-07 04:44:33 +00006785 if (ToolChain.getArch() == llvm::Triple::x86) {
Daniel Dunbar008f54a2009-04-01 19:36:32 +00006786 CmdArgs.push_back("-m");
6787 CmdArgs.push_back("elf_i386_fbsd");
6788 }
6789
Rafael Espindola64f7ad92012-10-07 04:44:33 +00006790 if (ToolChain.getArch() == llvm::Triple::ppc) {
Roman Divacky000a6552011-06-04 07:40:24 +00006791 CmdArgs.push_back("-m");
Roman Divacky1052c1d2011-11-21 16:50:32 +00006792 CmdArgs.push_back("elf32ppc_fbsd");
Roman Divacky000a6552011-06-04 07:40:24 +00006793 }
6794
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00006795 if (Output.isFilename()) {
Daniel Dunbar008f54a2009-04-01 19:36:32 +00006796 CmdArgs.push_back("-o");
6797 CmdArgs.push_back(Output.getFilename());
6798 } else {
6799 assert(Output.isNothing() && "Invalid output.");
6800 }
6801
6802 if (!Args.hasArg(options::OPT_nostdlib) &&
6803 !Args.hasArg(options::OPT_nostartfiles)) {
Stephen Hines6bcf27b2014-05-29 04:14:42 -07006804 const char *crt1 = nullptr;
Daniel Dunbar008f54a2009-04-01 19:36:32 +00006805 if (!Args.hasArg(options::OPT_shared)) {
Roman Divackyc16bb762011-02-10 16:59:40 +00006806 if (Args.hasArg(options::OPT_pg))
Roman Divacky94380162012-08-28 15:09:03 +00006807 crt1 = "gcrt1.o";
Stephen Hines651f13c2014-04-23 16:59:28 -07006808 else if (IsPIE)
Roman Divacky94380162012-08-28 15:09:03 +00006809 crt1 = "Scrt1.o";
6810 else
6811 crt1 = "crt1.o";
Daniel Dunbar008f54a2009-04-01 19:36:32 +00006812 }
Roman Divacky94380162012-08-28 15:09:03 +00006813 if (crt1)
6814 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crt1)));
6815
6816 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
6817
Stephen Hines6bcf27b2014-05-29 04:14:42 -07006818 const char *crtbegin = nullptr;
Roman Divacky94380162012-08-28 15:09:03 +00006819 if (Args.hasArg(options::OPT_static))
6820 crtbegin = "crtbeginT.o";
Stephen Hines651f13c2014-04-23 16:59:28 -07006821 else if (Args.hasArg(options::OPT_shared) || IsPIE)
Roman Divacky94380162012-08-28 15:09:03 +00006822 crtbegin = "crtbeginS.o";
6823 else
6824 crtbegin = "crtbegin.o";
6825
6826 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtbegin)));
Daniel Dunbar008f54a2009-04-01 19:36:32 +00006827 }
6828
6829 Args.AddAllArgs(CmdArgs, options::OPT_L);
Stephen Hines176edba2014-12-01 14:53:08 -08006830 const ToolChain::path_list &Paths = ToolChain.getFilePaths();
Stephen Hinesef822542014-07-21 00:47:37 -07006831 for (const auto &Path : Paths)
6832 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
Daniel Dunbar008f54a2009-04-01 19:36:32 +00006833 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
6834 Args.AddAllArgs(CmdArgs, options::OPT_e);
David Chisnallc7363772010-08-15 22:58:12 +00006835 Args.AddAllArgs(CmdArgs, options::OPT_s);
6836 Args.AddAllArgs(CmdArgs, options::OPT_t);
6837 Args.AddAllArgs(CmdArgs, options::OPT_Z_Flag);
6838 Args.AddAllArgs(CmdArgs, options::OPT_r);
Daniel Dunbar008f54a2009-04-01 19:36:32 +00006839
Stephen Hines0e2c34f2015-03-23 12:09:02 -07006840 if (D.IsUsingLTO(getToolChain(), Args))
Stephen Hines651f13c2014-04-23 16:59:28 -07006841 AddGoldPlugin(ToolChain, Args, CmdArgs);
Roman Divackydb334192013-11-10 09:31:43 +00006842
Stephen Hines176edba2014-12-01 14:53:08 -08006843 bool NeedsSanitizerDeps = addSanitizerRuntimes(ToolChain, Args, CmdArgs);
Roman Divacky94380162012-08-28 15:09:03 +00006844 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
Daniel Dunbar008f54a2009-04-01 19:36:32 +00006845
6846 if (!Args.hasArg(options::OPT_nostdlib) &&
6847 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg76b86c22013-07-18 20:29:38 +00006848 if (D.CCCIsCXX()) {
Roman Divacky94380162012-08-28 15:09:03 +00006849 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
Roman Divackyc16bb762011-02-10 16:59:40 +00006850 if (Args.hasArg(options::OPT_pg))
6851 CmdArgs.push_back("-lm_p");
6852 else
6853 CmdArgs.push_back("-lm");
Daniel Dunbar20022632010-02-17 08:07:51 +00006854 }
Stephen Hines176edba2014-12-01 14:53:08 -08006855 if (NeedsSanitizerDeps)
6856 linkSanitizerRuntimeDeps(ToolChain, CmdArgs);
Daniel Dunbar008f54a2009-04-01 19:36:32 +00006857 // FIXME: For some reason GCC passes -lgcc and -lgcc_s before adding
6858 // the default system libraries. Just mimic this for now.
Roman Divackyc16bb762011-02-10 16:59:40 +00006859 if (Args.hasArg(options::OPT_pg))
6860 CmdArgs.push_back("-lgcc_p");
6861 else
6862 CmdArgs.push_back("-lgcc");
Daniel Dunbar008f54a2009-04-01 19:36:32 +00006863 if (Args.hasArg(options::OPT_static)) {
6864 CmdArgs.push_back("-lgcc_eh");
Roman Divackyc16bb762011-02-10 16:59:40 +00006865 } else if (Args.hasArg(options::OPT_pg)) {
6866 CmdArgs.push_back("-lgcc_eh_p");
Daniel Dunbar008f54a2009-04-01 19:36:32 +00006867 } else {
6868 CmdArgs.push_back("--as-needed");
6869 CmdArgs.push_back("-lgcc_s");
6870 CmdArgs.push_back("--no-as-needed");
6871 }
6872
Matt Beaumont-Gay24230262011-02-10 20:35:01 +00006873 if (Args.hasArg(options::OPT_pthread)) {
Roman Divackyc16bb762011-02-10 16:59:40 +00006874 if (Args.hasArg(options::OPT_pg))
6875 CmdArgs.push_back("-lpthread_p");
6876 else
6877 CmdArgs.push_back("-lpthread");
Matt Beaumont-Gay24230262011-02-10 20:35:01 +00006878 }
Daniel Dunbar008f54a2009-04-01 19:36:32 +00006879
Roman Divackyc16bb762011-02-10 16:59:40 +00006880 if (Args.hasArg(options::OPT_pg)) {
6881 if (Args.hasArg(options::OPT_shared))
6882 CmdArgs.push_back("-lc");
6883 else
6884 CmdArgs.push_back("-lc_p");
6885 CmdArgs.push_back("-lgcc_p");
6886 } else {
6887 CmdArgs.push_back("-lc");
6888 CmdArgs.push_back("-lgcc");
6889 }
6890
Daniel Dunbar008f54a2009-04-01 19:36:32 +00006891 if (Args.hasArg(options::OPT_static)) {
6892 CmdArgs.push_back("-lgcc_eh");
Roman Divackyc16bb762011-02-10 16:59:40 +00006893 } else if (Args.hasArg(options::OPT_pg)) {
6894 CmdArgs.push_back("-lgcc_eh_p");
Daniel Dunbar008f54a2009-04-01 19:36:32 +00006895 } else {
6896 CmdArgs.push_back("--as-needed");
6897 CmdArgs.push_back("-lgcc_s");
6898 CmdArgs.push_back("--no-as-needed");
6899 }
6900 }
6901
6902 if (!Args.hasArg(options::OPT_nostdlib) &&
6903 !Args.hasArg(options::OPT_nostartfiles)) {
Stephen Hines651f13c2014-04-23 16:59:28 -07006904 if (Args.hasArg(options::OPT_shared) || IsPIE)
Roman Divacky94380162012-08-28 15:09:03 +00006905 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtendS.o")));
Roman Divackyf6513812012-09-07 13:36:21 +00006906 else
6907 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtend.o")));
Roman Divacky94380162012-08-28 15:09:03 +00006908 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
Daniel Dunbar008f54a2009-04-01 19:36:32 +00006909 }
6910
Stephen Hines651f13c2014-04-23 16:59:28 -07006911 addProfileRT(ToolChain, Args, CmdArgs);
Nick Lewycky2e95a6d2011-05-24 21:54:59 +00006912
Daniel Dunbarc21c4852009-04-08 23:54:23 +00006913 const char *Exec =
Stephen Hinesef822542014-07-21 00:47:37 -07006914 Args.MakeArgString(getToolChain().GetLinkerPath());
Stephen Hines176edba2014-12-01 14:53:08 -08006915 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Daniel Dunbar008f54a2009-04-01 19:36:32 +00006916}
Daniel Dunbar11e1b402009-05-02 18:28:39 +00006917
Benjamin Kramer8e50a962011-02-02 18:59:27 +00006918void netbsd::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
6919 const InputInfo &Output,
6920 const InputInfoList &Inputs,
6921 const ArgList &Args,
6922 const char *LinkingOutput) const {
Stephen Hines0e2c34f2015-03-23 12:09:02 -07006923 claimNoWarnArgs(Args);
Benjamin Kramer8e50a962011-02-02 18:59:27 +00006924 ArgStringList CmdArgs;
6925
Stephen Hines651f13c2014-04-23 16:59:28 -07006926 // GNU as needs different flags for creating the correct output format
6927 // on architectures with different ABIs or optional feature sets.
6928 switch (getToolChain().getArch()) {
6929 case llvm::Triple::x86:
Benjamin Kramer8e50a962011-02-02 18:59:27 +00006930 CmdArgs.push_back("--32");
Stephen Hines651f13c2014-04-23 16:59:28 -07006931 break;
6932 case llvm::Triple::arm:
6933 case llvm::Triple::armeb:
6934 case llvm::Triple::thumb:
6935 case llvm::Triple::thumbeb: {
6936 std::string MArch(arm::getARMTargetCPU(Args, getToolChain().getTriple()));
Bill Wendlingcf660bd2013-12-06 19:12:36 +00006937 CmdArgs.push_back(Args.MakeArgString("-mcpu=" + MArch));
Stephen Hines651f13c2014-04-23 16:59:28 -07006938 break;
Bill Wendlingcf660bd2013-12-06 19:12:36 +00006939 }
6940
Stephen Hines651f13c2014-04-23 16:59:28 -07006941 case llvm::Triple::mips:
6942 case llvm::Triple::mipsel:
6943 case llvm::Triple::mips64:
6944 case llvm::Triple::mips64el: {
Bill Wendlingc54c8852013-12-09 02:59:27 +00006945 StringRef CPUName;
6946 StringRef ABIName;
Stephen Hines176edba2014-12-01 14:53:08 -08006947 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Bill Wendlingc54c8852013-12-09 02:59:27 +00006948
6949 CmdArgs.push_back("-march");
6950 CmdArgs.push_back(CPUName.data());
6951
6952 CmdArgs.push_back("-mabi");
6953 CmdArgs.push_back(getGnuCompatibleMipsABIName(ABIName).data());
6954
6955 if (getToolChain().getArch() == llvm::Triple::mips ||
6956 getToolChain().getArch() == llvm::Triple::mips64)
6957 CmdArgs.push_back("-EB");
6958 else
6959 CmdArgs.push_back("-EL");
6960
Stephen Hines651f13c2014-04-23 16:59:28 -07006961 addAssemblerKPIC(Args, CmdArgs);
6962 break;
6963 }
6964
6965 case llvm::Triple::sparc:
6966 CmdArgs.push_back("-32");
6967 addAssemblerKPIC(Args, CmdArgs);
6968 break;
6969
6970 case llvm::Triple::sparcv9:
6971 CmdArgs.push_back("-64");
6972 CmdArgs.push_back("-Av9");
6973 addAssemblerKPIC(Args, CmdArgs);
6974 break;
6975
6976 default:
6977 break;
Bill Wendlingc54c8852013-12-09 02:59:27 +00006978 }
Benjamin Kramer8e50a962011-02-02 18:59:27 +00006979
6980 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
6981 options::OPT_Xassembler);
6982
6983 CmdArgs.push_back("-o");
6984 CmdArgs.push_back(Output.getFilename());
6985
Stephen Hinesef822542014-07-21 00:47:37 -07006986 for (const auto &II : Inputs)
Benjamin Kramer8e50a962011-02-02 18:59:27 +00006987 CmdArgs.push_back(II.getFilename());
Benjamin Kramer8e50a962011-02-02 18:59:27 +00006988
David Chisnall5adcec12011-09-27 22:03:18 +00006989 const char *Exec = Args.MakeArgString((getToolChain().GetProgramPath("as")));
Stephen Hines176edba2014-12-01 14:53:08 -08006990 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Benjamin Kramer8e50a962011-02-02 18:59:27 +00006991}
6992
6993void netbsd::Link::ConstructJob(Compilation &C, const JobAction &JA,
6994 const InputInfo &Output,
6995 const InputInfoList &Inputs,
6996 const ArgList &Args,
6997 const char *LinkingOutput) const {
6998 const Driver &D = getToolChain().getDriver();
6999 ArgStringList CmdArgs;
7000
Joerg Sonnenberger8ab2bdc2011-03-21 13:51:29 +00007001 if (!D.SysRoot.empty())
7002 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
7003
Stephen Hines651f13c2014-04-23 16:59:28 -07007004 CmdArgs.push_back("--eh-frame-hdr");
Benjamin Kramer8e50a962011-02-02 18:59:27 +00007005 if (Args.hasArg(options::OPT_static)) {
7006 CmdArgs.push_back("-Bstatic");
7007 } else {
7008 if (Args.hasArg(options::OPT_rdynamic))
7009 CmdArgs.push_back("-export-dynamic");
Benjamin Kramer8e50a962011-02-02 18:59:27 +00007010 if (Args.hasArg(options::OPT_shared)) {
7011 CmdArgs.push_back("-Bshareable");
7012 } else {
7013 CmdArgs.push_back("-dynamic-linker");
7014 CmdArgs.push_back("/libexec/ld.elf_so");
7015 }
7016 }
7017
Stephen Hines651f13c2014-04-23 16:59:28 -07007018 // Many NetBSD architectures support more than one ABI.
7019 // Determine the correct emulation for ld.
7020 switch (getToolChain().getArch()) {
7021 case llvm::Triple::x86:
Benjamin Kramer8e50a962011-02-02 18:59:27 +00007022 CmdArgs.push_back("-m");
7023 CmdArgs.push_back("elf_i386");
Stephen Hines651f13c2014-04-23 16:59:28 -07007024 break;
7025 case llvm::Triple::arm:
Stephen Hines651f13c2014-04-23 16:59:28 -07007026 case llvm::Triple::thumb:
Stephen Hines651f13c2014-04-23 16:59:28 -07007027 CmdArgs.push_back("-m");
7028 switch (getToolChain().getTriple().getEnvironment()) {
7029 case llvm::Triple::EABI:
7030 case llvm::Triple::GNUEABI:
7031 CmdArgs.push_back("armelf_nbsd_eabi");
7032 break;
7033 case llvm::Triple::EABIHF:
7034 case llvm::Triple::GNUEABIHF:
7035 CmdArgs.push_back("armelf_nbsd_eabihf");
7036 break;
7037 default:
7038 CmdArgs.push_back("armelf_nbsd");
7039 break;
7040 }
7041 break;
Stephen Hines176edba2014-12-01 14:53:08 -08007042 case llvm::Triple::armeb:
7043 case llvm::Triple::thumbeb:
Stephen Hines0e2c34f2015-03-23 12:09:02 -07007044 arm::appendEBLinkFlags(Args, CmdArgs, getToolChain().getTriple());
Stephen Hines176edba2014-12-01 14:53:08 -08007045 CmdArgs.push_back("-m");
7046 switch (getToolChain().getTriple().getEnvironment()) {
7047 case llvm::Triple::EABI:
7048 case llvm::Triple::GNUEABI:
7049 CmdArgs.push_back("armelfb_nbsd_eabi");
7050 break;
7051 case llvm::Triple::EABIHF:
7052 case llvm::Triple::GNUEABIHF:
7053 CmdArgs.push_back("armelfb_nbsd_eabihf");
7054 break;
7055 default:
7056 CmdArgs.push_back("armelfb_nbsd");
7057 break;
7058 }
7059 break;
Stephen Hines651f13c2014-04-23 16:59:28 -07007060 case llvm::Triple::mips64:
7061 case llvm::Triple::mips64el:
7062 if (mips::hasMipsAbiArg(Args, "32")) {
7063 CmdArgs.push_back("-m");
7064 if (getToolChain().getArch() == llvm::Triple::mips64)
7065 CmdArgs.push_back("elf32btsmip");
7066 else
7067 CmdArgs.push_back("elf32ltsmip");
7068 } else if (mips::hasMipsAbiArg(Args, "64")) {
7069 CmdArgs.push_back("-m");
7070 if (getToolChain().getArch() == llvm::Triple::mips64)
7071 CmdArgs.push_back("elf64btsmip");
7072 else
7073 CmdArgs.push_back("elf64ltsmip");
7074 }
7075 break;
Stephen Hines176edba2014-12-01 14:53:08 -08007076 case llvm::Triple::ppc:
7077 CmdArgs.push_back("-m");
7078 CmdArgs.push_back("elf32ppc_nbsd");
7079 break;
7080
7081 case llvm::Triple::ppc64:
7082 case llvm::Triple::ppc64le:
7083 CmdArgs.push_back("-m");
7084 CmdArgs.push_back("elf64ppc");
7085 break;
Stephen Hines651f13c2014-04-23 16:59:28 -07007086
7087 case llvm::Triple::sparc:
7088 CmdArgs.push_back("-m");
7089 CmdArgs.push_back("elf32_sparc");
7090 break;
7091
7092 case llvm::Triple::sparcv9:
7093 CmdArgs.push_back("-m");
7094 CmdArgs.push_back("elf64_sparc");
7095 break;
7096
7097 default:
7098 break;
Benjamin Kramer8e50a962011-02-02 18:59:27 +00007099 }
7100
7101 if (Output.isFilename()) {
7102 CmdArgs.push_back("-o");
7103 CmdArgs.push_back(Output.getFilename());
7104 } else {
7105 assert(Output.isNothing() && "Invalid output.");
7106 }
7107
7108 if (!Args.hasArg(options::OPT_nostdlib) &&
7109 !Args.hasArg(options::OPT_nostartfiles)) {
7110 if (!Args.hasArg(options::OPT_shared)) {
7111 CmdArgs.push_back(Args.MakeArgString(
7112 getToolChain().GetFilePath("crt0.o")));
7113 CmdArgs.push_back(Args.MakeArgString(
7114 getToolChain().GetFilePath("crti.o")));
7115 CmdArgs.push_back(Args.MakeArgString(
7116 getToolChain().GetFilePath("crtbegin.o")));
7117 } else {
7118 CmdArgs.push_back(Args.MakeArgString(
7119 getToolChain().GetFilePath("crti.o")));
7120 CmdArgs.push_back(Args.MakeArgString(
7121 getToolChain().GetFilePath("crtbeginS.o")));
7122 }
7123 }
7124
7125 Args.AddAllArgs(CmdArgs, options::OPT_L);
7126 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
7127 Args.AddAllArgs(CmdArgs, options::OPT_e);
7128 Args.AddAllArgs(CmdArgs, options::OPT_s);
7129 Args.AddAllArgs(CmdArgs, options::OPT_t);
7130 Args.AddAllArgs(CmdArgs, options::OPT_Z_Flag);
7131 Args.AddAllArgs(CmdArgs, options::OPT_r);
7132
7133 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
7134
Joerg Sonnenbergere69cca42013-10-14 20:13:05 +00007135 unsigned Major, Minor, Micro;
7136 getToolChain().getTriple().getOSVersion(Major, Minor, Micro);
7137 bool useLibgcc = true;
Stephen Hines176edba2014-12-01 14:53:08 -08007138 if (Major >= 7 || (Major == 6 && Minor == 99 && Micro >= 49) || Major == 0) {
Stephen Hines651f13c2014-04-23 16:59:28 -07007139 switch(getToolChain().getArch()) {
Stephen Hines176edba2014-12-01 14:53:08 -08007140 case llvm::Triple::aarch64:
Stephen Hines6bcf27b2014-05-29 04:14:42 -07007141 case llvm::Triple::arm:
7142 case llvm::Triple::armeb:
7143 case llvm::Triple::thumb:
7144 case llvm::Triple::thumbeb:
Stephen Hines176edba2014-12-01 14:53:08 -08007145 case llvm::Triple::ppc:
7146 case llvm::Triple::ppc64:
7147 case llvm::Triple::ppc64le:
Stephen Hines651f13c2014-04-23 16:59:28 -07007148 case llvm::Triple::x86:
7149 case llvm::Triple::x86_64:
Joerg Sonnenbergere69cca42013-10-14 20:13:05 +00007150 useLibgcc = false;
Stephen Hines651f13c2014-04-23 16:59:28 -07007151 break;
7152 default:
7153 break;
7154 }
Joerg Sonnenbergere69cca42013-10-14 20:13:05 +00007155 }
7156
Benjamin Kramer8e50a962011-02-02 18:59:27 +00007157 if (!Args.hasArg(options::OPT_nostdlib) &&
7158 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg76b86c22013-07-18 20:29:38 +00007159 if (D.CCCIsCXX()) {
Benjamin Kramer8e50a962011-02-02 18:59:27 +00007160 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
7161 CmdArgs.push_back("-lm");
7162 }
Benjamin Kramer8e50a962011-02-02 18:59:27 +00007163 if (Args.hasArg(options::OPT_pthread))
7164 CmdArgs.push_back("-lpthread");
7165 CmdArgs.push_back("-lc");
7166
Joerg Sonnenbergere69cca42013-10-14 20:13:05 +00007167 if (useLibgcc) {
7168 if (Args.hasArg(options::OPT_static)) {
7169 // libgcc_eh depends on libc, so resolve as much as possible,
7170 // pull in any new requirements from libc and then get the rest
7171 // of libgcc.
7172 CmdArgs.push_back("-lgcc_eh");
7173 CmdArgs.push_back("-lc");
7174 CmdArgs.push_back("-lgcc");
7175 } else {
7176 CmdArgs.push_back("-lgcc");
7177 CmdArgs.push_back("--as-needed");
7178 CmdArgs.push_back("-lgcc_s");
7179 CmdArgs.push_back("--no-as-needed");
7180 }
Benjamin Kramer8e50a962011-02-02 18:59:27 +00007181 }
7182 }
7183
7184 if (!Args.hasArg(options::OPT_nostdlib) &&
7185 !Args.hasArg(options::OPT_nostartfiles)) {
7186 if (!Args.hasArg(options::OPT_shared))
7187 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath(
7188 "crtend.o")));
7189 else
7190 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath(
7191 "crtendS.o")));
7192 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath(
7193 "crtn.o")));
7194 }
7195
Stephen Hines651f13c2014-04-23 16:59:28 -07007196 addProfileRT(getToolChain(), Args, CmdArgs);
Nick Lewycky2e95a6d2011-05-24 21:54:59 +00007197
Stephen Hinesef822542014-07-21 00:47:37 -07007198 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Stephen Hines176edba2014-12-01 14:53:08 -08007199 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Benjamin Kramer8e50a962011-02-02 18:59:27 +00007200}
7201
Thomas Schwinge577bb0a2013-03-28 19:04:25 +00007202void gnutools::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
7203 const InputInfo &Output,
7204 const InputInfoList &Inputs,
7205 const ArgList &Args,
7206 const char *LinkingOutput) const {
Stephen Hines0e2c34f2015-03-23 12:09:02 -07007207 claimNoWarnArgs(Args);
7208
Rafael Espindolaba30bbe2010-08-10 00:25:48 +00007209 ArgStringList CmdArgs;
Stephen Hines651f13c2014-04-23 16:59:28 -07007210 bool NeedsKPIC = false;
Rafael Espindolaba30bbe2010-08-10 00:25:48 +00007211
7212 // Add --32/--64 to make sure we get the format we want.
7213 // This is incomplete
7214 if (getToolChain().getArch() == llvm::Triple::x86) {
7215 CmdArgs.push_back("--32");
7216 } else if (getToolChain().getArch() == llvm::Triple::x86_64) {
Stephen Hinesef822542014-07-21 00:47:37 -07007217 if (getToolChain().getTriple().getEnvironment() == llvm::Triple::GNUX32)
7218 CmdArgs.push_back("--x32");
7219 else
7220 CmdArgs.push_back("--64");
Eli Friedman7972c882011-11-28 23:46:52 +00007221 } else if (getToolChain().getArch() == llvm::Triple::ppc) {
7222 CmdArgs.push_back("-a32");
7223 CmdArgs.push_back("-mppc");
7224 CmdArgs.push_back("-many");
7225 } else if (getToolChain().getArch() == llvm::Triple::ppc64) {
7226 CmdArgs.push_back("-a64");
7227 CmdArgs.push_back("-mppc64");
7228 CmdArgs.push_back("-many");
Bill Schmidtea7fb0c2013-07-26 01:36:11 +00007229 } else if (getToolChain().getArch() == llvm::Triple::ppc64le) {
7230 CmdArgs.push_back("-a64");
Stephen Hines651f13c2014-04-23 16:59:28 -07007231 CmdArgs.push_back("-mppc64");
Bill Schmidtea7fb0c2013-07-26 01:36:11 +00007232 CmdArgs.push_back("-many");
Stephen Hines651f13c2014-04-23 16:59:28 -07007233 CmdArgs.push_back("-mlittle-endian");
7234 } else if (getToolChain().getArch() == llvm::Triple::sparc) {
7235 CmdArgs.push_back("-32");
7236 CmdArgs.push_back("-Av8plusa");
7237 NeedsKPIC = true;
7238 } else if (getToolChain().getArch() == llvm::Triple::sparcv9) {
7239 CmdArgs.push_back("-64");
7240 CmdArgs.push_back("-Av9a");
7241 NeedsKPIC = true;
7242 } else if (getToolChain().getArch() == llvm::Triple::arm ||
7243 getToolChain().getArch() == llvm::Triple::armeb) {
Chris Lattner5f9e2722011-07-23 10:55:15 +00007244 StringRef MArch = getToolChain().getArchName();
Rafael Espindolaba30bbe2010-08-10 00:25:48 +00007245 if (MArch == "armv7" || MArch == "armv7a" || MArch == "armv7-a")
7246 CmdArgs.push_back("-mfpu=neon");
Stephen Hines651f13c2014-04-23 16:59:28 -07007247 if (MArch == "armv8" || MArch == "armv8a" || MArch == "armv8-a" ||
7248 MArch == "armebv8" || MArch == "armebv8a" || MArch == "armebv8-a")
Bernard Ogden80e90c22013-10-24 18:32:41 +00007249 CmdArgs.push_back("-mfpu=crypto-neon-fp-armv8");
Evgeniy Stepanov700c5082012-04-20 09:03:40 +00007250
Stephen Hines651f13c2014-04-23 16:59:28 -07007251 StringRef ARMFloatABI = tools::arm::getARMFloatABI(
7252 getToolChain().getDriver(), Args, getToolChain().getTriple());
Evgeniy Stepanov700c5082012-04-20 09:03:40 +00007253 CmdArgs.push_back(Args.MakeArgString("-mfloat-abi=" + ARMFloatABI));
Evgeniy Stepanoveca187e2012-04-24 09:05:31 +00007254
7255 Args.AddLastArg(CmdArgs, options::OPT_march_EQ);
Stephen Hines651f13c2014-04-23 16:59:28 -07007256
7257 // FIXME: remove krait check when GNU tools support krait cpu
7258 // for now replace it with -march=armv7-a to avoid a lower
7259 // march from being picked in the absence of a cpu flag.
7260 Arg *A;
7261 if ((A = Args.getLastArg(options::OPT_mcpu_EQ)) &&
7262 StringRef(A->getValue()) == "krait")
7263 CmdArgs.push_back("-march=armv7-a");
7264 else
7265 Args.AddLastArg(CmdArgs, options::OPT_mcpu_EQ);
Evgeniy Stepanoveca187e2012-04-24 09:05:31 +00007266 Args.AddLastArg(CmdArgs, options::OPT_mfpu_EQ);
Akira Hatanakac85900f2011-11-30 19:31:38 +00007267 } else if (getToolChain().getArch() == llvm::Triple::mips ||
7268 getToolChain().getArch() == llvm::Triple::mipsel ||
7269 getToolChain().getArch() == llvm::Triple::mips64 ||
7270 getToolChain().getArch() == llvm::Triple::mips64el) {
Simon Atanasyan073a7802012-04-07 22:31:29 +00007271 StringRef CPUName;
7272 StringRef ABIName;
Stephen Hines176edba2014-12-01 14:53:08 -08007273 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
7274 ABIName = getGnuCompatibleMipsABIName(ABIName);
Akira Hatanakac85900f2011-11-30 19:31:38 +00007275
Simon Atanasyan073a7802012-04-07 22:31:29 +00007276 CmdArgs.push_back("-march");
7277 CmdArgs.push_back(CPUName.data());
7278
Simon Atanasyan073a7802012-04-07 22:31:29 +00007279 CmdArgs.push_back("-mabi");
Stephen Hines176edba2014-12-01 14:53:08 -08007280 CmdArgs.push_back(ABIName.data());
7281
7282 // -mno-shared should be emitted unless -fpic, -fpie, -fPIC, -fPIE,
7283 // or -mshared (not implemented) is in effect.
7284 bool IsPicOrPie = false;
7285 if (Arg *A = Args.getLastArg(options::OPT_fPIC, options::OPT_fno_PIC,
7286 options::OPT_fpic, options::OPT_fno_pic,
7287 options::OPT_fPIE, options::OPT_fno_PIE,
7288 options::OPT_fpie, options::OPT_fno_pie)) {
7289 if (A->getOption().matches(options::OPT_fPIC) ||
7290 A->getOption().matches(options::OPT_fpic) ||
7291 A->getOption().matches(options::OPT_fPIE) ||
7292 A->getOption().matches(options::OPT_fpie))
7293 IsPicOrPie = true;
7294 }
7295 if (!IsPicOrPie)
7296 CmdArgs.push_back("-mno-shared");
7297
7298 // LLVM doesn't support -mplt yet and acts as if it is always given.
7299 // However, -mplt has no effect with the N64 ABI.
7300 CmdArgs.push_back(ABIName == "64" ? "-KPIC" : "-call_nonpic");
Simon Atanasyan5f0a1c12012-04-06 19:15:24 +00007301
7302 if (getToolChain().getArch() == llvm::Triple::mips ||
7303 getToolChain().getArch() == llvm::Triple::mips64)
7304 CmdArgs.push_back("-EB");
7305 else
7306 CmdArgs.push_back("-EL");
Simon Atanasyan1f0646e2012-05-29 19:07:33 +00007307
Simon Atanasyanfc12c4a2013-09-24 09:09:16 +00007308 if (Arg *A = Args.getLastArg(options::OPT_mnan_EQ)) {
7309 if (StringRef(A->getValue()) == "2008")
7310 CmdArgs.push_back(Args.MakeArgString("-mnan=2008"));
7311 }
7312
Stephen Hines176edba2014-12-01 14:53:08 -08007313 // Add the last -mfp32/-mfpxx/-mfp64 or -mfpxx if it is enabled by default.
7314 if (Arg *A = Args.getLastArg(options::OPT_mfp32, options::OPT_mfpxx,
7315 options::OPT_mfp64)) {
7316 A->claim();
7317 A->render(Args, CmdArgs);
7318 } else if (mips::isFPXXDefault(getToolChain().getTriple(), CPUName,
7319 ABIName))
7320 CmdArgs.push_back("-mfpxx");
7321
7322 // Pass on -mmips16 or -mno-mips16. However, the assembler equivalent of
7323 // -mno-mips16 is actually -no-mips16.
7324 if (Arg *A = Args.getLastArg(options::OPT_mips16,
7325 options::OPT_mno_mips16)) {
7326 if (A->getOption().matches(options::OPT_mips16)) {
7327 A->claim();
7328 A->render(Args, CmdArgs);
7329 } else {
7330 A->claim();
7331 CmdArgs.push_back("-no-mips16");
7332 }
7333 }
7334
Simon Atanasyan9dbfc612013-04-30 07:47:13 +00007335 Args.AddLastArg(CmdArgs, options::OPT_mmicromips,
7336 options::OPT_mno_micromips);
7337 Args.AddLastArg(CmdArgs, options::OPT_mdsp, options::OPT_mno_dsp);
7338 Args.AddLastArg(CmdArgs, options::OPT_mdspr2, options::OPT_mno_dspr2);
7339
Daniel Sanders0d5d6ff2013-12-02 10:14:43 +00007340 if (Arg *A = Args.getLastArg(options::OPT_mmsa, options::OPT_mno_msa)) {
7341 // Do not use AddLastArg because not all versions of MIPS assembler
7342 // support -mmsa / -mno-msa options.
7343 if (A->getOption().matches(options::OPT_mmsa))
7344 CmdArgs.push_back(Args.MakeArgString("-mmsa"));
7345 }
7346
Stephen Hines176edba2014-12-01 14:53:08 -08007347 Args.AddLastArg(CmdArgs, options::OPT_mhard_float,
7348 options::OPT_msoft_float);
7349
7350 Args.AddLastArg(CmdArgs, options::OPT_modd_spreg,
7351 options::OPT_mno_odd_spreg);
7352
Stephen Hines651f13c2014-04-23 16:59:28 -07007353 NeedsKPIC = true;
Ulrich Weigandb8409212013-05-06 16:26:41 +00007354 } else if (getToolChain().getArch() == llvm::Triple::systemz) {
Richard Sandiford5c92b9a2013-07-19 16:51:51 +00007355 // Always pass an -march option, since our default of z10 is later
7356 // than the GNU assembler's default.
7357 StringRef CPUName = getSystemZTargetCPU(Args);
7358 CmdArgs.push_back(Args.MakeArgString("-march=" + CPUName));
Rafael Espindolaba30bbe2010-08-10 00:25:48 +00007359 }
7360
Stephen Hines651f13c2014-04-23 16:59:28 -07007361 if (NeedsKPIC)
7362 addAssemblerKPIC(Args, CmdArgs);
7363
Rafael Espindolaba30bbe2010-08-10 00:25:48 +00007364 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
7365 options::OPT_Xassembler);
7366
7367 CmdArgs.push_back("-o");
7368 CmdArgs.push_back(Output.getFilename());
7369
Stephen Hinesef822542014-07-21 00:47:37 -07007370 for (const auto &II : Inputs)
Rafael Espindolaba30bbe2010-08-10 00:25:48 +00007371 CmdArgs.push_back(II.getFilename());
Rafael Espindolaba30bbe2010-08-10 00:25:48 +00007372
Stephen Hinesef822542014-07-21 00:47:37 -07007373 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Stephen Hines176edba2014-12-01 14:53:08 -08007374 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Eric Christopherc47b6f32013-06-05 23:58:15 +00007375
7376 // Handle the debug info splitting at object creation time if we're
7377 // creating an object.
7378 // TODO: Currently only works on linux with newer objcopy.
7379 if (Args.hasArg(options::OPT_gsplit_dwarf) &&
Cameron Esfahani57b1da12013-09-14 01:09:11 +00007380 getToolChain().getTriple().isOSLinux())
Eric Christopherc47b6f32013-06-05 23:58:15 +00007381 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output,
7382 SplitDebugName(Args, Inputs));
Rafael Espindolaba30bbe2010-08-10 00:25:48 +00007383}
7384
Stephen Hines651f13c2014-04-23 16:59:28 -07007385static void AddLibgcc(const llvm::Triple &Triple, const Driver &D,
Evgeniy Stepanova6ddc022012-04-25 08:59:22 +00007386 ArgStringList &CmdArgs, const ArgList &Args) {
Logan Chien94a71422012-09-02 09:30:11 +00007387 bool isAndroid = Triple.getEnvironment() == llvm::Triple::Android;
Chandler Carruth68f94db2013-03-04 02:07:55 +00007388 bool StaticLibgcc = Args.hasArg(options::OPT_static_libgcc) ||
7389 Args.hasArg(options::OPT_static);
Hans Wennborg76b86c22013-07-18 20:29:38 +00007390 if (!D.CCCIsCXX())
Rafael Espindolaabf3ac72011-10-17 21:39:04 +00007391 CmdArgs.push_back("-lgcc");
7392
Logan Chien529a73d2012-11-19 12:04:11 +00007393 if (StaticLibgcc || isAndroid) {
Hans Wennborg76b86c22013-07-18 20:29:38 +00007394 if (D.CCCIsCXX())
Rafael Espindolaabf3ac72011-10-17 21:39:04 +00007395 CmdArgs.push_back("-lgcc");
7396 } else {
Hans Wennborg76b86c22013-07-18 20:29:38 +00007397 if (!D.CCCIsCXX())
Rafael Espindolaabf3ac72011-10-17 21:39:04 +00007398 CmdArgs.push_back("--as-needed");
7399 CmdArgs.push_back("-lgcc_s");
Hans Wennborg76b86c22013-07-18 20:29:38 +00007400 if (!D.CCCIsCXX())
Rafael Espindolaabf3ac72011-10-17 21:39:04 +00007401 CmdArgs.push_back("--no-as-needed");
7402 }
7403
Evgeniy Stepanova6ddc022012-04-25 08:59:22 +00007404 if (StaticLibgcc && !isAndroid)
Rafael Espindolaabf3ac72011-10-17 21:39:04 +00007405 CmdArgs.push_back("-lgcc_eh");
Hans Wennborg76b86c22013-07-18 20:29:38 +00007406 else if (!Args.hasArg(options::OPT_shared) && D.CCCIsCXX())
Rafael Espindolaabf3ac72011-10-17 21:39:04 +00007407 CmdArgs.push_back("-lgcc");
Logan Chien529a73d2012-11-19 12:04:11 +00007408
7409 // According to Android ABI, we have to link with libdl if we are
7410 // linking with non-static libgcc.
7411 //
7412 // NOTE: This fixes a link error on Android MIPS as well. The non-static
7413 // libgcc for MIPS relies on _Unwind_Find_FDE and dl_iterate_phdr from libdl.
7414 if (isAndroid && !StaticLibgcc)
7415 CmdArgs.push_back("-ldl");
Rafael Espindolaabf3ac72011-10-17 21:39:04 +00007416}
7417
Stephen Hines176edba2014-12-01 14:53:08 -08007418static std::string getLinuxDynamicLinker(const ArgList &Args,
7419 const toolchains::Linux &ToolChain) {
Stephen Hines651f13c2014-04-23 16:59:28 -07007420 if (ToolChain.getTriple().getEnvironment() == llvm::Triple::Android) {
7421 if (ToolChain.getTriple().isArch64Bit())
7422 return "/system/bin/linker64";
7423 else
7424 return "/system/bin/linker";
7425 } else if (ToolChain.getArch() == llvm::Triple::x86 ||
7426 ToolChain.getArch() == llvm::Triple::sparc)
Peter Collingbournebdaa1342013-05-27 21:40:20 +00007427 return "/lib/ld-linux.so.2";
Stephen Hines176edba2014-12-01 14:53:08 -08007428 else if (ToolChain.getArch() == llvm::Triple::aarch64)
Peter Collingbournebdaa1342013-05-27 21:40:20 +00007429 return "/lib/ld-linux-aarch64.so.1";
Stephen Hines176edba2014-12-01 14:53:08 -08007430 else if (ToolChain.getArch() == llvm::Triple::aarch64_be)
Stephen Hines651f13c2014-04-23 16:59:28 -07007431 return "/lib/ld-linux-aarch64_be.so.1";
Peter Collingbournebdaa1342013-05-27 21:40:20 +00007432 else if (ToolChain.getArch() == llvm::Triple::arm ||
7433 ToolChain.getArch() == llvm::Triple::thumb) {
7434 if (ToolChain.getTriple().getEnvironment() == llvm::Triple::GNUEABIHF)
7435 return "/lib/ld-linux-armhf.so.3";
7436 else
7437 return "/lib/ld-linux.so.3";
Stephen Hines651f13c2014-04-23 16:59:28 -07007438 } else if (ToolChain.getArch() == llvm::Triple::armeb ||
7439 ToolChain.getArch() == llvm::Triple::thumbeb) {
7440 if (ToolChain.getTriple().getEnvironment() == llvm::Triple::GNUEABIHF)
7441 return "/lib/ld-linux-armhf.so.3"; /* TODO: check which dynamic linker name. */
7442 else
7443 return "/lib/ld-linux.so.3"; /* TODO: check which dynamic linker name. */
Peter Collingbournebdaa1342013-05-27 21:40:20 +00007444 } else if (ToolChain.getArch() == llvm::Triple::mips ||
Stephen Hines176edba2014-12-01 14:53:08 -08007445 ToolChain.getArch() == llvm::Triple::mipsel ||
7446 ToolChain.getArch() == llvm::Triple::mips64 ||
Stephen Hinesef822542014-07-21 00:47:37 -07007447 ToolChain.getArch() == llvm::Triple::mips64el) {
Stephen Hines176edba2014-12-01 14:53:08 -08007448 StringRef CPUName;
7449 StringRef ABIName;
7450 mips::getMipsCPUAndABI(Args, ToolChain.getTriple(), CPUName, ABIName);
7451 bool IsNaN2008 = mips::isNaN2008(Args, ToolChain.getTriple());
7452
7453 StringRef LibDir = llvm::StringSwitch<llvm::StringRef>(ABIName)
7454 .Case("o32", "/lib")
7455 .Case("n32", "/lib32")
7456 .Case("n64", "/lib64")
7457 .Default("/lib");
7458 StringRef LibName;
7459 if (mips::isUCLibc(Args))
7460 LibName = IsNaN2008 ? "ld-uClibc-mipsn8.so.0" : "ld-uClibc.so.0";
7461 else
7462 LibName = IsNaN2008 ? "ld-linux-mipsn8.so.1" : "ld.so.1";
7463
7464 return (LibDir + "/" + LibName).str();
Peter Collingbournebdaa1342013-05-27 21:40:20 +00007465 } else if (ToolChain.getArch() == llvm::Triple::ppc)
7466 return "/lib/ld.so.1";
Stephen Hines176edba2014-12-01 14:53:08 -08007467 else if (ToolChain.getArch() == llvm::Triple::ppc64) {
7468 if (ppc::hasPPCAbiArg(Args, "elfv2"))
7469 return "/lib64/ld64.so.2";
Peter Collingbournebdaa1342013-05-27 21:40:20 +00007470 return "/lib64/ld64.so.1";
Stephen Hines176edba2014-12-01 14:53:08 -08007471 } else if (ToolChain.getArch() == llvm::Triple::ppc64le) {
7472 if (ppc::hasPPCAbiArg(Args, "elfv1"))
7473 return "/lib64/ld64.so.1";
Stephen Hinesef822542014-07-21 00:47:37 -07007474 return "/lib64/ld64.so.2";
Stephen Hines176edba2014-12-01 14:53:08 -08007475 } else if (ToolChain.getArch() == llvm::Triple::systemz)
7476 return "/lib64/ld64.so.1";
Stephen Hines651f13c2014-04-23 16:59:28 -07007477 else if (ToolChain.getArch() == llvm::Triple::sparcv9)
7478 return "/lib64/ld-linux.so.2";
Stephen Hinesef822542014-07-21 00:47:37 -07007479 else if (ToolChain.getArch() == llvm::Triple::x86_64 &&
7480 ToolChain.getTriple().getEnvironment() == llvm::Triple::GNUX32)
7481 return "/libx32/ld-linux-x32.so.2";
Peter Collingbournebdaa1342013-05-27 21:40:20 +00007482 else
7483 return "/lib64/ld-linux-x86-64.so.2";
7484}
7485
Stephen Hines651f13c2014-04-23 16:59:28 -07007486static void AddRunTimeLibs(const ToolChain &TC, const Driver &D,
Stephen Hines0e2c34f2015-03-23 12:09:02 -07007487 ArgStringList &CmdArgs, const ArgList &Args) {
Stephen Hines651f13c2014-04-23 16:59:28 -07007488 // Make use of compiler-rt if --rtlib option is used
7489 ToolChain::RuntimeLibType RLT = TC.GetRuntimeLibType(Args);
7490
Stephen Hines0e2c34f2015-03-23 12:09:02 -07007491 switch (RLT) {
Stephen Hines651f13c2014-04-23 16:59:28 -07007492 case ToolChain::RLT_CompilerRT:
Stephen Hines176edba2014-12-01 14:53:08 -08007493 switch (TC.getTriple().getOS()) {
7494 default: llvm_unreachable("unsupported OS");
7495 case llvm::Triple::Win32:
Stephen Hines176edba2014-12-01 14:53:08 -08007496 case llvm::Triple::Linux:
Stephen Hines0e2c34f2015-03-23 12:09:02 -07007497 addClangRT(TC, Args, CmdArgs);
Stephen Hines176edba2014-12-01 14:53:08 -08007498 break;
7499 }
Stephen Hines651f13c2014-04-23 16:59:28 -07007500 break;
7501 case ToolChain::RLT_Libgcc:
7502 AddLibgcc(TC.getTriple(), D, CmdArgs, Args);
7503 break;
7504 }
7505}
7506
Stephen Hines176edba2014-12-01 14:53:08 -08007507static const char *getLDMOption(const llvm::Triple &T, const ArgList &Args) {
7508 switch (T.getArch()) {
7509 case llvm::Triple::x86:
7510 return "elf_i386";
7511 case llvm::Triple::aarch64:
7512 return "aarch64linux";
7513 case llvm::Triple::aarch64_be:
7514 return "aarch64_be_linux";
7515 case llvm::Triple::arm:
7516 case llvm::Triple::thumb:
7517 return "armelf_linux_eabi";
7518 case llvm::Triple::armeb:
7519 case llvm::Triple::thumbeb:
7520 return "armebelf_linux_eabi"; /* TODO: check which NAME. */
7521 case llvm::Triple::ppc:
7522 return "elf32ppclinux";
7523 case llvm::Triple::ppc64:
7524 return "elf64ppc";
7525 case llvm::Triple::ppc64le:
7526 return "elf64lppc";
7527 case llvm::Triple::sparc:
7528 return "elf32_sparc";
7529 case llvm::Triple::sparcv9:
7530 return "elf64_sparc";
7531 case llvm::Triple::mips:
7532 return "elf32btsmip";
7533 case llvm::Triple::mipsel:
7534 return "elf32ltsmip";
7535 case llvm::Triple::mips64:
7536 if (mips::hasMipsAbiArg(Args, "n32"))
7537 return "elf32btsmipn32";
7538 return "elf64btsmip";
7539 case llvm::Triple::mips64el:
7540 if (mips::hasMipsAbiArg(Args, "n32"))
7541 return "elf32ltsmipn32";
7542 return "elf64ltsmip";
7543 case llvm::Triple::systemz:
7544 return "elf64_s390";
7545 case llvm::Triple::x86_64:
7546 if (T.getEnvironment() == llvm::Triple::GNUX32)
7547 return "elf32_x86_64";
7548 return "elf_x86_64";
7549 default:
7550 llvm_unreachable("Unexpected arch");
7551 }
7552}
7553
Thomas Schwinge577bb0a2013-03-28 19:04:25 +00007554void gnutools::Link::ConstructJob(Compilation &C, const JobAction &JA,
7555 const InputInfo &Output,
7556 const InputInfoList &Inputs,
7557 const ArgList &Args,
7558 const char *LinkingOutput) const {
Rafael Espindolac1da9812010-11-07 20:14:31 +00007559 const toolchains::Linux& ToolChain =
7560 static_cast<const toolchains::Linux&>(getToolChain());
7561 const Driver &D = ToolChain.getDriver();
Rafael Espindola715852c2012-11-02 20:41:30 +00007562 const bool isAndroid =
7563 ToolChain.getTriple().getEnvironment() == llvm::Triple::Android;
Peter Collingbourne52ca70d2013-04-09 04:35:11 +00007564 const bool IsPIE =
7565 !Args.hasArg(options::OPT_shared) &&
Stephen Hines6bcf27b2014-05-29 04:14:42 -07007566 !Args.hasArg(options::OPT_static) &&
7567 (Args.hasArg(options::OPT_pie) || ToolChain.isPIEDefault() ||
7568 // On Android every code is PIC so every executable is PIE
7569 // Cannot use isPIEDefault here since otherwise
7570 // PIE only logic will be enabled during compilation
7571 isAndroid);
Evgeniy Stepanova6ddc022012-04-25 08:59:22 +00007572
Rafael Espindolac1da9812010-11-07 20:14:31 +00007573 ArgStringList CmdArgs;
7574
Rafael Espindola26f14c32010-11-15 18:28:16 +00007575 // Silence warning for "clang -g foo.o -o foo"
7576 Args.ClaimAllArgs(options::OPT_g_Group);
Rafael Espindola9c094fb2011-03-01 05:25:27 +00007577 // and "clang -emit-llvm foo.o -o foo"
7578 Args.ClaimAllArgs(options::OPT_emit_llvm);
David Chisnalldfa210b2012-07-29 15:24:44 +00007579 // and for "clang -w foo.o -o foo". Other warning options are already
Rafael Espindola7f6458b2010-11-17 20:37:10 +00007580 // handled somewhere else.
7581 Args.ClaimAllArgs(options::OPT_w);
Rafael Espindola26f14c32010-11-15 18:28:16 +00007582
Joerg Sonnenberger8ab2bdc2011-03-21 13:51:29 +00007583 if (!D.SysRoot.empty())
7584 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
Rafael Espindolac1da9812010-11-07 20:14:31 +00007585
Peter Collingbourne52ca70d2013-04-09 04:35:11 +00007586 if (IsPIE)
Rafael Espindolafdda1712010-11-17 22:26:15 +00007587 CmdArgs.push_back("-pie");
7588
Rafael Espindoladc1b76d2010-11-07 22:57:16 +00007589 if (Args.hasArg(options::OPT_rdynamic))
7590 CmdArgs.push_back("-export-dynamic");
7591
Rafael Espindolae0e6d3b2010-11-11 19:34:42 +00007592 if (Args.hasArg(options::OPT_s))
7593 CmdArgs.push_back("-s");
7594
Stephen Hines0e2c34f2015-03-23 12:09:02 -07007595 if (ToolChain.getArch() == llvm::Triple::armeb ||
7596 ToolChain.getArch() == llvm::Triple::thumbeb)
7597 arm::appendEBLinkFlags(Args, CmdArgs, getToolChain().getTriple());
7598
Stephen Hinesef822542014-07-21 00:47:37 -07007599 for (const auto &Opt : ToolChain.ExtraOpts)
7600 CmdArgs.push_back(Opt.c_str());
Rafael Espindolac1da9812010-11-07 20:14:31 +00007601
7602 if (!Args.hasArg(options::OPT_static)) {
7603 CmdArgs.push_back("--eh-frame-hdr");
7604 }
7605
7606 CmdArgs.push_back("-m");
Stephen Hines176edba2014-12-01 14:53:08 -08007607 CmdArgs.push_back(getLDMOption(ToolChain.getTriple(), Args));
Rafael Espindolac1da9812010-11-07 20:14:31 +00007608
7609 if (Args.hasArg(options::OPT_static)) {
Stephen Hines651f13c2014-04-23 16:59:28 -07007610 if (ToolChain.getArch() == llvm::Triple::arm ||
7611 ToolChain.getArch() == llvm::Triple::armeb ||
7612 ToolChain.getArch() == llvm::Triple::thumb ||
7613 ToolChain.getArch() == llvm::Triple::thumbeb)
Rafael Espindolac1da9812010-11-07 20:14:31 +00007614 CmdArgs.push_back("-Bstatic");
7615 else
7616 CmdArgs.push_back("-static");
7617 } else if (Args.hasArg(options::OPT_shared)) {
7618 CmdArgs.push_back("-shared");
7619 }
7620
7621 if (ToolChain.getArch() == llvm::Triple::arm ||
Stephen Hines651f13c2014-04-23 16:59:28 -07007622 ToolChain.getArch() == llvm::Triple::armeb ||
Douglas Gregorf0594d82011-03-06 19:11:49 +00007623 ToolChain.getArch() == llvm::Triple::thumb ||
Stephen Hines651f13c2014-04-23 16:59:28 -07007624 ToolChain.getArch() == llvm::Triple::thumbeb ||
Rafael Espindolac1da9812010-11-07 20:14:31 +00007625 (!Args.hasArg(options::OPT_static) &&
7626 !Args.hasArg(options::OPT_shared))) {
7627 CmdArgs.push_back("-dynamic-linker");
Peter Collingbournebdaa1342013-05-27 21:40:20 +00007628 CmdArgs.push_back(Args.MakeArgString(
7629 D.DyldPrefix + getLinuxDynamicLinker(Args, ToolChain)));
Rafael Espindolac1da9812010-11-07 20:14:31 +00007630 }
7631
7632 CmdArgs.push_back("-o");
7633 CmdArgs.push_back(Output.getFilename());
7634
Rafael Espindola49c64fd2010-12-01 01:52:43 +00007635 if (!Args.hasArg(options::OPT_nostdlib) &&
7636 !Args.hasArg(options::OPT_nostartfiles)) {
Evgeniy Stepanova6ddc022012-04-25 08:59:22 +00007637 if (!isAndroid) {
Stephen Hines6bcf27b2014-05-29 04:14:42 -07007638 const char *crt1 = nullptr;
Evgeniy Stepanova6ddc022012-04-25 08:59:22 +00007639 if (!Args.hasArg(options::OPT_shared)){
Eric Christopher61f08682013-06-07 23:25:01 +00007640 if (Args.hasArg(options::OPT_pg))
7641 crt1 = "gcrt1.o";
7642 else if (IsPIE)
Evgeniy Stepanova6ddc022012-04-25 08:59:22 +00007643 crt1 = "Scrt1.o";
7644 else
7645 crt1 = "crt1.o";
7646 }
7647 if (crt1)
7648 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crt1)));
Rafael Espindolac1da9812010-11-07 20:14:31 +00007649
Evgeniy Stepanova6ddc022012-04-25 08:59:22 +00007650 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
7651 }
Rafael Espindolac1da9812010-11-07 20:14:31 +00007652
Rafael Espindola89414b32010-11-12 03:00:39 +00007653 const char *crtbegin;
7654 if (Args.hasArg(options::OPT_static))
Evgeniy Stepanova6ddc022012-04-25 08:59:22 +00007655 crtbegin = isAndroid ? "crtbegin_static.o" : "crtbeginT.o";
Evgeniy Stepanova92983d2012-09-10 10:30:12 +00007656 else if (Args.hasArg(options::OPT_shared))
Evgeniy Stepanova6ddc022012-04-25 08:59:22 +00007657 crtbegin = isAndroid ? "crtbegin_so.o" : "crtbeginS.o";
Peter Collingbourne52ca70d2013-04-09 04:35:11 +00007658 else if (IsPIE)
Evgeniy Stepanova92983d2012-09-10 10:30:12 +00007659 crtbegin = isAndroid ? "crtbegin_dynamic.o" : "crtbeginS.o";
Rafael Espindola89414b32010-11-12 03:00:39 +00007660 else
Evgeniy Stepanova6ddc022012-04-25 08:59:22 +00007661 crtbegin = isAndroid ? "crtbegin_dynamic.o" : "crtbegin.o";
Rafael Espindola89414b32010-11-12 03:00:39 +00007662 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtbegin)));
Benjamin Kramere20e5082012-10-04 19:42:20 +00007663
7664 // Add crtfastmath.o if available and fast math is enabled.
7665 ToolChain.AddFastMathRuntimeIfAvailable(Args, CmdArgs);
Rafael Espindola89414b32010-11-12 03:00:39 +00007666 }
Rafael Espindolac1da9812010-11-07 20:14:31 +00007667
7668 Args.AddAllArgs(CmdArgs, options::OPT_L);
Stephen Hinesef822542014-07-21 00:47:37 -07007669 Args.AddAllArgs(CmdArgs, options::OPT_u);
Rafael Espindolac1da9812010-11-07 20:14:31 +00007670
Stephen Hines176edba2014-12-01 14:53:08 -08007671 const ToolChain::path_list &Paths = ToolChain.getFilePaths();
Rafael Espindolac1da9812010-11-07 20:14:31 +00007672
Stephen Hinesef822542014-07-21 00:47:37 -07007673 for (const auto &Path : Paths)
7674 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
Rafael Espindolac1da9812010-11-07 20:14:31 +00007675
Stephen Hines0e2c34f2015-03-23 12:09:02 -07007676 if (D.IsUsingLTO(getToolChain(), Args))
Stephen Hines651f13c2014-04-23 16:59:28 -07007677 AddGoldPlugin(ToolChain, Args, CmdArgs);
Chandler Carruth700d4e42013-01-13 11:46:33 +00007678
Nick Lewyckye276cfc2012-08-17 03:39:16 +00007679 if (Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
7680 CmdArgs.push_back("--no-demangle");
7681
Stephen Hines176edba2014-12-01 14:53:08 -08007682 bool NeedsSanitizerDeps = addSanitizerRuntimes(ToolChain, Args, CmdArgs);
Rafael Espindolac1da9812010-11-07 20:14:31 +00007683 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
Chandler Carruth80a393e2013-06-24 09:38:45 +00007684 // The profile runtime also needs access to system libraries.
Stephen Hines651f13c2014-04-23 16:59:28 -07007685 addProfileRT(getToolChain(), Args, CmdArgs);
Chandler Carruth80a393e2013-06-24 09:38:45 +00007686
Hans Wennborg76b86c22013-07-18 20:29:38 +00007687 if (D.CCCIsCXX() &&
Chandler Carruth2ba542c2012-05-14 18:31:18 +00007688 !Args.hasArg(options::OPT_nostdlib) &&
7689 !Args.hasArg(options::OPT_nodefaultlibs)) {
Rafael Espindola19706f82011-10-17 22:14:51 +00007690 bool OnlyLibstdcxxStatic = Args.hasArg(options::OPT_static_libstdcxx) &&
7691 !Args.hasArg(options::OPT_static);
7692 if (OnlyLibstdcxxStatic)
7693 CmdArgs.push_back("-Bstatic");
Rafael Espindolac1da9812010-11-07 20:14:31 +00007694 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
Rafael Espindola19706f82011-10-17 22:14:51 +00007695 if (OnlyLibstdcxxStatic)
7696 CmdArgs.push_back("-Bdynamic");
Rafael Espindolac1da9812010-11-07 20:14:31 +00007697 CmdArgs.push_back("-lm");
7698 }
7699
Rafael Espindola89414b32010-11-12 03:00:39 +00007700 if (!Args.hasArg(options::OPT_nostdlib)) {
Chandler Carruth2ba542c2012-05-14 18:31:18 +00007701 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
7702 if (Args.hasArg(options::OPT_static))
7703 CmdArgs.push_back("--start-group");
Nick Lewycky80df0252011-06-04 06:27:06 +00007704
Stephen Hines176edba2014-12-01 14:53:08 -08007705 if (NeedsSanitizerDeps)
7706 linkSanitizerRuntimeDeps(ToolChain, CmdArgs);
7707
Stephen Hines651f13c2014-04-23 16:59:28 -07007708 LibOpenMP UsedOpenMPLib = LibUnknown;
7709 if (Args.hasArg(options::OPT_fopenmp)) {
7710 UsedOpenMPLib = LibGOMP;
7711 } else if (const Arg *A = Args.getLastArg(options::OPT_fopenmp_EQ)) {
7712 UsedOpenMPLib = llvm::StringSwitch<LibOpenMP>(A->getValue())
7713 .Case("libgomp", LibGOMP)
7714 .Case("libiomp5", LibIOMP5)
7715 .Default(LibUnknown);
7716 if (UsedOpenMPLib == LibUnknown)
7717 D.Diag(diag::err_drv_unsupported_option_argument)
7718 << A->getOption().getName() << A->getValue();
7719 }
7720 switch (UsedOpenMPLib) {
7721 case LibGOMP:
Chandler Carruthdf96e022013-01-17 13:19:29 +00007722 CmdArgs.push_back("-lgomp");
7723
Stephen Hines651f13c2014-04-23 16:59:28 -07007724 // FIXME: Exclude this for platforms with libgomp that don't require
7725 // librt. Most modern Linux platforms require it, but some may not.
Chandler Carruthdf96e022013-01-17 13:19:29 +00007726 CmdArgs.push_back("-lrt");
Stephen Hines651f13c2014-04-23 16:59:28 -07007727 break;
7728 case LibIOMP5:
7729 CmdArgs.push_back("-liomp5");
7730 break;
7731 case LibUnknown:
7732 break;
Chandler Carruthdf96e022013-01-17 13:19:29 +00007733 }
Stephen Hines651f13c2014-04-23 16:59:28 -07007734 AddRunTimeLibs(ToolChain, D, CmdArgs, Args);
Rafael Espindola89414b32010-11-12 03:00:39 +00007735
Stephen Hinesef822542014-07-21 00:47:37 -07007736 if ((Args.hasArg(options::OPT_pthread) ||
7737 Args.hasArg(options::OPT_pthreads) || UsedOpenMPLib != LibUnknown) &&
7738 !isAndroid)
Chandler Carruth2ba542c2012-05-14 18:31:18 +00007739 CmdArgs.push_back("-lpthread");
7740
7741 CmdArgs.push_back("-lc");
7742
7743 if (Args.hasArg(options::OPT_static))
7744 CmdArgs.push_back("--end-group");
7745 else
Stephen Hines651f13c2014-04-23 16:59:28 -07007746 AddRunTimeLibs(ToolChain, D, CmdArgs, Args);
Chandler Carruth2ba542c2012-05-14 18:31:18 +00007747 }
Rafael Espindolafdda1712010-11-17 22:26:15 +00007748
Rafael Espindola49c64fd2010-12-01 01:52:43 +00007749 if (!Args.hasArg(options::OPT_nostartfiles)) {
7750 const char *crtend;
Evgeniy Stepanova92983d2012-09-10 10:30:12 +00007751 if (Args.hasArg(options::OPT_shared))
Evgeniy Stepanova6ddc022012-04-25 08:59:22 +00007752 crtend = isAndroid ? "crtend_so.o" : "crtendS.o";
Peter Collingbourne52ca70d2013-04-09 04:35:11 +00007753 else if (IsPIE)
Evgeniy Stepanova92983d2012-09-10 10:30:12 +00007754 crtend = isAndroid ? "crtend_android.o" : "crtendS.o";
Rafael Espindola49c64fd2010-12-01 01:52:43 +00007755 else
Evgeniy Stepanova6ddc022012-04-25 08:59:22 +00007756 crtend = isAndroid ? "crtend_android.o" : "crtend.o";
Rafael Espindola89414b32010-11-12 03:00:39 +00007757
Rafael Espindola49c64fd2010-12-01 01:52:43 +00007758 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtend)));
Evgeniy Stepanova6ddc022012-04-25 08:59:22 +00007759 if (!isAndroid)
7760 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
Rafael Espindola49c64fd2010-12-01 01:52:43 +00007761 }
Rafael Espindolac1da9812010-11-07 20:14:31 +00007762 }
7763
Stephen Hines176edba2014-12-01 14:53:08 -08007764 C.addCommand(
7765 llvm::make_unique<Command>(JA, *this, ToolChain.Linker.c_str(), CmdArgs));
Rafael Espindolac1da9812010-11-07 20:14:31 +00007766}
Rafael Espindolaba30bbe2010-08-10 00:25:48 +00007767
Chris Lattner38e317d2010-07-07 16:01:42 +00007768void minix::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00007769 const InputInfo &Output,
7770 const InputInfoList &Inputs,
7771 const ArgList &Args,
7772 const char *LinkingOutput) const {
Stephen Hines0e2c34f2015-03-23 12:09:02 -07007773 claimNoWarnArgs(Args);
Chris Lattner38e317d2010-07-07 16:01:42 +00007774 ArgStringList CmdArgs;
7775
Stephen Hinesef822542014-07-21 00:47:37 -07007776 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Chris Lattner38e317d2010-07-07 16:01:42 +00007777
7778 CmdArgs.push_back("-o");
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00007779 CmdArgs.push_back(Output.getFilename());
Chris Lattner38e317d2010-07-07 16:01:42 +00007780
Stephen Hinesef822542014-07-21 00:47:37 -07007781 for (const auto &II : Inputs)
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00007782 CmdArgs.push_back(II.getFilename());
Chris Lattner38e317d2010-07-07 16:01:42 +00007783
Stephen Hinesef822542014-07-21 00:47:37 -07007784 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Stephen Hines176edba2014-12-01 14:53:08 -08007785 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Chris Lattner38e317d2010-07-07 16:01:42 +00007786}
7787
7788void minix::Link::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00007789 const InputInfo &Output,
7790 const InputInfoList &Inputs,
7791 const ArgList &Args,
7792 const char *LinkingOutput) const {
Chris Lattner38e317d2010-07-07 16:01:42 +00007793 const Driver &D = getToolChain().getDriver();
7794 ArgStringList CmdArgs;
7795
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00007796 if (Output.isFilename()) {
Chris Lattner38e317d2010-07-07 16:01:42 +00007797 CmdArgs.push_back("-o");
7798 CmdArgs.push_back(Output.getFilename());
7799 } else {
7800 assert(Output.isNothing() && "Invalid output.");
7801 }
7802
7803 if (!Args.hasArg(options::OPT_nostdlib) &&
Eli Friedman6d402dc2011-12-08 23:54:21 +00007804 !Args.hasArg(options::OPT_nostartfiles)) {
7805 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crt1.o")));
7806 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
7807 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
7808 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
7809 }
Chris Lattner38e317d2010-07-07 16:01:42 +00007810
7811 Args.AddAllArgs(CmdArgs, options::OPT_L);
7812 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
7813 Args.AddAllArgs(CmdArgs, options::OPT_e);
7814
Daniel Dunbar2008fee2010-09-17 00:24:54 +00007815 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Chris Lattner38e317d2010-07-07 16:01:42 +00007816
Stephen Hines651f13c2014-04-23 16:59:28 -07007817 addProfileRT(getToolChain(), Args, CmdArgs);
Eli Friedman6d402dc2011-12-08 23:54:21 +00007818
Chris Lattner38e317d2010-07-07 16:01:42 +00007819 if (!Args.hasArg(options::OPT_nostdlib) &&
7820 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg76b86c22013-07-18 20:29:38 +00007821 if (D.CCCIsCXX()) {
Daniel Dunbar132e35d2010-09-17 01:20:05 +00007822 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Chris Lattner38e317d2010-07-07 16:01:42 +00007823 CmdArgs.push_back("-lm");
7824 }
Chris Lattner38e317d2010-07-07 16:01:42 +00007825 }
7826
7827 if (!Args.hasArg(options::OPT_nostdlib) &&
7828 !Args.hasArg(options::OPT_nostartfiles)) {
Eli Friedman6d402dc2011-12-08 23:54:21 +00007829 if (Args.hasArg(options::OPT_pthread))
7830 CmdArgs.push_back("-lpthread");
7831 CmdArgs.push_back("-lc");
7832 CmdArgs.push_back("-lCompilerRT-Generic");
7833 CmdArgs.push_back("-L/usr/pkg/compiler-rt/lib");
7834 CmdArgs.push_back(
Eric Christopher27e2b982012-12-18 00:31:10 +00007835 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Chris Lattner38e317d2010-07-07 16:01:42 +00007836 }
7837
Stephen Hinesef822542014-07-21 00:47:37 -07007838 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Stephen Hines176edba2014-12-01 14:53:08 -08007839 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Chris Lattner38e317d2010-07-07 16:01:42 +00007840}
7841
Daniel Dunbar11e1b402009-05-02 18:28:39 +00007842/// DragonFly Tools
7843
7844// For now, DragonFly Assemble does just about the same as for
7845// FreeBSD, but this may change soon.
7846void dragonfly::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00007847 const InputInfo &Output,
Daniel Dunbar294691e2009-11-04 06:24:38 +00007848 const InputInfoList &Inputs,
7849 const ArgList &Args,
7850 const char *LinkingOutput) const {
Stephen Hines0e2c34f2015-03-23 12:09:02 -07007851 claimNoWarnArgs(Args);
Daniel Dunbar11e1b402009-05-02 18:28:39 +00007852 ArgStringList CmdArgs;
7853
7854 // When building 32-bit code on DragonFly/pc64, we have to explicitly
7855 // instruct as in the base system to assemble 32-bit code.
Rafael Espindola64f7ad92012-10-07 04:44:33 +00007856 if (getToolChain().getArch() == llvm::Triple::x86)
Daniel Dunbar11e1b402009-05-02 18:28:39 +00007857 CmdArgs.push_back("--32");
7858
Stephen Hinesef822542014-07-21 00:47:37 -07007859 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbar11e1b402009-05-02 18:28:39 +00007860
7861 CmdArgs.push_back("-o");
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00007862 CmdArgs.push_back(Output.getFilename());
Daniel Dunbar11e1b402009-05-02 18:28:39 +00007863
Stephen Hinesef822542014-07-21 00:47:37 -07007864 for (const auto &II : Inputs)
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00007865 CmdArgs.push_back(II.getFilename());
Daniel Dunbar11e1b402009-05-02 18:28:39 +00007866
Stephen Hinesef822542014-07-21 00:47:37 -07007867 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Stephen Hines176edba2014-12-01 14:53:08 -08007868 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Daniel Dunbar11e1b402009-05-02 18:28:39 +00007869}
7870
7871void dragonfly::Link::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar2fe238e2010-08-02 02:38:28 +00007872 const InputInfo &Output,
7873 const InputInfoList &Inputs,
7874 const ArgList &Args,
7875 const char *LinkingOutput) const {
Daniel Dunbaree788e72009-12-21 18:54:17 +00007876 const Driver &D = getToolChain().getDriver();
Daniel Dunbar11e1b402009-05-02 18:28:39 +00007877 ArgStringList CmdArgs;
Stephen Hines176edba2014-12-01 14:53:08 -08007878 bool UseGCC47 = llvm::sys::fs::exists("/usr/lib/gcc47");
John McCall8cfb7202013-04-11 22:55:55 +00007879
Joerg Sonnenberger8ab2bdc2011-03-21 13:51:29 +00007880 if (!D.SysRoot.empty())
7881 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
7882
John McCall8cfb7202013-04-11 22:55:55 +00007883 CmdArgs.push_back("--eh-frame-hdr");
Daniel Dunbar11e1b402009-05-02 18:28:39 +00007884 if (Args.hasArg(options::OPT_static)) {
7885 CmdArgs.push_back("-Bstatic");
7886 } else {
John McCall8cfb7202013-04-11 22:55:55 +00007887 if (Args.hasArg(options::OPT_rdynamic))
7888 CmdArgs.push_back("-export-dynamic");
Daniel Dunbar11e1b402009-05-02 18:28:39 +00007889 if (Args.hasArg(options::OPT_shared))
7890 CmdArgs.push_back("-Bshareable");
7891 else {
7892 CmdArgs.push_back("-dynamic-linker");
7893 CmdArgs.push_back("/usr/libexec/ld-elf.so.2");
7894 }
John McCall8cfb7202013-04-11 22:55:55 +00007895 CmdArgs.push_back("--hash-style=both");
Daniel Dunbar11e1b402009-05-02 18:28:39 +00007896 }
7897
7898 // When building 32-bit code on DragonFly/pc64, we have to explicitly
7899 // instruct ld in the base system to link 32-bit code.
Rafael Espindola64f7ad92012-10-07 04:44:33 +00007900 if (getToolChain().getArch() == llvm::Triple::x86) {
Daniel Dunbar11e1b402009-05-02 18:28:39 +00007901 CmdArgs.push_back("-m");
7902 CmdArgs.push_back("elf_i386");
7903 }
7904
Daniel Dunbar7c1e4652010-08-02 02:38:21 +00007905 if (Output.isFilename()) {
Daniel Dunbar11e1b402009-05-02 18:28:39 +00007906 CmdArgs.push_back("-o");
7907 CmdArgs.push_back(Output.getFilename());
7908 } else {
7909 assert(Output.isNothing() && "Invalid output.");
7910 }
7911
7912 if (!Args.hasArg(options::OPT_nostdlib) &&
7913 !Args.hasArg(options::OPT_nostartfiles)) {
7914 if (!Args.hasArg(options::OPT_shared)) {
John McCall8cfb7202013-04-11 22:55:55 +00007915 if (Args.hasArg(options::OPT_pg))
7916 CmdArgs.push_back(Args.MakeArgString(
7917 getToolChain().GetFilePath("gcrt1.o")));
7918 else {
7919 if (Args.hasArg(options::OPT_pie))
7920 CmdArgs.push_back(Args.MakeArgString(
7921 getToolChain().GetFilePath("Scrt1.o")));
7922 else
7923 CmdArgs.push_back(Args.MakeArgString(
7924 getToolChain().GetFilePath("crt1.o")));
7925 }
Daniel Dunbar11e1b402009-05-02 18:28:39 +00007926 }
John McCall8cfb7202013-04-11 22:55:55 +00007927 CmdArgs.push_back(Args.MakeArgString(
7928 getToolChain().GetFilePath("crti.o")));
7929 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_pie))
7930 CmdArgs.push_back(Args.MakeArgString(
7931 getToolChain().GetFilePath("crtbeginS.o")));
7932 else
7933 CmdArgs.push_back(Args.MakeArgString(
7934 getToolChain().GetFilePath("crtbegin.o")));
Daniel Dunbar11e1b402009-05-02 18:28:39 +00007935 }
7936
7937 Args.AddAllArgs(CmdArgs, options::OPT_L);
7938 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
7939 Args.AddAllArgs(CmdArgs, options::OPT_e);
7940
Daniel Dunbar2008fee2010-09-17 00:24:54 +00007941 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Daniel Dunbar11e1b402009-05-02 18:28:39 +00007942
7943 if (!Args.hasArg(options::OPT_nostdlib) &&
7944 !Args.hasArg(options::OPT_nodefaultlibs)) {
7945 // FIXME: GCC passes on -lgcc, -lgcc_pic and a whole lot of
7946 // rpaths
John McCall8cfb7202013-04-11 22:55:55 +00007947 if (UseGCC47)
7948 CmdArgs.push_back("-L/usr/lib/gcc47");
7949 else
7950 CmdArgs.push_back("-L/usr/lib/gcc44");
Daniel Dunbar11e1b402009-05-02 18:28:39 +00007951
7952 if (!Args.hasArg(options::OPT_static)) {
John McCall8cfb7202013-04-11 22:55:55 +00007953 if (UseGCC47) {
7954 CmdArgs.push_back("-rpath");
7955 CmdArgs.push_back("/usr/lib/gcc47");
7956 } else {
7957 CmdArgs.push_back("-rpath");
7958 CmdArgs.push_back("/usr/lib/gcc44");
7959 }
Daniel Dunbar11e1b402009-05-02 18:28:39 +00007960 }
7961
Hans Wennborg76b86c22013-07-18 20:29:38 +00007962 if (D.CCCIsCXX()) {
Daniel Dunbar132e35d2010-09-17 01:20:05 +00007963 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Rafael Espindola405861d2010-07-20 12:59:03 +00007964 CmdArgs.push_back("-lm");
7965 }
7966
Daniel Dunbar11e1b402009-05-02 18:28:39 +00007967 if (Args.hasArg(options::OPT_pthread))
Mike Stump4d63f8b2009-10-31 20:11:46 +00007968 CmdArgs.push_back("-lpthread");
Daniel Dunbar11e1b402009-05-02 18:28:39 +00007969
7970 if (!Args.hasArg(options::OPT_nolibc)) {
7971 CmdArgs.push_back("-lc");
7972 }
7973
John McCall8cfb7202013-04-11 22:55:55 +00007974 if (UseGCC47) {
7975 if (Args.hasArg(options::OPT_static) ||
7976 Args.hasArg(options::OPT_static_libgcc)) {
7977 CmdArgs.push_back("-lgcc");
7978 CmdArgs.push_back("-lgcc_eh");
7979 } else {
7980 if (Args.hasArg(options::OPT_shared_libgcc)) {
7981 CmdArgs.push_back("-lgcc_pic");
7982 if (!Args.hasArg(options::OPT_shared))
7983 CmdArgs.push_back("-lgcc");
7984 } else {
7985 CmdArgs.push_back("-lgcc");
7986 CmdArgs.push_back("--as-needed");
7987 CmdArgs.push_back("-lgcc_pic");
7988 CmdArgs.push_back("--no-as-needed");
7989 }
7990 }
Daniel Dunbar11e1b402009-05-02 18:28:39 +00007991 } else {
John McCall8cfb7202013-04-11 22:55:55 +00007992 if (Args.hasArg(options::OPT_shared)) {
7993 CmdArgs.push_back("-lgcc_pic");
7994 } else {
7995 CmdArgs.push_back("-lgcc");
7996 }
Daniel Dunbar11e1b402009-05-02 18:28:39 +00007997 }
7998 }
7999
8000 if (!Args.hasArg(options::OPT_nostdlib) &&
8001 !Args.hasArg(options::OPT_nostartfiles)) {
John McCall8cfb7202013-04-11 22:55:55 +00008002 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_pie))
Chris Lattner38e317d2010-07-07 16:01:42 +00008003 CmdArgs.push_back(Args.MakeArgString(
Daniel Dunbar4a7e8892010-07-14 18:46:23 +00008004 getToolChain().GetFilePath("crtendS.o")));
John McCall8cfb7202013-04-11 22:55:55 +00008005 else
8006 CmdArgs.push_back(Args.MakeArgString(
8007 getToolChain().GetFilePath("crtend.o")));
Chris Lattner38e317d2010-07-07 16:01:42 +00008008 CmdArgs.push_back(Args.MakeArgString(
John McCall8cfb7202013-04-11 22:55:55 +00008009 getToolChain().GetFilePath("crtn.o")));
Daniel Dunbar11e1b402009-05-02 18:28:39 +00008010 }
8011
Stephen Hines651f13c2014-04-23 16:59:28 -07008012 addProfileRT(getToolChain(), Args, CmdArgs);
Nick Lewycky2e95a6d2011-05-24 21:54:59 +00008013
Stephen Hinesef822542014-07-21 00:47:37 -07008014 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Stephen Hines176edba2014-12-01 14:53:08 -08008015 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Daniel Dunbar11e1b402009-05-02 18:28:39 +00008016}
Michael J. Spencerff58e362010-08-21 21:55:07 +00008017
Stephen Hines176edba2014-12-01 14:53:08 -08008018// Try to find Exe from a Visual Studio distribution. This first tries to find
8019// an installed copy of Visual Studio and, failing that, looks in the PATH,
8020// making sure that whatever executable that's found is not a same-named exe
8021// from clang itself to prevent clang from falling back to itself.
8022static std::string FindVisualStudioExecutable(const ToolChain &TC,
8023 const char *Exe,
8024 const char *ClangProgramPath) {
8025 const auto &MSVC = static_cast<const toolchains::MSVCToolChain &>(TC);
8026 std::string visualStudioBinDir;
8027 if (MSVC.getVisualStudioBinariesFolder(ClangProgramPath,
8028 visualStudioBinDir)) {
8029 SmallString<128> FilePath(visualStudioBinDir);
8030 llvm::sys::path::append(FilePath, Exe);
8031 if (llvm::sys::fs::can_execute(FilePath.c_str()))
8032 return FilePath.str();
8033 }
8034
8035 return Exe;
8036}
8037
Michael J. Spencerff58e362010-08-21 21:55:07 +00008038void visualstudio::Link::ConstructJob(Compilation &C, const JobAction &JA,
8039 const InputInfo &Output,
8040 const InputInfoList &Inputs,
8041 const ArgList &Args,
8042 const char *LinkingOutput) const {
Michael J. Spencerff58e362010-08-21 21:55:07 +00008043 ArgStringList CmdArgs;
Stephen Hines0e2c34f2015-03-23 12:09:02 -07008044 const ToolChain &TC = getToolChain();
Michael J. Spencerff58e362010-08-21 21:55:07 +00008045
Stephen Hines0e2c34f2015-03-23 12:09:02 -07008046 assert((Output.isFilename() || Output.isNothing()) && "invalid output");
8047 if (Output.isFilename())
Daniel Dunbare5a37f42010-09-17 00:45:02 +00008048 CmdArgs.push_back(Args.MakeArgString(std::string("-out:") +
8049 Output.getFilename()));
Michael J. Spencerff58e362010-08-21 21:55:07 +00008050
8051 if (!Args.hasArg(options::OPT_nostdlib) &&
Stephen Hines0e2c34f2015-03-23 12:09:02 -07008052 !Args.hasArg(options::OPT_nostartfiles) && !C.getDriver().IsCLMode())
Michael J. Spencerff58e362010-08-21 21:55:07 +00008053 CmdArgs.push_back("-defaultlib:libcmt");
Michael J. Spencerff58e362010-08-21 21:55:07 +00008054
Stephen Hines176edba2014-12-01 14:53:08 -08008055 if (!llvm::sys::Process::GetEnv("LIB")) {
8056 // If the VC environment hasn't been configured (perhaps because the user
8057 // did not run vcvarsall), try to build a consistent link environment. If
8058 // the environment variable is set however, assume the user knows what he's
8059 // doing.
8060 std::string VisualStudioDir;
Stephen Hines0e2c34f2015-03-23 12:09:02 -07008061 const auto &MSVC = static_cast<const toolchains::MSVCToolChain &>(TC);
Stephen Hines176edba2014-12-01 14:53:08 -08008062 if (MSVC.getVisualStudioInstallDir(VisualStudioDir)) {
8063 SmallString<128> LibDir(VisualStudioDir);
8064 llvm::sys::path::append(LibDir, "VC", "lib");
8065 switch (MSVC.getArch()) {
8066 case llvm::Triple::x86:
8067 // x86 just puts the libraries directly in lib
8068 break;
8069 case llvm::Triple::x86_64:
8070 llvm::sys::path::append(LibDir, "amd64");
8071 break;
8072 case llvm::Triple::arm:
8073 llvm::sys::path::append(LibDir, "arm");
8074 break;
8075 default:
8076 break;
8077 }
8078 CmdArgs.push_back(
8079 Args.MakeArgString(std::string("-libpath:") + LibDir.c_str()));
8080 }
8081
8082 std::string WindowsSdkLibPath;
8083 if (MSVC.getWindowsSDKLibraryPath(WindowsSdkLibPath))
8084 CmdArgs.push_back(Args.MakeArgString(std::string("-libpath:") +
8085 WindowsSdkLibPath.c_str()));
8086 }
8087
Michael J. Spencerff58e362010-08-21 21:55:07 +00008088 CmdArgs.push_back("-nologo");
8089
Stephen Hines0e2c34f2015-03-23 12:09:02 -07008090 if (Args.hasArg(options::OPT_g_Group))
Stephen Hines6bcf27b2014-05-29 04:14:42 -07008091 CmdArgs.push_back("-debug");
Stephen Hines6bcf27b2014-05-29 04:14:42 -07008092
Hans Wennborg6d0a8d52013-09-10 20:18:04 +00008093 bool DLL = Args.hasArg(options::OPT__SLASH_LD, options::OPT__SLASH_LDd);
Hans Wennborg6d0a8d52013-09-10 20:18:04 +00008094 if (DLL) {
8095 CmdArgs.push_back(Args.MakeArgString("-dll"));
8096
8097 SmallString<128> ImplibName(Output.getFilename());
8098 llvm::sys::path::replace_extension(ImplibName, "lib");
8099 CmdArgs.push_back(Args.MakeArgString(std::string("-implib:") +
8100 ImplibName.str()));
8101 }
8102
Stephen Hines0e2c34f2015-03-23 12:09:02 -07008103 if (TC.getSanitizerArgs().needsAsanRt()) {
Hans Wennborg324cc032013-08-28 17:36:07 +00008104 CmdArgs.push_back(Args.MakeArgString("-debug"));
Hans Wennborg2ddffa12013-08-30 10:50:52 +00008105 CmdArgs.push_back(Args.MakeArgString("-incremental:no"));
Stephen Hines176edba2014-12-01 14:53:08 -08008106 if (Args.hasArg(options::OPT__SLASH_MD, options::OPT__SLASH_MDd)) {
Stephen Hines0e2c34f2015-03-23 12:09:02 -07008107 static const char *CompilerRTComponents[] = {
8108 "asan_dynamic",
8109 "asan_dynamic_runtime_thunk",
8110 };
8111 for (const auto &Component : CompilerRTComponents)
8112 CmdArgs.push_back(Args.MakeArgString(getCompilerRT(TC, Component)));
Stephen Hines176edba2014-12-01 14:53:08 -08008113 // Make sure the dynamic runtime thunk is not optimized out at link time
8114 // to ensure proper SEH handling.
8115 CmdArgs.push_back(Args.MakeArgString("-include:___asan_seh_interceptor"));
8116 } else if (DLL) {
Stephen Hines0e2c34f2015-03-23 12:09:02 -07008117 CmdArgs.push_back(Args.MakeArgString(getCompilerRT(TC, "asan_dll_thunk")));
Stephen Hines6bcf27b2014-05-29 04:14:42 -07008118 } else {
Stephen Hines0e2c34f2015-03-23 12:09:02 -07008119 static const char *CompilerRTComponents[] = {
8120 "asan",
8121 "asan_cxx",
8122 };
8123 for (const auto &Component : CompilerRTComponents)
8124 CmdArgs.push_back(Args.MakeArgString(getCompilerRT(TC, Component)));
Stephen Hines6bcf27b2014-05-29 04:14:42 -07008125 }
Hans Wennborg3c4da0c2013-08-27 18:10:21 +00008126 }
8127
Hans Wennborg5db95272013-08-13 23:38:57 +00008128 Args.AddAllArgValues(CmdArgs, options::OPT__SLASH_link);
Michael J. Spencera2284f52012-06-18 16:56:04 +00008129
Stephen Hines176edba2014-12-01 14:53:08 -08008130 // Add filenames, libraries, and other linker inputs.
8131 for (const auto &Input : Inputs) {
8132 if (Input.isFilename()) {
Stephen Hinesef822542014-07-21 00:47:37 -07008133 CmdArgs.push_back(Input.getFilename());
Stephen Hines176edba2014-12-01 14:53:08 -08008134 continue;
8135 }
Michael J. Spencerff58e362010-08-21 21:55:07 +00008136
Stephen Hines176edba2014-12-01 14:53:08 -08008137 const Arg &A = Input.getInputArg();
8138
8139 // Render -l options differently for the MSVC linker.
8140 if (A.getOption().matches(options::OPT_l)) {
8141 StringRef Lib = A.getValue();
8142 const char *LinkLibArg;
8143 if (Lib.endswith(".lib"))
8144 LinkLibArg = Args.MakeArgString(Lib);
8145 else
8146 LinkLibArg = Args.MakeArgString(Lib + ".lib");
8147 CmdArgs.push_back(LinkLibArg);
8148 continue;
8149 }
8150
8151 // Otherwise, this is some other kind of linker input option like -Wl, -z,
8152 // or -L. Render it, even if MSVC doesn't understand it.
8153 A.renderAsInput(Args, CmdArgs);
8154 }
8155
Stephen Hines0e2c34f2015-03-23 12:09:02 -07008156 // We need to special case some linker paths. In the case of lld, we need to
8157 // translate 'lld' into 'lld-link', and in the case of the regular msvc
8158 // linker, we need to use a special search algorithm.
8159 llvm::SmallString<128> linkPath;
8160 StringRef Linker = Args.getLastArgValue(options::OPT_fuse_ld_EQ, "link");
8161 if (Linker.equals_lower("lld"))
8162 Linker = "lld-link";
8163
8164 if (Linker.equals_lower("link")) {
8165 // If we're using the MSVC linker, it's not sufficient to just use link
8166 // from the program PATH, because other environments like GnuWin32 install
8167 // their own link.exe which may come first.
8168 linkPath = FindVisualStudioExecutable(TC, "link.exe",
8169 C.getDriver().getClangProgramPath());
8170 } else {
8171 linkPath = Linker;
8172 llvm::sys::path::replace_extension(linkPath, "exe");
8173 linkPath = TC.GetProgramPath(linkPath.c_str());
8174 }
8175
Stephen Hines176edba2014-12-01 14:53:08 -08008176 const char *Exec = Args.MakeArgString(linkPath);
8177 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Michael J. Spencerff58e362010-08-21 21:55:07 +00008178}
Hans Wennborgc8ba0a02013-09-19 20:32:16 +00008179
8180void visualstudio::Compile::ConstructJob(Compilation &C, const JobAction &JA,
8181 const InputInfo &Output,
8182 const InputInfoList &Inputs,
8183 const ArgList &Args,
8184 const char *LinkingOutput) const {
8185 C.addCommand(GetCommand(C, JA, Output, Inputs, Args, LinkingOutput));
8186}
8187
Stephen Hines176edba2014-12-01 14:53:08 -08008188std::unique_ptr<Command> visualstudio::Compile::GetCommand(
8189 Compilation &C, const JobAction &JA, const InputInfo &Output,
8190 const InputInfoList &Inputs, const ArgList &Args,
8191 const char *LinkingOutput) const {
Hans Wennborgc8ba0a02013-09-19 20:32:16 +00008192 ArgStringList CmdArgs;
Hans Wennborg1413d622013-09-24 17:36:21 +00008193 CmdArgs.push_back("/nologo");
Hans Wennborgc8ba0a02013-09-19 20:32:16 +00008194 CmdArgs.push_back("/c"); // Compile only.
8195 CmdArgs.push_back("/W0"); // No warnings.
8196
8197 // The goal is to be able to invoke this tool correctly based on
8198 // any flag accepted by clang-cl.
8199
8200 // These are spelled the same way in clang and cl.exe,.
8201 Args.AddAllArgs(CmdArgs, options::OPT_D, options::OPT_U);
8202 Args.AddAllArgs(CmdArgs, options::OPT_I);
Hans Wennborga8ffc162013-09-24 18:17:21 +00008203
8204 // Optimization level.
8205 if (Arg *A = Args.getLastArg(options::OPT_O, options::OPT_O0)) {
8206 if (A->getOption().getID() == options::OPT_O0) {
8207 CmdArgs.push_back("/Od");
8208 } else {
8209 StringRef OptLevel = A->getValue();
8210 if (OptLevel == "1" || OptLevel == "2" || OptLevel == "s")
8211 A->render(Args, CmdArgs);
8212 else if (OptLevel == "3")
8213 CmdArgs.push_back("/Ox");
8214 }
8215 }
Hans Wennborgc8ba0a02013-09-19 20:32:16 +00008216
8217 // Flags for which clang-cl have an alias.
8218 // FIXME: How can we ensure this stays in sync with relevant clang-cl options?
8219
Stephen Hinesef822542014-07-21 00:47:37 -07008220 if (Args.hasFlag(options::OPT__SLASH_GR_, options::OPT__SLASH_GR,
8221 /*default=*/false))
8222 CmdArgs.push_back("/GR-");
Stephen Hines651f13c2014-04-23 16:59:28 -07008223 if (Arg *A = Args.getLastArg(options::OPT_ffunction_sections,
8224 options::OPT_fno_function_sections))
8225 CmdArgs.push_back(A->getOption().getID() == options::OPT_ffunction_sections
8226 ? "/Gy"
8227 : "/Gy-");
Stephen Hines6bcf27b2014-05-29 04:14:42 -07008228 if (Arg *A = Args.getLastArg(options::OPT_fdata_sections,
8229 options::OPT_fno_data_sections))
8230 CmdArgs.push_back(
8231 A->getOption().getID() == options::OPT_fdata_sections ? "/Gw" : "/Gw-");
Hans Wennborgc8ba0a02013-09-19 20:32:16 +00008232 if (Args.hasArg(options::OPT_fsyntax_only))
8233 CmdArgs.push_back("/Zs");
Stephen Hines651f13c2014-04-23 16:59:28 -07008234 if (Args.hasArg(options::OPT_g_Flag, options::OPT_gline_tables_only))
8235 CmdArgs.push_back("/Z7");
Hans Wennborgc8ba0a02013-09-19 20:32:16 +00008236
Hans Wennborg4fe475a2013-09-27 17:54:18 +00008237 std::vector<std::string> Includes = Args.getAllArgValues(options::OPT_include);
Stephen Hinesef822542014-07-21 00:47:37 -07008238 for (const auto &Include : Includes)
8239 CmdArgs.push_back(Args.MakeArgString(std::string("/FI") + Include));
Hans Wennborg4fe475a2013-09-27 17:54:18 +00008240
Hans Wennborgc8ba0a02013-09-19 20:32:16 +00008241 // Flags that can simply be passed through.
8242 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_LD);
8243 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_LDd);
Stephen Hinesef822542014-07-21 00:47:37 -07008244 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_EH);
Hans Wennborgc8ba0a02013-09-19 20:32:16 +00008245
8246 // The order of these flags is relevant, so pick the last one.
8247 if (Arg *A = Args.getLastArg(options::OPT__SLASH_MD, options::OPT__SLASH_MDd,
8248 options::OPT__SLASH_MT, options::OPT__SLASH_MTd))
8249 A->render(Args, CmdArgs);
8250
8251
8252 // Input filename.
8253 assert(Inputs.size() == 1);
8254 const InputInfo &II = Inputs[0];
8255 assert(II.getType() == types::TY_C || II.getType() == types::TY_CXX);
8256 CmdArgs.push_back(II.getType() == types::TY_C ? "/Tc" : "/Tp");
8257 if (II.isFilename())
8258 CmdArgs.push_back(II.getFilename());
8259 else
8260 II.getInputArg().renderAsInput(Args, CmdArgs);
8261
8262 // Output filename.
8263 assert(Output.getType() == types::TY_Object);
8264 const char *Fo = Args.MakeArgString(std::string("/Fo") +
8265 Output.getFilename());
8266 CmdArgs.push_back(Fo);
8267
Hans Wennborgdc40bf92013-09-20 18:16:35 +00008268 const Driver &D = getToolChain().getDriver();
Stephen Hines176edba2014-12-01 14:53:08 -08008269 std::string Exec = FindVisualStudioExecutable(getToolChain(), "cl.exe",
8270 D.getClangProgramPath());
8271 return llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Exec),
8272 CmdArgs);
Hans Wennborgc8ba0a02013-09-19 20:32:16 +00008273}
Robert Lytton4e490e22013-10-11 10:29:40 +00008274
8275
8276/// XCore Tools
8277// We pass assemble and link construction to the xcc tool.
8278
8279void XCore::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
8280 const InputInfo &Output,
8281 const InputInfoList &Inputs,
8282 const ArgList &Args,
8283 const char *LinkingOutput) const {
Stephen Hines0e2c34f2015-03-23 12:09:02 -07008284 claimNoWarnArgs(Args);
Robert Lytton4e490e22013-10-11 10:29:40 +00008285 ArgStringList CmdArgs;
8286
8287 CmdArgs.push_back("-o");
8288 CmdArgs.push_back(Output.getFilename());
8289
8290 CmdArgs.push_back("-c");
8291
Stephen Hines651f13c2014-04-23 16:59:28 -07008292 if (Args.hasArg(options::OPT_v))
8293 CmdArgs.push_back("-v");
8294
Stephen Hines6bcf27b2014-05-29 04:14:42 -07008295 if (Arg *A = Args.getLastArg(options::OPT_g_Group))
8296 if (!A->getOption().matches(options::OPT_g0))
8297 CmdArgs.push_back("-g");
Stephen Hines651f13c2014-04-23 16:59:28 -07008298
8299 if (Args.hasFlag(options::OPT_fverbose_asm, options::OPT_fno_verbose_asm,
8300 false))
8301 CmdArgs.push_back("-fverbose-asm");
Robert Lytton4e490e22013-10-11 10:29:40 +00008302
8303 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA,
8304 options::OPT_Xassembler);
8305
Stephen Hinesef822542014-07-21 00:47:37 -07008306 for (const auto &II : Inputs)
Robert Lytton4e490e22013-10-11 10:29:40 +00008307 CmdArgs.push_back(II.getFilename());
Robert Lytton4e490e22013-10-11 10:29:40 +00008308
Stephen Hinesef822542014-07-21 00:47:37 -07008309 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("xcc"));
Stephen Hines176edba2014-12-01 14:53:08 -08008310 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Robert Lytton4e490e22013-10-11 10:29:40 +00008311}
8312
8313void XCore::Link::ConstructJob(Compilation &C, const JobAction &JA,
8314 const InputInfo &Output,
8315 const InputInfoList &Inputs,
8316 const ArgList &Args,
8317 const char *LinkingOutput) const {
8318 ArgStringList CmdArgs;
8319
8320 if (Output.isFilename()) {
8321 CmdArgs.push_back("-o");
8322 CmdArgs.push_back(Output.getFilename());
8323 } else {
8324 assert(Output.isNothing() && "Invalid output.");
8325 }
8326
Stephen Hines651f13c2014-04-23 16:59:28 -07008327 if (Args.hasArg(options::OPT_v))
8328 CmdArgs.push_back("-v");
8329
Stephen Hines0e2c34f2015-03-23 12:09:02 -07008330 if (exceptionSettings(Args, getToolChain().getTriple()))
Stephen Hines651f13c2014-04-23 16:59:28 -07008331 CmdArgs.push_back("-fexceptions");
8332
Robert Lytton4e490e22013-10-11 10:29:40 +00008333 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
8334
Stephen Hinesef822542014-07-21 00:47:37 -07008335 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("xcc"));
Stephen Hines176edba2014-12-01 14:53:08 -08008336 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
Robert Lytton4e490e22013-10-11 10:29:40 +00008337}
Stephen Hines176edba2014-12-01 14:53:08 -08008338
8339void CrossWindows::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
8340 const InputInfo &Output,
8341 const InputInfoList &Inputs,
8342 const ArgList &Args,
8343 const char *LinkingOutput) const {
Stephen Hines0e2c34f2015-03-23 12:09:02 -07008344 claimNoWarnArgs(Args);
Stephen Hines176edba2014-12-01 14:53:08 -08008345 const auto &TC =
8346 static_cast<const toolchains::CrossWindowsToolChain &>(getToolChain());
8347 ArgStringList CmdArgs;
8348 const char *Exec;
8349
8350 switch (TC.getArch()) {
8351 default: llvm_unreachable("unsupported architecture");
8352 case llvm::Triple::arm:
8353 case llvm::Triple::thumb:
8354 break;
8355 case llvm::Triple::x86:
8356 CmdArgs.push_back("--32");
8357 break;
8358 case llvm::Triple::x86_64:
8359 CmdArgs.push_back("--64");
8360 break;
8361 }
8362
8363 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
8364
8365 CmdArgs.push_back("-o");
8366 CmdArgs.push_back(Output.getFilename());
8367
8368 for (const auto &Input : Inputs)
8369 CmdArgs.push_back(Input.getFilename());
8370
8371 const std::string Assembler = TC.GetProgramPath("as");
8372 Exec = Args.MakeArgString(Assembler);
8373
8374 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
8375}
8376
8377void CrossWindows::Link::ConstructJob(Compilation &C, const JobAction &JA,
8378 const InputInfo &Output,
8379 const InputInfoList &Inputs,
8380 const ArgList &Args,
8381 const char *LinkingOutput) const {
8382 const auto &TC =
8383 static_cast<const toolchains::CrossWindowsToolChain &>(getToolChain());
8384 const llvm::Triple &T = TC.getTriple();
8385 const Driver &D = TC.getDriver();
8386 SmallString<128> EntryPoint;
8387 ArgStringList CmdArgs;
8388 const char *Exec;
8389
8390 // Silence warning for "clang -g foo.o -o foo"
8391 Args.ClaimAllArgs(options::OPT_g_Group);
8392 // and "clang -emit-llvm foo.o -o foo"
8393 Args.ClaimAllArgs(options::OPT_emit_llvm);
8394 // and for "clang -w foo.o -o foo"
8395 Args.ClaimAllArgs(options::OPT_w);
8396 // Other warning options are already handled somewhere else.
8397
8398 if (!D.SysRoot.empty())
8399 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
8400
8401 if (Args.hasArg(options::OPT_pie))
8402 CmdArgs.push_back("-pie");
8403 if (Args.hasArg(options::OPT_rdynamic))
8404 CmdArgs.push_back("-export-dynamic");
8405 if (Args.hasArg(options::OPT_s))
8406 CmdArgs.push_back("--strip-all");
8407
8408 CmdArgs.push_back("-m");
8409 switch (TC.getArch()) {
8410 default: llvm_unreachable("unsupported architecture");
8411 case llvm::Triple::arm:
8412 case llvm::Triple::thumb:
8413 // FIXME: this is incorrect for WinCE
8414 CmdArgs.push_back("thumb2pe");
8415 break;
8416 case llvm::Triple::x86:
8417 CmdArgs.push_back("i386pe");
8418 EntryPoint.append("_");
8419 break;
8420 case llvm::Triple::x86_64:
8421 CmdArgs.push_back("i386pep");
8422 break;
8423 }
8424
8425 if (Args.hasArg(options::OPT_shared)) {
8426 switch (T.getArch()) {
8427 default: llvm_unreachable("unsupported architecture");
8428 case llvm::Triple::arm:
8429 case llvm::Triple::thumb:
8430 case llvm::Triple::x86_64:
8431 EntryPoint.append("_DllMainCRTStartup");
8432 break;
8433 case llvm::Triple::x86:
8434 EntryPoint.append("_DllMainCRTStartup@12");
8435 break;
8436 }
8437
8438 CmdArgs.push_back("-shared");
8439 CmdArgs.push_back("-Bdynamic");
8440
8441 CmdArgs.push_back("--enable-auto-image-base");
8442
8443 CmdArgs.push_back("--entry");
8444 CmdArgs.push_back(Args.MakeArgString(EntryPoint));
8445 } else {
8446 EntryPoint.append("mainCRTStartup");
8447
8448 CmdArgs.push_back(Args.hasArg(options::OPT_static) ? "-Bstatic"
8449 : "-Bdynamic");
8450
8451 if (!Args.hasArg(options::OPT_nostdlib) &&
8452 !Args.hasArg(options::OPT_nostartfiles)) {
8453 CmdArgs.push_back("--entry");
8454 CmdArgs.push_back(Args.MakeArgString(EntryPoint));
8455 }
8456
8457 // FIXME: handle subsystem
8458 }
8459
8460 // NOTE: deal with multiple definitions on Windows (e.g. COMDAT)
8461 CmdArgs.push_back("--allow-multiple-definition");
8462
8463 CmdArgs.push_back("-o");
8464 CmdArgs.push_back(Output.getFilename());
8465
8466 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_rdynamic)) {
8467 SmallString<261> ImpLib(Output.getFilename());
8468 llvm::sys::path::replace_extension(ImpLib, ".lib");
8469
8470 CmdArgs.push_back("--out-implib");
8471 CmdArgs.push_back(Args.MakeArgString(ImpLib));
8472 }
8473
8474 if (!Args.hasArg(options::OPT_nostdlib) &&
8475 !Args.hasArg(options::OPT_nostartfiles)) {
8476 const std::string CRTPath(D.SysRoot + "/usr/lib/");
8477 const char *CRTBegin;
8478
8479 CRTBegin =
8480 Args.hasArg(options::OPT_shared) ? "crtbeginS.obj" : "crtbegin.obj";
8481 CmdArgs.push_back(Args.MakeArgString(CRTPath + CRTBegin));
8482 }
8483
8484 Args.AddAllArgs(CmdArgs, options::OPT_L);
8485
8486 const auto &Paths = TC.getFilePaths();
8487 for (const auto &Path : Paths)
8488 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
8489
8490 AddLinkerInputs(TC, Inputs, Args, CmdArgs);
8491
8492 if (D.CCCIsCXX() && !Args.hasArg(options::OPT_nostdlib) &&
8493 !Args.hasArg(options::OPT_nodefaultlibs)) {
8494 bool StaticCXX = Args.hasArg(options::OPT_static_libstdcxx) &&
8495 !Args.hasArg(options::OPT_static);
8496 if (StaticCXX)
8497 CmdArgs.push_back("-Bstatic");
8498 TC.AddCXXStdlibLibArgs(Args, CmdArgs);
8499 if (StaticCXX)
8500 CmdArgs.push_back("-Bdynamic");
8501 }
8502
8503 if (!Args.hasArg(options::OPT_nostdlib)) {
8504 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
8505 // TODO handle /MT[d] /MD[d]
8506 CmdArgs.push_back("-lmsvcrt");
8507 AddRunTimeLibs(TC, D, CmdArgs, Args);
8508 }
8509 }
8510
8511 const std::string Linker = TC.GetProgramPath("ld");
8512 Exec = Args.MakeArgString(Linker);
8513
8514 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs));
8515}