blob: 6c0be7c39d8ccf14131acd23f0aa0cea9cf16f77 [file] [log] [blame]
Nick Lewyckye47c2452010-09-23 23:48:20 +00001//===--- Tools.cpp - Tools Implementations --------------------------------===//
Daniel Dunbar1a093d22009-03-18 06:00:36 +00002//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
10#include "Tools.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000011#include "InputInfo.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000012#include "ToolChains.h"
Ben Langmuire056ec32015-02-04 18:34:23 +000013#include "clang/Basic/CharInfo.h"
Josh Mageee0fc1a82014-02-11 01:35:14 +000014#include "clang/Basic/LangOptions.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000015#include "clang/Basic/ObjCRuntime.h"
Kevin Enderbyae2ec472013-01-17 21:38:06 +000016#include "clang/Basic/Version.h"
Rafael Espindola3e34e652015-02-03 16:33:53 +000017#include "clang/Config/config.h"
Daniel Dunbara2aedc62009-03-18 10:01:51 +000018#include "clang/Driver/Action.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000019#include "clang/Driver/Compilation.h"
Daniel Dunbar1a8a2e82009-10-29 02:39:57 +000020#include "clang/Driver/Driver.h"
21#include "clang/Driver/DriverDiagnostic.h"
Daniel Dunbar04c4c2c2009-03-18 07:06:02 +000022#include "clang/Driver/Job.h"
Daniel Dunbarda13faf2009-11-19 04:25:22 +000023#include "clang/Driver/Options.h"
Alexey Samsonov609213f92013-08-19 09:14:21 +000024#include "clang/Driver/SanitizerArgs.h"
Daniel Dunbara3246a02009-03-18 08:07:30 +000025#include "clang/Driver/ToolChain.h"
Daniel Dunbar04c4c2c2009-03-18 07:06:02 +000026#include "clang/Driver/Util.h"
Benjamin Kramer33335df2015-03-01 21:36:40 +000027#include "llvm/ADT/STLExtras.h"
Daniel Dunbar1c28f1e2009-09-09 22:32:48 +000028#include "llvm/ADT/SmallString.h"
Hans Wennborg188382e2013-09-20 18:16:35 +000029#include "llvm/ADT/StringExtras.h"
Douglas Gregorf7b87cb2009-10-29 00:41:01 +000030#include "llvm/ADT/StringSwitch.h"
Daniel Dunbarb4a3e432009-09-09 22:32:34 +000031#include "llvm/ADT/Twine.h"
Reid Kleckner898229a2013-06-14 17:17:23 +000032#include "llvm/Option/Arg.h"
33#include "llvm/Option/ArgList.h"
34#include "llvm/Option/Option.h"
James Y Knight5bdf7ab2015-08-19 15:12:02 +000035#include "llvm/Support/CodeGen.h"
David Blaikie24bbfed22014-03-31 23:29:38 +000036#include "llvm/Support/Compression.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000037#include "llvm/Support/ErrorHandling.h"
Michael J. Spencerf6efe582011-01-10 02:34:13 +000038#include "llvm/Support/FileSystem.h"
Michael J. Spencer8aaf4992010-11-29 18:12:39 +000039#include "llvm/Support/Host.h"
Hans Wennborg188382e2013-09-20 18:16:35 +000040#include "llvm/Support/Path.h"
Michael J. Spencer8aaf4992010-11-29 18:12:39 +000041#include "llvm/Support/Process.h"
Chandler Carruth5553d0d2014-01-07 11:51:46 +000042#include "llvm/Support/Program.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000043#include "llvm/Support/raw_ostream.h"
James Y Knight5bdf7ab2015-08-19 15:12:02 +000044#include "llvm/Support/TargetParser.h"
Daniel Dunbar04c4c2c2009-03-18 07:06:02 +000045
Ben Langmuir3b7b5402015-02-03 19:28:37 +000046#ifdef LLVM_ON_UNIX
47#include <unistd.h> // For getuid().
48#endif
49
Daniel Dunbar1a093d22009-03-18 06:00:36 +000050using namespace clang::driver;
51using namespace clang::driver::tools;
Chris Lattner0e62c1c2011-07-23 10:55:15 +000052using namespace clang;
Reid Kleckner898229a2013-06-14 17:17:23 +000053using namespace llvm::opt;
Daniel Dunbar1a093d22009-03-18 06:00:36 +000054
Daniel Dunbar64198ef2009-09-10 01:21:05 +000055/// CheckPreprocessingOptions - Perform some validation of preprocessing
56/// arguments that is shared with gcc.
57static void CheckPreprocessingOptions(const Driver &D, const ArgList &Args) {
Hans Wennborg8f008372014-06-11 19:44:53 +000058 if (Arg *A = Args.getLastArg(options::OPT_C, options::OPT_CC)) {
59 if (!Args.hasArg(options::OPT_E) && !Args.hasArg(options::OPT__SLASH_P) &&
60 !Args.hasArg(options::OPT__SLASH_EP) && !D.CCCIsCPP()) {
Chris Lattner0e62c1c2011-07-23 10:55:15 +000061 D.Diag(diag::err_drv_argument_only_allowed_with)
Hans Wennborg8f008372014-06-11 19:44:53 +000062 << A->getBaseArg().getAsString(Args)
63 << (D.IsCLMode() ? "/E, /P or /EP" : "-E");
64 }
65 }
Daniel Dunbar64198ef2009-09-10 01:21:05 +000066}
67
Daniel Dunbar4eadb602009-09-10 01:21:12 +000068/// CheckCodeGenerationOptions - Perform some validation of code generation
69/// arguments that is shared with gcc.
70static void CheckCodeGenerationOptions(const Driver &D, const ArgList &Args) {
71 // In gcc, only ARM checks this, but it seems reasonable to check universally.
72 if (Args.hasArg(options::OPT_static))
Douglas Katzmana67e50c2015-06-26 15:47:46 +000073 if (const Arg *A =
74 Args.getLastArg(options::OPT_dynamic, options::OPT_mdynamic_no_pic))
75 D.Diag(diag::err_drv_argument_not_allowed_with) << A->getAsString(Args)
76 << "-static";
Daniel Dunbar4eadb602009-09-10 01:21:12 +000077}
78
Bob Wilsond5aad2a2014-11-04 22:28:48 +000079// Add backslashes to escape spaces and other backslashes.
80// This is used for the space-separated argument list specified with
81// the -dwarf-debug-flags option.
82static void EscapeSpacesAndBackslashes(const char *Arg,
83 SmallVectorImpl<char> &Res) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +000084 for (; *Arg; ++Arg) {
Bob Wilsond5aad2a2014-11-04 22:28:48 +000085 switch (*Arg) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +000086 default:
87 break;
Bob Wilsond5aad2a2014-11-04 22:28:48 +000088 case ' ':
89 case '\\':
90 Res.push_back('\\');
91 break;
92 }
93 Res.push_back(*Arg);
94 }
95}
96
Chris Lattnerbf2803f2010-03-29 17:55:58 +000097// Quote target names for inclusion in GNU Make dependency files.
98// Only the characters '$', '#', ' ', '\t' are quoted.
Douglas Katzmana67e50c2015-06-26 15:47:46 +000099static void QuoteTarget(StringRef Target, SmallVectorImpl<char> &Res) {
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000100 for (unsigned i = 0, e = Target.size(); i != e; ++i) {
101 switch (Target[i]) {
102 case ' ':
103 case '\t':
104 // Escape the preceding backslashes
105 for (int j = i - 1; j >= 0 && Target[j] == '\\'; --j)
106 Res.push_back('\\');
107
108 // Escape the space/tab
109 Res.push_back('\\');
110 break;
111 case '$':
112 Res.push_back('$');
113 break;
114 case '#':
115 Res.push_back('\\');
116 break;
117 default:
118 break;
119 }
120
121 Res.push_back(Target[i]);
122 }
123}
124
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000125static void addDirectoryList(const ArgList &Args, ArgStringList &CmdArgs,
126 const char *ArgName, const char *EnvVar) {
Bill Wendlingc0938f32012-03-12 22:10:06 +0000127 const char *DirList = ::getenv(EnvVar);
Chad Rosier616e8a52012-10-30 21:42:09 +0000128 bool CombinedArg = false;
129
Bill Wendling281ca292012-03-12 21:22:35 +0000130 if (!DirList)
131 return; // Nothing to do.
132
Chad Rosier616e8a52012-10-30 21:42:09 +0000133 StringRef Name(ArgName);
134 if (Name.equals("-I") || Name.equals("-L"))
135 CombinedArg = true;
136
Bill Wendling281ca292012-03-12 21:22:35 +0000137 StringRef Dirs(DirList);
138 if (Dirs.empty()) // Empty string should not add '.'.
139 return;
140
141 StringRef::size_type Delim;
Rafael Espindola04b3fc42013-06-25 14:29:51 +0000142 while ((Delim = Dirs.find(llvm::sys::EnvPathSeparator)) != StringRef::npos) {
Bill Wendling281ca292012-03-12 21:22:35 +0000143 if (Delim == 0) { // Leading colon.
Chad Rosier616e8a52012-10-30 21:42:09 +0000144 if (CombinedArg) {
145 CmdArgs.push_back(Args.MakeArgString(std::string(ArgName) + "."));
146 } else {
147 CmdArgs.push_back(ArgName);
148 CmdArgs.push_back(".");
149 }
Bill Wendling281ca292012-03-12 21:22:35 +0000150 } else {
Chad Rosier616e8a52012-10-30 21:42:09 +0000151 if (CombinedArg) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000152 CmdArgs.push_back(
153 Args.MakeArgString(std::string(ArgName) + Dirs.substr(0, Delim)));
Chad Rosier616e8a52012-10-30 21:42:09 +0000154 } else {
155 CmdArgs.push_back(ArgName);
156 CmdArgs.push_back(Args.MakeArgString(Dirs.substr(0, Delim)));
157 }
Bill Wendling281ca292012-03-12 21:22:35 +0000158 }
Nico Weber89355782012-03-19 15:00:03 +0000159 Dirs = Dirs.substr(Delim + 1);
Bill Wendling281ca292012-03-12 21:22:35 +0000160 }
161
162 if (Dirs.empty()) { // Trailing colon.
Chad Rosier616e8a52012-10-30 21:42:09 +0000163 if (CombinedArg) {
164 CmdArgs.push_back(Args.MakeArgString(std::string(ArgName) + "."));
165 } else {
166 CmdArgs.push_back(ArgName);
167 CmdArgs.push_back(".");
168 }
Bill Wendling281ca292012-03-12 21:22:35 +0000169 } else { // Add the last path.
Chad Rosier616e8a52012-10-30 21:42:09 +0000170 if (CombinedArg) {
171 CmdArgs.push_back(Args.MakeArgString(std::string(ArgName) + Dirs));
172 } else {
173 CmdArgs.push_back(ArgName);
174 CmdArgs.push_back(Args.MakeArgString(Dirs));
175 }
Bill Wendling281ca292012-03-12 21:22:35 +0000176 }
177}
178
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000179static void AddLinkerInputs(const ToolChain &TC, const InputInfoList &Inputs,
180 const ArgList &Args, ArgStringList &CmdArgs) {
Daniel Dunbar54423b22010-09-17 00:24:54 +0000181 const Driver &D = TC.getDriver();
182
Daniel Dunbar1094bb12011-02-19 05:33:51 +0000183 // Add extra linker input arguments which are not treated as inputs
184 // (constructed via -Xarch_).
185 Args.AddAllArgValues(CmdArgs, options::OPT_Zlinker_input);
186
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +0000187 for (const auto &II : Inputs) {
Daniel Dunbar54423b22010-09-17 00:24:54 +0000188 if (!TC.HasNativeLLVMSupport()) {
189 // Don't try to pass LLVM inputs unless we have native support.
190 if (II.getType() == types::TY_LLVM_IR ||
191 II.getType() == types::TY_LTO_IR ||
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000192 II.getType() == types::TY_LLVM_BC || II.getType() == types::TY_LTO_BC)
193 D.Diag(diag::err_drv_no_linker_llvm_support) << TC.getTripleString();
Daniel Dunbar54423b22010-09-17 00:24:54 +0000194 }
195
Daniel Dunbar2cc3f172010-09-17 00:45:02 +0000196 // Add filenames immediately.
197 if (II.isFilename()) {
Daniel Dunbar54423b22010-09-17 00:24:54 +0000198 CmdArgs.push_back(II.getFilename());
Daniel Dunbar2cc3f172010-09-17 00:45:02 +0000199 continue;
200 }
201
202 // Otherwise, this is a linker input argument.
203 const Arg &A = II.getInputArg();
204
205 // Handle reserved library options.
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +0000206 if (A.getOption().matches(options::OPT_Z_reserved_lib_stdcxx))
Daniel Dunbar3f7796f2010-09-17 01:20:05 +0000207 TC.AddCXXStdlibLibArgs(Args, CmdArgs);
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +0000208 else if (A.getOption().matches(options::OPT_Z_reserved_lib_cckext))
Shantonu Senafeb03b2010-09-17 18:39:08 +0000209 TC.AddCCKextLibArgs(Args, CmdArgs);
Arthur Marble31fb6f42014-07-16 21:16:16 +0000210 else if (A.getOption().matches(options::OPT_z)) {
211 // Pass -z prefix for gcc linker compatibility.
212 A.claim();
213 A.render(Args, CmdArgs);
214 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000215 A.renderAsInput(Args, CmdArgs);
Arthur Marble31fb6f42014-07-16 21:16:16 +0000216 }
Daniel Dunbar54423b22010-09-17 00:24:54 +0000217 }
Bill Wendling281ca292012-03-12 21:22:35 +0000218
219 // LIBRARY_PATH - included following the user specified library paths.
Richard Barton5828d7b2013-12-17 11:11:25 +0000220 // and only supported on native toolchains.
221 if (!TC.isCrossCompiling())
222 addDirectoryList(Args, CmdArgs, "-L", "LIBRARY_PATH");
Daniel Dunbar54423b22010-09-17 00:24:54 +0000223}
224
John McCall31168b02011-06-15 23:02:42 +0000225/// \brief Determine whether Objective-C automated reference counting is
226/// enabled.
227static bool isObjCAutoRefCount(const ArgList &Args) {
228 return Args.hasFlag(options::OPT_fobjc_arc, options::OPT_fno_objc_arc, false);
229}
230
Ted Kremeneke65b0862012-03-06 20:05:56 +0000231/// \brief Determine whether we are linking the ObjC runtime.
232static bool isObjCRuntimeLinked(const ArgList &Args) {
Bob Wilson29536fc2012-08-07 19:58:00 +0000233 if (isObjCAutoRefCount(Args)) {
234 Args.ClaimAllArgs(options::OPT_fobjc_link_runtime);
Ted Kremeneke65b0862012-03-06 20:05:56 +0000235 return true;
Bob Wilson29536fc2012-08-07 19:58:00 +0000236 }
Ted Kremeneke65b0862012-03-06 20:05:56 +0000237 return Args.hasArg(options::OPT_fobjc_link_runtime);
238}
239
Michael J. Spencer66e2b202012-10-19 22:37:06 +0000240static bool forwardToGCC(const Option &O) {
Reid Kleckner3793d5e2013-06-19 15:09:06 +0000241 // Don't forward inputs from the original command line. They are added from
242 // InputInfoList.
Richard Smith8e5e9762013-06-20 01:33:59 +0000243 return O.getKind() != Option::InputClass &&
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000244 !O.hasFlag(options::DriverOption) && !O.hasFlag(options::LinkerInput);
Michael J. Spencer66e2b202012-10-19 22:37:06 +0000245}
246
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000247void Clang::AddPreprocessingOptions(Compilation &C, const JobAction &JA,
248 const Driver &D, const ArgList &Args,
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000249 ArgStringList &CmdArgs,
250 const InputInfo &Output,
251 const InputInfoList &Inputs) const {
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000252 Arg *A;
Daniel Dunbar367dbb92009-06-08 21:48:20 +0000253
Daniel Dunbar64198ef2009-09-10 01:21:05 +0000254 CheckPreprocessingOptions(D, Args);
255
256 Args.AddLastArg(CmdArgs, options::OPT_C);
257 Args.AddLastArg(CmdArgs, options::OPT_CC);
Daniel Dunbar367dbb92009-06-08 21:48:20 +0000258
259 // Handle dependency file generation.
Daniel Dunbar86aed7d2010-12-08 21:33:40 +0000260 if ((A = Args.getLastArg(options::OPT_M, options::OPT_MM)) ||
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000261 (A = Args.getLastArg(options::OPT_MD)) ||
262 (A = Args.getLastArg(options::OPT_MMD))) {
263 // Determine the output location.
264 const char *DepFile;
Benjamin Kramer2715fce2012-09-26 19:01:49 +0000265 if (Arg *MF = Args.getLastArg(options::OPT_MF)) {
Richard Smithbd55daf2012-11-01 04:30:05 +0000266 DepFile = MF->getValue();
Chad Rosier633dcdc2013-01-24 19:14:47 +0000267 C.addFailureResultFile(DepFile, &JA);
Benjamin Kramer2715fce2012-09-26 19:01:49 +0000268 } else if (Output.getType() == types::TY_Dependencies) {
269 DepFile = Output.getFilename();
Daniel Dunbar0bfb21e2009-11-19 03:26:40 +0000270 } else if (A->getOption().matches(options::OPT_M) ||
271 A->getOption().matches(options::OPT_MM)) {
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000272 DepFile = "-";
273 } else {
Bob Wilsondecc03e2012-11-23 06:14:39 +0000274 DepFile = getDependencyFileName(Args, Inputs);
Chad Rosier633dcdc2013-01-24 19:14:47 +0000275 C.addFailureResultFile(DepFile, &JA);
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000276 }
277 CmdArgs.push_back("-dependency-file");
278 CmdArgs.push_back(DepFile);
279
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000280 // Add a default target if one wasn't specified.
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000281 if (!Args.hasArg(options::OPT_MT) && !Args.hasArg(options::OPT_MQ)) {
282 const char *DepTarget;
283
284 // If user provided -o, that is the dependency target, except
285 // when we are only generating a dependency file.
286 Arg *OutputOpt = Args.getLastArg(options::OPT_o);
287 if (OutputOpt && Output.getType() != types::TY_Dependencies) {
Richard Smithbd55daf2012-11-01 04:30:05 +0000288 DepTarget = OutputOpt->getValue();
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000289 } else {
290 // Otherwise derive from the base input.
291 //
292 // FIXME: This should use the computed output file location.
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +0000293 SmallString<128> P(Inputs[0].getBaseInput());
Michael J. Spencere1696752010-12-18 00:19:12 +0000294 llvm::sys::path::replace_extension(P, "o");
295 DepTarget = Args.MakeArgString(llvm::sys::path::filename(P));
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000296 }
297
298 CmdArgs.push_back("-MT");
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +0000299 SmallString<128> Quoted;
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000300 QuoteTarget(DepTarget, Quoted);
301 CmdArgs.push_back(Args.MakeArgString(Quoted));
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000302 }
303
Daniel Dunbar0bfb21e2009-11-19 03:26:40 +0000304 if (A->getOption().matches(options::OPT_M) ||
305 A->getOption().matches(options::OPT_MD))
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000306 CmdArgs.push_back("-sys-header-deps");
Manuel Klimekc68aa162015-03-19 12:00:22 +0000307 if ((isa<PrecompileJobAction>(JA) &&
308 !Args.hasArg(options::OPT_fno_module_file_deps)) ||
309 Args.hasArg(options::OPT_fmodule_file_deps))
Argyrios Kyrtzidis6d0753d2014-03-14 03:07:38 +0000310 CmdArgs.push_back("-module-file-deps");
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000311 }
312
Peter Collingbourne77b0e7f22011-07-12 19:35:15 +0000313 if (Args.hasArg(options::OPT_MG)) {
314 if (!A || A->getOption().matches(options::OPT_MD) ||
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000315 A->getOption().matches(options::OPT_MMD))
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000316 D.Diag(diag::err_drv_mg_requires_m_or_mm);
Peter Collingbourne77b0e7f22011-07-12 19:35:15 +0000317 CmdArgs.push_back("-MG");
318 }
319
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000320 Args.AddLastArg(CmdArgs, options::OPT_MP);
Paul Robinsond7214a72015-04-27 18:14:32 +0000321 Args.AddLastArg(CmdArgs, options::OPT_MV);
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000322
323 // Convert all -MQ <target> args to -MT <quoted target>
Sean Silva14facf32015-06-09 01:57:17 +0000324 for (const Arg *A : Args.filtered(options::OPT_MT, options::OPT_MQ)) {
Daniel Dunbara442fd52010-06-11 22:00:13 +0000325 A->claim();
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000326
Daniel Dunbara442fd52010-06-11 22:00:13 +0000327 if (A->getOption().matches(options::OPT_MQ)) {
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000328 CmdArgs.push_back("-MT");
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +0000329 SmallString<128> Quoted;
Richard Smithbd55daf2012-11-01 04:30:05 +0000330 QuoteTarget(A->getValue(), Quoted);
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000331 CmdArgs.push_back(Args.MakeArgString(Quoted));
332
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000333 // -MT flag - no change
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000334 } else {
Daniel Dunbara442fd52010-06-11 22:00:13 +0000335 A->render(Args, CmdArgs);
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000336 }
337 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000338
Douglas Gregor111af7d2009-04-18 00:34:01 +0000339 // Add -i* options, and automatically translate to
340 // -include-pch/-include-pth for transparent PCH support. It's
341 // wonky, but we include looking for .gch so we can support seamless
342 // replacement into a build system already set up to be generating
343 // .gch files.
Argyrios Kyrtzidis2f23b412010-09-30 16:53:47 +0000344 bool RenderedImplicitInclude = false;
Sean Silva14facf32015-06-09 01:57:17 +0000345 for (const Arg *A : Args.filtered(options::OPT_clang_i_Group)) {
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000346 if (A->getOption().matches(options::OPT_include)) {
Argyrios Kyrtzidis2f23b412010-09-30 16:53:47 +0000347 bool IsFirstImplicitInclude = !RenderedImplicitInclude;
348 RenderedImplicitInclude = true;
349
Argyrios Kyrtzidis90bdfbb2010-08-11 23:27:58 +0000350 // Use PCH if the user requested it.
Daniel Dunbarcbc34b72009-10-15 20:02:44 +0000351 bool UsePCH = D.CCCUsePCH;
Daniel Dunbarcbc34b72009-10-15 20:02:44 +0000352
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000353 bool FoundPTH = false;
Douglas Gregor111af7d2009-04-18 00:34:01 +0000354 bool FoundPCH = false;
Rafael Espindola00eaafd2013-06-25 15:03:59 +0000355 SmallString<128> P(A->getValue());
356 // We want the files to have a name like foo.h.pch. Add a dummy extension
357 // so that replace_extension does the right thing.
358 P += ".dummy";
Daniel Dunbarcbc34b72009-10-15 20:02:44 +0000359 if (UsePCH) {
Rafael Espindola00eaafd2013-06-25 15:03:59 +0000360 llvm::sys::path::replace_extension(P, "pch");
Yaron Keren92e1b622015-03-18 10:17:07 +0000361 if (llvm::sys::fs::exists(P))
Douglas Gregor111af7d2009-04-18 00:34:01 +0000362 FoundPCH = true;
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000363 }
364
Douglas Gregor111af7d2009-04-18 00:34:01 +0000365 if (!FoundPCH) {
Rafael Espindola00eaafd2013-06-25 15:03:59 +0000366 llvm::sys::path::replace_extension(P, "pth");
Yaron Keren92e1b622015-03-18 10:17:07 +0000367 if (llvm::sys::fs::exists(P))
Douglas Gregor111af7d2009-04-18 00:34:01 +0000368 FoundPTH = true;
Mike Stump11289f42009-09-09 15:08:12 +0000369 }
370
Douglas Gregor111af7d2009-04-18 00:34:01 +0000371 if (!FoundPCH && !FoundPTH) {
Rafael Espindola00eaafd2013-06-25 15:03:59 +0000372 llvm::sys::path::replace_extension(P, "gch");
Yaron Keren92e1b622015-03-18 10:17:07 +0000373 if (llvm::sys::fs::exists(P)) {
Daniel Dunbarcbc34b72009-10-15 20:02:44 +0000374 FoundPCH = UsePCH;
375 FoundPTH = !UsePCH;
Douglas Gregor111af7d2009-04-18 00:34:01 +0000376 }
Douglas Gregor111af7d2009-04-18 00:34:01 +0000377 }
378
379 if (FoundPCH || FoundPTH) {
Argyrios Kyrtzidis2f23b412010-09-30 16:53:47 +0000380 if (IsFirstImplicitInclude) {
381 A->claim();
382 if (UsePCH)
383 CmdArgs.push_back("-include-pch");
384 else
385 CmdArgs.push_back("-include-pth");
Yaron Keren92e1b622015-03-18 10:17:07 +0000386 CmdArgs.push_back(Args.MakeArgString(P));
Argyrios Kyrtzidis2f23b412010-09-30 16:53:47 +0000387 continue;
388 } else {
389 // Ignore the PCH if not first on command line and emit warning.
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000390 D.Diag(diag::warn_drv_pch_not_first_include) << P
391 << A->getAsString(Args);
Argyrios Kyrtzidis2f23b412010-09-30 16:53:47 +0000392 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000393 }
394 }
395
396 // Not translated, render as usual.
397 A->claim();
398 A->render(Args, CmdArgs);
399 }
400
Douglas Katzman57a9c7e2015-07-29 18:39:14 +0000401 Args.AddAllArgs(CmdArgs,
402 {options::OPT_D, options::OPT_U, options::OPT_I_Group,
403 options::OPT_F, options::OPT_index_header_map});
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000404
405 // Add -Wp, and -Xassembler if using the preprocessor.
406
407 // FIXME: There is a very unfortunate problem here, some troubled
408 // souls abuse -Wp, to pass preprocessor options in gcc syntax. To
409 // really support that we would have to parse and then translate
410 // those options. :(
411 Args.AddAllArgValues(CmdArgs, options::OPT_Wp_COMMA,
412 options::OPT_Xpreprocessor);
Daniel Dunbar38b62792009-10-29 01:53:44 +0000413
414 // -I- is a deprecated GCC feature, reject it.
415 if (Arg *A = Args.getLastArg(options::OPT_I_))
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000416 D.Diag(diag::err_drv_I_dash_not_supported) << A->getAsString(Args);
Chandler Carruth24e17e12010-10-20 07:00:47 +0000417
418 // If we have a --sysroot, and don't have an explicit -isysroot flag, add an
419 // -isysroot to the CC1 invocation.
Sebastian Pop980920a2012-04-16 04:16:43 +0000420 StringRef sysroot = C.getSysRoot();
421 if (sysroot != "") {
Chandler Carruth24e17e12010-10-20 07:00:47 +0000422 if (!Args.hasArg(options::OPT_isysroot)) {
423 CmdArgs.push_back("-isysroot");
Sebastian Pop980920a2012-04-16 04:16:43 +0000424 CmdArgs.push_back(C.getArgs().MakeArgString(sysroot));
Chandler Carruth24e17e12010-10-20 07:00:47 +0000425 }
426 }
Douglas Gregor5dc38992013-02-07 00:21:12 +0000427
Benjamin Kramer8404eb02011-09-22 21:41:16 +0000428 // Parse additional include paths from environment variables.
Chandler Carruth9802c142011-11-04 07:12:58 +0000429 // FIXME: We should probably sink the logic for handling these from the
430 // frontend into the driver. It will allow deleting 4 otherwise unused flags.
Benjamin Kramer8404eb02011-09-22 21:41:16 +0000431 // CPATH - included following the user specified includes (but prior to
432 // builtin and standard includes).
Bill Wendlingc0938f32012-03-12 22:10:06 +0000433 addDirectoryList(Args, CmdArgs, "-I", "CPATH");
Benjamin Kramer8404eb02011-09-22 21:41:16 +0000434 // C_INCLUDE_PATH - system includes enabled when compiling C.
Bill Wendlingc0938f32012-03-12 22:10:06 +0000435 addDirectoryList(Args, CmdArgs, "-c-isystem", "C_INCLUDE_PATH");
Benjamin Kramer8404eb02011-09-22 21:41:16 +0000436 // CPLUS_INCLUDE_PATH - system includes enabled when compiling C++.
Bill Wendlingc0938f32012-03-12 22:10:06 +0000437 addDirectoryList(Args, CmdArgs, "-cxx-isystem", "CPLUS_INCLUDE_PATH");
Benjamin Kramer8404eb02011-09-22 21:41:16 +0000438 // OBJC_INCLUDE_PATH - system includes enabled when compiling ObjC.
Bill Wendlingc0938f32012-03-12 22:10:06 +0000439 addDirectoryList(Args, CmdArgs, "-objc-isystem", "OBJC_INCLUDE_PATH");
Benjamin Kramer8404eb02011-09-22 21:41:16 +0000440 // OBJCPLUS_INCLUDE_PATH - system includes enabled when compiling ObjC++.
Bill Wendlingc0938f32012-03-12 22:10:06 +0000441 addDirectoryList(Args, CmdArgs, "-objcxx-isystem", "OBJCPLUS_INCLUDE_PATH");
Chandler Carruth6bfd84f2011-11-04 07:12:53 +0000442
Chandler Carruth6bfd84f2011-11-04 07:12:53 +0000443 // Add C++ include arguments, if needed.
Chandler Carruth4c81dfa2011-11-04 07:43:33 +0000444 if (types::isCXX(Inputs[0].getType()))
Chandler Carruth491db322011-11-04 07:34:47 +0000445 getToolChain().AddClangCXXStdlibIncludeArgs(Args, CmdArgs);
Chandler Carrutha796f532011-11-05 20:17:13 +0000446
447 // Add system include arguments.
448 getToolChain().AddClangSystemIncludeArgs(Args, CmdArgs);
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000449}
450
Daniel Dunbard609b7b2009-11-17 06:37:03 +0000451// FIXME: Move to target hook.
452static bool isSignedCharDefault(const llvm::Triple &Triple) {
453 switch (Triple.getArch()) {
454 default:
455 return true;
456
Tim Northover9bb857a2013-01-31 12:13:10 +0000457 case llvm::Triple::aarch64:
Christian Pirker9b019ae2014-02-25 13:51:00 +0000458 case llvm::Triple::aarch64_be:
Jim Grosbach7c2c6642011-05-24 15:40:46 +0000459 case llvm::Triple::arm:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +0000460 case llvm::Triple::armeb:
Oliver Stannardabed2ee2014-10-24 11:28:47 +0000461 case llvm::Triple::thumb:
462 case llvm::Triple::thumbeb:
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +0000463 if (Triple.isOSDarwin() || Triple.isOSWindows())
464 return true;
465 return false;
466
Daniel Dunbard609b7b2009-11-17 06:37:03 +0000467 case llvm::Triple::ppc:
468 case llvm::Triple::ppc64:
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +0000469 if (Triple.isOSDarwin())
Daniel Dunbard609b7b2009-11-17 06:37:03 +0000470 return true;
471 return false;
Ulrich Weigand47445072013-05-06 16:26:41 +0000472
David Majnemerdcecd932015-05-23 19:23:55 +0000473 case llvm::Triple::hexagon:
Bill Schmidt778d3872013-07-26 01:36:11 +0000474 case llvm::Triple::ppc64le:
Ulrich Weigand47445072013-05-06 16:26:41 +0000475 case llvm::Triple::systemz:
Robert Lytton0e076492013-08-13 09:43:10 +0000476 case llvm::Triple::xcore:
Ulrich Weigand47445072013-05-06 16:26:41 +0000477 return false;
Daniel Dunbard609b7b2009-11-17 06:37:03 +0000478 }
479}
480
Robert Lytton0e076492013-08-13 09:43:10 +0000481static bool isNoCommonDefault(const llvm::Triple &Triple) {
482 switch (Triple.getArch()) {
483 default:
484 return false;
485
486 case llvm::Triple::xcore:
Dan Gohmanc2853072015-09-03 22:51:53 +0000487 case llvm::Triple::wasm32:
488 case llvm::Triple::wasm64:
Robert Lytton0e076492013-08-13 09:43:10 +0000489 return true;
490 }
491}
492
Renato Goline17c5802015-07-27 23:44:42 +0000493// ARM tools start.
494
495// Get SubArch (vN).
496static int getARMSubArchVersionNumber(const llvm::Triple &Triple) {
497 llvm::StringRef Arch = Triple.getArchName();
Chandler Carruthaa0caeb2015-08-30 02:16:36 +0000498 return llvm::ARM::parseArchVersion(Arch);
Renato Goline17c5802015-07-27 23:44:42 +0000499}
500
501// True if M-profile.
502static bool isARMMProfile(const llvm::Triple &Triple) {
503 llvm::StringRef Arch = Triple.getArchName();
Chandler Carruthaa0caeb2015-08-30 02:16:36 +0000504 unsigned Profile = llvm::ARM::parseArchProfile(Arch);
Renato Goline17c5802015-07-27 23:44:42 +0000505 return Profile == llvm::ARM::PK_M;
506}
507
508// Get Arch/CPU from args.
Renato Golin7c542b42015-07-27 23:44:45 +0000509static void getARMArchCPUFromArgs(const ArgList &Args, llvm::StringRef &Arch,
510 llvm::StringRef &CPU, bool FromAs = false) {
Renato Goline17c5802015-07-27 23:44:42 +0000511 if (const Arg *A = Args.getLastArg(options::OPT_mcpu_EQ))
512 CPU = A->getValue();
513 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ))
514 Arch = A->getValue();
Renato Golin7c542b42015-07-27 23:44:45 +0000515 if (!FromAs)
516 return;
517
518 for (const Arg *A :
519 Args.filtered(options::OPT_Wa_COMMA, options::OPT_Xassembler)) {
520 StringRef Value = A->getValue();
521 if (Value.startswith("-mcpu="))
522 CPU = Value.substr(6);
523 if (Value.startswith("-march="))
524 Arch = Value.substr(7);
525 }
Renato Goline17c5802015-07-27 23:44:42 +0000526}
527
Silviu Barangaf9671dd2013-10-21 10:54:53 +0000528// Handle -mhwdiv=.
Renato Golin7c542b42015-07-27 23:44:45 +0000529// FIXME: Use ARMTargetParser.
Silviu Barangaf9671dd2013-10-21 10:54:53 +0000530static void getARMHWDivFeatures(const Driver &D, const Arg *A,
Renato Golin7c542b42015-07-27 23:44:45 +0000531 const ArgList &Args, StringRef HWDiv,
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000532 std::vector<const char *> &Features) {
Chandler Carruthaa0caeb2015-08-30 02:16:36 +0000533 unsigned HWDivID = llvm::ARM::parseHWDiv(HWDiv);
534 if (!llvm::ARM::getHWDivFeatures(HWDivID, Features))
Silviu Barangaf9671dd2013-10-21 10:54:53 +0000535 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
536}
Reid Kleckner0290c9c2014-09-15 17:45:39 +0000537
Amara Emerson4cdb87b2013-10-01 10:20:54 +0000538// Handle -mfpu=.
Amara Emerson4cdb87b2013-10-01 10:20:54 +0000539static void getARMFPUFeatures(const Driver &D, const Arg *A,
Renato Golin7c542b42015-07-27 23:44:45 +0000540 const ArgList &Args, StringRef FPU,
Amara Emerson4cdb87b2013-10-01 10:20:54 +0000541 std::vector<const char *> &Features) {
Chandler Carruthaa0caeb2015-08-30 02:16:36 +0000542 unsigned FPUID = llvm::ARM::parseFPU(FPU);
543 if (!llvm::ARM::getFPUFeatures(FPUID, Features))
Chad Rosiercfbfc582012-04-04 20:51:35 +0000544 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
545}
546
Renato Golin7c542b42015-07-27 23:44:45 +0000547// Check if -march is valid by checking if it can be canonicalised and parsed.
548// getARMArch is used here instead of just checking the -march value in order
549// to handle -march=native correctly.
550static void checkARMArchName(const Driver &D, const Arg *A, const ArgList &Args,
Renato Goline17c5802015-07-27 23:44:42 +0000551 llvm::StringRef ArchName,
552 const llvm::Triple &Triple) {
553 std::string MArch = arm::getARMArch(ArchName, Triple);
Chandler Carruthaa0caeb2015-08-30 02:16:36 +0000554 if (llvm::ARM::parseArch(MArch) == llvm::ARM::AK_INVALID)
Renato Goline17c5802015-07-27 23:44:42 +0000555 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
John Brawn94fd9632015-05-21 12:19:49 +0000556}
557
Renato Golin7c542b42015-07-27 23:44:45 +0000558// Check -mcpu=. Needs ArchName to handle -mcpu=generic.
559static void checkARMCPUName(const Driver &D, const Arg *A, const ArgList &Args,
560 llvm::StringRef CPUName, llvm::StringRef ArchName,
Renato Goline17c5802015-07-27 23:44:42 +0000561 const llvm::Triple &Triple) {
562 std::string CPU = arm::getARMTargetCPU(CPUName, ArchName, Triple);
Vladimir Sukharev64f68242015-09-23 09:29:32 +0000563 if (arm::getLLVMArchSuffixForARM(CPU, ArchName, Triple).empty())
Renato Goline17c5802015-07-27 23:44:42 +0000564 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
John Brawn94fd9632015-05-21 12:19:49 +0000565}
566
Akira Hatanaka9d99bb52015-08-26 19:00:11 +0000567static bool useAAPCSForMachO(const llvm::Triple &T) {
568 // The backend is hardwired to assume AAPCS for M-class processors, ensure
569 // the frontend matches that.
570 return T.getEnvironment() == llvm::Triple::EABI ||
571 T.getOS() == llvm::Triple::UnknownOS || isARMMProfile(T);
572}
573
Asiri Rathnayake9e3c7cb2014-10-03 09:11:41 +0000574// Select the float ABI as determined by -msoft-float, -mhard-float, and
575// -mfloat-abi=.
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +0000576arm::FloatABI arm::getARMFloatABI(const ToolChain &TC, const ArgList &Args) {
577 const Driver &D = TC.getDriver();
578 const llvm::Triple Triple(TC.ComputeEffectiveClangTriple(Args));
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000579 auto SubArch = getARMSubArchVersionNumber(Triple);
580 arm::FloatABI ABI = FloatABI::Invalid;
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000581 if (Arg *A =
582 Args.getLastArg(options::OPT_msoft_float, options::OPT_mhard_float,
583 options::OPT_mfloat_abi_EQ)) {
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000584 if (A->getOption().matches(options::OPT_msoft_float)) {
585 ABI = FloatABI::Soft;
586 } else if (A->getOption().matches(options::OPT_mhard_float)) {
587 ABI = FloatABI::Hard;
588 } else {
589 ABI = llvm::StringSwitch<arm::FloatABI>(A->getValue())
590 .Case("soft", FloatABI::Soft)
591 .Case("softfp", FloatABI::SoftFP)
592 .Case("hard", FloatABI::Hard)
593 .Default(FloatABI::Invalid);
594 if (ABI == FloatABI::Invalid && !StringRef(A->getValue()).empty()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000595 D.Diag(diag::err_drv_invalid_mfloat_abi) << A->getAsString(Args);
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000596 ABI = FloatABI::Soft;
Daniel Dunbar78485922009-09-10 23:00:09 +0000597 }
598 }
Akira Hatanaka9d99bb52015-08-26 19:00:11 +0000599
600 // It is incorrect to select hard float ABI on MachO platforms if the ABI is
601 // "apcs-gnu".
602 if (Triple.isOSBinFormatMachO() && !useAAPCSForMachO(Triple) &&
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000603 ABI == FloatABI::Hard) {
Akira Hatanaka9d99bb52015-08-26 19:00:11 +0000604 D.Diag(diag::err_drv_unsupported_opt_for_target) << A->getAsString(Args)
605 << Triple.getArchName();
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000606 }
Daniel Dunbar78485922009-09-10 23:00:09 +0000607 }
608
609 // If unspecified, choose the default based on the platform.
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000610 if (ABI == FloatABI::Invalid) {
Rafael Espindola0e1fb4f2010-06-28 17:18:09 +0000611 switch (Triple.getOS()) {
Bob Wilson6524dd32011-10-14 05:03:44 +0000612 case llvm::Triple::Darwin:
613 case llvm::Triple::MacOSX:
614 case llvm::Triple::IOS: {
Daniel Dunbar78485922009-09-10 23:00:09 +0000615 // Darwin defaults to "softfp" for v6 and v7.
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000616 ABI = (SubArch == 6 || SubArch == 7) ? FloatABI::SoftFP : FloatABI::Soft;
Daniel Dunbar78485922009-09-10 23:00:09 +0000617 break;
618 }
619
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +0000620 // FIXME: this is invalid for WindowsCE
621 case llvm::Triple::Win32:
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000622 ABI = FloatABI::Hard;
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +0000623 break;
624
Rafael Espindola0f207ed2012-12-13 04:17:14 +0000625 case llvm::Triple::FreeBSD:
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000626 switch (Triple.getEnvironment()) {
Renato Golinf4421f72014-02-19 10:44:07 +0000627 case llvm::Triple::GNUEABIHF:
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000628 ABI = FloatABI::Hard;
Renato Golinf4421f72014-02-19 10:44:07 +0000629 break;
630 default:
631 // FreeBSD defaults to soft float
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000632 ABI = FloatABI::Soft;
Renato Golinf4421f72014-02-19 10:44:07 +0000633 break;
634 }
Rafael Espindola0f207ed2012-12-13 04:17:14 +0000635 break;
636
Daniel Dunbar78485922009-09-10 23:00:09 +0000637 default:
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000638 switch (Triple.getEnvironment()) {
Jiangning Liu61b06cb2012-07-31 08:06:29 +0000639 case llvm::Triple::GNUEABIHF:
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000640 case llvm::Triple::EABIHF:
641 ABI = FloatABI::Hard;
Jiangning Liu61b06cb2012-07-31 08:06:29 +0000642 break;
Bob Wilsond1447c42011-02-04 17:59:28 +0000643 case llvm::Triple::GNUEABI:
Bob Wilsond1447c42011-02-04 17:59:28 +0000644 case llvm::Triple::EABI:
645 // EABI is always AAPCS, and if it was not marked 'hard', it's softfp
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000646 ABI = FloatABI::SoftFP;
Bob Wilsond1447c42011-02-04 17:59:28 +0000647 break;
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000648 case llvm::Triple::Android:
649 ABI = (SubArch == 7) ? FloatABI::SoftFP : FloatABI::Soft;
Chandler Carruthc89aa9d2012-01-10 19:47:42 +0000650 break;
Bob Wilsond1447c42011-02-04 17:59:28 +0000651 default:
652 // Assume "soft", but warn the user we are guessing.
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000653 ABI = FloatABI::Soft;
Saleem Abdulrasool377066a2014-03-27 22:50:18 +0000654 if (Triple.getOS() != llvm::Triple::UnknownOS ||
655 !Triple.isOSBinFormatMachO())
656 D.Diag(diag::warn_drv_assuming_mfloat_abi_is) << "soft";
Bob Wilsond1447c42011-02-04 17:59:28 +0000657 break;
658 }
Daniel Dunbar78485922009-09-10 23:00:09 +0000659 }
660 }
661
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000662 assert(ABI != FloatABI::Invalid && "must select an ABI");
663 return ABI;
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000664}
665
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +0000666static void getARMTargetFeatures(const ToolChain &TC,
667 const llvm::Triple &Triple,
Rafael Espindola28e1f4b2013-08-21 16:39:20 +0000668 const ArgList &Args,
Rafael Espindola9c6fb0f2013-11-23 14:36:40 +0000669 std::vector<const char *> &Features,
670 bool ForAS) {
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +0000671 const Driver &D = TC.getDriver();
672
Akira Hatanaka3fb33a52015-07-07 06:42:05 +0000673 bool KernelOrKext =
674 Args.hasArg(options::OPT_mkernel, options::OPT_fapple_kext);
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +0000675 arm::FloatABI ABI = arm::getARMFloatABI(TC, Args);
Renato Golin7c542b42015-07-27 23:44:45 +0000676 const Arg *WaCPU = nullptr, *WaFPU = nullptr;
677 const Arg *WaHDiv = nullptr, *WaArch = nullptr;
678
Nico Weber6e0ebae2015-04-29 21:16:40 +0000679 if (!ForAS) {
680 // FIXME: Note, this is a hack, the LLVM backend doesn't actually use these
681 // yet (it uses the -mfloat-abi and -msoft-float options), and it is
682 // stripped out by the ARM target. We should probably pass this a new
683 // -target-option, which is handled by the -cc1/-cc1as invocation.
684 //
685 // FIXME2: For consistency, it would be ideal if we set up the target
686 // machine state the same when using the frontend or the assembler. We don't
687 // currently do that for the assembler, we pass the options directly to the
688 // backend and never even instantiate the frontend TargetInfo. If we did,
689 // and used its handleTargetFeatures hook, then we could ensure the
690 // assembler and the frontend behave the same.
691
692 // Use software floating point operations?
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000693 if (ABI == arm::FloatABI::Soft)
Nico Weber6e0ebae2015-04-29 21:16:40 +0000694 Features.push_back("+soft-float");
695
696 // Use software floating point argument passing?
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000697 if (ABI != arm::FloatABI::Hard)
Nico Weber6e0ebae2015-04-29 21:16:40 +0000698 Features.push_back("+soft-float-abi");
Renato Golin7c542b42015-07-27 23:44:45 +0000699 } else {
700 // Here, we make sure that -Wa,-mfpu/cpu/arch/hwdiv will be passed down
701 // to the assembler correctly.
702 for (const Arg *A :
703 Args.filtered(options::OPT_Wa_COMMA, options::OPT_Xassembler)) {
704 StringRef Value = A->getValue();
705 if (Value.startswith("-mfpu=")) {
706 WaFPU = A;
707 } else if (Value.startswith("-mcpu=")) {
708 WaCPU = A;
709 } else if (Value.startswith("-mhwdiv=")) {
710 WaHDiv = A;
711 } else if (Value.startswith("-march=")) {
712 WaArch = A;
713 }
714 }
Nico Weber6e0ebae2015-04-29 21:16:40 +0000715 }
716
Renato Golin7c542b42015-07-27 23:44:45 +0000717 // Check -march. ClangAs gives preference to -Wa,-march=.
718 const Arg *ArchArg = Args.getLastArg(options::OPT_march_EQ);
Renato Goline17c5802015-07-27 23:44:42 +0000719 StringRef ArchName;
Renato Golin7c542b42015-07-27 23:44:45 +0000720 if (WaArch) {
721 if (ArchArg)
722 D.Diag(clang::diag::warn_drv_unused_argument)
723 << ArchArg->getAsString(Args);
724 ArchName = StringRef(WaArch->getValue()).substr(7);
725 checkARMArchName(D, WaArch, Args, ArchName, Triple);
726 // FIXME: Set Arch.
727 D.Diag(clang::diag::warn_drv_unused_argument) << WaArch->getAsString(Args);
728 } else if (ArchArg) {
729 ArchName = ArchArg->getValue();
730 checkARMArchName(D, ArchArg, Args, ArchName, Triple);
John Brawn94fd9632015-05-21 12:19:49 +0000731 }
732
Renato Golin7c542b42015-07-27 23:44:45 +0000733 // Check -mcpu. ClangAs gives preference to -Wa,-mcpu=.
734 const Arg *CPUArg = Args.getLastArg(options::OPT_mcpu_EQ);
Renato Goline17c5802015-07-27 23:44:42 +0000735 StringRef CPUName;
Renato Golin7c542b42015-07-27 23:44:45 +0000736 if (WaCPU) {
737 if (CPUArg)
738 D.Diag(clang::diag::warn_drv_unused_argument)
739 << CPUArg->getAsString(Args);
740 CPUName = StringRef(WaCPU->getValue()).substr(6);
741 checkARMCPUName(D, WaCPU, Args, CPUName, ArchName, Triple);
742 } else if (CPUArg) {
743 CPUName = CPUArg->getValue();
744 checkARMCPUName(D, CPUArg, Args, CPUName, ArchName, Triple);
John Brawn94fd9632015-05-21 12:19:49 +0000745 }
John Brawna95c1a82015-05-08 12:52:18 +0000746
Renato Golin23459c62015-07-30 16:40:17 +0000747 // Add CPU features for generic CPUs
748 if (CPUName == "native") {
749 llvm::StringMap<bool> HostFeatures;
750 if (llvm::sys::getHostCPUFeatures(HostFeatures))
751 for (auto &F : HostFeatures)
752 Features.push_back(
753 Args.MakeArgString((F.second ? "+" : "-") + F.first()));
754 }
755
756 // Honor -mfpu=. ClangAs gives preference to -Wa,-mfpu=.
757 const Arg *FPUArg = Args.getLastArg(options::OPT_mfpu_EQ);
758 if (WaFPU) {
759 if (FPUArg)
760 D.Diag(clang::diag::warn_drv_unused_argument)
761 << FPUArg->getAsString(Args);
762 getARMFPUFeatures(D, WaFPU, Args, StringRef(WaFPU->getValue()).substr(6),
763 Features);
764 } else if (FPUArg) {
765 getARMFPUFeatures(D, FPUArg, Args, FPUArg->getValue(), Features);
766 }
767
768 // Honor -mhwdiv=. ClangAs gives preference to -Wa,-mhwdiv=.
769 const Arg *HDivArg = Args.getLastArg(options::OPT_mhwdiv_EQ);
770 if (WaHDiv) {
771 if (HDivArg)
772 D.Diag(clang::diag::warn_drv_unused_argument)
773 << HDivArg->getAsString(Args);
774 getARMHWDivFeatures(D, WaHDiv, Args,
775 StringRef(WaHDiv->getValue()).substr(8), Features);
776 } else if (HDivArg)
777 getARMHWDivFeatures(D, HDivArg, Args, HDivArg->getValue(), Features);
778
Rafael Espindola28e1f4b2013-08-21 16:39:20 +0000779 // Setting -msoft-float effectively disables NEON because of the GCC
780 // implementation, although the same isn't true of VFP or VFP3.
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000781 if (ABI == arm::FloatABI::Soft) {
Rafael Espindola28e1f4b2013-08-21 16:39:20 +0000782 Features.push_back("-neon");
Amara Emersonecbe18e2014-02-12 10:22:35 +0000783 // Also need to explicitly disable features which imply NEON.
784 Features.push_back("-crypto");
785 }
Bernard Ogden18b57012013-10-29 09:47:51 +0000786
Eric Christopher269c2a22015-04-04 03:34:43 +0000787 // En/disable crc code generation.
788 if (Arg *A = Args.getLastArg(options::OPT_mcrc, options::OPT_mnocrc)) {
Bernard Ogden18b57012013-10-29 09:47:51 +0000789 if (A->getOption().matches(options::OPT_mcrc))
790 Features.push_back("+crc");
791 else
792 Features.push_back("-crc");
793 }
Vladimir Sukharevc6dab752015-05-14 08:25:18 +0000794
795 if (Triple.getSubArch() == llvm::Triple::SubArchType::ARMSubArch_v8_1a) {
796 Features.insert(Features.begin(), "+v8.1a");
797 }
Akira Hatanaka3fb33a52015-07-07 06:42:05 +0000798
Akira Hatanakac2694822015-07-07 08:28:42 +0000799 // Look for the last occurrence of -mlong-calls or -mno-long-calls. If
800 // neither options are specified, see if we are compiling for kernel/kext and
801 // decide whether to pass "+long-calls" based on the OS and its version.
Akira Hatanaka3fb33a52015-07-07 06:42:05 +0000802 if (Arg *A = Args.getLastArg(options::OPT_mlong_calls,
803 options::OPT_mno_long_calls)) {
804 if (A->getOption().matches(options::OPT_mlong_calls))
805 Features.push_back("+long-calls");
806 } else if (KernelOrKext && (!Triple.isiOS() || Triple.isOSVersionLT(6))) {
807 Features.push_back("+long-calls");
808 }
Akira Hatanaka580efb22015-07-16 00:43:00 +0000809
Akira Hatanaka7651dd82015-07-28 22:26:45 +0000810 // Kernel code has more strict alignment requirements.
811 if (KernelOrKext)
812 Features.push_back("+strict-align");
813 else if (Arg *A = Args.getLastArg(options::OPT_mno_unaligned_access,
814 options::OPT_munaligned_access)) {
815 if (A->getOption().matches(options::OPT_munaligned_access)) {
816 // No v6M core supports unaligned memory access (v6M ARM ARM A3.2).
817 if (Triple.getSubArch() == llvm::Triple::SubArchType::ARMSubArch_v6m)
818 D.Diag(diag::err_target_unsupported_unaligned) << "v6m";
819 } else
820 Features.push_back("+strict-align");
821 } else {
822 // Assume pre-ARMv6 doesn't support unaligned accesses.
823 //
824 // ARMv6 may or may not support unaligned accesses depending on the
825 // SCTLR.U bit, which is architecture-specific. We assume ARMv6
826 // Darwin and NetBSD targets support unaligned accesses, and others don't.
827 //
828 // ARMv7 always has SCTLR.U set to 1, but it has a new SCTLR.A bit
829 // which raises an alignment fault on unaligned accesses. Linux
830 // defaults this bit to 0 and handles it as a system-wide (not
831 // per-process) setting. It is therefore safe to assume that ARMv7+
832 // Linux targets support unaligned accesses. The same goes for NaCl.
833 //
834 // The above behavior is consistent with GCC.
835 int VersionNum = getARMSubArchVersionNumber(Triple);
836 if (Triple.isOSDarwin() || Triple.isOSNetBSD()) {
837 if (VersionNum < 6)
838 Features.push_back("+strict-align");
839 } else if (Triple.isOSLinux() || Triple.isOSNaCl()) {
840 if (VersionNum < 7)
841 Features.push_back("+strict-align");
842 } else
843 Features.push_back("+strict-align");
844 }
845
Akira Hatanaka0a23fac2015-07-21 01:41:08 +0000846 // llvm does not support reserving registers in general. There is support
847 // for reserving r9 on ARM though (defined as a platform-specific register
848 // in ARM EABI).
849 if (Args.hasArg(options::OPT_ffixed_r9))
850 Features.push_back("+reserve-r9");
851
Akira Hatanaka580efb22015-07-16 00:43:00 +0000852 // The kext linker doesn't know how to deal with movw/movt.
853 if (KernelOrKext)
854 Features.push_back("+no-movt");
Rafael Espindola28e1f4b2013-08-21 16:39:20 +0000855}
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000856
Saleem Abdulrasoolce63ce92015-09-19 18:19:44 +0000857void Clang::AddARMTargetArgs(const llvm::Triple &Triple, const ArgList &Args,
858 ArgStringList &CmdArgs, bool KernelOrKext) const {
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000859 // Select the ABI to use.
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000860 // FIXME: Support -meabi.
Eric Christopher52276532014-12-10 22:58:34 +0000861 // FIXME: Parts of this are duplicated in the backend, unify this somehow.
Craig Topper92fc2df2014-05-17 16:56:41 +0000862 const char *ABIName = nullptr;
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000863 if (Arg *A = Args.getLastArg(options::OPT_mabi_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +0000864 ABIName = A->getValue();
Tim Northovere5c6f4c2014-05-22 12:54:30 +0000865 } else if (Triple.isOSBinFormatMachO()) {
Akira Hatanaka9d99bb52015-08-26 19:00:11 +0000866 if (useAAPCSForMachO(Triple)) {
Daniel Dunbar5f18f6e2012-10-22 18:30:51 +0000867 ABIName = "aapcs";
868 } else {
869 ABIName = "apcs-gnu";
870 }
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +0000871 } else if (Triple.isOSWindows()) {
872 // FIXME: this is invalid for WindowsCE
873 ABIName = "aapcs";
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000874 } else {
875 // Select the default based on the platform.
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000876 switch (Triple.getEnvironment()) {
Logan Chienc6fd8202012-09-02 09:30:11 +0000877 case llvm::Triple::Android:
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000878 case llvm::Triple::GNUEABI:
Jiangning Liu61b06cb2012-07-31 08:06:29 +0000879 case llvm::Triple::GNUEABIHF:
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000880 ABIName = "aapcs-linux";
881 break;
Joerg Sonnenbergerd75a1f82013-12-16 19:16:04 +0000882 case llvm::Triple::EABIHF:
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000883 case llvm::Triple::EABI:
884 ABIName = "aapcs";
885 break;
Oliver Stannardec8b6b32014-09-04 10:38:53 +0000886 default:
Eric Christopher7a8b31d2014-12-18 02:08:51 +0000887 if (Triple.getOS() == llvm::Triple::NetBSD)
888 ABIName = "apcs-gnu";
889 else
890 ABIName = "aapcs";
Oliver Stannardec8b6b32014-09-04 10:38:53 +0000891 break;
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000892 }
893 }
894 CmdArgs.push_back("-target-abi");
895 CmdArgs.push_back(ABIName);
896
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000897 // Determine floating point ABI from the options & target defaults.
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +0000898 arm::FloatABI ABI = arm::getARMFloatABI(getToolChain(), Args);
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000899 if (ABI == arm::FloatABI::Soft) {
Daniel Dunbar78485922009-09-10 23:00:09 +0000900 // Floating point operations and argument passing are soft.
Daniel Dunbar78485922009-09-10 23:00:09 +0000901 // FIXME: This changes CPP defines, we need -target-soft-float.
Daniel Dunbara74f8ff2009-11-30 08:42:00 +0000902 CmdArgs.push_back("-msoft-float");
Daniel Dunbar6cc525b2009-12-08 19:49:51 +0000903 CmdArgs.push_back("-mfloat-abi");
904 CmdArgs.push_back("soft");
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000905 } else if (ABI == arm::FloatABI::SoftFP) {
Daniel Dunbar78485922009-09-10 23:00:09 +0000906 // Floating point operations are hard, but argument passing is soft.
Daniel Dunbar6cc525b2009-12-08 19:49:51 +0000907 CmdArgs.push_back("-mfloat-abi");
908 CmdArgs.push_back("soft");
Daniel Dunbar78485922009-09-10 23:00:09 +0000909 } else {
910 // Floating point operations and argument passing are hard.
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000911 assert(ABI == arm::FloatABI::Hard && "Invalid float abi!");
Daniel Dunbar6cc525b2009-12-08 19:49:51 +0000912 CmdArgs.push_back("-mfloat-abi");
913 CmdArgs.push_back("hard");
Daniel Dunbar78485922009-09-10 23:00:09 +0000914 }
Daniel Dunbar893d4752009-12-19 04:15:38 +0000915
Ahmed Bougacha256a8692015-04-11 00:10:44 +0000916 // Forward the -mglobal-merge option for explicit control over the pass.
Chad Rosierba3df1d2011-08-26 00:26:29 +0000917 if (Arg *A = Args.getLastArg(options::OPT_mglobal_merge,
918 options::OPT_mno_global_merge)) {
Ahmed Bougacha256a8692015-04-11 00:10:44 +0000919 CmdArgs.push_back("-backend-option");
Chad Rosierba3df1d2011-08-26 00:26:29 +0000920 if (A->getOption().matches(options::OPT_mno_global_merge))
Ahmed Bougacha256a8692015-04-11 00:10:44 +0000921 CmdArgs.push_back("-arm-global-merge=false");
922 else
923 CmdArgs.push_back("-arm-global-merge=true");
Chad Rosierba3df1d2011-08-26 00:26:29 +0000924 }
Chad Rosierf1985d22012-05-16 20:40:09 +0000925
Bob Wilson9c8af452013-04-11 18:53:25 +0000926 if (!Args.hasFlag(options::OPT_mimplicit_float,
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000927 options::OPT_mno_implicit_float, true))
Chad Rosierf1985d22012-05-16 20:40:09 +0000928 CmdArgs.push_back("-no-implicit-float");
Daniel Dunbar0f5c5422009-09-10 04:57:17 +0000929}
Renato Goline17c5802015-07-27 23:44:42 +0000930// ARM tools end.
Daniel Dunbar0f5c5422009-09-10 04:57:17 +0000931
Tim Northover573cbee2014-05-24 12:52:07 +0000932/// getAArch64TargetCPU - Get the (LLVM) name of the AArch64 cpu we are
933/// targeting.
934static std::string getAArch64TargetCPU(const ArgList &Args) {
Kevin Qin110db6f2014-07-18 07:03:22 +0000935 Arg *A;
936 std::string CPU;
937 // If we have -mtune or -mcpu, use that.
938 if ((A = Args.getLastArg(options::OPT_mtune_EQ))) {
Gabor Ballabasa24a1a42015-07-20 11:28:20 +0000939 CPU = StringRef(A->getValue()).lower();
Kevin Qin110db6f2014-07-18 07:03:22 +0000940 } else if ((A = Args.getLastArg(options::OPT_mcpu_EQ))) {
Renato Golin4045f662015-05-08 15:44:36 +0000941 StringRef Mcpu = A->getValue();
Gabor Ballabas726ce7f2015-06-12 17:33:37 +0000942 CPU = Mcpu.split("+").first.lower();
Tim Northovera2ee4332014-03-29 15:09:45 +0000943 }
944
Kevin Qin110db6f2014-07-18 07:03:22 +0000945 // Handle CPU name is 'native'.
946 if (CPU == "native")
947 return llvm::sys::getHostCPUName();
948 else if (CPU.size())
949 return CPU;
Tim Northovera2ee4332014-03-29 15:09:45 +0000950
James Molloy9b1586b2014-04-17 12:51:17 +0000951 // Make sure we pick "cyclone" if -arch is used.
952 // FIXME: Should this be picked by checking the target triple instead?
953 if (Args.getLastArg(options::OPT_arch))
954 return "cyclone";
955
956 return "generic";
Tim Northovera2ee4332014-03-29 15:09:45 +0000957}
958
Tim Northover573cbee2014-05-24 12:52:07 +0000959void Clang::AddAArch64TargetArgs(const ArgList &Args,
960 ArgStringList &CmdArgs) const {
Tim Northovera2ee4332014-03-29 15:09:45 +0000961 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
962 llvm::Triple Triple(TripleStr);
963
964 if (!Args.hasFlag(options::OPT_mred_zone, options::OPT_mno_red_zone, true) ||
965 Args.hasArg(options::OPT_mkernel) ||
966 Args.hasArg(options::OPT_fapple_kext))
967 CmdArgs.push_back("-disable-red-zone");
968
969 if (!Args.hasFlag(options::OPT_mimplicit_float,
970 options::OPT_mno_implicit_float, true))
971 CmdArgs.push_back("-no-implicit-float");
972
Craig Topper92fc2df2014-05-17 16:56:41 +0000973 const char *ABIName = nullptr;
Tim Northovera2ee4332014-03-29 15:09:45 +0000974 if (Arg *A = Args.getLastArg(options::OPT_mabi_EQ))
975 ABIName = A->getValue();
976 else if (Triple.isOSDarwin())
977 ABIName = "darwinpcs";
978 else
979 ABIName = "aapcs";
980
981 CmdArgs.push_back("-target-abi");
982 CmdArgs.push_back(ABIName);
983
Bradley Smith9ff64332014-10-13 10:16:06 +0000984 if (Arg *A = Args.getLastArg(options::OPT_mfix_cortex_a53_835769,
985 options::OPT_mno_fix_cortex_a53_835769)) {
986 CmdArgs.push_back("-backend-option");
987 if (A->getOption().matches(options::OPT_mfix_cortex_a53_835769))
988 CmdArgs.push_back("-aarch64-fix-cortex-a53-835769=1");
989 else
990 CmdArgs.push_back("-aarch64-fix-cortex-a53-835769=0");
Bradley Smith04ee8aa2014-10-16 16:35:14 +0000991 } else if (Triple.getEnvironment() == llvm::Triple::Android) {
992 // Enabled A53 errata (835769) workaround by default on android
993 CmdArgs.push_back("-backend-option");
994 CmdArgs.push_back("-aarch64-fix-cortex-a53-835769=1");
Bradley Smith9ff64332014-10-13 10:16:06 +0000995 }
996
Ahmed Bougacha256a8692015-04-11 00:10:44 +0000997 // Forward the -mglobal-merge option for explicit control over the pass.
Bob Wilsonbdd2b3c2014-05-29 19:43:02 +0000998 if (Arg *A = Args.getLastArg(options::OPT_mglobal_merge,
999 options::OPT_mno_global_merge)) {
Ahmed Bougacha256a8692015-04-11 00:10:44 +00001000 CmdArgs.push_back("-backend-option");
Bob Wilsonbdd2b3c2014-05-29 19:43:02 +00001001 if (A->getOption().matches(options::OPT_mno_global_merge))
Ahmed Bougacha256a8692015-04-11 00:10:44 +00001002 CmdArgs.push_back("-aarch64-global-merge=false");
1003 else
1004 CmdArgs.push_back("-aarch64-global-merge=true");
Bob Wilsonbdd2b3c2014-05-29 19:43:02 +00001005 }
Tim Northovera2ee4332014-03-29 15:09:45 +00001006}
1007
Simon Atanasyan3b7589a2012-04-07 22:09:23 +00001008// Get CPU and ABI names. They are not independent
1009// so we have to calculate them together.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001010void mips::getMipsCPUAndABI(const ArgList &Args, const llvm::Triple &Triple,
1011 StringRef &CPUName, StringRef &ABIName) {
Simon Atanasyan1a3665b62014-01-27 13:59:04 +00001012 const char *DefMips32CPU = "mips32r2";
1013 const char *DefMips64CPU = "mips64r2";
Akira Hatanaka37fd9e92011-09-26 21:07:52 +00001014
Daniel Sanders2bf13662014-07-10 14:40:57 +00001015 // MIPS32r6 is the default for mips(el)?-img-linux-gnu and MIPS64r6 is the
1016 // default for mips64(el)?-img-linux-gnu.
1017 if (Triple.getVendor() == llvm::Triple::ImaginationTechnologies &&
1018 Triple.getEnvironment() == llvm::Triple::GNU) {
1019 DefMips32CPU = "mips32r6";
1020 DefMips64CPU = "mips64r6";
1021 }
Renato Golin7c542b42015-07-27 23:44:45 +00001022
Petar Jovanovic9fe32cd2015-07-17 12:57:30 +00001023 // MIPS64r6 is the default for Android MIPS64 (mips64el-linux-android).
1024 if (Triple.getEnvironment() == llvm::Triple::Android)
1025 DefMips64CPU = "mips64r6";
Daniel Sanders2bf13662014-07-10 14:40:57 +00001026
Brad Smithba26f582015-01-06 02:53:17 +00001027 // MIPS3 is the default for mips64*-unknown-openbsd.
1028 if (Triple.getOS() == llvm::Triple::OpenBSD)
1029 DefMips64CPU = "mips3";
1030
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001031 if (Arg *A = Args.getLastArg(options::OPT_march_EQ, options::OPT_mcpu_EQ))
Simon Atanasyane0cc7c72013-10-09 12:12:24 +00001032 CPUName = A->getValue();
Simon Atanasyan464a7f72012-09-10 08:32:41 +00001033
Simon Atanasyan4938ddb2013-04-21 13:30:10 +00001034 if (Arg *A = Args.getLastArg(options::OPT_mabi_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00001035 ABIName = A->getValue();
Simon Atanasyan4938ddb2013-04-21 13:30:10 +00001036 // Convert a GNU style Mips ABI name to the name
1037 // accepted by LLVM Mips backend.
1038 ABIName = llvm::StringSwitch<llvm::StringRef>(ABIName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001039 .Case("32", "o32")
1040 .Case("64", "n64")
1041 .Default(ABIName);
Simon Atanasyan4938ddb2013-04-21 13:30:10 +00001042 }
Simon Atanasyan464a7f72012-09-10 08:32:41 +00001043
1044 // Setup default CPU and ABI names.
1045 if (CPUName.empty() && ABIName.empty()) {
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001046 switch (Triple.getArch()) {
Simon Atanasyan464a7f72012-09-10 08:32:41 +00001047 default:
1048 llvm_unreachable("Unexpected triple arch name");
1049 case llvm::Triple::mips:
1050 case llvm::Triple::mipsel:
1051 CPUName = DefMips32CPU;
1052 break;
1053 case llvm::Triple::mips64:
1054 case llvm::Triple::mips64el:
1055 CPUName = DefMips64CPU;
1056 break;
1057 }
1058 }
1059
Simon Atanasyana42a84e2014-07-02 13:20:36 +00001060 if (ABIName.empty()) {
1061 // Deduce ABI name from the target triple.
1062 if (Triple.getArch() == llvm::Triple::mips ||
1063 Triple.getArch() == llvm::Triple::mipsel)
1064 ABIName = "o32";
1065 else
1066 ABIName = "n64";
1067 }
1068
1069 if (CPUName.empty()) {
Simon Atanasyan464a7f72012-09-10 08:32:41 +00001070 // Deduce CPU name from ABI name.
1071 CPUName = llvm::StringSwitch<const char *>(ABIName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001072 .Cases("o32", "eabi", DefMips32CPU)
1073 .Cases("n32", "n64", DefMips64CPU)
1074 .Default("");
Simon Atanasyan464a7f72012-09-10 08:32:41 +00001075 }
Simon Atanasyanc92717f2014-07-23 09:27:10 +00001076
1077 // FIXME: Warn on inconsistent use of -march and -mabi.
Simon Atanasyan3b7589a2012-04-07 22:09:23 +00001078}
1079
Vasileios Kalintiris712f0882015-10-02 14:38:23 +00001080std::string mips::getMipsABILibSuffix(const ArgList &Args,
1081 const llvm::Triple &Triple) {
1082 StringRef CPUName, ABIName;
1083 tools::mips::getMipsCPUAndABI(Args, Triple, CPUName, ABIName);
1084 return llvm::StringSwitch<std::string>(ABIName)
1085 .Case("o32", "")
1086 .Case("n32", "32")
1087 .Case("n64", "64");
1088}
1089
Simon Atanasyan0da400c2013-02-27 14:55:49 +00001090// Convert ABI name to the GNU tools acceptable variant.
1091static StringRef getGnuCompatibleMipsABIName(StringRef ABI) {
1092 return llvm::StringSwitch<llvm::StringRef>(ABI)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001093 .Case("o32", "32")
1094 .Case("n64", "64")
1095 .Default(ABI);
Simon Atanasyan0da400c2013-02-27 14:55:49 +00001096}
1097
Simon Atanasyan590ad8f2012-06-02 15:06:29 +00001098// Select the MIPS float ABI as determined by -msoft-float, -mhard-float,
1099// and -mfloat-abi=.
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001100static mips::FloatABI getMipsFloatABI(const Driver &D, const ArgList &Args) {
1101 mips::FloatABI ABI = mips::FloatABI::Invalid;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001102 if (Arg *A =
1103 Args.getLastArg(options::OPT_msoft_float, options::OPT_mhard_float,
1104 options::OPT_mfloat_abi_EQ)) {
Eric Christopher0b26a612010-03-02 02:41:08 +00001105 if (A->getOption().matches(options::OPT_msoft_float))
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001106 ABI = mips::FloatABI::Soft;
Eric Christopher0b26a612010-03-02 02:41:08 +00001107 else if (A->getOption().matches(options::OPT_mhard_float))
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001108 ABI = mips::FloatABI::Hard;
Akira Hatanaka6976ec82012-03-23 23:07:09 +00001109 else {
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001110 ABI = llvm::StringSwitch<mips::FloatABI>(A->getValue())
1111 .Case("soft", mips::FloatABI::Soft)
1112 .Case("hard", mips::FloatABI::Hard)
1113 .Default(mips::FloatABI::Invalid);
1114 if (ABI == mips::FloatABI::Invalid && !StringRef(A->getValue()).empty()) {
Simon Atanasyan590ad8f2012-06-02 15:06:29 +00001115 D.Diag(diag::err_drv_invalid_mfloat_abi) << A->getAsString(Args);
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001116 ABI = mips::FloatABI::Hard;
Akira Hatanaka6976ec82012-03-23 23:07:09 +00001117 }
1118 }
Eric Christopher0b26a612010-03-02 02:41:08 +00001119 }
1120
1121 // If unspecified, choose the default based on the platform.
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001122 if (ABI == mips::FloatABI::Invalid) {
Akira Hatanaka6976ec82012-03-23 23:07:09 +00001123 // Assume "hard", because it's a default value used by gcc.
1124 // When we start to recognize specific target MIPS processors,
1125 // we will be able to select the default more correctly.
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001126 ABI = mips::FloatABI::Hard;
Eric Christopher0b26a612010-03-02 02:41:08 +00001127 }
1128
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001129 assert(ABI != mips::FloatABI::Invalid && "must select an ABI");
1130 return ABI;
Simon Atanasyan590ad8f2012-06-02 15:06:29 +00001131}
1132
Simon Atanasyan9b1932d2012-07-05 18:51:43 +00001133static void AddTargetFeature(const ArgList &Args,
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001134 std::vector<const char *> &Features,
1135 OptSpecifier OnOpt, OptSpecifier OffOpt,
Simon Atanasyan9b1932d2012-07-05 18:51:43 +00001136 StringRef FeatureName) {
1137 if (Arg *A = Args.getLastArg(OnOpt, OffOpt)) {
Simon Atanasyan9b1932d2012-07-05 18:51:43 +00001138 if (A->getOption().matches(OnOpt))
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001139 Features.push_back(Args.MakeArgString("+" + FeatureName));
Simon Atanasyan9b1932d2012-07-05 18:51:43 +00001140 else
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001141 Features.push_back(Args.MakeArgString("-" + FeatureName));
Simon Atanasyan9b1932d2012-07-05 18:51:43 +00001142 }
1143}
1144
Daniel Sanders379d44b2014-07-16 11:52:23 +00001145static void getMIPSTargetFeatures(const Driver &D, const llvm::Triple &Triple,
1146 const ArgList &Args,
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001147 std::vector<const char *> &Features) {
Daniel Sanders379d44b2014-07-16 11:52:23 +00001148 StringRef CPUName;
1149 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00001150 mips::getMipsCPUAndABI(Args, Triple, CPUName, ABIName);
Daniel Sanders379d44b2014-07-16 11:52:23 +00001151 ABIName = getGnuCompatibleMipsABIName(ABIName);
1152
Daniel Sandersfeb61302014-08-08 15:47:17 +00001153 AddTargetFeature(Args, Features, options::OPT_mno_abicalls,
1154 options::OPT_mabicalls, "noabicalls");
Daniel Sanderse805f442014-08-08 13:44:50 +00001155
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001156 mips::FloatABI FloatABI = getMipsFloatABI(D, Args);
1157 if (FloatABI == mips::FloatABI::Soft) {
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001158 // FIXME: Note, this is a hack. We need to pass the selected float
1159 // mode to the MipsTargetInfoBase to define appropriate macros there.
1160 // Now it is the only method.
1161 Features.push_back("+soft-float");
1162 }
1163
Simon Atanasyan22127ce2013-09-24 09:09:16 +00001164 if (Arg *A = Args.getLastArg(options::OPT_mnan_EQ)) {
Matheus Almeida602bff32014-05-07 16:16:07 +00001165 StringRef Val = StringRef(A->getValue());
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00001166 if (Val == "2008") {
1167 if (mips::getSupportedNanEncoding(CPUName) & mips::Nan2008)
1168 Features.push_back("+nan2008");
1169 else {
1170 Features.push_back("-nan2008");
1171 D.Diag(diag::warn_target_unsupported_nan2008) << CPUName;
1172 }
1173 } else if (Val == "legacy") {
1174 if (mips::getSupportedNanEncoding(CPUName) & mips::NanLegacy)
1175 Features.push_back("-nan2008");
1176 else {
1177 Features.push_back("+nan2008");
1178 D.Diag(diag::warn_target_unsupported_nanlegacy) << CPUName;
1179 }
1180 } else
Matheus Almeida602bff32014-05-07 16:16:07 +00001181 D.Diag(diag::err_drv_unsupported_option_argument)
1182 << A->getOption().getName() << Val;
Simon Atanasyan22127ce2013-09-24 09:09:16 +00001183 }
1184
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001185 AddTargetFeature(Args, Features, options::OPT_msingle_float,
1186 options::OPT_mdouble_float, "single-float");
1187 AddTargetFeature(Args, Features, options::OPT_mips16, options::OPT_mno_mips16,
1188 "mips16");
1189 AddTargetFeature(Args, Features, options::OPT_mmicromips,
1190 options::OPT_mno_micromips, "micromips");
1191 AddTargetFeature(Args, Features, options::OPT_mdsp, options::OPT_mno_dsp,
1192 "dsp");
1193 AddTargetFeature(Args, Features, options::OPT_mdspr2, options::OPT_mno_dspr2,
1194 "dspr2");
1195 AddTargetFeature(Args, Features, options::OPT_mmsa, options::OPT_mno_msa,
1196 "msa");
Daniel Sanders379d44b2014-07-16 11:52:23 +00001197
1198 // Add the last -mfp32/-mfpxx/-mfp64 or if none are given and the ABI is O32
1199 // pass -mfpxx
1200 if (Arg *A = Args.getLastArg(options::OPT_mfp32, options::OPT_mfpxx,
1201 options::OPT_mfp64)) {
1202 if (A->getOption().matches(options::OPT_mfp32))
1203 Features.push_back(Args.MakeArgString("-fp64"));
1204 else if (A->getOption().matches(options::OPT_mfpxx)) {
1205 Features.push_back(Args.MakeArgString("+fpxx"));
1206 Features.push_back(Args.MakeArgString("+nooddspreg"));
1207 } else
1208 Features.push_back(Args.MakeArgString("+fp64"));
Toma Tabacu94ea6862015-06-16 13:54:13 +00001209 } else if (mips::shouldUseFPXX(Args, Triple, CPUName, ABIName, FloatABI)) {
Daniel Sanders2e9427a2014-07-16 09:57:54 +00001210 Features.push_back(Args.MakeArgString("+fpxx"));
1211 Features.push_back(Args.MakeArgString("+nooddspreg"));
1212 }
Daniel Sanders379d44b2014-07-16 11:52:23 +00001213
Daniel Sanders28e5d392014-07-10 10:39:51 +00001214 AddTargetFeature(Args, Features, options::OPT_mno_odd_spreg,
1215 options::OPT_modd_spreg, "nooddspreg");
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001216}
1217
Simon Atanasyan590ad8f2012-06-02 15:06:29 +00001218void Clang::AddMIPSTargetArgs(const ArgList &Args,
Simon Atanasyanf0087242013-04-14 14:07:41 +00001219 ArgStringList &CmdArgs) const {
Simon Atanasyan590ad8f2012-06-02 15:06:29 +00001220 const Driver &D = getToolChain().getDriver();
1221 StringRef CPUName;
1222 StringRef ABIName;
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001223 const llvm::Triple &Triple = getToolChain().getTriple();
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00001224 mips::getMipsCPUAndABI(Args, Triple, CPUName, ABIName);
Simon Atanasyan590ad8f2012-06-02 15:06:29 +00001225
1226 CmdArgs.push_back("-target-abi");
1227 CmdArgs.push_back(ABIName.data());
1228
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001229 mips::FloatABI ABI = getMipsFloatABI(D, Args);
1230 if (ABI == mips::FloatABI::Soft) {
Eric Christopher0b26a612010-03-02 02:41:08 +00001231 // Floating point operations and argument passing are soft.
Eric Christopher0b26a612010-03-02 02:41:08 +00001232 CmdArgs.push_back("-msoft-float");
Akira Hatanaka6976ec82012-03-23 23:07:09 +00001233 CmdArgs.push_back("-mfloat-abi");
1234 CmdArgs.push_back("soft");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001235 } else {
Akira Hatanaka6976ec82012-03-23 23:07:09 +00001236 // Floating point operations and argument passing are hard.
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001237 assert(ABI == mips::FloatABI::Hard && "Invalid float abi!");
Akira Hatanaka6976ec82012-03-23 23:07:09 +00001238 CmdArgs.push_back("-mfloat-abi");
1239 CmdArgs.push_back("hard");
Eric Christopher0b26a612010-03-02 02:41:08 +00001240 }
Simon Atanasyan6f23fa02012-07-05 14:19:39 +00001241
Simon Atanasyan2eaec512012-12-01 18:27:21 +00001242 if (Arg *A = Args.getLastArg(options::OPT_mxgot, options::OPT_mno_xgot)) {
1243 if (A->getOption().matches(options::OPT_mxgot)) {
1244 CmdArgs.push_back("-mllvm");
1245 CmdArgs.push_back("-mxgot");
1246 }
1247 }
1248
Simon Atanasyanc580b322013-05-11 06:33:44 +00001249 if (Arg *A = Args.getLastArg(options::OPT_mldc1_sdc1,
1250 options::OPT_mno_ldc1_sdc1)) {
1251 if (A->getOption().matches(options::OPT_mno_ldc1_sdc1)) {
1252 CmdArgs.push_back("-mllvm");
1253 CmdArgs.push_back("-mno-ldc1-sdc1");
1254 }
1255 }
1256
Akira Hatanaka0aa60ef2013-07-19 18:58:48 +00001257 if (Arg *A = Args.getLastArg(options::OPT_mcheck_zero_division,
1258 options::OPT_mno_check_zero_division)) {
1259 if (A->getOption().matches(options::OPT_mno_check_zero_division)) {
1260 CmdArgs.push_back("-mllvm");
1261 CmdArgs.push_back("-mno-check-zero-division");
1262 }
1263 }
1264
Simon Atanasyanec4b1c12012-08-27 20:55:56 +00001265 if (Arg *A = Args.getLastArg(options::OPT_G)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00001266 StringRef v = A->getValue();
Simon Atanasyanec4b1c12012-08-27 20:55:56 +00001267 CmdArgs.push_back("-mllvm");
1268 CmdArgs.push_back(Args.MakeArgString("-mips-ssection-threshold=" + v));
1269 A->claim();
1270 }
Eric Christopher0b26a612010-03-02 02:41:08 +00001271}
1272
Hal Finkel8eb59282012-06-11 22:35:19 +00001273/// getPPCTargetCPU - Get the (LLVM) name of the PowerPC cpu we are targeting.
1274static std::string getPPCTargetCPU(const ArgList &Args) {
1275 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00001276 StringRef CPUName = A->getValue();
Hal Finkel8eb59282012-06-11 22:35:19 +00001277
1278 if (CPUName == "native") {
1279 std::string CPU = llvm::sys::getHostCPUName();
1280 if (!CPU.empty() && CPU != "generic")
1281 return CPU;
1282 else
1283 return "";
1284 }
1285
1286 return llvm::StringSwitch<const char *>(CPUName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001287 .Case("common", "generic")
1288 .Case("440", "440")
1289 .Case("440fp", "440")
1290 .Case("450", "450")
1291 .Case("601", "601")
1292 .Case("602", "602")
1293 .Case("603", "603")
1294 .Case("603e", "603e")
1295 .Case("603ev", "603ev")
1296 .Case("604", "604")
1297 .Case("604e", "604e")
1298 .Case("620", "620")
1299 .Case("630", "pwr3")
1300 .Case("G3", "g3")
1301 .Case("7400", "7400")
1302 .Case("G4", "g4")
1303 .Case("7450", "7450")
1304 .Case("G4+", "g4+")
1305 .Case("750", "750")
1306 .Case("970", "970")
1307 .Case("G5", "g5")
1308 .Case("a2", "a2")
1309 .Case("a2q", "a2q")
1310 .Case("e500mc", "e500mc")
1311 .Case("e5500", "e5500")
1312 .Case("power3", "pwr3")
1313 .Case("power4", "pwr4")
1314 .Case("power5", "pwr5")
1315 .Case("power5x", "pwr5x")
1316 .Case("power6", "pwr6")
1317 .Case("power6x", "pwr6x")
1318 .Case("power7", "pwr7")
1319 .Case("power8", "pwr8")
1320 .Case("pwr3", "pwr3")
1321 .Case("pwr4", "pwr4")
1322 .Case("pwr5", "pwr5")
1323 .Case("pwr5x", "pwr5x")
1324 .Case("pwr6", "pwr6")
1325 .Case("pwr6x", "pwr6x")
1326 .Case("pwr7", "pwr7")
1327 .Case("pwr8", "pwr8")
1328 .Case("powerpc", "ppc")
1329 .Case("powerpc64", "ppc64")
1330 .Case("powerpc64le", "ppc64le")
1331 .Default("");
Hal Finkel8eb59282012-06-11 22:35:19 +00001332 }
1333
1334 return "";
1335}
1336
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001337static void getPPCTargetFeatures(const ArgList &Args,
1338 std::vector<const char *> &Features) {
Sean Silva14facf32015-06-09 01:57:17 +00001339 for (const Arg *A : Args.filtered(options::OPT_m_ppc_Features_Group)) {
1340 StringRef Name = A->getOption().getName();
1341 A->claim();
Eric Christopher643bb6a2013-10-16 20:40:08 +00001342
1343 // Skip over "-m".
1344 assert(Name.startswith("m") && "Invalid feature name.");
1345 Name = Name.substr(1);
1346
1347 bool IsNegative = Name.startswith("no-");
1348 if (IsNegative)
1349 Name = Name.substr(3);
1350
1351 // Note that gcc calls this mfcrf and LLVM calls this mfocrf so we
1352 // pass the correct option to the backend while calling the frontend
1353 // option the same.
1354 // TODO: Change the LLVM backend option maybe?
1355 if (Name == "mfcrf")
1356 Name = "mfocrf";
1357
1358 Features.push_back(Args.MakeArgString((IsNegative ? "-" : "+") + Name));
1359 }
1360
1361 // Altivec is a bit weird, allow overriding of the Altivec feature here.
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001362 AddTargetFeature(Args, Features, options::OPT_faltivec,
1363 options::OPT_fno_altivec, "altivec");
Hal Finkel8eb59282012-06-11 22:35:19 +00001364}
1365
Ulrich Weigand8afad612014-07-28 13:17:52 +00001366void Clang::AddPPCTargetArgs(const ArgList &Args,
1367 ArgStringList &CmdArgs) const {
1368 // Select the ABI to use.
1369 const char *ABIName = nullptr;
Eric Christopher71e5e3d2015-07-10 18:25:54 +00001370 if (getToolChain().getTriple().isOSLinux())
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001371 switch (getToolChain().getArch()) {
Hal Finkel0d0a1a52015-03-11 19:14:15 +00001372 case llvm::Triple::ppc64: {
1373 // When targeting a processor that supports QPX, or if QPX is
1374 // specifically enabled, default to using the ABI that supports QPX (so
1375 // long as it is not specifically disabled).
1376 bool HasQPX = false;
1377 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ))
1378 HasQPX = A->getValue() == StringRef("a2q");
1379 HasQPX = Args.hasFlag(options::OPT_mqpx, options::OPT_mno_qpx, HasQPX);
1380 if (HasQPX) {
1381 ABIName = "elfv1-qpx";
1382 break;
1383 }
1384
Ulrich Weigand8afad612014-07-28 13:17:52 +00001385 ABIName = "elfv1";
1386 break;
Hal Finkel0d0a1a52015-03-11 19:14:15 +00001387 }
Ulrich Weigand8afad612014-07-28 13:17:52 +00001388 case llvm::Triple::ppc64le:
1389 ABIName = "elfv2";
1390 break;
1391 default:
1392 break;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001393 }
Ulrich Weigand8afad612014-07-28 13:17:52 +00001394
Eric Christopher71e5e3d2015-07-10 18:25:54 +00001395 if (Arg *A = Args.getLastArg(options::OPT_mabi_EQ))
1396 // The ppc64 linux abis are all "altivec" abis by default. Accept and ignore
1397 // the option if given as we don't have backend support for any targets
1398 // that don't use the altivec abi.
1399 if (StringRef(A->getValue()) != "altivec")
1400 ABIName = A->getValue();
1401
Ulrich Weigand8afad612014-07-28 13:17:52 +00001402 if (ABIName) {
1403 CmdArgs.push_back("-target-abi");
1404 CmdArgs.push_back(ABIName);
1405 }
1406}
1407
1408bool ppc::hasPPCAbiArg(const ArgList &Args, const char *Value) {
1409 Arg *A = Args.getLastArg(options::OPT_mabi_EQ);
1410 return A && (A->getValue() == StringRef(Value));
1411}
1412
Tom Stellard6674c702013-04-01 20:56:53 +00001413/// Get the (LLVM) name of the R600 gpu we are targeting.
1414static std::string getR600TargetGPU(const ArgList &Args) {
1415 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ)) {
Benjamin Kramerb2ccade2013-10-21 12:33:55 +00001416 const char *GPUName = A->getValue();
Tom Stellard6674c702013-04-01 20:56:53 +00001417 return llvm::StringSwitch<const char *>(GPUName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001418 .Cases("rv630", "rv635", "r600")
1419 .Cases("rv610", "rv620", "rs780", "rs880")
1420 .Case("rv740", "rv770")
1421 .Case("palm", "cedar")
1422 .Cases("sumo", "sumo2", "sumo")
1423 .Case("hemlock", "cypress")
1424 .Case("aruba", "cayman")
1425 .Default(GPUName);
Tom Stellard6674c702013-04-01 20:56:53 +00001426 }
1427 return "";
1428}
1429
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001430void Clang::AddSparcTargetArgs(const ArgList &Args,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001431 ArgStringList &CmdArgs) const {
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001432 const Driver &D = getToolChain().getDriver();
James Y Knightb2406522015-06-15 20:51:24 +00001433 std::string Triple = getToolChain().ComputeEffectiveClangTriple(Args);
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001434
James Y Knightb2406522015-06-15 20:51:24 +00001435 bool SoftFloatABI = false;
1436 if (Arg *A =
1437 Args.getLastArg(options::OPT_msoft_float, options::OPT_mhard_float)) {
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001438 if (A->getOption().matches(options::OPT_msoft_float))
James Y Knightb2406522015-06-15 20:51:24 +00001439 SoftFloatABI = true;
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001440 }
1441
James Y Knightb2406522015-06-15 20:51:24 +00001442 // Only the hard-float ABI on Sparc is standardized, and it is the
1443 // default. GCC also supports a nonstandard soft-float ABI mode, and
1444 // perhaps LLVM should implement that, too. However, since llvm
1445 // currently does not support Sparc soft-float, at all, display an
1446 // error if it's requested.
1447 if (SoftFloatABI) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001448 D.Diag(diag::err_drv_unsupported_opt_for_target) << "-msoft-float"
1449 << Triple;
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001450 }
1451}
1452
Richard Sandiford4652d892013-07-19 16:51:51 +00001453static const char *getSystemZTargetCPU(const ArgList &Args) {
1454 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ))
1455 return A->getValue();
1456 return "z10";
1457}
1458
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00001459static void getSystemZTargetFeatures(const ArgList &Args,
1460 std::vector<const char *> &Features) {
1461 // -m(no-)htm overrides use of the transactional-execution facility.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001462 if (Arg *A = Args.getLastArg(options::OPT_mhtm, options::OPT_mno_htm)) {
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00001463 if (A->getOption().matches(options::OPT_mhtm))
1464 Features.push_back("+transactional-execution");
1465 else
1466 Features.push_back("-transactional-execution");
1467 }
Ulrich Weigand66ff51b2015-05-05 19:35:52 +00001468 // -m(no-)vx overrides use of the vector facility.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001469 if (Arg *A = Args.getLastArg(options::OPT_mvx, options::OPT_mno_vx)) {
Ulrich Weigand66ff51b2015-05-05 19:35:52 +00001470 if (A->getOption().matches(options::OPT_mvx))
1471 Features.push_back("+vector");
1472 else
1473 Features.push_back("-vector");
1474 }
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00001475}
1476
Chandler Carruth953fb082013-01-13 11:46:33 +00001477static const char *getX86TargetCPU(const ArgList &Args,
1478 const llvm::Triple &Triple) {
1479 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ)) {
Jim Grosbach82eee262013-11-16 00:53:35 +00001480 if (StringRef(A->getValue()) != "native") {
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00001481 if (Triple.isOSDarwin() && Triple.getArchName() == "x86_64h")
Jim Grosbach82eee262013-11-16 00:53:35 +00001482 return "core-avx2";
1483
Chandler Carruth953fb082013-01-13 11:46:33 +00001484 return A->getValue();
Jim Grosbach82eee262013-11-16 00:53:35 +00001485 }
Chandler Carruth953fb082013-01-13 11:46:33 +00001486
1487 // FIXME: Reject attempts to use -march=native unless the target matches
1488 // the host.
1489 //
1490 // FIXME: We should also incorporate the detected target features for use
1491 // with -native.
1492 std::string CPU = llvm::sys::getHostCPUName();
1493 if (!CPU.empty() && CPU != "generic")
1494 return Args.MakeArgString(CPU);
1495 }
1496
Reid Kleckner3123eff2015-06-30 16:32:04 +00001497 if (const Arg *A = Args.getLastArg(options::OPT__SLASH_arch)) {
1498 // Mapping built by referring to X86TargetInfo::getDefaultFeatures().
1499 StringRef Arch = A->getValue();
1500 const char *CPU;
1501 if (Triple.getArch() == llvm::Triple::x86) {
1502 CPU = llvm::StringSwitch<const char *>(Arch)
1503 .Case("IA32", "i386")
1504 .Case("SSE", "pentium3")
1505 .Case("SSE2", "pentium4")
1506 .Case("AVX", "sandybridge")
1507 .Case("AVX2", "haswell")
1508 .Default(nullptr);
1509 } else {
1510 CPU = llvm::StringSwitch<const char *>(Arch)
1511 .Case("AVX", "sandybridge")
1512 .Case("AVX2", "haswell")
1513 .Default(nullptr);
1514 }
1515 if (CPU)
1516 return CPU;
1517 }
1518
Chandler Carruth953fb082013-01-13 11:46:33 +00001519 // Select the default CPU if none was given (or detection failed).
1520
1521 if (Triple.getArch() != llvm::Triple::x86_64 &&
1522 Triple.getArch() != llvm::Triple::x86)
Craig Topper92fc2df2014-05-17 16:56:41 +00001523 return nullptr; // This routine is only handling x86 targets.
Chandler Carruth953fb082013-01-13 11:46:33 +00001524
1525 bool Is64Bit = Triple.getArch() == llvm::Triple::x86_64;
1526
1527 // FIXME: Need target hooks.
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00001528 if (Triple.isOSDarwin()) {
Jim Grosbach82eee262013-11-16 00:53:35 +00001529 if (Triple.getArchName() == "x86_64h")
1530 return "core-avx2";
Chandler Carruth953fb082013-01-13 11:46:33 +00001531 return Is64Bit ? "core2" : "yonah";
Jim Grosbach82eee262013-11-16 00:53:35 +00001532 }
Chandler Carruth953fb082013-01-13 11:46:33 +00001533
Filipe Cabecinhas4b442572015-01-27 17:27:37 +00001534 // Set up default CPU name for PS4 compilers.
1535 if (Triple.isPS4CPU())
1536 return "btver2";
1537
Alexey Bataev286d1b92014-01-31 04:07:13 +00001538 // On Android use targets compatible with gcc
Chandler Carruth953fb082013-01-13 11:46:33 +00001539 if (Triple.getEnvironment() == llvm::Triple::Android)
Alexey Bataev286d1b92014-01-31 04:07:13 +00001540 return Is64Bit ? "x86-64" : "i686";
Chandler Carruth953fb082013-01-13 11:46:33 +00001541
Benjamin Kramerb2ccade2013-10-21 12:33:55 +00001542 // Everything else goes to x86-64 in 64-bit mode.
1543 if (Is64Bit)
1544 return "x86-64";
1545
1546 switch (Triple.getOS()) {
1547 case llvm::Triple::FreeBSD:
1548 case llvm::Triple::NetBSD:
1549 case llvm::Triple::OpenBSD:
1550 return "i486";
1551 case llvm::Triple::Haiku:
1552 return "i586";
1553 case llvm::Triple::Bitrig:
1554 return "i686";
1555 default:
1556 // Fallback to p4.
1557 return "pentium4";
1558 }
Chandler Carruth953fb082013-01-13 11:46:33 +00001559}
1560
Dan Gohmanc2853072015-09-03 22:51:53 +00001561/// Get the (LLVM) name of the WebAssembly cpu we are targeting.
1562static StringRef getWebAssemblyTargetCPU(const ArgList &Args) {
1563 // If we have -mcpu=, use that.
1564 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ)) {
1565 StringRef CPU = A->getValue();
1566
1567#ifdef __wasm__
1568 // Handle "native" by examining the host. "native" isn't meaningful when
1569 // cross compiling, so only support this when the host is also WebAssembly.
1570 if (CPU == "native")
1571 return llvm::sys::getHostCPUName();
1572#endif
1573
1574 return CPU;
1575 }
1576
1577 return "generic";
1578}
1579
Renato Golin7c542b42015-07-27 23:44:45 +00001580static std::string getCPUName(const ArgList &Args, const llvm::Triple &T,
1581 bool FromAs = false) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001582 switch (T.getArch()) {
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001583 default:
1584 return "";
1585
Amara Emerson703da2e2013-10-31 09:32:33 +00001586 case llvm::Triple::aarch64:
Christian Pirker9b019ae2014-02-25 13:51:00 +00001587 case llvm::Triple::aarch64_be:
Tim Northover573cbee2014-05-24 12:52:07 +00001588 return getAArch64TargetCPU(Args);
Quentin Colombetd9f26202014-04-15 00:27:35 +00001589
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001590 case llvm::Triple::arm:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00001591 case llvm::Triple::armeb:
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001592 case llvm::Triple::thumb:
Renato Goline17c5802015-07-27 23:44:42 +00001593 case llvm::Triple::thumbeb: {
1594 StringRef MArch, MCPU;
Renato Golin7c542b42015-07-27 23:44:45 +00001595 getARMArchCPUFromArgs(Args, MArch, MCPU, FromAs);
Renato Goline17c5802015-07-27 23:44:42 +00001596 return arm::getARMTargetCPU(MCPU, MArch, T);
1597 }
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001598 case llvm::Triple::mips:
1599 case llvm::Triple::mipsel:
1600 case llvm::Triple::mips64:
1601 case llvm::Triple::mips64el: {
1602 StringRef CPUName;
1603 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00001604 mips::getMipsCPUAndABI(Args, T, CPUName, ABIName);
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001605 return CPUName;
1606 }
1607
Artem Belevich0ff05cd2015-07-13 23:27:56 +00001608 case llvm::Triple::nvptx:
1609 case llvm::Triple::nvptx64:
1610 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ))
1611 return A->getValue();
1612 return "";
1613
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001614 case llvm::Triple::ppc:
1615 case llvm::Triple::ppc64:
1616 case llvm::Triple::ppc64le: {
1617 std::string TargetCPUName = getPPCTargetCPU(Args);
1618 // LLVM may default to generating code for the native CPU,
1619 // but, like gcc, we default to a more generic option for
1620 // each architecture. (except on Darwin)
1621 if (TargetCPUName.empty() && !T.isOSDarwin()) {
1622 if (T.getArch() == llvm::Triple::ppc64)
1623 TargetCPUName = "ppc64";
1624 else if (T.getArch() == llvm::Triple::ppc64le)
1625 TargetCPUName = "ppc64le";
1626 else
1627 TargetCPUName = "ppc";
1628 }
1629 return TargetCPUName;
1630 }
1631
1632 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00001633 case llvm::Triple::sparcel:
Roman Divackyb1ae3d42014-02-25 18:35:30 +00001634 case llvm::Triple::sparcv9:
1635 if (const Arg *A = Args.getLastArg(options::OPT_mcpu_EQ))
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001636 return A->getValue();
1637 return "";
1638
1639 case llvm::Triple::x86:
1640 case llvm::Triple::x86_64:
1641 return getX86TargetCPU(Args, T);
1642
1643 case llvm::Triple::hexagon:
Douglas Katzman54366072015-07-27 16:53:08 +00001644 return "hexagon" + toolchains::HexagonToolChain::GetTargetCPU(Args).str();
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001645
1646 case llvm::Triple::systemz:
1647 return getSystemZTargetCPU(Args);
1648
1649 case llvm::Triple::r600:
Tom Stellardd8e38a32015-01-06 20:34:47 +00001650 case llvm::Triple::amdgcn:
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001651 return getR600TargetGPU(Args);
Dan Gohmanc2853072015-09-03 22:51:53 +00001652
1653 case llvm::Triple::wasm32:
1654 case llvm::Triple::wasm64:
1655 return getWebAssemblyTargetCPU(Args);
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001656 }
1657}
1658
Alp Tokerce365ca2013-12-02 12:43:03 +00001659static void AddGoldPlugin(const ToolChain &ToolChain, const ArgList &Args,
1660 ArgStringList &CmdArgs) {
1661 // Tell the linker to load the plugin. This has to come before AddLinkerInputs
1662 // as gold requires -plugin to come before any -plugin-opt that -Wl might
1663 // forward.
1664 CmdArgs.push_back("-plugin");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001665 std::string Plugin =
1666 ToolChain.getDriver().Dir + "/../lib" CLANG_LIBDIR_SUFFIX "/LLVMgold.so";
Alp Tokerce365ca2013-12-02 12:43:03 +00001667 CmdArgs.push_back(Args.MakeArgString(Plugin));
1668
1669 // Try to pass driver level flags relevant to LTO code generation down to
1670 // the plugin.
1671
1672 // Handle flags for selecting CPU variants.
1673 std::string CPU = getCPUName(Args, ToolChain.getTriple());
1674 if (!CPU.empty())
1675 CmdArgs.push_back(Args.MakeArgString(Twine("-plugin-opt=mcpu=") + CPU));
1676}
1677
Sanjay Patel2987c292015-06-11 14:53:41 +00001678/// This is a helper function for validating the optional refinement step
1679/// parameter in reciprocal argument strings. Return false if there is an error
1680/// parsing the refinement step. Otherwise, return true and set the Position
1681/// of the refinement step in the input string.
Craig Topper3db9ba42015-09-21 00:20:04 +00001682static bool getRefinementStep(StringRef In, const Driver &D,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001683 const Arg &A, size_t &Position) {
Sanjay Patel2987c292015-06-11 14:53:41 +00001684 const char RefinementStepToken = ':';
1685 Position = In.find(RefinementStepToken);
1686 if (Position != StringRef::npos) {
1687 StringRef Option = A.getOption().getName();
1688 StringRef RefStep = In.substr(Position + 1);
1689 // Allow exactly one numeric character for the additional refinement
1690 // step parameter. This is reasonable for all currently-supported
1691 // operations and architectures because we would expect that a larger value
1692 // of refinement steps would cause the estimate "optimization" to
1693 // under-perform the native operation. Also, if the estimate does not
1694 // converge quickly, it probably will not ever converge, so further
1695 // refinement steps will not produce a better answer.
1696 if (RefStep.size() != 1) {
1697 D.Diag(diag::err_drv_invalid_value) << Option << RefStep;
1698 return false;
1699 }
1700 char RefStepChar = RefStep[0];
1701 if (RefStepChar < '0' || RefStepChar > '9') {
1702 D.Diag(diag::err_drv_invalid_value) << Option << RefStep;
1703 return false;
1704 }
1705 }
1706 return true;
1707}
1708
1709/// The -mrecip flag requires processing of many optional parameters.
1710static void ParseMRecip(const Driver &D, const ArgList &Args,
1711 ArgStringList &OutStrings) {
1712 StringRef DisabledPrefixIn = "!";
1713 StringRef DisabledPrefixOut = "!";
1714 StringRef EnabledPrefixOut = "";
1715 StringRef Out = "-mrecip=";
1716
1717 Arg *A = Args.getLastArg(options::OPT_mrecip, options::OPT_mrecip_EQ);
1718 if (!A)
1719 return;
1720
1721 unsigned NumOptions = A->getNumValues();
1722 if (NumOptions == 0) {
1723 // No option is the same as "all".
1724 OutStrings.push_back(Args.MakeArgString(Out + "all"));
1725 return;
1726 }
1727
1728 // Pass through "all", "none", or "default" with an optional refinement step.
1729 if (NumOptions == 1) {
1730 StringRef Val = A->getValue(0);
1731 size_t RefStepLoc;
1732 if (!getRefinementStep(Val, D, *A, RefStepLoc))
1733 return;
1734 StringRef ValBase = Val.slice(0, RefStepLoc);
1735 if (ValBase == "all" || ValBase == "none" || ValBase == "default") {
1736 OutStrings.push_back(Args.MakeArgString(Out + Val));
1737 return;
1738 }
1739 }
1740
1741 // Each reciprocal type may be enabled or disabled individually.
1742 // Check each input value for validity, concatenate them all back together,
1743 // and pass through.
1744
1745 llvm::StringMap<bool> OptionStrings;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001746 OptionStrings.insert(std::make_pair("divd", false));
1747 OptionStrings.insert(std::make_pair("divf", false));
1748 OptionStrings.insert(std::make_pair("vec-divd", false));
1749 OptionStrings.insert(std::make_pair("vec-divf", false));
1750 OptionStrings.insert(std::make_pair("sqrtd", false));
1751 OptionStrings.insert(std::make_pair("sqrtf", false));
1752 OptionStrings.insert(std::make_pair("vec-sqrtd", false));
1753 OptionStrings.insert(std::make_pair("vec-sqrtf", false));
Sanjay Patel2987c292015-06-11 14:53:41 +00001754
1755 for (unsigned i = 0; i != NumOptions; ++i) {
1756 StringRef Val = A->getValue(i);
1757
1758 bool IsDisabled = Val.startswith(DisabledPrefixIn);
1759 // Ignore the disablement token for string matching.
1760 if (IsDisabled)
1761 Val = Val.substr(1);
1762
1763 size_t RefStep;
1764 if (!getRefinementStep(Val, D, *A, RefStep))
1765 return;
1766
1767 StringRef ValBase = Val.slice(0, RefStep);
1768 llvm::StringMap<bool>::iterator OptionIter = OptionStrings.find(ValBase);
1769 if (OptionIter == OptionStrings.end()) {
1770 // Try again specifying float suffix.
1771 OptionIter = OptionStrings.find(ValBase.str() + 'f');
1772 if (OptionIter == OptionStrings.end()) {
1773 // The input name did not match any known option string.
1774 D.Diag(diag::err_drv_unknown_argument) << Val;
1775 return;
1776 }
1777 // The option was specified without a float or double suffix.
1778 // Make sure that the double entry was not already specified.
1779 // The float entry will be checked below.
1780 if (OptionStrings[ValBase.str() + 'd']) {
1781 D.Diag(diag::err_drv_invalid_value) << A->getOption().getName() << Val;
1782 return;
1783 }
1784 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001785
Sanjay Patel2987c292015-06-11 14:53:41 +00001786 if (OptionIter->second == true) {
1787 // Duplicate option specified.
1788 D.Diag(diag::err_drv_invalid_value) << A->getOption().getName() << Val;
1789 return;
1790 }
1791
1792 // Mark the matched option as found. Do not allow duplicate specifiers.
1793 OptionIter->second = true;
1794
1795 // If the precision was not specified, also mark the double entry as found.
1796 if (ValBase.back() != 'f' && ValBase.back() != 'd')
1797 OptionStrings[ValBase.str() + 'd'] = true;
1798
1799 // Build the output string.
1800 StringRef Prefix = IsDisabled ? DisabledPrefixOut : EnabledPrefixOut;
1801 Out = Args.MakeArgString(Out + Prefix + Val);
1802 if (i != NumOptions - 1)
1803 Out = Args.MakeArgString(Out + ",");
1804 }
1805
1806 OutStrings.push_back(Args.MakeArgString(Out));
1807}
1808
Eric Christopherc54920a2015-03-23 19:26:05 +00001809static void getX86TargetFeatures(const Driver &D, const llvm::Triple &Triple,
Jim Grosbach82eee262013-11-16 00:53:35 +00001810 const ArgList &Args,
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001811 std::vector<const char *> &Features) {
Craig Toppera8bd6002015-03-31 05:45:00 +00001812 // If -march=native, autodetect the feature list.
1813 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ)) {
1814 if (StringRef(A->getValue()) == "native") {
1815 llvm::StringMap<bool> HostFeatures;
1816 if (llvm::sys::getHostCPUFeatures(HostFeatures))
1817 for (auto &F : HostFeatures)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001818 Features.push_back(
1819 Args.MakeArgString((F.second ? "+" : "-") + F.first()));
Craig Toppera8bd6002015-03-31 05:45:00 +00001820 }
1821 }
1822
Jim Grosbach82eee262013-11-16 00:53:35 +00001823 if (Triple.getArchName() == "x86_64h") {
1824 // x86_64h implies quite a few of the more modern subtarget features
1825 // for Haswell class CPUs, but not all of them. Opt-out of a few.
1826 Features.push_back("-rdrnd");
1827 Features.push_back("-aes");
1828 Features.push_back("-pclmul");
1829 Features.push_back("-rtm");
1830 Features.push_back("-hle");
1831 Features.push_back("-fsgsbase");
1832 }
1833
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00001834 const llvm::Triple::ArchType ArchType = Triple.getArch();
Eric Christopherc54920a2015-03-23 19:26:05 +00001835 // Add features to be compatible with gcc for Android.
Alexey Bataev286d1b92014-01-31 04:07:13 +00001836 if (Triple.getEnvironment() == llvm::Triple::Android) {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00001837 if (ArchType == llvm::Triple::x86_64) {
Alexey Volkov54ff0802014-06-25 12:15:36 +00001838 Features.push_back("+sse4.2");
1839 Features.push_back("+popcnt");
1840 } else
1841 Features.push_back("+ssse3");
Alexey Bataev286d1b92014-01-31 04:07:13 +00001842 }
1843
Eric Christopherc54920a2015-03-23 19:26:05 +00001844 // Set features according to the -arch flag on MSVC.
Ehsan Akhgarieeb7e652014-07-15 18:27:51 +00001845 if (Arg *A = Args.getLastArg(options::OPT__SLASH_arch)) {
1846 StringRef Arch = A->getValue();
1847 bool ArchUsed = false;
1848 // First, look for flags that are shared in x86 and x86-64.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00001849 if (ArchType == llvm::Triple::x86_64 || ArchType == llvm::Triple::x86) {
Ehsan Akhgarieeb7e652014-07-15 18:27:51 +00001850 if (Arch == "AVX" || Arch == "AVX2") {
1851 ArchUsed = true;
1852 Features.push_back(Args.MakeArgString("+" + Arch.lower()));
1853 }
1854 }
1855 // Then, look for x86-specific flags.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00001856 if (ArchType == llvm::Triple::x86) {
Ehsan Akhgarieeb7e652014-07-15 18:27:51 +00001857 if (Arch == "IA32") {
1858 ArchUsed = true;
1859 } else if (Arch == "SSE" || Arch == "SSE2") {
1860 ArchUsed = true;
1861 Features.push_back(Args.MakeArgString("+" + Arch.lower()));
1862 }
1863 }
1864 if (!ArchUsed)
1865 D.Diag(clang::diag::warn_drv_unused_argument) << A->getAsString(Args);
1866 }
1867
Jim Grosbach82eee262013-11-16 00:53:35 +00001868 // Now add any that the user explicitly requested on the command line,
1869 // which may override the defaults.
Sean Silva14facf32015-06-09 01:57:17 +00001870 for (const Arg *A : Args.filtered(options::OPT_m_x86_Features_Group)) {
1871 StringRef Name = A->getOption().getName();
1872 A->claim();
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001873
1874 // Skip over "-m".
1875 assert(Name.startswith("m") && "Invalid feature name.");
1876 Name = Name.substr(1);
1877
1878 bool IsNegative = Name.startswith("no-");
1879 if (IsNegative)
1880 Name = Name.substr(3);
1881
1882 Features.push_back(Args.MakeArgString((IsNegative ? "-" : "+") + Name));
1883 }
1884}
1885
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00001886void Clang::AddX86TargetArgs(const ArgList &Args,
1887 ArgStringList &CmdArgs) const {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001888 if (!Args.hasFlag(options::OPT_mred_zone, options::OPT_mno_red_zone, true) ||
Daniel Dunbare2cf8f72009-09-10 22:59:57 +00001889 Args.hasArg(options::OPT_mkernel) ||
1890 Args.hasArg(options::OPT_fapple_kext))
Daniel Dunbar8bed86c2009-11-20 22:21:36 +00001891 CmdArgs.push_back("-disable-red-zone");
Daniel Dunbare2cf8f72009-09-10 22:59:57 +00001892
Bob Wilson2616e2e2013-02-10 16:01:41 +00001893 // Default to avoid implicit floating-point for kernel/kext code, but allow
1894 // that to be overridden with -mno-soft-float.
1895 bool NoImplicitFloat = (Args.hasArg(options::OPT_mkernel) ||
1896 Args.hasArg(options::OPT_fapple_kext));
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001897 if (Arg *A = Args.getLastArg(
1898 options::OPT_msoft_float, options::OPT_mno_soft_float,
1899 options::OPT_mimplicit_float, options::OPT_mno_implicit_float)) {
Bob Wilson2616e2e2013-02-10 16:01:41 +00001900 const Option &O = A->getOption();
1901 NoImplicitFloat = (O.matches(options::OPT_mno_implicit_float) ||
1902 O.matches(options::OPT_msoft_float));
1903 }
1904 if (NoImplicitFloat)
Daniel Dunbar8bed86c2009-11-20 22:21:36 +00001905 CmdArgs.push_back("-no-implicit-float");
Nico Weberad8e36c2014-05-13 11:11:24 +00001906
1907 if (Arg *A = Args.getLastArg(options::OPT_masm_EQ)) {
1908 StringRef Value = A->getValue();
1909 if (Value == "intel" || Value == "att") {
1910 CmdArgs.push_back("-mllvm");
1911 CmdArgs.push_back(Args.MakeArgString("-x86-asm-syntax=" + Value));
1912 } else {
1913 getToolChain().getDriver().Diag(diag::err_drv_unsupported_option_argument)
1914 << A->getOption().getName() << Value;
1915 }
1916 }
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00001917}
1918
Tony Linthicum76329bf2011-12-12 21:14:55 +00001919void Clang::AddHexagonTargetArgs(const ArgList &Args,
1920 ArgStringList &CmdArgs) const {
Matthew Curtis6b222782012-12-07 13:52:44 +00001921 CmdArgs.push_back("-mqdsp6-compat");
1922 CmdArgs.push_back("-Wreturn-type");
Tony Linthicum76329bf2011-12-12 21:14:55 +00001923
Douglas Katzman54366072015-07-27 16:53:08 +00001924 if (const char *v =
1925 toolchains::HexagonToolChain::GetSmallDataThreshold(Args)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001926 std::string SmallDataThreshold = "-hexagon-small-data-threshold=";
Ikhlas Ajbar522e6192015-05-14 13:52:08 +00001927 SmallDataThreshold += v;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001928 CmdArgs.push_back("-mllvm");
Ikhlas Ajbar522e6192015-05-14 13:52:08 +00001929 CmdArgs.push_back(Args.MakeArgString(SmallDataThreshold));
Tony Linthicum76329bf2011-12-12 21:14:55 +00001930 }
1931
Sirish Pande11ebc4e2012-05-10 20:19:54 +00001932 if (!Args.hasArg(options::OPT_fno_short_enums))
1933 CmdArgs.push_back("-fshort-enums");
1934 if (Args.getLastArg(options::OPT_mieee_rnd_near)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001935 CmdArgs.push_back("-mllvm");
1936 CmdArgs.push_back("-enable-hexagon-ieee-rnd-near");
Sirish Pande11ebc4e2012-05-10 20:19:54 +00001937 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001938 CmdArgs.push_back("-mllvm");
1939 CmdArgs.push_back("-machine-sink-split=0");
Tony Linthicum76329bf2011-12-12 21:14:55 +00001940}
1941
Kevin Qin110db6f2014-07-18 07:03:22 +00001942// Decode AArch64 features from string like +[no]featureA+[no]featureB+...
Craig Topperbf3e3272014-08-30 16:55:52 +00001943static bool DecodeAArch64Features(const Driver &D, StringRef text,
Kevin Qin110db6f2014-07-18 07:03:22 +00001944 std::vector<const char *> &Features) {
1945 SmallVector<StringRef, 8> Split;
1946 text.split(Split, StringRef("+"), -1, false);
1947
Benjamin Kramer72e64312015-09-24 14:48:49 +00001948 for (StringRef Feature : Split) {
Douglas Katzman2675d012015-06-29 19:12:56 +00001949 const char *result = llvm::StringSwitch<const char *>(Feature)
Kevin Qin110db6f2014-07-18 07:03:22 +00001950 .Case("fp", "+fp-armv8")
1951 .Case("simd", "+neon")
1952 .Case("crc", "+crc")
1953 .Case("crypto", "+crypto")
1954 .Case("nofp", "-fp-armv8")
1955 .Case("nosimd", "-neon")
1956 .Case("nocrc", "-crc")
1957 .Case("nocrypto", "-crypto")
1958 .Default(nullptr);
1959 if (result)
1960 Features.push_back(result);
Douglas Katzman2675d012015-06-29 19:12:56 +00001961 else if (Feature == "neon" || Feature == "noneon")
Kevin Qin110db6f2014-07-18 07:03:22 +00001962 D.Diag(diag::err_drv_no_neon_modifier);
1963 else
1964 return false;
1965 }
1966 return true;
1967}
1968
1969// Check if the CPU name and feature modifiers in -mcpu are legal. If yes,
1970// decode CPU and feature.
1971static bool DecodeAArch64Mcpu(const Driver &D, StringRef Mcpu, StringRef &CPU,
1972 std::vector<const char *> &Features) {
1973 std::pair<StringRef, StringRef> Split = Mcpu.split("+");
1974 CPU = Split.first;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001975 if (CPU == "cyclone" || CPU == "cortex-a53" || CPU == "cortex-a57" ||
1976 CPU == "cortex-a72") {
Kevin Qin110db6f2014-07-18 07:03:22 +00001977 Features.push_back("+neon");
1978 Features.push_back("+crc");
1979 Features.push_back("+crypto");
1980 } else if (CPU == "generic") {
1981 Features.push_back("+neon");
1982 } else {
1983 return false;
1984 }
1985
1986 if (Split.second.size() && !DecodeAArch64Features(D, Split.second, Features))
1987 return false;
1988
1989 return true;
1990}
1991
1992static bool
1993getAArch64ArchFeaturesFromMarch(const Driver &D, StringRef March,
1994 const ArgList &Args,
1995 std::vector<const char *> &Features) {
Gabor Ballabas36451492015-06-18 14:23:12 +00001996 std::string MarchLowerCase = March.lower();
1997 std::pair<StringRef, StringRef> Split = StringRef(MarchLowerCase).split("+");
Vladimir Sukhareve851e042015-04-16 15:53:09 +00001998
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001999 if (Split.first == "armv8-a" || Split.first == "armv8a") {
Vladimir Sukhareve851e042015-04-16 15:53:09 +00002000 // ok, no additional features.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002001 } else if (Split.first == "armv8.1-a" || Split.first == "armv8.1a") {
Vladimir Sukhareve851e042015-04-16 15:53:09 +00002002 Features.push_back("+v8.1a");
2003 } else {
Kevin Qin110db6f2014-07-18 07:03:22 +00002004 return false;
Vladimir Sukhareve851e042015-04-16 15:53:09 +00002005 }
Kevin Qin110db6f2014-07-18 07:03:22 +00002006
2007 if (Split.second.size() && !DecodeAArch64Features(D, Split.second, Features))
2008 return false;
2009
2010 return true;
2011}
2012
2013static bool
2014getAArch64ArchFeaturesFromMcpu(const Driver &D, StringRef Mcpu,
2015 const ArgList &Args,
2016 std::vector<const char *> &Features) {
2017 StringRef CPU;
Gabor Ballabas726ce7f2015-06-12 17:33:37 +00002018 std::string McpuLowerCase = Mcpu.lower();
2019 if (!DecodeAArch64Mcpu(D, McpuLowerCase, CPU, Features))
Kevin Qin110db6f2014-07-18 07:03:22 +00002020 return false;
2021
2022 return true;
2023}
2024
2025static bool
2026getAArch64MicroArchFeaturesFromMtune(const Driver &D, StringRef Mtune,
2027 const ArgList &Args,
2028 std::vector<const char *> &Features) {
Gabor Ballabasa24a1a42015-07-20 11:28:20 +00002029 std::string MtuneLowerCase = Mtune.lower();
Kevin Qin110db6f2014-07-18 07:03:22 +00002030 // Handle CPU name is 'native'.
Gabor Ballabasa24a1a42015-07-20 11:28:20 +00002031 if (MtuneLowerCase == "native")
2032 MtuneLowerCase = llvm::sys::getHostCPUName();
2033 if (MtuneLowerCase == "cyclone") {
Kevin Qin110db6f2014-07-18 07:03:22 +00002034 Features.push_back("+zcm");
2035 Features.push_back("+zcz");
2036 }
2037 return true;
2038}
2039
2040static bool
2041getAArch64MicroArchFeaturesFromMcpu(const Driver &D, StringRef Mcpu,
2042 const ArgList &Args,
2043 std::vector<const char *> &Features) {
2044 StringRef CPU;
2045 std::vector<const char *> DecodedFeature;
Gabor Ballabas726ce7f2015-06-12 17:33:37 +00002046 std::string McpuLowerCase = Mcpu.lower();
2047 if (!DecodeAArch64Mcpu(D, McpuLowerCase, CPU, DecodedFeature))
Kevin Qin110db6f2014-07-18 07:03:22 +00002048 return false;
2049
2050 return getAArch64MicroArchFeaturesFromMtune(D, CPU, Args, Features);
2051}
2052
Akira Hatanaka92500472015-07-27 19:29:04 +00002053static void getAArch64TargetFeatures(const Driver &D,
2054 const llvm::Triple &Triple,
2055 const ArgList &Args,
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002056 std::vector<const char *> &Features) {
Kevin Qin110db6f2014-07-18 07:03:22 +00002057 Arg *A;
2058 bool success = true;
2059 // Enable NEON by default.
2060 Features.push_back("+neon");
2061 if ((A = Args.getLastArg(options::OPT_march_EQ)))
2062 success = getAArch64ArchFeaturesFromMarch(D, A->getValue(), Args, Features);
2063 else if ((A = Args.getLastArg(options::OPT_mcpu_EQ)))
2064 success = getAArch64ArchFeaturesFromMcpu(D, A->getValue(), Args, Features);
Tim Northover642e7702014-11-10 21:17:23 +00002065 else if (Args.hasArg(options::OPT_arch))
2066 success = getAArch64ArchFeaturesFromMcpu(D, getAArch64TargetCPU(Args), Args,
2067 Features);
Kevin Qin110db6f2014-07-18 07:03:22 +00002068
2069 if (success && (A = Args.getLastArg(options::OPT_mtune_EQ)))
2070 success =
2071 getAArch64MicroArchFeaturesFromMtune(D, A->getValue(), Args, Features);
2072 else if (success && (A = Args.getLastArg(options::OPT_mcpu_EQ)))
2073 success =
2074 getAArch64MicroArchFeaturesFromMcpu(D, A->getValue(), Args, Features);
Tim Northover642e7702014-11-10 21:17:23 +00002075 else if (Args.hasArg(options::OPT_arch))
2076 success = getAArch64MicroArchFeaturesFromMcpu(D, getAArch64TargetCPU(Args),
2077 Args, Features);
Kevin Qin110db6f2014-07-18 07:03:22 +00002078
2079 if (!success)
2080 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
Amara Emerson04e2ecf2014-01-23 15:48:30 +00002081
2082 if (Args.getLastArg(options::OPT_mgeneral_regs_only)) {
2083 Features.push_back("-fp-armv8");
2084 Features.push_back("-crypto");
2085 Features.push_back("-neon");
2086 }
Bradley Smith418c5932014-05-02 15:17:51 +00002087
2088 // En/disable crc
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002089 if (Arg *A = Args.getLastArg(options::OPT_mcrc, options::OPT_mnocrc)) {
Bradley Smith418c5932014-05-02 15:17:51 +00002090 if (A->getOption().matches(options::OPT_mcrc))
2091 Features.push_back("+crc");
2092 else
2093 Features.push_back("-crc");
2094 }
Akira Hatanaka4e3c86f2015-07-25 00:18:00 +00002095
Akira Hatanaka085da7e2015-07-29 14:25:58 +00002096 if (Arg *A = Args.getLastArg(options::OPT_mno_unaligned_access,
2097 options::OPT_munaligned_access))
2098 if (A->getOption().matches(options::OPT_mno_unaligned_access))
2099 Features.push_back("+strict-align");
2100
Akira Hatanaka92500472015-07-27 19:29:04 +00002101 if (Args.hasArg(options::OPT_ffixed_x18) || Triple.isOSDarwin())
Akira Hatanaka4e3c86f2015-07-25 00:18:00 +00002102 Features.push_back("+reserve-x18");
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002103}
2104
Dan Gohmanc2853072015-09-03 22:51:53 +00002105static void getWebAssemblyTargetFeatures(const ArgList &Args,
2106 std::vector<const char *> &Features) {
2107 for (const Arg *A : Args.filtered(options::OPT_m_wasm_Features_Group)) {
2108 StringRef Name = A->getOption().getName();
2109 A->claim();
2110
2111 // Skip over "-m".
2112 assert(Name.startswith("m") && "Invalid feature name.");
2113 Name = Name.substr(1);
2114
2115 bool IsNegative = Name.startswith("no-");
2116 if (IsNegative)
2117 Name = Name.substr(3);
2118
2119 Features.push_back(Args.MakeArgString((IsNegative ? "-" : "+") + Name));
2120 }
2121}
2122
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00002123static void getTargetFeatures(const ToolChain &TC, const llvm::Triple &Triple,
Rafael Espindola9c6fb0f2013-11-23 14:36:40 +00002124 const ArgList &Args, ArgStringList &CmdArgs,
2125 bool ForAS) {
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00002126 const Driver &D = TC.getDriver();
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002127 std::vector<const char *> Features;
2128 switch (Triple.getArch()) {
2129 default:
2130 break;
2131 case llvm::Triple::mips:
2132 case llvm::Triple::mipsel:
2133 case llvm::Triple::mips64:
2134 case llvm::Triple::mips64el:
Daniel Sanders379d44b2014-07-16 11:52:23 +00002135 getMIPSTargetFeatures(D, Triple, Args, Features);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002136 break;
2137
2138 case llvm::Triple::arm:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00002139 case llvm::Triple::armeb:
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002140 case llvm::Triple::thumb:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00002141 case llvm::Triple::thumbeb:
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00002142 getARMTargetFeatures(TC, Triple, Args, Features, ForAS);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002143 break;
2144
2145 case llvm::Triple::ppc:
2146 case llvm::Triple::ppc64:
2147 case llvm::Triple::ppc64le:
2148 getPPCTargetFeatures(Args, Features);
2149 break;
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00002150 case llvm::Triple::systemz:
2151 getSystemZTargetFeatures(Args, Features);
2152 break;
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002153 case llvm::Triple::aarch64:
Christian Pirker9b019ae2014-02-25 13:51:00 +00002154 case llvm::Triple::aarch64_be:
Akira Hatanaka92500472015-07-27 19:29:04 +00002155 getAArch64TargetFeatures(D, Triple, Args, Features);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002156 break;
2157 case llvm::Triple::x86:
2158 case llvm::Triple::x86_64:
Ehsan Akhgarieeb7e652014-07-15 18:27:51 +00002159 getX86TargetFeatures(D, Triple, Args, Features);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002160 break;
Dan Gohmanc2853072015-09-03 22:51:53 +00002161 case llvm::Triple::wasm32:
2162 case llvm::Triple::wasm64:
2163 getWebAssemblyTargetFeatures(Args, Features);
2164 break;
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002165 }
Rafael Espindola43964802013-08-21 17:34:32 +00002166
2167 // Find the last of each feature.
2168 llvm::StringMap<unsigned> LastOpt;
2169 for (unsigned I = 0, N = Features.size(); I < N; ++I) {
2170 const char *Name = Features[I];
2171 assert(Name[0] == '-' || Name[0] == '+');
2172 LastOpt[Name + 1] = I;
2173 }
2174
2175 for (unsigned I = 0, N = Features.size(); I < N; ++I) {
2176 // If this feature was overridden, ignore it.
2177 const char *Name = Features[I];
2178 llvm::StringMap<unsigned>::iterator LastI = LastOpt.find(Name + 1);
2179 assert(LastI != LastOpt.end());
2180 unsigned Last = LastI->second;
2181 if (Last != I)
2182 continue;
2183
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002184 CmdArgs.push_back("-target-feature");
Rafael Espindola43964802013-08-21 17:34:32 +00002185 CmdArgs.push_back(Name);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002186 }
Tim Northover2fe823a2013-08-01 09:23:19 +00002187}
2188
David Majnemerae394812014-12-09 00:12:30 +00002189static bool
2190shouldUseExceptionTablesForObjCExceptions(const ObjCRuntime &runtime,
2191 const llvm::Triple &Triple) {
2192 // We use the zero-cost exception tables for Objective-C if the non-fragile
2193 // ABI is enabled or when compiling for x86_64 and ARM on Snow Leopard and
2194 // later.
2195 if (runtime.isNonFragile())
2196 return true;
2197
2198 if (!Triple.isMacOSX())
2199 return false;
2200
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002201 return (!Triple.isMacOSXVersionLT(10, 5) &&
David Majnemerae394812014-12-09 00:12:30 +00002202 (Triple.getArch() == llvm::Triple::x86_64 ||
2203 Triple.getArch() == llvm::Triple::arm));
2204}
2205
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002206/// Adds exception related arguments to the driver command arguments. There's a
2207/// master flag, -fexceptions and also language specific flags to enable/disable
2208/// C++ and Objective-C exceptions. This makes it possible to for example
2209/// disable C++ exceptions but enable Objective-C exceptions.
Anders Carlssone96ab552011-02-28 02:27:16 +00002210static void addExceptionArgs(const ArgList &Args, types::ID InputType,
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002211 const ToolChain &TC, bool KernelOrKext,
John McCall5fb5df92012-06-20 06:18:46 +00002212 const ObjCRuntime &objcRuntime,
Anders Carlssone96ab552011-02-28 02:27:16 +00002213 ArgStringList &CmdArgs) {
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002214 const Driver &D = TC.getDriver();
2215 const llvm::Triple &Triple = TC.getTriple();
2216
Chad Rosier4fab82c2012-03-26 22:04:46 +00002217 if (KernelOrKext) {
2218 // -mkernel and -fapple-kext imply no exceptions, so claim exception related
2219 // arguments now to avoid warnings about unused arguments.
2220 Args.ClaimAllArgs(options::OPT_fexceptions);
2221 Args.ClaimAllArgs(options::OPT_fno_exceptions);
2222 Args.ClaimAllArgs(options::OPT_fobjc_exceptions);
2223 Args.ClaimAllArgs(options::OPT_fno_objc_exceptions);
2224 Args.ClaimAllArgs(options::OPT_fcxx_exceptions);
2225 Args.ClaimAllArgs(options::OPT_fno_cxx_exceptions);
Anders Carlssone96ab552011-02-28 02:27:16 +00002226 return;
Chad Rosier4fab82c2012-03-26 22:04:46 +00002227 }
Anders Carlssone96ab552011-02-28 02:27:16 +00002228
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00002229 // See if the user explicitly enabled exceptions.
2230 bool EH = Args.hasFlag(options::OPT_fexceptions, options::OPT_fno_exceptions,
2231 false);
Daniel Dunbar30a12b82010-09-14 23:12:31 +00002232
David Majnemerae394812014-12-09 00:12:30 +00002233 // Obj-C exceptions are enabled by default, regardless of -fexceptions. This
2234 // is not necessarily sensible, but follows GCC.
2235 if (types::isObjC(InputType) &&
2236 Args.hasFlag(options::OPT_fobjc_exceptions,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002237 options::OPT_fno_objc_exceptions, true)) {
David Majnemerae394812014-12-09 00:12:30 +00002238 CmdArgs.push_back("-fobjc-exceptions");
Anders Carlssone96ab552011-02-28 02:27:16 +00002239
David Majnemerae394812014-12-09 00:12:30 +00002240 EH |= shouldUseExceptionTablesForObjCExceptions(objcRuntime, Triple);
Anders Carlssone96ab552011-02-28 02:27:16 +00002241 }
2242
2243 if (types::isCXX(InputType)) {
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00002244 // Disable C++ EH by default on XCore, PS4, and MSVC.
2245 // FIXME: Remove MSVC from this list once things work.
2246 bool CXXExceptionsEnabled = Triple.getArch() != llvm::Triple::xcore &&
2247 !Triple.isPS4CPU() &&
2248 !Triple.isWindowsMSVCEnvironment();
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002249 Arg *ExceptionArg = Args.getLastArg(
2250 options::OPT_fcxx_exceptions, options::OPT_fno_cxx_exceptions,
2251 options::OPT_fexceptions, options::OPT_fno_exceptions);
2252 if (ExceptionArg)
David Majnemer8de68642014-12-05 08:11:58 +00002253 CXXExceptionsEnabled =
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002254 ExceptionArg->getOption().matches(options::OPT_fcxx_exceptions) ||
2255 ExceptionArg->getOption().matches(options::OPT_fexceptions);
Anders Carlssone96ab552011-02-28 02:27:16 +00002256
2257 if (CXXExceptionsEnabled) {
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002258 if (Triple.isPS4CPU()) {
2259 ToolChain::RTTIMode RTTIMode = TC.getRTTIMode();
2260 assert(ExceptionArg &&
2261 "On the PS4 exceptions should only be enabled if passing "
2262 "an argument");
2263 if (RTTIMode == ToolChain::RM_DisabledExplicitly) {
2264 const Arg *RTTIArg = TC.getRTTIArg();
2265 assert(RTTIArg && "RTTI disabled explicitly but no RTTIArg!");
2266 D.Diag(diag::err_drv_argument_not_allowed_with)
2267 << RTTIArg->getAsString(Args) << ExceptionArg->getAsString(Args);
2268 } else if (RTTIMode == ToolChain::RM_EnabledImplicitly)
2269 D.Diag(diag::warn_drv_enabling_rtti_with_exceptions);
2270 } else
2271 assert(TC.getRTTIMode() != ToolChain::RM_DisabledImplicitly);
2272
Anders Carlssone96ab552011-02-28 02:27:16 +00002273 CmdArgs.push_back("-fcxx-exceptions");
2274
David Majnemer8de68642014-12-05 08:11:58 +00002275 EH = true;
Anders Carlssone96ab552011-02-28 02:27:16 +00002276 }
2277 }
2278
David Majnemer8de68642014-12-05 08:11:58 +00002279 if (EH)
Anders Carlssone96ab552011-02-28 02:27:16 +00002280 CmdArgs.push_back("-fexceptions");
Rafael Espindola00a66572009-10-01 13:33:33 +00002281}
2282
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002283static bool ShouldDisableAutolink(const ArgList &Args, const ToolChain &TC) {
Daniel Dunbare246fbe2013-04-16 18:21:19 +00002284 bool Default = true;
2285 if (TC.getTriple().isOSDarwin()) {
2286 // The native darwin assembler doesn't support the linker_option directives,
2287 // so we disable them if we think the .s file will be passed to it.
2288 Default = TC.useIntegratedAs();
2289 }
2290 return !Args.hasFlag(options::OPT_fautolink, options::OPT_fno_autolink,
2291 Default);
2292}
2293
Ted Kremenek62093662013-03-12 17:02:12 +00002294static bool ShouldDisableDwarfDirectory(const ArgList &Args,
2295 const ToolChain &TC) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002296 bool UseDwarfDirectory =
2297 Args.hasFlag(options::OPT_fdwarf_directory_asm,
2298 options::OPT_fno_dwarf_directory_asm, TC.useIntegratedAs());
Nick Lewycky1d617ac2011-10-17 23:05:52 +00002299 return !UseDwarfDirectory;
2300}
2301
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00002302/// \brief Check whether the given input tree contains any compilation actions.
2303static bool ContainsCompileAction(const Action *A) {
Bob Wilson23a55f12014-12-21 07:00:00 +00002304 if (isa<CompileJobAction>(A) || isa<BackendJobAction>(A))
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00002305 return true;
2306
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00002307 for (const auto &Act : *A)
2308 if (ContainsCompileAction(Act))
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00002309 return true;
2310
2311 return false;
2312}
2313
2314/// \brief Check if -relax-all should be passed to the internal assembler.
2315/// This is done by default when compiling non-assembler source with -O0.
2316static bool UseRelaxAll(Compilation &C, const ArgList &Args) {
2317 bool RelaxDefault = true;
2318
2319 if (Arg *A = Args.getLastArg(options::OPT_O_Group))
2320 RelaxDefault = A->getOption().matches(options::OPT_O0);
2321
2322 if (RelaxDefault) {
2323 RelaxDefault = false;
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00002324 for (const auto &Act : C.getActions()) {
2325 if (ContainsCompileAction(Act)) {
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00002326 RelaxDefault = true;
2327 break;
2328 }
2329 }
2330 }
2331
2332 return Args.hasFlag(options::OPT_mrelax_all, options::OPT_mno_relax_all,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002333 RelaxDefault);
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00002334}
2335
David Blaikie9260ed62013-07-25 21:19:01 +00002336static void CollectArgsForIntegratedAssembler(Compilation &C,
2337 const ArgList &Args,
2338 ArgStringList &CmdArgs,
2339 const Driver &D) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002340 if (UseRelaxAll(C, Args))
2341 CmdArgs.push_back("-mrelax-all");
David Blaikie9260ed62013-07-25 21:19:01 +00002342
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002343 // When passing -I arguments to the assembler we sometimes need to
2344 // unconditionally take the next argument. For example, when parsing
2345 // '-Wa,-I -Wa,foo' we need to accept the -Wa,foo arg after seeing the
2346 // -Wa,-I arg and when parsing '-Wa,-I,foo' we need to accept the 'foo'
2347 // arg after parsing the '-I' arg.
2348 bool TakeNextArg = false;
David Peixottodfb66142013-11-14 22:52:58 +00002349
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002350 // When using an integrated assembler, translate -Wa, and -Xassembler
2351 // options.
2352 bool CompressDebugSections = false;
2353 for (const Arg *A :
2354 Args.filtered(options::OPT_Wa_COMMA, options::OPT_Xassembler)) {
2355 A->claim();
David Blaikie9260ed62013-07-25 21:19:01 +00002356
Benjamin Kramer72e64312015-09-24 14:48:49 +00002357 for (StringRef Value : A->getValues()) {
Renato Golin7c542b42015-07-27 23:44:45 +00002358 if (TakeNextArg) {
2359 CmdArgs.push_back(Value.data());
2360 TakeNextArg = false;
2361 continue;
2362 }
David Blaikie9260ed62013-07-25 21:19:01 +00002363
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002364 if (Value == "-force_cpusubtype_ALL") {
2365 // Do nothing, this is the default and we don't support anything else.
2366 } else if (Value == "-L") {
2367 CmdArgs.push_back("-msave-temp-labels");
2368 } else if (Value == "--fatal-warnings") {
2369 CmdArgs.push_back("-massembler-fatal-warnings");
2370 } else if (Value == "--noexecstack") {
2371 CmdArgs.push_back("-mnoexecstack");
2372 } else if (Value == "-compress-debug-sections" ||
2373 Value == "--compress-debug-sections") {
2374 CompressDebugSections = true;
2375 } else if (Value == "-nocompress-debug-sections" ||
2376 Value == "--nocompress-debug-sections") {
2377 CompressDebugSections = false;
2378 } else if (Value.startswith("-I")) {
2379 CmdArgs.push_back(Value.data());
2380 // We need to consume the next argument if the current arg is a plain
2381 // -I. The next arg will be the include directory.
2382 if (Value == "-I")
2383 TakeNextArg = true;
2384 } else if (Value.startswith("-gdwarf-")) {
2385 CmdArgs.push_back(Value.data());
Renato Golin7c542b42015-07-27 23:44:45 +00002386 } else if (Value.startswith("-mcpu") || Value.startswith("-mfpu") ||
2387 Value.startswith("-mhwdiv") || Value.startswith("-march")) {
2388 // Do nothing, we'll validate it later.
Daniel Sanders4f7cd232015-09-03 12:58:39 +00002389 } else if (Value == "--trap") {
2390 CmdArgs.push_back("-target-feature");
2391 CmdArgs.push_back("+use-tcc-in-div");
2392 } else if (Value == "--break") {
2393 CmdArgs.push_back("-target-feature");
2394 CmdArgs.push_back("-use-tcc-in-div");
Daniel Sanders63f28262015-09-22 13:52:32 +00002395 } else if (Value.startswith("-msoft-float")) {
2396 CmdArgs.push_back("-target-feature");
2397 CmdArgs.push_back("+soft-float");
2398 } else if (Value.startswith("-mhard-float")) {
2399 CmdArgs.push_back("-target-feature");
2400 CmdArgs.push_back("-soft-float");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002401 } else {
2402 D.Diag(diag::err_drv_unsupported_option_argument)
David Blaikie9260ed62013-07-25 21:19:01 +00002403 << A->getOption().getName() << Value;
David Blaikie9260ed62013-07-25 21:19:01 +00002404 }
2405 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002406 }
2407 if (CompressDebugSections) {
2408 if (llvm::zlib::isAvailable())
2409 CmdArgs.push_back("-compress-debug-sections");
2410 else
2411 D.Diag(diag::warn_debug_compression_unavailable);
2412 }
David Blaikie9260ed62013-07-25 21:19:01 +00002413}
2414
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00002415static const char *getCompilerRTArgString(const ToolChain &TC,
2416 const llvm::opt::ArgList &Args,
2417 StringRef Component,
2418 bool Shared = false) {
Vasileios Kalintiris447e3572015-10-01 16:54:58 +00002419 return Args.MakeArgString(TC.getCompilerRT(Args, Component, Shared));
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00002420}
2421
Alexey Samsonov99ee10d2014-05-22 21:13:30 +00002422// This adds the static libclang_rt.builtins-arch.a directly to the command line
Renato Golinc4b49242014-02-13 10:01:16 +00002423// FIXME: Make sure we can also emit shared objects if they're requested
2424// and available, check for possible errors, etc.
Saleem Abdulrasool8d7ade72014-12-30 02:10:36 +00002425static void addClangRT(const ToolChain &TC, const ArgList &Args,
2426 ArgStringList &CmdArgs) {
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00002427 CmdArgs.push_back(getCompilerRTArgString(TC, Args, "builtins"));
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00002428}
2429
Saleem Abdulrasool2e46ebe2014-12-30 22:52:06 +00002430static void addProfileRT(const ToolChain &TC, const ArgList &Args,
2431 ArgStringList &CmdArgs) {
Justin Bogner31a4aca2014-08-07 03:14:34 +00002432 if (!(Args.hasFlag(options::OPT_fprofile_arcs, options::OPT_fno_profile_arcs,
2433 false) ||
Chandler Carruth36381702013-06-23 11:28:48 +00002434 Args.hasArg(options::OPT_fprofile_generate) ||
Diego Novillo578caf52015-07-09 17:23:53 +00002435 Args.hasArg(options::OPT_fprofile_generate_EQ) ||
Justin Bogner6a9d2cf2014-01-06 22:27:36 +00002436 Args.hasArg(options::OPT_fprofile_instr_generate) ||
Justin Bognera71e6812015-04-30 23:49:42 +00002437 Args.hasArg(options::OPT_fprofile_instr_generate_EQ) ||
Chandler Carruth36381702013-06-23 11:28:48 +00002438 Args.hasArg(options::OPT_fcreate_profile) ||
2439 Args.hasArg(options::OPT_coverage)))
2440 return;
2441
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00002442 CmdArgs.push_back(getCompilerRTArgString(TC, Args, "profile"));
Alexey Samsonovbdfa6c22014-04-01 13:31:10 +00002443}
2444
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002445namespace {
2446enum OpenMPRuntimeKind {
2447 /// An unknown OpenMP runtime. We can't generate effective OpenMP code
2448 /// without knowing what runtime to target.
2449 OMPRT_Unknown,
2450
2451 /// The LLVM OpenMP runtime. When completed and integrated, this will become
2452 /// the default for Clang.
2453 OMPRT_OMP,
2454
2455 /// The GNU OpenMP runtime. Clang doesn't support generating OpenMP code for
2456 /// this runtime but can swallow the pragmas, and find and link against the
2457 /// runtime library itself.
2458 OMPRT_GOMP,
2459
Chandler Carruthc6625c62015-05-28 21:10:31 +00002460 /// The legacy name for the LLVM OpenMP runtime from when it was the Intel
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002461 /// OpenMP runtime. We support this mode for users with existing dependencies
2462 /// on this runtime library name.
2463 OMPRT_IOMP5
2464};
Alexander Kornienkoab9db512015-06-22 23:07:51 +00002465}
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002466
2467/// Compute the desired OpenMP runtime from the flag provided.
Chandler Carruthc6625c62015-05-28 21:10:31 +00002468static OpenMPRuntimeKind getOpenMPRuntime(const ToolChain &TC,
2469 const ArgList &Args) {
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002470 StringRef RuntimeName(CLANG_DEFAULT_OPENMP_RUNTIME);
2471
2472 const Arg *A = Args.getLastArg(options::OPT_fopenmp_EQ);
2473 if (A)
2474 RuntimeName = A->getValue();
2475
2476 auto RT = llvm::StringSwitch<OpenMPRuntimeKind>(RuntimeName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002477 .Case("libomp", OMPRT_OMP)
2478 .Case("libgomp", OMPRT_GOMP)
2479 .Case("libiomp5", OMPRT_IOMP5)
2480 .Default(OMPRT_Unknown);
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002481
2482 if (RT == OMPRT_Unknown) {
2483 if (A)
2484 TC.getDriver().Diag(diag::err_drv_unsupported_option_argument)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002485 << A->getOption().getName() << A->getValue();
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002486 else
2487 // FIXME: We could use a nicer diagnostic here.
2488 TC.getDriver().Diag(diag::err_drv_unsupported_opt) << "-fopenmp";
2489 }
2490
2491 return RT;
2492}
2493
Joerg Sonnenberger95a90132015-09-23 14:06:52 +00002494static void addOpenMPRuntime(ArgStringList &CmdArgs, const ToolChain &TC,
2495 const ArgList &Args) {
2496 if (!Args.hasFlag(options::OPT_fopenmp, options::OPT_fopenmp_EQ,
2497 options::OPT_fno_openmp, false))
2498 return;
2499
2500 switch (getOpenMPRuntime(TC, Args)) {
2501 case OMPRT_OMP:
2502 CmdArgs.push_back("-lomp");
2503 break;
2504 case OMPRT_GOMP:
2505 CmdArgs.push_back("-lgomp");
2506 break;
2507 case OMPRT_IOMP5:
2508 CmdArgs.push_back("-liomp5");
2509 break;
2510 case OMPRT_Unknown:
2511 // Already diagnosed.
2512 break;
2513 }
2514}
2515
Alexey Samsonov52550342014-09-15 19:58:40 +00002516static void addSanitizerRuntime(const ToolChain &TC, const ArgList &Args,
2517 ArgStringList &CmdArgs, StringRef Sanitizer,
2518 bool IsShared) {
Alexey Samsonov52550342014-09-15 19:58:40 +00002519 // Static runtimes must be forced into executable, so we wrap them in
Peter Collingbournef7ef3fd812013-10-20 21:29:13 +00002520 // whole-archive.
Alexey Samsonov52550342014-09-15 19:58:40 +00002521 if (!IsShared)
2522 CmdArgs.push_back("-whole-archive");
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00002523 CmdArgs.push_back(getCompilerRTArgString(TC, Args, Sanitizer, IsShared));
Alexey Samsonov52550342014-09-15 19:58:40 +00002524 if (!IsShared)
2525 CmdArgs.push_back("-no-whole-archive");
Alexey Samsonovbfb0cd32013-02-27 11:14:55 +00002526}
2527
Alexey Samsonov52550342014-09-15 19:58:40 +00002528// Tries to use a file with the list of dynamic symbols that need to be exported
2529// from the runtime library. Returns true if the file was found.
2530static bool addSanitizerDynamicList(const ToolChain &TC, const ArgList &Args,
2531 ArgStringList &CmdArgs,
2532 StringRef Sanitizer) {
Vasileios Kalintiris447e3572015-10-01 16:54:58 +00002533 SmallString<128> SanRT(TC.getCompilerRT(Args, Sanitizer));
Saleem Abdulrasool68150942014-12-30 22:52:08 +00002534 if (llvm::sys::fs::exists(SanRT + ".syms")) {
2535 CmdArgs.push_back(Args.MakeArgString("--dynamic-list=" + SanRT + ".syms"));
Alexey Samsonov52550342014-09-15 19:58:40 +00002536 return true;
2537 }
2538 return false;
2539}
2540
2541static void linkSanitizerRuntimeDeps(const ToolChain &TC,
2542 ArgStringList &CmdArgs) {
2543 // Force linking against the system libraries sanitizers depends on
2544 // (see PR15823 why this is necessary).
2545 CmdArgs.push_back("--no-as-needed");
2546 CmdArgs.push_back("-lpthread");
2547 CmdArgs.push_back("-lrt");
2548 CmdArgs.push_back("-lm");
2549 // There's no libdl on FreeBSD.
2550 if (TC.getTriple().getOS() != llvm::Triple::FreeBSD)
2551 CmdArgs.push_back("-ldl");
2552}
2553
2554static void
2555collectSanitizerRuntimes(const ToolChain &TC, const ArgList &Args,
2556 SmallVectorImpl<StringRef> &SharedRuntimes,
2557 SmallVectorImpl<StringRef> &StaticRuntimes,
2558 SmallVectorImpl<StringRef> &HelperStaticRuntimes) {
2559 const SanitizerArgs &SanArgs = TC.getSanitizerArgs();
2560 // Collect shared runtimes.
2561 if (SanArgs.needsAsanRt() && SanArgs.needsSharedAsanRt()) {
2562 SharedRuntimes.push_back("asan");
Evgeniy Stepanov77866712012-04-25 08:59:22 +00002563 }
Alexey Samsonovbdfa6c22014-04-01 13:31:10 +00002564
Alexey Samsonov52550342014-09-15 19:58:40 +00002565 // Collect static runtimes.
Alexey Samsonovbdfa6c22014-04-01 13:31:10 +00002566 if (Args.hasArg(options::OPT_shared) ||
Alexey Samsonov52550342014-09-15 19:58:40 +00002567 (TC.getTriple().getEnvironment() == llvm::Triple::Android)) {
2568 // Don't link static runtimes into DSOs or if compiling for Android.
Alexey Samsonovbdfa6c22014-04-01 13:31:10 +00002569 return;
Alexey Samsonov52550342014-09-15 19:58:40 +00002570 }
2571 if (SanArgs.needsAsanRt()) {
2572 if (SanArgs.needsSharedAsanRt()) {
2573 HelperStaticRuntimes.push_back("asan-preinit");
2574 } else {
2575 StaticRuntimes.push_back("asan");
2576 if (SanArgs.linkCXXRuntimes())
2577 StaticRuntimes.push_back("asan_cxx");
2578 }
2579 }
2580 if (SanArgs.needsDfsanRt())
2581 StaticRuntimes.push_back("dfsan");
2582 if (SanArgs.needsLsanRt())
2583 StaticRuntimes.push_back("lsan");
Alexey Samsonov381845d2015-04-27 22:07:50 +00002584 if (SanArgs.needsMsanRt()) {
Alexey Samsonov52550342014-09-15 19:58:40 +00002585 StaticRuntimes.push_back("msan");
Alexey Samsonov381845d2015-04-27 22:07:50 +00002586 if (SanArgs.linkCXXRuntimes())
2587 StaticRuntimes.push_back("msan_cxx");
2588 }
2589 if (SanArgs.needsTsanRt()) {
Alexey Samsonov52550342014-09-15 19:58:40 +00002590 StaticRuntimes.push_back("tsan");
Alexey Samsonov381845d2015-04-27 22:07:50 +00002591 if (SanArgs.linkCXXRuntimes())
2592 StaticRuntimes.push_back("tsan_cxx");
2593 }
Alexey Samsonov52550342014-09-15 19:58:40 +00002594 if (SanArgs.needsUbsanRt()) {
Alexey Samsonov31095462015-04-01 22:42:25 +00002595 StaticRuntimes.push_back("ubsan_standalone");
2596 if (SanArgs.linkCXXRuntimes())
2597 StaticRuntimes.push_back("ubsan_standalone_cxx");
Alexey Samsonovb01f9362014-05-12 18:39:51 +00002598 }
Peter Collingbournec4122c12015-06-15 21:08:13 +00002599 if (SanArgs.needsSafeStackRt())
2600 StaticRuntimes.push_back("safestack");
Kostya Serebryany7bca6c22011-11-30 01:39:16 +00002601}
2602
Alexey Samsonov52550342014-09-15 19:58:40 +00002603// Should be called before we add system libraries (C++ ABI, libstdc++/libc++,
2604// C runtime, etc). Returns true if sanitizer system deps need to be linked in.
2605static bool addSanitizerRuntimes(const ToolChain &TC, const ArgList &Args,
Alexey Samsonovce8ab102014-02-25 12:43:43 +00002606 ArgStringList &CmdArgs) {
Alexey Samsonov52550342014-09-15 19:58:40 +00002607 SmallVector<StringRef, 4> SharedRuntimes, StaticRuntimes,
2608 HelperStaticRuntimes;
2609 collectSanitizerRuntimes(TC, Args, SharedRuntimes, StaticRuntimes,
2610 HelperStaticRuntimes);
2611 for (auto RT : SharedRuntimes)
2612 addSanitizerRuntime(TC, Args, CmdArgs, RT, true);
2613 for (auto RT : HelperStaticRuntimes)
2614 addSanitizerRuntime(TC, Args, CmdArgs, RT, false);
2615 bool AddExportDynamic = false;
2616 for (auto RT : StaticRuntimes) {
2617 addSanitizerRuntime(TC, Args, CmdArgs, RT, false);
2618 AddExportDynamic |= !addSanitizerDynamicList(TC, Args, CmdArgs, RT);
2619 }
2620 // If there is a static runtime with no dynamic list, force all the symbols
2621 // to be dynamic to be sure we export sanitizer interface functions.
2622 if (AddExportDynamic)
2623 CmdArgs.push_back("-export-dynamic");
2624 return !StaticRuntimes.empty();
Peter Collingbournec3772752013-08-07 22:47:34 +00002625}
2626
Reid Kleckner86ea7702015-02-04 23:45:07 +00002627static bool areOptimizationsEnabled(const ArgList &Args) {
2628 // Find the last -O arg and see if it is non-zero.
2629 if (Arg *A = Args.getLastArg(options::OPT_O_Group))
2630 return !A->getOption().matches(options::OPT_O0);
2631 // Defaults to -O0.
2632 return false;
2633}
2634
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002635static bool shouldUseFramePointerForTarget(const ArgList &Args,
2636 const llvm::Triple &Triple) {
Dan Gohmanc2853072015-09-03 22:51:53 +00002637 switch (Triple.getArch()) {
2638 case llvm::Triple::xcore:
2639 case llvm::Triple::wasm32:
2640 case llvm::Triple::wasm64:
2641 // XCore never wants frame pointers, regardless of OS.
2642 // WebAssembly never wants frame pointers.
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002643 return false;
Dan Gohmanc2853072015-09-03 22:51:53 +00002644 default:
2645 break;
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002646 }
Reid Kleckner86ea7702015-02-04 23:45:07 +00002647
2648 if (Triple.isOSLinux()) {
2649 switch (Triple.getArch()) {
2650 // Don't use a frame pointer on linux if optimizing for certain targets.
2651 case llvm::Triple::mips64:
2652 case llvm::Triple::mips64el:
2653 case llvm::Triple::mips:
2654 case llvm::Triple::mipsel:
2655 case llvm::Triple::systemz:
2656 case llvm::Triple::x86:
2657 case llvm::Triple::x86_64:
2658 return !areOptimizationsEnabled(Args);
2659 default:
2660 return true;
2661 }
2662 }
2663
2664 if (Triple.isOSWindows()) {
2665 switch (Triple.getArch()) {
2666 case llvm::Triple::x86:
2667 return !areOptimizationsEnabled(Args);
2668 default:
2669 // All other supported Windows ISAs use xdata unwind information, so frame
2670 // pointers are not generally useful.
2671 return false;
2672 }
2673 }
2674
2675 return true;
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002676}
2677
Rafael Espindola224dd632011-12-14 21:02:23 +00002678static bool shouldUseFramePointer(const ArgList &Args,
2679 const llvm::Triple &Triple) {
2680 if (Arg *A = Args.getLastArg(options::OPT_fno_omit_frame_pointer,
2681 options::OPT_fomit_frame_pointer))
2682 return A->getOption().matches(options::OPT_fno_omit_frame_pointer);
2683
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002684 return shouldUseFramePointerForTarget(Args, Triple);
Rafael Espindola224dd632011-12-14 21:02:23 +00002685}
2686
Eric Christopherb7d97e92013-04-03 01:58:53 +00002687static bool shouldUseLeafFramePointer(const ArgList &Args,
2688 const llvm::Triple &Triple) {
2689 if (Arg *A = Args.getLastArg(options::OPT_mno_omit_leaf_frame_pointer,
2690 options::OPT_momit_leaf_frame_pointer))
2691 return A->getOption().matches(options::OPT_mno_omit_leaf_frame_pointer);
2692
Filipe Cabecinhasb1e6c2d2015-01-27 18:08:32 +00002693 if (Triple.isPS4CPU())
2694 return false;
2695
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002696 return shouldUseFramePointerForTarget(Args, Triple);
Eric Christopherb7d97e92013-04-03 01:58:53 +00002697}
2698
Rafael Espindolac7367ff2013-08-10 01:40:10 +00002699/// Add a CC1 option to specify the debug compilation directory.
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00002700static void addDebugCompDirArg(const ArgList &Args, ArgStringList &CmdArgs) {
Benjamin Kramer698d7c82013-04-27 08:12:29 +00002701 SmallString<128> cwd;
2702 if (!llvm::sys::fs::current_path(cwd)) {
Chad Rosiera35d5a32013-04-26 20:49:50 +00002703 CmdArgs.push_back("-fdebug-compilation-dir");
2704 CmdArgs.push_back(Args.MakeArgString(cwd));
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00002705 }
2706}
2707
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002708static const char *SplitDebugName(const ArgList &Args, const InputInfo &Input) {
Eric Christopherd3804002013-02-22 20:12:52 +00002709 Arg *FinalOutput = Args.getLastArg(options::OPT_o);
2710 if (FinalOutput && Args.hasArg(options::OPT_c)) {
2711 SmallString<128> T(FinalOutput->getValue());
2712 llvm::sys::path::replace_extension(T, "dwo");
2713 return Args.MakeArgString(T);
2714 } else {
2715 // Use the compilation dir.
Nico Webere8e53112014-05-11 01:04:02 +00002716 SmallString<128> T(
2717 Args.getLastArgValue(options::OPT_fdebug_compilation_dir));
Artem Belevichba558952015-05-06 18:20:23 +00002718 SmallString<128> F(llvm::sys::path::stem(Input.getBaseInput()));
Eric Christopherd3804002013-02-22 20:12:52 +00002719 llvm::sys::path::replace_extension(F, "dwo");
2720 T += F;
2721 return Args.MakeArgString(F);
2722 }
2723}
2724
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002725static void SplitDebugInfo(const ToolChain &TC, Compilation &C, const Tool &T,
2726 const JobAction &JA, const ArgList &Args,
2727 const InputInfo &Output, const char *OutFile) {
Eric Christopher248357f2013-02-21 22:35:01 +00002728 ArgStringList ExtractArgs;
2729 ExtractArgs.push_back("--extract-dwo");
2730
2731 ArgStringList StripArgs;
2732 StripArgs.push_back("--strip-dwo");
2733
2734 // Grabbing the output of the earlier compile step.
2735 StripArgs.push_back(Output.getFilename());
2736 ExtractArgs.push_back(Output.getFilename());
Eric Christopher248357f2013-02-21 22:35:01 +00002737 ExtractArgs.push_back(OutFile);
2738
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002739 const char *Exec = Args.MakeArgString(TC.GetProgramPath("objcopy"));
Justin Bognerd3371d82015-07-17 03:35:54 +00002740 InputInfo II(Output.getFilename(), types::TY_Object, Output.getFilename());
Eric Christopher248357f2013-02-21 22:35:01 +00002741
2742 // First extract the dwo sections.
Justin Bognerd3371d82015-07-17 03:35:54 +00002743 C.addCommand(llvm::make_unique<Command>(JA, T, Exec, ExtractArgs, II));
Eric Christopher248357f2013-02-21 22:35:01 +00002744
2745 // Then remove them from the original .o file.
Justin Bognerd3371d82015-07-17 03:35:54 +00002746 C.addCommand(llvm::make_unique<Command>(JA, T, Exec, StripArgs, II));
Eric Christopher248357f2013-02-21 22:35:01 +00002747}
2748
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002749/// \brief Vectorize at all optimization levels greater than 1 except for -Oz.
Chad Rosier3ba81bd2014-05-02 18:41:57 +00002750/// For -Oz the loop vectorizer is disable, while the slp vectorizer is enabled.
2751static bool shouldEnableVectorizerAtOLevel(const ArgList &Args, bool isSlpVec) {
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002752 if (Arg *A = Args.getLastArg(options::OPT_O_Group)) {
Rafael Espindolaad70d962013-08-27 16:58:15 +00002753 if (A->getOption().matches(options::OPT_O4) ||
2754 A->getOption().matches(options::OPT_Ofast))
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002755 return true;
2756
2757 if (A->getOption().matches(options::OPT_O0))
2758 return false;
2759
2760 assert(A->getOption().matches(options::OPT_O) && "Must have a -O flag");
2761
Rafael Espindola91780de2013-08-26 14:05:41 +00002762 // Vectorize -Os.
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002763 StringRef S(A->getValue());
Rafael Espindola91780de2013-08-26 14:05:41 +00002764 if (S == "s")
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002765 return true;
2766
Chad Rosier3ba81bd2014-05-02 18:41:57 +00002767 // Don't vectorize -Oz, unless it's the slp vectorizer.
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002768 if (S == "z")
Chad Rosier3ba81bd2014-05-02 18:41:57 +00002769 return isSlpVec;
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002770
2771 unsigned OptLevel = 0;
2772 if (S.getAsInteger(10, OptLevel))
2773 return false;
2774
2775 return OptLevel > 1;
2776 }
2777
2778 return false;
2779}
2780
Ben Langmuir2cb4a782014-02-05 22:21:15 +00002781/// Add -x lang to \p CmdArgs for \p Input.
2782static void addDashXForInput(const ArgList &Args, const InputInfo &Input,
2783 ArgStringList &CmdArgs) {
2784 // When using -verify-pch, we don't want to provide the type
2785 // 'precompiled-header' if it was inferred from the file extension
2786 if (Args.hasArg(options::OPT_verify_pch) && Input.getType() == types::TY_PCH)
2787 return;
2788
2789 CmdArgs.push_back("-x");
2790 if (Args.hasArg(options::OPT_rewrite_objc))
2791 CmdArgs.push_back(types::getTypeName(types::TY_PP_ObjCXX));
2792 else
2793 CmdArgs.push_back(types::getTypeName(Input.getType()));
2794}
2795
David Majnemerc371ff02015-03-22 08:39:22 +00002796static VersionTuple getMSCompatibilityVersion(unsigned Version) {
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00002797 if (Version < 100)
David Majnemerc371ff02015-03-22 08:39:22 +00002798 return VersionTuple(Version);
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00002799
2800 if (Version < 10000)
David Majnemerc371ff02015-03-22 08:39:22 +00002801 return VersionTuple(Version / 100, Version % 100);
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00002802
2803 unsigned Build = 0, Factor = 1;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002804 for (; Version > 10000; Version = Version / 10, Factor = Factor * 10)
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00002805 Build = Build + (Version % 10) * Factor;
David Majnemerc371ff02015-03-22 08:39:22 +00002806 return VersionTuple(Version / 100, Version % 100, Build);
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00002807}
2808
Rafael Espindola577637a2015-01-03 00:06:04 +00002809// Claim options we don't want to warn if they are unused. We do this for
Rafael Espindola7a45e872015-01-05 13:44:59 +00002810// options that build systems might add but are unused when assembling or only
2811// running the preprocessor for example.
Rafael Espindola577637a2015-01-03 00:06:04 +00002812static void claimNoWarnArgs(const ArgList &Args) {
2813 // Don't warn about unused -f(no-)?lto. This can happen when we're
Rafael Espindola7a45e872015-01-05 13:44:59 +00002814 // preprocessing, precompiling or assembling.
Rafael Espindola577637a2015-01-03 00:06:04 +00002815 Args.ClaimAllArgs(options::OPT_flto);
2816 Args.ClaimAllArgs(options::OPT_fno_lto);
2817}
2818
Ben Langmuir3b7b5402015-02-03 19:28:37 +00002819static void appendUserToPath(SmallVectorImpl<char> &Result) {
2820#ifdef LLVM_ON_UNIX
2821 const char *Username = getenv("LOGNAME");
2822#else
2823 const char *Username = getenv("USERNAME");
2824#endif
2825 if (Username) {
2826 // Validate that LoginName can be used in a path, and get its length.
2827 size_t Len = 0;
2828 for (const char *P = Username; *P; ++P, ++Len) {
Ben Langmuire056ec32015-02-04 18:34:23 +00002829 if (!isAlphanumeric(*P) && *P != '_') {
Ben Langmuir3b7b5402015-02-03 19:28:37 +00002830 Username = nullptr;
2831 break;
2832 }
2833 }
2834
2835 if (Username && Len > 0) {
2836 Result.append(Username, Username + Len);
2837 return;
2838 }
2839 }
2840
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002841// Fallback to user id.
Ben Langmuir3b7b5402015-02-03 19:28:37 +00002842#ifdef LLVM_ON_UNIX
2843 std::string UID = llvm::utostr(getuid());
2844#else
2845 // FIXME: Windows seems to have an 'SID' that might work.
2846 std::string UID = "9999";
2847#endif
2848 Result.append(UID.begin(), UID.end());
2849}
2850
David Majnemere11d3732015-06-08 00:22:46 +00002851VersionTuple visualstudio::getMSVCVersion(const Driver *D,
2852 const llvm::Triple &Triple,
2853 const llvm::opt::ArgList &Args,
2854 bool IsWindowsMSVC) {
2855 if (Args.hasFlag(options::OPT_fms_extensions, options::OPT_fno_ms_extensions,
2856 IsWindowsMSVC) ||
2857 Args.hasArg(options::OPT_fmsc_version) ||
2858 Args.hasArg(options::OPT_fms_compatibility_version)) {
2859 const Arg *MSCVersion = Args.getLastArg(options::OPT_fmsc_version);
2860 const Arg *MSCompatibilityVersion =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002861 Args.getLastArg(options::OPT_fms_compatibility_version);
David Majnemere11d3732015-06-08 00:22:46 +00002862
2863 if (MSCVersion && MSCompatibilityVersion) {
2864 if (D)
2865 D->Diag(diag::err_drv_argument_not_allowed_with)
2866 << MSCVersion->getAsString(Args)
2867 << MSCompatibilityVersion->getAsString(Args);
2868 return VersionTuple();
2869 }
2870
2871 if (MSCompatibilityVersion) {
2872 VersionTuple MSVT;
2873 if (MSVT.tryParse(MSCompatibilityVersion->getValue()) && D)
2874 D->Diag(diag::err_drv_invalid_value)
2875 << MSCompatibilityVersion->getAsString(Args)
2876 << MSCompatibilityVersion->getValue();
2877 return MSVT;
2878 }
2879
2880 if (MSCVersion) {
2881 unsigned Version = 0;
2882 if (StringRef(MSCVersion->getValue()).getAsInteger(10, Version) && D)
2883 D->Diag(diag::err_drv_invalid_value) << MSCVersion->getAsString(Args)
2884 << MSCVersion->getValue();
2885 return getMSCompatibilityVersion(Version);
2886 }
2887
2888 unsigned Major, Minor, Micro;
2889 Triple.getEnvironmentVersion(Major, Minor, Micro);
2890 if (Major || Minor || Micro)
2891 return VersionTuple(Major, Minor, Micro);
2892
2893 return VersionTuple(18);
2894 }
2895 return VersionTuple();
2896}
2897
Diego Novilloa0545962015-07-10 18:00:07 +00002898static void addPGOAndCoverageFlags(Compilation &C, const Driver &D,
2899 const InputInfo &Output, const ArgList &Args,
2900 ArgStringList &CmdArgs) {
2901 auto *ProfileGenerateArg = Args.getLastArg(
2902 options::OPT_fprofile_instr_generate,
2903 options::OPT_fprofile_instr_generate_EQ, options::OPT_fprofile_generate,
Diego Novillo758f3f52015-08-05 21:49:51 +00002904 options::OPT_fprofile_generate_EQ,
2905 options::OPT_fno_profile_instr_generate);
2906 if (ProfileGenerateArg &&
2907 ProfileGenerateArg->getOption().matches(
2908 options::OPT_fno_profile_instr_generate))
2909 ProfileGenerateArg = nullptr;
Diego Novilloa0545962015-07-10 18:00:07 +00002910
2911 auto *ProfileUseArg = Args.getLastArg(
2912 options::OPT_fprofile_instr_use, options::OPT_fprofile_instr_use_EQ,
Diego Novillo758f3f52015-08-05 21:49:51 +00002913 options::OPT_fprofile_use, options::OPT_fprofile_use_EQ,
2914 options::OPT_fno_profile_instr_use);
2915 if (ProfileUseArg &&
2916 ProfileUseArg->getOption().matches(options::OPT_fno_profile_instr_use))
2917 ProfileUseArg = nullptr;
Diego Novilloa0545962015-07-10 18:00:07 +00002918
2919 if (ProfileGenerateArg && ProfileUseArg)
2920 D.Diag(diag::err_drv_argument_not_allowed_with)
Renato Golin7c542b42015-07-27 23:44:45 +00002921 << ProfileGenerateArg->getSpelling() << ProfileUseArg->getSpelling();
Diego Novilloa0545962015-07-10 18:00:07 +00002922
Diego Novillo758f3f52015-08-05 21:49:51 +00002923 if (ProfileGenerateArg) {
2924 if (ProfileGenerateArg->getOption().matches(
2925 options::OPT_fprofile_instr_generate_EQ))
2926 ProfileGenerateArg->render(Args, CmdArgs);
2927 else if (ProfileGenerateArg->getOption().matches(
2928 options::OPT_fprofile_generate_EQ)) {
2929 SmallString<128> Path(ProfileGenerateArg->getValue());
2930 llvm::sys::path::append(Path, "default.profraw");
2931 CmdArgs.push_back(
2932 Args.MakeArgString(Twine("-fprofile-instr-generate=") + Path));
2933 } else
2934 Args.AddAllArgs(CmdArgs, options::OPT_fprofile_instr_generate);
2935 }
Diego Novilloa0545962015-07-10 18:00:07 +00002936
Diego Novillo758f3f52015-08-05 21:49:51 +00002937 if (ProfileUseArg) {
2938 if (ProfileUseArg->getOption().matches(options::OPT_fprofile_instr_use_EQ))
2939 ProfileUseArg->render(Args, CmdArgs);
2940 else if ((ProfileUseArg->getOption().matches(
2941 options::OPT_fprofile_use_EQ) ||
2942 ProfileUseArg->getOption().matches(
2943 options::OPT_fprofile_instr_use))) {
2944 SmallString<128> Path(
2945 ProfileUseArg->getNumValues() == 0 ? "" : ProfileUseArg->getValue());
2946 if (Path.empty() || llvm::sys::fs::is_directory(Path))
2947 llvm::sys::path::append(Path, "default.profdata");
2948 CmdArgs.push_back(
2949 Args.MakeArgString(Twine("-fprofile-instr-use=") + Path));
2950 }
Diego Novilloa0545962015-07-10 18:00:07 +00002951 }
2952
2953 if (Args.hasArg(options::OPT_ftest_coverage) ||
2954 Args.hasArg(options::OPT_coverage))
2955 CmdArgs.push_back("-femit-coverage-notes");
2956 if (Args.hasFlag(options::OPT_fprofile_arcs, options::OPT_fno_profile_arcs,
2957 false) ||
2958 Args.hasArg(options::OPT_coverage))
2959 CmdArgs.push_back("-femit-coverage-data");
2960
Diego Novilloc4b94da2015-08-05 23:27:40 +00002961 if (Args.hasFlag(options::OPT_fcoverage_mapping,
2962 options::OPT_fno_coverage_mapping, false) &&
2963 !ProfileGenerateArg)
Diego Novilloa0545962015-07-10 18:00:07 +00002964 D.Diag(diag::err_drv_argument_only_allowed_with)
2965 << "-fcoverage-mapping"
2966 << "-fprofile-instr-generate";
2967
Diego Novilloc4b94da2015-08-05 23:27:40 +00002968 if (Args.hasFlag(options::OPT_fcoverage_mapping,
2969 options::OPT_fno_coverage_mapping, false))
Diego Novilloa0545962015-07-10 18:00:07 +00002970 CmdArgs.push_back("-fcoverage-mapping");
2971
2972 if (C.getArgs().hasArg(options::OPT_c) ||
2973 C.getArgs().hasArg(options::OPT_S)) {
2974 if (Output.isFilename()) {
2975 CmdArgs.push_back("-coverage-file");
2976 SmallString<128> CoverageFilename;
2977 if (Arg *FinalOutput = C.getArgs().getLastArg(options::OPT_o)) {
2978 CoverageFilename = FinalOutput->getValue();
2979 } else {
2980 CoverageFilename = llvm::sys::path::filename(Output.getBaseInput());
2981 }
2982 if (llvm::sys::path::is_relative(CoverageFilename)) {
2983 SmallString<128> Pwd;
2984 if (!llvm::sys::fs::current_path(Pwd)) {
2985 llvm::sys::path::append(Pwd, CoverageFilename);
2986 CoverageFilename.swap(Pwd);
2987 }
2988 }
2989 CmdArgs.push_back(Args.MakeArgString(CoverageFilename));
2990 }
2991 }
2992}
2993
James Y Knight5bdf7ab2015-08-19 15:12:02 +00002994/// Parses the various -fpic/-fPIC/-fpie/-fPIE arguments. Then,
2995/// smooshes them together with platform defaults, to decide whether
2996/// this compile should be using PIC mode or not. Returns a tuple of
2997/// (RelocationModel, PICLevel, IsPIE).
2998static std::tuple<llvm::Reloc::Model, unsigned, bool>
2999ParsePICArgs(const ToolChain &ToolChain, const llvm::Triple &Triple,
3000 const ArgList &Args) {
3001 // FIXME: why does this code...and so much everywhere else, use both
3002 // ToolChain.getTriple() and Triple?
3003 bool PIE = ToolChain.isPIEDefault();
3004 bool PIC = PIE || ToolChain.isPICDefault();
3005 bool IsPICLevelTwo = PIC;
3006
3007 bool KernelOrKext =
3008 Args.hasArg(options::OPT_mkernel, options::OPT_fapple_kext);
3009
3010 // Android-specific defaults for PIC/PIE
3011 if (ToolChain.getTriple().getEnvironment() == llvm::Triple::Android) {
3012 switch (ToolChain.getArch()) {
3013 case llvm::Triple::arm:
3014 case llvm::Triple::armeb:
3015 case llvm::Triple::thumb:
3016 case llvm::Triple::thumbeb:
3017 case llvm::Triple::aarch64:
3018 case llvm::Triple::mips:
3019 case llvm::Triple::mipsel:
3020 case llvm::Triple::mips64:
3021 case llvm::Triple::mips64el:
3022 PIC = true; // "-fpic"
3023 break;
3024
3025 case llvm::Triple::x86:
3026 case llvm::Triple::x86_64:
3027 PIC = true; // "-fPIC"
3028 IsPICLevelTwo = true;
3029 break;
3030
3031 default:
3032 break;
3033 }
3034 }
3035
3036 // OpenBSD-specific defaults for PIE
3037 if (ToolChain.getTriple().getOS() == llvm::Triple::OpenBSD) {
3038 switch (ToolChain.getArch()) {
3039 case llvm::Triple::mips64:
3040 case llvm::Triple::mips64el:
3041 case llvm::Triple::sparcel:
3042 case llvm::Triple::x86:
3043 case llvm::Triple::x86_64:
3044 IsPICLevelTwo = false; // "-fpie"
3045 break;
3046
3047 case llvm::Triple::ppc:
3048 case llvm::Triple::sparc:
3049 case llvm::Triple::sparcv9:
3050 IsPICLevelTwo = true; // "-fPIE"
3051 break;
3052
3053 default:
3054 break;
3055 }
3056 }
3057
3058 // The last argument relating to either PIC or PIE wins, and no
3059 // other argument is used. If the last argument is any flavor of the
3060 // '-fno-...' arguments, both PIC and PIE are disabled. Any PIE
3061 // option implicitly enables PIC at the same level.
3062 Arg *LastPICArg = Args.getLastArg(options::OPT_fPIC, options::OPT_fno_PIC,
3063 options::OPT_fpic, options::OPT_fno_pic,
3064 options::OPT_fPIE, options::OPT_fno_PIE,
3065 options::OPT_fpie, options::OPT_fno_pie);
3066 // Check whether the tool chain trumps the PIC-ness decision. If the PIC-ness
3067 // is forced, then neither PIC nor PIE flags will have no effect.
3068 if (!ToolChain.isPICDefaultForced()) {
3069 if (LastPICArg) {
3070 Option O = LastPICArg->getOption();
3071 if (O.matches(options::OPT_fPIC) || O.matches(options::OPT_fpic) ||
3072 O.matches(options::OPT_fPIE) || O.matches(options::OPT_fpie)) {
3073 PIE = O.matches(options::OPT_fPIE) || O.matches(options::OPT_fpie);
3074 PIC =
3075 PIE || O.matches(options::OPT_fPIC) || O.matches(options::OPT_fpic);
3076 IsPICLevelTwo =
3077 O.matches(options::OPT_fPIE) || O.matches(options::OPT_fPIC);
3078 } else {
3079 PIE = PIC = false;
3080 }
3081 }
3082 }
3083
Greg Bedwell80b325c2015-09-25 16:11:00 +00003084 // Introduce a Darwin-specific hack. If the default is PIC, but the
3085 // PIC level would've been set to level 1, force it back to level 2
3086 // PIC instead. This matches the behavior of Darwin GCC (based on
3087 // chandlerc's informal testing in 2012).
3088 if (PIC && ToolChain.getTriple().isOSDarwin())
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003089 IsPICLevelTwo |= ToolChain.isPICDefault();
3090
James Y Knightc4015d32015-08-21 04:14:55 +00003091 // This kernel flags are a trump-card: they will disable PIC/PIE
3092 // generation, independent of the argument order.
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003093 if (KernelOrKext && (!Triple.isiOS() || Triple.isOSVersionLT(6)))
3094 PIC = PIE = false;
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003095
3096 if (Arg *A = Args.getLastArg(options::OPT_mdynamic_no_pic)) {
3097 // This is a very special mode. It trumps the other modes, almost no one
3098 // uses it, and it isn't even valid on any OS but Darwin.
3099 if (!ToolChain.getTriple().isOSDarwin())
3100 ToolChain.getDriver().Diag(diag::err_drv_unsupported_opt_for_target)
3101 << A->getSpelling() << ToolChain.getTriple().str();
3102
3103 // FIXME: Warn when this flag trumps some other PIC or PIE flag.
3104
3105 // Only a forced PIC mode can cause the actual compile to have PIC defines
3106 // etc., no flags are sufficient. This behavior was selected to closely
3107 // match that of llvm-gcc and Apple GCC before that.
3108 PIC = ToolChain.isPICDefault() && ToolChain.isPICDefaultForced();
3109
3110 return std::make_tuple(llvm::Reloc::DynamicNoPIC, PIC ? 2 : 0, false);
3111 }
3112
3113 if (PIC)
3114 return std::make_tuple(llvm::Reloc::PIC_, IsPICLevelTwo ? 2 : 1, PIE);
3115
3116 return std::make_tuple(llvm::Reloc::Static, 0, false);
3117}
3118
3119static const char *RelocationModelName(llvm::Reloc::Model Model) {
3120 switch (Model) {
3121 case llvm::Reloc::Default:
3122 return nullptr;
3123 case llvm::Reloc::Static:
3124 return "static";
3125 case llvm::Reloc::PIC_:
3126 return "pic";
3127 case llvm::Reloc::DynamicNoPIC:
3128 return "dynamic-no-pic";
3129 }
Aaron Ballman2ec49282015-08-20 13:31:16 +00003130 llvm_unreachable("Unknown Reloc::Model kind");
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003131}
3132
3133static void AddAssemblerKPIC(const ToolChain &ToolChain, const ArgList &Args,
3134 ArgStringList &CmdArgs) {
3135 llvm::Reloc::Model RelocationModel;
3136 unsigned PICLevel;
3137 bool IsPIE;
3138 std::tie(RelocationModel, PICLevel, IsPIE) =
3139 ParsePICArgs(ToolChain, ToolChain.getTriple(), Args);
3140
3141 if (RelocationModel != llvm::Reloc::Static)
3142 CmdArgs.push_back("-KPIC");
3143}
3144
Daniel Dunbar1a093d22009-03-18 06:00:36 +00003145void Clang::ConstructJob(Compilation &C, const JobAction &JA,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003146 const InputInfo &Output, const InputInfoList &Inputs,
3147 const ArgList &Args, const char *LinkingOutput) const {
James Y Knight2db38f32015-08-15 03:45:25 +00003148 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
3149 const llvm::Triple Triple(TripleStr);
3150
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003151 bool KernelOrKext =
3152 Args.hasArg(options::OPT_mkernel, options::OPT_fapple_kext);
Daniel Dunbar083edf72009-12-21 18:54:17 +00003153 const Driver &D = getToolChain().getDriver();
Daniel Dunbara3246a02009-03-18 08:07:30 +00003154 ArgStringList CmdArgs;
3155
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00003156 bool IsWindowsGNU = getToolChain().getTriple().isWindowsGNUEnvironment();
Nico Webere8e53112014-05-11 01:04:02 +00003157 bool IsWindowsCygnus =
3158 getToolChain().getTriple().isWindowsCygwinEnvironment();
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00003159 bool IsWindowsMSVC = getToolChain().getTriple().isWindowsMSVCEnvironment();
3160
Artem Belevich0ff05cd2015-07-13 23:27:56 +00003161 // Check number of inputs for sanity. We need at least one input.
3162 assert(Inputs.size() >= 1 && "Must have at least one input.");
Artem Belevichba558952015-05-06 18:20:23 +00003163 const InputInfo &Input = Inputs[0];
Artem Belevich0ff05cd2015-07-13 23:27:56 +00003164 // CUDA compilation may have multiple inputs (source file + results of
3165 // device-side compilations). All other jobs are expected to have exactly one
3166 // input.
3167 bool IsCuda = types::isCuda(Input.getType());
3168 assert((IsCuda || Inputs.size() == 1) && "Unable to handle multiple inputs.");
Daniel Dunbare521a892009-03-31 20:53:55 +00003169
Daniel Dunbar6c536aa2009-12-11 23:00:49 +00003170 // Invoke ourselves in -cc1 mode.
3171 //
3172 // FIXME: Implement custom jobs for internal actions.
3173 CmdArgs.push_back("-cc1");
3174
Daniel Dunbar624c21b2009-10-30 18:12:20 +00003175 // Add the "effective" target triple.
Daniel Dunbard640be22009-03-31 17:35:15 +00003176 CmdArgs.push_back("-triple");
Daniel Dunbar624c21b2009-10-30 18:12:20 +00003177 CmdArgs.push_back(Args.MakeArgString(TripleStr));
Daniel Dunbarfb58b0a2009-09-10 06:49:20 +00003178
James Y Knight2db38f32015-08-15 03:45:25 +00003179 if (Triple.isOSWindows() && (Triple.getArch() == llvm::Triple::arm ||
3180 Triple.getArch() == llvm::Triple::thumb)) {
3181 unsigned Offset = Triple.getArch() == llvm::Triple::arm ? 4 : 6;
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +00003182 unsigned Version;
James Y Knight2db38f32015-08-15 03:45:25 +00003183 Triple.getArchName().substr(Offset).getAsInteger(10, Version);
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +00003184 if (Version < 7)
James Y Knight2db38f32015-08-15 03:45:25 +00003185 D.Diag(diag::err_target_unsupported_arch) << Triple.getArchName()
Nico Webere8e53112014-05-11 01:04:02 +00003186 << TripleStr;
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +00003187 }
3188
Tim Northover336f1892014-03-29 13:16:12 +00003189 // Push all default warning arguments that are specific to
3190 // the given target. These come before user provided warning options
3191 // are provided.
3192 getToolChain().addClangWarningOptions(CmdArgs);
3193
Daniel Dunbar624c21b2009-10-30 18:12:20 +00003194 // Select the appropriate action.
John McCall5fb5df92012-06-20 06:18:46 +00003195 RewriteKind rewriteKind = RK_None;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003196
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003197 if (isa<AnalyzeJobAction>(JA)) {
3198 assert(JA.getType() == types::TY_Plist && "Invalid output type.");
3199 CmdArgs.push_back("-analyze");
Ted Kremenekf7639e12012-03-06 20:06:33 +00003200 } else if (isa<MigrateJobAction>(JA)) {
3201 CmdArgs.push_back("-migrate");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003202 } else if (isa<PreprocessJobAction>(JA)) {
Daniel Dunbard67a3222009-03-30 06:36:42 +00003203 if (Output.getType() == types::TY_Dependencies)
3204 CmdArgs.push_back("-Eonly");
Fariborz Jahaniane0a75d62013-03-18 19:41:18 +00003205 else {
Daniel Dunbard67a3222009-03-30 06:36:42 +00003206 CmdArgs.push_back("-E");
Fariborz Jahaniane0a75d62013-03-18 19:41:18 +00003207 if (Args.hasArg(options::OPT_rewrite_objc) &&
3208 !Args.hasArg(options::OPT_g_Group))
3209 CmdArgs.push_back("-P");
3210 }
Daniel Dunbarc4343942010-02-03 03:07:56 +00003211 } else if (isa<AssembleJobAction>(JA)) {
3212 CmdArgs.push_back("-emit-obj");
Daniel Dunbar06e2cc32010-05-27 06:18:05 +00003213
David Blaikie9260ed62013-07-25 21:19:01 +00003214 CollectArgsForIntegratedAssembler(C, Args, CmdArgs, D);
Daniel Dunbar7c874332010-11-19 16:23:35 +00003215
3216 // Also ignore explicit -force_cpusubtype_ALL option.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003217 (void)Args.hasArg(options::OPT_force__cpusubtype__ALL);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003218 } else if (isa<PrecompileJobAction>(JA)) {
Argyrios Kyrtzidis90bdfbb2010-08-11 23:27:58 +00003219 // Use PCH if the user requested it.
Daniel Dunbarcbc34b72009-10-15 20:02:44 +00003220 bool UsePCH = D.CCCUsePCH;
Daniel Dunbarcbc34b72009-10-15 20:02:44 +00003221
Aaron Ballman1f10cc52012-07-31 01:21:00 +00003222 if (JA.getType() == types::TY_Nothing)
3223 CmdArgs.push_back("-fsyntax-only");
3224 else if (UsePCH)
Douglas Gregor111af7d2009-04-18 00:34:01 +00003225 CmdArgs.push_back("-emit-pch");
3226 else
3227 CmdArgs.push_back("-emit-pth");
Ben Langmuir9b9a8d32014-02-06 18:53:25 +00003228 } else if (isa<VerifyPCHJobAction>(JA)) {
3229 CmdArgs.push_back("-verify-pch");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003230 } else {
Bob Wilson23a55f12014-12-21 07:00:00 +00003231 assert((isa<CompileJobAction>(JA) || isa<BackendJobAction>(JA)) &&
3232 "Invalid action for clang tool.");
Daniel Dunbard067f7f2009-04-08 23:54:23 +00003233
Renato Golin7c542b42015-07-27 23:44:45 +00003234 if (JA.getType() == types::TY_LTO_IR || JA.getType() == types::TY_LTO_BC) {
Teresa Johnson8749d8042015-07-06 16:23:00 +00003235 CmdArgs.push_back("-flto");
3236 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003237 if (JA.getType() == types::TY_Nothing) {
Ben Langmuir9b9a8d32014-02-06 18:53:25 +00003238 CmdArgs.push_back("-fsyntax-only");
Daniel Dunbar24e52992010-06-07 23:28:45 +00003239 } else if (JA.getType() == types::TY_LLVM_IR ||
3240 JA.getType() == types::TY_LTO_IR) {
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003241 CmdArgs.push_back("-emit-llvm");
Daniel Dunbar24e52992010-06-07 23:28:45 +00003242 } else if (JA.getType() == types::TY_LLVM_BC ||
3243 JA.getType() == types::TY_LTO_BC) {
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003244 CmdArgs.push_back("-emit-llvm-bc");
3245 } else if (JA.getType() == types::TY_PP_Asm) {
Daniel Dunbard112f102009-09-17 00:47:53 +00003246 CmdArgs.push_back("-S");
Daniel Dunbar6cdf83c2009-09-01 16:57:46 +00003247 } else if (JA.getType() == types::TY_AST) {
3248 CmdArgs.push_back("-emit-pch");
Douglas Gregorbf7fc9c2013-03-27 16:47:18 +00003249 } else if (JA.getType() == types::TY_ModuleFile) {
3250 CmdArgs.push_back("-module-file-info");
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00003251 } else if (JA.getType() == types::TY_RewrittenObjC) {
3252 CmdArgs.push_back("-rewrite-objc");
John McCall5fb5df92012-06-20 06:18:46 +00003253 rewriteKind = RK_NonFragile;
Fariborz Jahanian73223bb2012-04-02 15:59:19 +00003254 } else if (JA.getType() == types::TY_RewrittenLegacyObjC) {
3255 CmdArgs.push_back("-rewrite-objc");
John McCall5fb5df92012-06-20 06:18:46 +00003256 rewriteKind = RK_Fragile;
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00003257 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003258 assert(JA.getType() == types::TY_PP_Asm && "Unexpected output type!");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003259 }
Duncan P. N. Exon Smithd863f6f2015-04-14 18:30:13 +00003260
3261 // Preserve use-list order by default when emitting bitcode, so that
3262 // loading the bitcode up in 'opt' or 'llc' and running passes gives the
3263 // same result as running passes here. For LTO, we don't need to preserve
3264 // the use-list order, since serialization to bitcode is part of the flow.
Duncan P. N. Exon Smithbb618252015-04-15 01:16:18 +00003265 if (JA.getType() == types::TY_LLVM_BC)
3266 CmdArgs.push_back("-emit-llvm-uselists");
Daniel Dunbara3246a02009-03-18 08:07:30 +00003267 }
3268
Justin Bognera88f0122014-06-20 22:59:50 +00003269 // We normally speed up the clang process a bit by skipping destructors at
3270 // exit, but when we're generating diagnostics we can rely on some of the
3271 // cleanup.
3272 if (!C.isForDiagnostics())
3273 CmdArgs.push_back("-disable-free");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003274
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003275// Disable the verification pass in -asserts builds.
John McCallbb79b5f2010-02-13 03:50:24 +00003276#ifdef NDEBUG
3277 CmdArgs.push_back("-disable-llvm-verifier");
3278#endif
3279
Daniel Dunbar3b358a32009-04-08 05:11:16 +00003280 // Set the main file name, so that debug info works even with
3281 // -save-temps.
3282 CmdArgs.push_back("-main-file-name");
Artem Belevichba558952015-05-06 18:20:23 +00003283 CmdArgs.push_back(getBaseInputName(Args, Input));
Daniel Dunbar3b358a32009-04-08 05:11:16 +00003284
Daniel Dunbar17ddaa62009-04-08 18:03:55 +00003285 // Some flags which affect the language (via preprocessor
Bob Wilsondecc03e2012-11-23 06:14:39 +00003286 // defines).
Daniel Dunbar17ddaa62009-04-08 18:03:55 +00003287 if (Args.hasArg(options::OPT_static))
3288 CmdArgs.push_back("-static-define");
3289
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003290 if (isa<AnalyzeJobAction>(JA)) {
Ted Kremenek05e6f5b2009-09-25 05:55:59 +00003291 // Enable region store model by default.
3292 CmdArgs.push_back("-analyzer-store=region");
3293
Ted Kremenek7bea9a12009-12-07 22:26:14 +00003294 // Treat blocks as analysis entry points.
3295 CmdArgs.push_back("-analyzer-opt-analyze-nested-blocks");
3296
Ted Kremenek49c79792011-03-24 00:28:47 +00003297 CmdArgs.push_back("-analyzer-eagerly-assume");
3298
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003299 // Add default argument set.
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00003300 if (!Args.hasArg(options::OPT__analyzer_no_default_checks)) {
Argyrios Kyrtzidisa6d04d52011-02-15 07:42:33 +00003301 CmdArgs.push_back("-analyzer-checker=core");
Ted Kremenek49c79792011-03-24 00:28:47 +00003302
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00003303 if (!IsWindowsMSVC)
Argyrios Kyrtzidisa6d04d52011-02-15 07:42:33 +00003304 CmdArgs.push_back("-analyzer-checker=unix");
Ted Kremenek49c79792011-03-24 00:28:47 +00003305
Argyrios Kyrtzidisa6d04d52011-02-15 07:42:33 +00003306 if (getToolChain().getTriple().getVendor() == llvm::Triple::Apple)
Ted Kremenek49c79792011-03-24 00:28:47 +00003307 CmdArgs.push_back("-analyzer-checker=osx");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003308
Ted Kremenekb9ff6b22012-01-20 06:00:17 +00003309 CmdArgs.push_back("-analyzer-checker=deadcode");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003310
Artem Belevichba558952015-05-06 18:20:23 +00003311 if (types::isCXX(Input.getType()))
Jordan Rose10ad0812013-04-05 17:55:07 +00003312 CmdArgs.push_back("-analyzer-checker=cplusplus");
3313
Nico Webere8e53112014-05-11 01:04:02 +00003314 // Enable the following experimental checkers for testing.
3315 CmdArgs.push_back(
3316 "-analyzer-checker=security.insecureAPI.UncheckedReturn");
Ted Kremenek37e96522012-01-26 02:27:38 +00003317 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.getpw");
3318 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.gets");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003319 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.mktemp");
Ted Kremenek37e96522012-01-26 02:27:38 +00003320 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.mkstemp");
3321 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.vfork");
Gabor Horvathe3085992015-09-14 20:34:06 +00003322
3323 // Default nullability checks.
3324 CmdArgs.push_back("-analyzer-checker=nullability.NullPassedToNonnull");
3325 CmdArgs.push_back(
3326 "-analyzer-checker=nullability.NullReturnedFromNonnull");
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00003327 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00003328
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00003329 // Set the output format. The default is plist, for (lame) historical
3330 // reasons.
3331 CmdArgs.push_back("-analyzer-output");
3332 if (Arg *A = Args.getLastArg(options::OPT__analyzer_output))
Richard Smithbd55daf2012-11-01 04:30:05 +00003333 CmdArgs.push_back(A->getValue());
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00003334 else
3335 CmdArgs.push_back("plist");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003336
Ted Kremenekfe449a22010-03-22 22:32:05 +00003337 // Disable the presentation of standard compiler warnings when
3338 // using --analyze. We only want to show static analyzer diagnostics
3339 // or frontend errors.
3340 CmdArgs.push_back("-w");
3341
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003342 // Add -Xanalyzer arguments when running as analyzer.
3343 Args.AddAllArgValues(CmdArgs, options::OPT_Xanalyzer);
Mike Stump11289f42009-09-09 15:08:12 +00003344 }
3345
Daniel Dunbar4eadb602009-09-10 01:21:12 +00003346 CheckCodeGenerationOptions(D, Args);
3347
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003348 llvm::Reloc::Model RelocationModel;
3349 unsigned PICLevel;
3350 bool IsPIE;
3351 std::tie(RelocationModel, PICLevel, IsPIE) =
3352 ParsePICArgs(getToolChain(), Triple, Args);
Peter Collingbourne54d770c2013-04-09 04:35:11 +00003353
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003354 const char *RMName = RelocationModelName(RelocationModel);
3355 if (RMName) {
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003356 CmdArgs.push_back("-mrelocation-model");
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003357 CmdArgs.push_back(RMName);
3358 }
3359 if (PICLevel > 0) {
3360 CmdArgs.push_back("-pic-level");
3361 CmdArgs.push_back(PICLevel == 1 ? "1" : "2");
3362 if (IsPIE) {
3363 CmdArgs.push_back("-pie-level");
3364 CmdArgs.push_back(PICLevel == 1 ? "1" : "2");
Chandler Carruth76a943b2012-11-19 03:52:03 +00003365 }
Daniel Dunbar44e71222009-04-29 18:32:25 +00003366 }
Chandler Carruthc0c04552012-04-08 16:40:35 +00003367
Jonathan Roelofsb140a102014-10-03 21:57:44 +00003368 CmdArgs.push_back("-mthread-model");
3369 if (Arg *A = Args.getLastArg(options::OPT_mthread_model))
3370 CmdArgs.push_back(A->getValue());
3371 else
3372 CmdArgs.push_back(Args.MakeArgString(getToolChain().getThreadModel()));
3373
Michael Zolotukhinc888dd02015-03-17 20:03:11 +00003374 Args.AddLastArg(CmdArgs, options::OPT_fveclib);
3375
Tanya Lattnerf9d41df2009-11-04 01:18:09 +00003376 if (!Args.hasFlag(options::OPT_fmerge_all_constants,
3377 options::OPT_fno_merge_all_constants))
Chris Lattner9242b332011-04-08 18:06:54 +00003378 CmdArgs.push_back("-fno-merge-all-constants");
Daniel Dunbar306945d2009-09-16 06:17:29 +00003379
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003380 // LLVM Code Generator Options.
3381
Saleem Abdulrasool76a4b952015-01-09 05:10:20 +00003382 if (Args.hasArg(options::OPT_frewrite_map_file) ||
3383 Args.hasArg(options::OPT_frewrite_map_file_EQ)) {
Sean Silva14facf32015-06-09 01:57:17 +00003384 for (const Arg *A : Args.filtered(options::OPT_frewrite_map_file,
3385 options::OPT_frewrite_map_file_EQ)) {
Saleem Abdulrasool76a4b952015-01-09 05:10:20 +00003386 CmdArgs.push_back("-frewrite-map-file");
Sean Silva14facf32015-06-09 01:57:17 +00003387 CmdArgs.push_back(A->getValue());
3388 A->claim();
Saleem Abdulrasool76a4b952015-01-09 05:10:20 +00003389 }
3390 }
3391
Alp Tokerfb8d02b2014-06-05 22:10:59 +00003392 if (Arg *A = Args.getLastArg(options::OPT_Wframe_larger_than_EQ)) {
3393 StringRef v = A->getValue();
3394 CmdArgs.push_back("-mllvm");
3395 CmdArgs.push_back(Args.MakeArgString("-warn-stack-size=" + v));
3396 A->claim();
3397 }
3398
Daniel Dunbar0bb03312011-02-09 17:54:19 +00003399 if (Arg *A = Args.getLastArg(options::OPT_mregparm_EQ)) {
3400 CmdArgs.push_back("-mregparm");
Richard Smithbd55daf2012-11-01 04:30:05 +00003401 CmdArgs.push_back(A->getValue());
Daniel Dunbar0bb03312011-02-09 17:54:19 +00003402 }
3403
Nick Lewyckyd3f3e4f2013-06-25 01:49:44 +00003404 if (Arg *A = Args.getLastArg(options::OPT_fpcc_struct_return,
3405 options::OPT_freg_struct_return)) {
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00003406 if (getToolChain().getArch() != llvm::Triple::x86) {
John McCall1fe2a8c2013-06-18 02:46:29 +00003407 D.Diag(diag::err_drv_unsupported_opt_for_target)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003408 << A->getSpelling() << getToolChain().getTriple().str();
John McCall1fe2a8c2013-06-18 02:46:29 +00003409 } else if (A->getOption().matches(options::OPT_fpcc_struct_return)) {
3410 CmdArgs.push_back("-fpcc-struct-return");
3411 } else {
3412 assert(A->getOption().matches(options::OPT_freg_struct_return));
3413 CmdArgs.push_back("-freg-struct-return");
3414 }
3415 }
3416
Roman Divacky65b88cd2011-03-01 17:40:53 +00003417 if (Args.hasFlag(options::OPT_mrtd, options::OPT_mno_rtd, false))
3418 CmdArgs.push_back("-mrtd");
3419
Rafael Espindola224dd632011-12-14 21:02:23 +00003420 if (shouldUseFramePointer(Args, getToolChain().getTriple()))
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003421 CmdArgs.push_back("-mdisable-fp-elim");
3422 if (!Args.hasFlag(options::OPT_fzero_initialized_in_bss,
3423 options::OPT_fno_zero_initialized_in_bss))
3424 CmdArgs.push_back("-mno-zero-initialized-in-bss");
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003425
3426 bool OFastEnabled = isOptimizationLevelFast(Args);
3427 // If -Ofast is the optimization level, then -fstrict-aliasing should be
3428 // enabled. This alias option is being used to simplify the hasFlag logic.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003429 OptSpecifier StrictAliasingAliasOption =
3430 OFastEnabled ? options::OPT_Ofast : options::OPT_fstrict_aliasing;
Reid Kleckner2a24e3a2014-04-09 20:07:39 +00003431 // We turn strict aliasing off by default if we're in CL mode, since MSVC
3432 // doesn't do any TBAA.
3433 bool TBAAOnByDefault = !getToolChain().getDriver().IsCLMode();
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003434 if (!Args.hasFlag(options::OPT_fstrict_aliasing, StrictAliasingAliasOption,
Reid Kleckner2a24e3a2014-04-09 20:07:39 +00003435 options::OPT_fno_strict_aliasing, TBAAOnByDefault))
Dan Gohman10169b92010-10-14 22:36:56 +00003436 CmdArgs.push_back("-relaxed-aliasing");
Manman Renf5d9d342013-10-11 20:48:38 +00003437 if (!Args.hasFlag(options::OPT_fstruct_path_tbaa,
3438 options::OPT_fno_struct_path_tbaa))
3439 CmdArgs.push_back("-no-struct-path-tbaa");
Chandler Carruth8b4140d2012-03-27 23:58:37 +00003440 if (Args.hasFlag(options::OPT_fstrict_enums, options::OPT_fno_strict_enums,
3441 false))
3442 CmdArgs.push_back("-fstrict-enums");
Piotr Padlewski338c9d02015-09-15 21:46:47 +00003443 if (Args.hasFlag(options::OPT_fstrict_vtable_pointers,
3444 options::OPT_fno_strict_vtable_pointers,
3445 false))
3446 CmdArgs.push_back("-fstrict-vtable-pointers");
Nick Lewycky1c8c4362012-01-23 08:29:12 +00003447 if (!Args.hasFlag(options::OPT_foptimize_sibling_calls,
3448 options::OPT_fno_optimize_sibling_calls))
3449 CmdArgs.push_back("-mdisable-tail-calls");
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00003450
Eric Christopher006208c2013-04-04 06:29:47 +00003451 // Handle segmented stacks.
3452 if (Args.hasArg(options::OPT_fsplit_stack))
3453 CmdArgs.push_back("-split-stacks");
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003454
3455 // If -Ofast is the optimization level, then -ffast-math should be enabled.
3456 // This alias option is being used to simplify the getLastArg logic.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003457 OptSpecifier FastMathAliasOption =
3458 OFastEnabled ? options::OPT_Ofast : options::OPT_ffast_math;
3459
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003460 // Handle various floating point optimization flags, mapping them to the
3461 // appropriate LLVM code generation flags. The pattern for all of these is to
3462 // default off the codegen optimizations, and if any flag enables them and no
3463 // flag disables them after the flag enabling them, enable the codegen
3464 // optimization. This is complicated by several "umbrella" flags.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003465 if (Arg *A = Args.getLastArg(
3466 options::OPT_ffast_math, FastMathAliasOption,
3467 options::OPT_fno_fast_math, options::OPT_ffinite_math_only,
3468 options::OPT_fno_finite_math_only, options::OPT_fhonor_infinities,
3469 options::OPT_fno_honor_infinities))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003470 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3471 A->getOption().getID() != options::OPT_fno_finite_math_only &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003472 A->getOption().getID() != options::OPT_fhonor_infinities)
3473 CmdArgs.push_back("-menable-no-infs");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003474 if (Arg *A = Args.getLastArg(
3475 options::OPT_ffast_math, FastMathAliasOption,
3476 options::OPT_fno_fast_math, options::OPT_ffinite_math_only,
3477 options::OPT_fno_finite_math_only, options::OPT_fhonor_nans,
3478 options::OPT_fno_honor_nans))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003479 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3480 A->getOption().getID() != options::OPT_fno_finite_math_only &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003481 A->getOption().getID() != options::OPT_fhonor_nans)
3482 CmdArgs.push_back("-menable-no-nans");
3483
Benjamin Kramerc242ef22012-05-02 14:55:48 +00003484 // -fmath-errno is the default on some platforms, e.g. BSD-derived OSes.
3485 bool MathErrno = getToolChain().IsMathErrnoDefault();
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003486 if (Arg *A =
3487 Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
3488 options::OPT_fno_fast_math, options::OPT_fmath_errno,
3489 options::OPT_fno_math_errno)) {
Chandler Carruth0d4b9e62013-05-18 20:47:36 +00003490 // Turning on -ffast_math (with either flag) removes the need for MathErrno.
3491 // However, turning *off* -ffast_math merely restores the toolchain default
3492 // (which may be false).
3493 if (A->getOption().getID() == options::OPT_fno_math_errno ||
3494 A->getOption().getID() == options::OPT_ffast_math ||
3495 A->getOption().getID() == options::OPT_Ofast)
3496 MathErrno = false;
3497 else if (A->getOption().getID() == options::OPT_fmath_errno)
3498 MathErrno = true;
3499 }
Chandler Carruth3634c662012-04-26 02:10:51 +00003500 if (MathErrno)
3501 CmdArgs.push_back("-fmath-errno");
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003502
3503 // There are several flags which require disabling very specific
3504 // optimizations. Any of these being disabled forces us to turn off the
3505 // entire set of LLVM optimizations, so collect them through all the flag
3506 // madness.
3507 bool AssociativeMath = false;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003508 if (Arg *A = Args.getLastArg(
3509 options::OPT_ffast_math, FastMathAliasOption,
3510 options::OPT_fno_fast_math, options::OPT_funsafe_math_optimizations,
3511 options::OPT_fno_unsafe_math_optimizations,
3512 options::OPT_fassociative_math, options::OPT_fno_associative_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003513 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3514 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003515 A->getOption().getID() != options::OPT_fno_associative_math)
3516 AssociativeMath = true;
3517 bool ReciprocalMath = false;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003518 if (Arg *A = Args.getLastArg(
3519 options::OPT_ffast_math, FastMathAliasOption,
3520 options::OPT_fno_fast_math, options::OPT_funsafe_math_optimizations,
3521 options::OPT_fno_unsafe_math_optimizations,
3522 options::OPT_freciprocal_math, options::OPT_fno_reciprocal_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003523 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3524 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003525 A->getOption().getID() != options::OPT_fno_reciprocal_math)
3526 ReciprocalMath = true;
3527 bool SignedZeros = true;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003528 if (Arg *A = Args.getLastArg(
3529 options::OPT_ffast_math, FastMathAliasOption,
3530 options::OPT_fno_fast_math, options::OPT_funsafe_math_optimizations,
3531 options::OPT_fno_unsafe_math_optimizations,
3532 options::OPT_fsigned_zeros, options::OPT_fno_signed_zeros))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003533 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3534 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003535 A->getOption().getID() != options::OPT_fsigned_zeros)
3536 SignedZeros = false;
3537 bool TrappingMath = true;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003538 if (Arg *A = Args.getLastArg(
3539 options::OPT_ffast_math, FastMathAliasOption,
3540 options::OPT_fno_fast_math, options::OPT_funsafe_math_optimizations,
3541 options::OPT_fno_unsafe_math_optimizations,
3542 options::OPT_ftrapping_math, options::OPT_fno_trapping_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003543 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3544 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003545 A->getOption().getID() != options::OPT_ftrapping_math)
3546 TrappingMath = false;
3547 if (!MathErrno && AssociativeMath && ReciprocalMath && !SignedZeros &&
3548 !TrappingMath)
3549 CmdArgs.push_back("-menable-unsafe-fp-math");
3550
Sanjay Patel76c9e092015-01-23 16:40:50 +00003551 if (!SignedZeros)
3552 CmdArgs.push_back("-fno-signed-zeros");
Lang Hamesaa53b932012-07-06 00:59:19 +00003553
Sanjay Patel359b1052015-04-09 15:03:23 +00003554 if (ReciprocalMath)
3555 CmdArgs.push_back("-freciprocal-math");
3556
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003557 // Validate and pass through -fp-contract option.
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003558 if (Arg *A = Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003559 options::OPT_fno_fast_math,
Lang Hamesaa53b932012-07-06 00:59:19 +00003560 options::OPT_ffp_contract)) {
3561 if (A->getOption().getID() == options::OPT_ffp_contract) {
Richard Smithbd55daf2012-11-01 04:30:05 +00003562 StringRef Val = A->getValue();
Lang Hamesaa53b932012-07-06 00:59:19 +00003563 if (Val == "fast" || Val == "on" || Val == "off") {
3564 CmdArgs.push_back(Args.MakeArgString("-ffp-contract=" + Val));
3565 } else {
3566 D.Diag(diag::err_drv_unsupported_option_argument)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003567 << A->getOption().getName() << Val;
Lang Hamesaa53b932012-07-06 00:59:19 +00003568 }
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003569 } else if (A->getOption().matches(options::OPT_ffast_math) ||
3570 (OFastEnabled && A->getOption().matches(options::OPT_Ofast))) {
Lang Hamesaa53b932012-07-06 00:59:19 +00003571 // If fast-math is set then set the fp-contract mode to fast.
3572 CmdArgs.push_back(Args.MakeArgString("-ffp-contract=fast"));
3573 }
3574 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003575
Sanjay Patel2987c292015-06-11 14:53:41 +00003576 ParseMRecip(getToolChain().getDriver(), Args, CmdArgs);
Lang Hamesaa53b932012-07-06 00:59:19 +00003577
Bob Wilson6a039162012-07-19 03:52:53 +00003578 // We separately look for the '-ffast-math' and '-ffinite-math-only' flags,
3579 // and if we find them, tell the frontend to provide the appropriate
3580 // preprocessor macros. This is distinct from enabling any optimizations as
3581 // these options induce language changes which must survive serialization
3582 // and deserialization, etc.
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003583 if (Arg *A = Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
3584 options::OPT_fno_fast_math))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003585 if (!A->getOption().matches(options::OPT_fno_fast_math))
3586 CmdArgs.push_back("-ffast-math");
Nico Webere8e53112014-05-11 01:04:02 +00003587 if (Arg *A = Args.getLastArg(options::OPT_ffinite_math_only,
3588 options::OPT_fno_fast_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003589 if (A->getOption().matches(options::OPT_ffinite_math_only))
3590 CmdArgs.push_back("-ffinite-math-only");
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003591
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00003592 // Decide whether to use verbose asm. Verbose assembly is the default on
3593 // toolchains which have the integrated assembler on by default.
Saleem Abdulrasool42e4b592014-02-22 23:37:58 +00003594 bool IsIntegratedAssemblerDefault =
3595 getToolChain().IsIntegratedAssemblerDefault();
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00003596 if (Args.hasFlag(options::OPT_fverbose_asm, options::OPT_fno_verbose_asm,
Saleem Abdulrasool42e4b592014-02-22 23:37:58 +00003597 IsIntegratedAssemblerDefault) ||
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00003598 Args.hasArg(options::OPT_dA))
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003599 CmdArgs.push_back("-masm-verbose");
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00003600
Rafael Espindolab8a12932015-05-22 20:44:03 +00003601 if (!Args.hasFlag(options::OPT_fintegrated_as, options::OPT_fno_integrated_as,
3602 IsIntegratedAssemblerDefault))
Saleem Abdulrasool42e4b592014-02-22 23:37:58 +00003603 CmdArgs.push_back("-no-integrated-as");
3604
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003605 if (Args.hasArg(options::OPT_fdebug_pass_structure)) {
3606 CmdArgs.push_back("-mdebug-pass");
3607 CmdArgs.push_back("Structure");
3608 }
3609 if (Args.hasArg(options::OPT_fdebug_pass_arguments)) {
3610 CmdArgs.push_back("-mdebug-pass");
3611 CmdArgs.push_back("Arguments");
3612 }
3613
John McCall8517abc2010-02-19 02:45:38 +00003614 // Enable -mconstructor-aliases except on darwin, where we have to
3615 // work around a linker bug; see <rdar://problem/7651567>.
Bob Wilson6524dd32011-10-14 05:03:44 +00003616 if (!getToolChain().getTriple().isOSDarwin())
John McCall8517abc2010-02-19 02:45:38 +00003617 CmdArgs.push_back("-mconstructor-aliases");
NAKAMURA Takumi029d74b2011-02-17 08:50:50 +00003618
John McCall7ef5cb32011-03-18 02:56:14 +00003619 // Darwin's kernel doesn't support guard variables; just die if we
3620 // try to use them.
Bob Wilson6524dd32011-10-14 05:03:44 +00003621 if (KernelOrKext && getToolChain().getTriple().isOSDarwin())
John McCall7ef5cb32011-03-18 02:56:14 +00003622 CmdArgs.push_back("-fforbid-guard-variables");
3623
Douglas Gregordbe39272011-02-01 15:15:22 +00003624 if (Args.hasArg(options::OPT_mms_bitfields)) {
3625 CmdArgs.push_back("-mms-bitfields");
3626 }
John McCall8517abc2010-02-19 02:45:38 +00003627
Daniel Dunbar306945d2009-09-16 06:17:29 +00003628 // This is a coarse approximation of what llvm-gcc actually does, both
3629 // -fasynchronous-unwind-tables and -fnon-call-exceptions interact in more
3630 // complicated ways.
3631 bool AsynchronousUnwindTables =
Evgeniy Stepanov7429c592014-02-14 08:56:25 +00003632 Args.hasFlag(options::OPT_fasynchronous_unwind_tables,
3633 options::OPT_fno_asynchronous_unwind_tables,
3634 (getToolChain().IsUnwindTablesDefault() ||
3635 getToolChain().getSanitizerArgs().needsUnwindTables()) &&
3636 !KernelOrKext);
Daniel Dunbar306945d2009-09-16 06:17:29 +00003637 if (Args.hasFlag(options::OPT_funwind_tables, options::OPT_fno_unwind_tables,
3638 AsynchronousUnwindTables))
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003639 CmdArgs.push_back("-munwind-tables");
3640
Chandler Carruth05fb5852012-11-21 23:40:23 +00003641 getToolChain().addClangTargetOptions(Args, CmdArgs);
Rafael Espindola66aa0452012-06-19 01:26:10 +00003642
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003643 if (Arg *A = Args.getLastArg(options::OPT_flimited_precision_EQ)) {
3644 CmdArgs.push_back("-mlimit-float-precision");
Richard Smithbd55daf2012-11-01 04:30:05 +00003645 CmdArgs.push_back(A->getValue());
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003646 }
Daniel Dunbar44e71222009-04-29 18:32:25 +00003647
Daniel Dunbar4dbaaa62009-05-06 03:16:41 +00003648 // FIXME: Handle -mtune=.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003649 (void)Args.hasArg(options::OPT_mtune_EQ);
Daniel Dunbar44e71222009-04-29 18:32:25 +00003650
Benjamin Kramercf4371a2009-08-05 14:30:52 +00003651 if (Arg *A = Args.getLastArg(options::OPT_mcmodel_EQ)) {
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003652 CmdArgs.push_back("-mcode-model");
Richard Smithbd55daf2012-11-01 04:30:05 +00003653 CmdArgs.push_back(A->getValue());
Benjamin Kramercf4371a2009-08-05 14:30:52 +00003654 }
3655
Rafael Espindola22ce34a2013-08-20 22:12:08 +00003656 // Add the target cpu
Renato Golin7c542b42015-07-27 23:44:45 +00003657 std::string CPU = getCPUName(Args, Triple, /*FromAs*/ false);
Rafael Espindola22ce34a2013-08-20 22:12:08 +00003658 if (!CPU.empty()) {
3659 CmdArgs.push_back("-target-cpu");
3660 CmdArgs.push_back(Args.MakeArgString(CPU));
3661 }
3662
Rafael Espindolaeb265472013-08-21 21:59:03 +00003663 if (const Arg *A = Args.getLastArg(options::OPT_mfpmath_EQ)) {
3664 CmdArgs.push_back("-mfpmath");
3665 CmdArgs.push_back(A->getValue());
3666 }
3667
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00003668 // Add the target features
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00003669 getTargetFeatures(getToolChain(), Triple, Args, CmdArgs, false);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00003670
Rafael Espindola22ce34a2013-08-20 22:12:08 +00003671 // Add target specific flags.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003672 switch (getToolChain().getArch()) {
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00003673 default:
3674 break;
Daniel Dunbar4dbaaa62009-05-06 03:16:41 +00003675
Daniel Dunbar0f5c5422009-09-10 04:57:17 +00003676 case llvm::Triple::arm:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00003677 case llvm::Triple::armeb:
Daniel Dunbar0f5c5422009-09-10 04:57:17 +00003678 case llvm::Triple::thumb:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00003679 case llvm::Triple::thumbeb:
Saleem Abdulrasoolce63ce92015-09-19 18:19:44 +00003680 // Use the effective triple, which takes into account the deployment target.
3681 AddARMTargetArgs(Triple, Args, CmdArgs, KernelOrKext);
Daniel Dunbar0f5c5422009-09-10 04:57:17 +00003682 break;
3683
Tim Northover573cbee2014-05-24 12:52:07 +00003684 case llvm::Triple::aarch64:
3685 case llvm::Triple::aarch64_be:
Tim Northover573cbee2014-05-24 12:52:07 +00003686 AddAArch64TargetArgs(Args, CmdArgs);
Tim Northovera2ee4332014-03-29 15:09:45 +00003687 break;
3688
Eric Christopher0b26a612010-03-02 02:41:08 +00003689 case llvm::Triple::mips:
3690 case llvm::Triple::mipsel:
Akira Hatanaka94ab5542011-09-21 02:13:07 +00003691 case llvm::Triple::mips64:
3692 case llvm::Triple::mips64el:
Eric Christopher0b26a612010-03-02 02:41:08 +00003693 AddMIPSTargetArgs(Args, CmdArgs);
3694 break;
3695
Ulrich Weigand8afad612014-07-28 13:17:52 +00003696 case llvm::Triple::ppc:
3697 case llvm::Triple::ppc64:
3698 case llvm::Triple::ppc64le:
3699 AddPPCTargetArgs(Args, CmdArgs);
3700 break;
3701
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00003702 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00003703 case llvm::Triple::sparcel:
Brad Smith10cd0f42014-07-11 20:12:08 +00003704 case llvm::Triple::sparcv9:
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00003705 AddSparcTargetArgs(Args, CmdArgs);
3706 break;
3707
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00003708 case llvm::Triple::x86:
3709 case llvm::Triple::x86_64:
3710 AddX86TargetArgs(Args, CmdArgs);
3711 break;
Tony Linthicum76329bf2011-12-12 21:14:55 +00003712
3713 case llvm::Triple::hexagon:
3714 AddHexagonTargetArgs(Args, CmdArgs);
3715 break;
Daniel Dunbar44e71222009-04-29 18:32:25 +00003716 }
3717
Hans Wennborg75958c42013-08-08 00:17:41 +00003718 // Add clang-cl arguments.
3719 if (getToolChain().getDriver().IsCLMode())
3720 AddClangCLArgs(Args, CmdArgs);
3721
Daniel Dunbar976a2f52010-08-11 23:07:47 +00003722 // Pass the linker version in use.
3723 if (Arg *A = Args.getLastArg(options::OPT_mlinker_version_EQ)) {
3724 CmdArgs.push_back("-target-linker-version");
Richard Smithbd55daf2012-11-01 04:30:05 +00003725 CmdArgs.push_back(A->getValue());
Daniel Dunbar976a2f52010-08-11 23:07:47 +00003726 }
3727
Eric Christopherb7d97e92013-04-03 01:58:53 +00003728 if (!shouldUseLeafFramePointer(Args, getToolChain().getTriple()))
Daniel Dunbarbb7ac522010-07-01 01:31:45 +00003729 CmdArgs.push_back("-momit-leaf-frame-pointer");
3730
Daniel Dunbarfcc49a82010-05-12 18:19:58 +00003731 // Explicitly error on some things we know we don't support and can't just
3732 // ignore.
Artem Belevichba558952015-05-06 18:20:23 +00003733 types::ID InputType = Input.getType();
Daniel Dunbar4ed214a2010-09-24 19:39:37 +00003734 if (!Args.hasArg(options::OPT_fallow_unsupported)) {
3735 Arg *Unsupported;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003736 if (types::isCXX(InputType) && getToolChain().getTriple().isOSDarwin() &&
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00003737 getToolChain().getArch() == llvm::Triple::x86) {
Bob Wilson0d45f582011-08-13 23:48:55 +00003738 if ((Unsupported = Args.getLastArg(options::OPT_fapple_kext)) ||
3739 (Unsupported = Args.getLastArg(options::OPT_mkernel)))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00003740 D.Diag(diag::err_drv_clang_unsupported_opt_cxx_darwin_i386)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003741 << Unsupported->getOption().getName();
Daniel Dunbar4ed214a2010-09-24 19:39:37 +00003742 }
Daniel Dunbarfcc49a82010-05-12 18:19:58 +00003743 }
3744
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003745 Args.AddAllArgs(CmdArgs, options::OPT_v);
Daniel Dunbard4352752010-08-24 22:44:13 +00003746 Args.AddLastArg(CmdArgs, options::OPT_H);
Chad Rosierbe10f982011-08-02 17:58:04 +00003747 if (D.CCPrintHeaders && !D.CCGenDiagnostics) {
Daniel Dunbarac540b32011-02-02 21:11:35 +00003748 CmdArgs.push_back("-header-include-file");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003749 CmdArgs.push_back(D.CCPrintHeadersFilename ? D.CCPrintHeadersFilename
3750 : "-");
Daniel Dunbarac540b32011-02-02 21:11:35 +00003751 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003752 Args.AddLastArg(CmdArgs, options::OPT_P);
Mike Stump11289f42009-09-09 15:08:12 +00003753 Args.AddLastArg(CmdArgs, options::OPT_print_ivar_layout);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003754
Chad Rosierbe10f982011-08-02 17:58:04 +00003755 if (D.CCLogDiagnostics && !D.CCGenDiagnostics) {
Daniel Dunbar529c03b2011-04-07 18:01:20 +00003756 CmdArgs.push_back("-diagnostic-log-file");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003757 CmdArgs.push_back(D.CCLogDiagnosticsFilename ? D.CCLogDiagnosticsFilename
3758 : "-");
Daniel Dunbar529c03b2011-04-07 18:01:20 +00003759 }
3760
Manman Ren17bdb0f2013-11-20 20:22:14 +00003761 // Use the last option from "-g" group. "-gline-tables-only" and "-gdwarf-x"
3762 // are preserved, all other debug options are substituted with "-g".
Rafael Espindola08a692a2010-03-07 04:46:18 +00003763 Args.ClaimAllArgs(options::OPT_g_Group);
David Blaikiece3e7a62015-07-30 21:42:22 +00003764 Arg *SplitDwarfArg = Args.getLastArg(options::OPT_gsplit_dwarf);
Alexey Samsonovdda3a7f2012-05-29 08:10:34 +00003765 if (Arg *A = Args.getLastArg(options::OPT_g_Group)) {
Douglas Katzman9a2ef282015-09-30 15:55:59 +00003766 if (A->getOption().matches(options::OPT_gline_tables_only) &&
David Blaikiece3e7a62015-07-30 21:42:22 +00003767 (!SplitDwarfArg || A->getIndex() > SplitDwarfArg->getIndex())) {
Manman Ren17bdb0f2013-11-20 20:22:14 +00003768 // FIXME: we should support specifying dwarf version with
3769 // -gline-tables-only.
Alexey Samsonovdda3a7f2012-05-29 08:10:34 +00003770 CmdArgs.push_back("-gline-tables-only");
Alexander Eremin670c6272014-10-16 05:55:24 +00003771 // Default is dwarf-2 for Darwin, OpenBSD, FreeBSD and Solaris.
Brad Smith378e7f9b2014-06-13 03:35:37 +00003772 const llvm::Triple &Triple = getToolChain().getTriple();
3773 if (Triple.isOSDarwin() || Triple.getOS() == llvm::Triple::OpenBSD ||
Alexander Eremin670c6272014-10-16 05:55:24 +00003774 Triple.getOS() == llvm::Triple::FreeBSD ||
3775 Triple.getOS() == llvm::Triple::Solaris)
Adrian Prantl549c5142014-02-17 17:40:52 +00003776 CmdArgs.push_back("-gdwarf-2");
David Blaikiece3e7a62015-07-30 21:42:22 +00003777 SplitDwarfArg = nullptr;
Douglas Katzman553927a2015-09-14 20:31:28 +00003778 } else if (A->getOption().matches(options::OPT_gdwarf_2) ||
3779 A->getOption().matches(options::OPT_gdwarf_3) ||
3780 A->getOption().matches(options::OPT_gdwarf_4)) {
3781 A->render(Args, CmdArgs);
Douglas Katzman9a2ef282015-09-30 15:55:59 +00003782 } else if (!A->getOption().matches(options::OPT_g0)) {
Alexander Eremin670c6272014-10-16 05:55:24 +00003783 // Default is dwarf-2 for Darwin, OpenBSD, FreeBSD and Solaris.
Brad Smith378e7f9b2014-06-13 03:35:37 +00003784 const llvm::Triple &Triple = getToolChain().getTriple();
3785 if (Triple.isOSDarwin() || Triple.getOS() == llvm::Triple::OpenBSD ||
Alexander Eremin670c6272014-10-16 05:55:24 +00003786 Triple.getOS() == llvm::Triple::FreeBSD ||
3787 Triple.getOS() == llvm::Triple::Solaris)
Adrian Prantl549c5142014-02-17 17:40:52 +00003788 CmdArgs.push_back("-gdwarf-2");
3789 else
3790 CmdArgs.push_back("-g");
3791 }
Alexey Samsonovdda3a7f2012-05-29 08:10:34 +00003792 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003793
Reid Kleckner124955a2015-08-05 18:51:13 +00003794 // Forward -gcodeview.
3795 Args.AddLastArg(CmdArgs, options::OPT_gcodeview);
3796
Alexey Samsonovf50a9ff2012-06-21 08:22:39 +00003797 // We ignore flags -gstrict-dwarf and -grecord-gcc-switches for now.
3798 Args.ClaimAllArgs(options::OPT_g_flags_Group);
Diego Novillo94b276d2014-07-10 23:29:28 +00003799 if (Args.hasFlag(options::OPT_gcolumn_info, options::OPT_gno_column_info,
Greg Bedwell80b325c2015-09-25 16:11:00 +00003800 /*Default*/ true))
Eric Christophera2f7eb72012-10-18 21:52:18 +00003801 CmdArgs.push_back("-dwarf-column-info");
Alexey Samsonovf50a9ff2012-06-21 08:22:39 +00003802
Eric Christopher138c32b2013-09-13 22:37:55 +00003803 // FIXME: Move backend command line options to the module.
Adrian Prantl6b21ab22015-08-27 19:46:20 +00003804 if (Args.hasArg(options::OPT_gmodules)) {
3805 CmdArgs.push_back("-g");
3806 CmdArgs.push_back("-dwarf-ext-refs");
3807 CmdArgs.push_back("-fmodule-format=obj");
3808 }
3809
Eric Christopher2ba5fcb2013-02-05 07:29:57 +00003810 // -gsplit-dwarf should turn on -g and enable the backend dwarf
3811 // splitting and extraction.
Eric Christopherd42fb732013-02-21 22:35:05 +00003812 // FIXME: Currently only works on Linux.
David Blaikiece3e7a62015-07-30 21:42:22 +00003813 if (getToolChain().getTriple().isOSLinux() && SplitDwarfArg) {
Eric Christopher2ba5fcb2013-02-05 07:29:57 +00003814 CmdArgs.push_back("-g");
3815 CmdArgs.push_back("-backend-option");
3816 CmdArgs.push_back("-split-dwarf=Enable");
3817 }
3818
Eric Christopher138c32b2013-09-13 22:37:55 +00003819 // -ggnu-pubnames turns on gnu style pubnames in the backend.
3820 if (Args.hasArg(options::OPT_ggnu_pubnames)) {
3821 CmdArgs.push_back("-backend-option");
3822 CmdArgs.push_back("-generate-gnu-dwarf-pub-sections");
3823 }
Eric Christophereec89c22013-06-18 00:03:50 +00003824
Eric Christopher0d403d22014-02-14 01:27:03 +00003825 // -gdwarf-aranges turns on the emission of the aranges section in the
3826 // backend.
Greg Bedwell80b325c2015-09-25 16:11:00 +00003827 if (Args.hasArg(options::OPT_gdwarf_aranges)) {
Eric Christopher0d403d22014-02-14 01:27:03 +00003828 CmdArgs.push_back("-backend-option");
3829 CmdArgs.push_back("-generate-arange-section");
3830 }
3831
David Blaikief36d9ba2014-01-27 18:52:43 +00003832 if (Args.hasFlag(options::OPT_fdebug_types_section,
3833 options::OPT_fno_debug_types_section, false)) {
David Blaikied74be702014-01-18 02:02:06 +00003834 CmdArgs.push_back("-backend-option");
3835 CmdArgs.push_back("-generate-type-units");
3836 }
Eric Christophereec89c22013-06-18 00:03:50 +00003837
Ed Schouten6e576152015-03-26 17:50:28 +00003838 // CloudABI uses -ffunction-sections and -fdata-sections by default.
3839 bool UseSeparateSections = Triple.getOS() == llvm::Triple::CloudABI;
3840
Evgeniy Stepanov9e7cb332014-02-03 11:11:37 +00003841 if (Args.hasFlag(options::OPT_ffunction_sections,
Ed Schouten6e576152015-03-26 17:50:28 +00003842 options::OPT_fno_function_sections, UseSeparateSections)) {
Evgeniy Stepanov9e7cb332014-02-03 11:11:37 +00003843 CmdArgs.push_back("-ffunction-sections");
3844 }
3845
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003846 if (Args.hasFlag(options::OPT_fdata_sections, options::OPT_fno_data_sections,
3847 UseSeparateSections)) {
Evgeniy Stepanov9e7cb332014-02-03 11:11:37 +00003848 CmdArgs.push_back("-fdata-sections");
3849 }
Rafael Espindola66bfb2752010-05-06 21:06:04 +00003850
Rafael Espindola6b07a1c2015-02-20 18:08:57 +00003851 if (!Args.hasFlag(options::OPT_funique_section_names,
Rafael Espindolab8a12932015-05-22 20:44:03 +00003852 options::OPT_fno_unique_section_names, true))
Rafael Espindola6b07a1c2015-02-20 18:08:57 +00003853 CmdArgs.push_back("-fno-unique-section-names");
3854
Chris Lattner3c77a352010-06-22 00:03:40 +00003855 Args.AddAllArgs(CmdArgs, options::OPT_finstrument_functions);
3856
Diego Novilloa0545962015-07-10 18:00:07 +00003857 addPGOAndCoverageFlags(C, D, Output, Args, CmdArgs);
Nick Lewycky480cb992011-05-04 20:46:58 +00003858
Daniel Dunbarb25bfde2011-10-11 18:20:10 +00003859 // Pass options for controlling the default header search paths.
3860 if (Args.hasArg(options::OPT_nostdinc)) {
3861 CmdArgs.push_back("-nostdsysteminc");
3862 CmdArgs.push_back("-nobuiltininc");
3863 } else {
Daniel Dunbar0f41eee2011-10-11 18:20:16 +00003864 if (Args.hasArg(options::OPT_nostdlibinc))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003865 CmdArgs.push_back("-nostdsysteminc");
Daniel Dunbarb25bfde2011-10-11 18:20:10 +00003866 Args.AddLastArg(CmdArgs, options::OPT_nostdincxx);
3867 Args.AddLastArg(CmdArgs, options::OPT_nobuiltininc);
3868 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003869
Daniel Dunbar34e0b8c2009-12-15 01:02:52 +00003870 // Pass the path to compiler resource files.
Daniel Dunbar34e0b8c2009-12-15 01:02:52 +00003871 CmdArgs.push_back("-resource-dir");
Daniel Dunbar3f3e2cd2010-01-20 02:35:16 +00003872 CmdArgs.push_back(D.ResourceDir.c_str());
Daniel Dunbar9dc82a22009-04-07 21:42:00 +00003873
Argyrios Kyrtzidis71731d62010-11-03 22:45:23 +00003874 Args.AddLastArg(CmdArgs, options::OPT_working_directory);
3875
Ted Kremenekf7639e12012-03-06 20:06:33 +00003876 bool ARCMTEnabled = false;
Argyrios Kyrtzidis85230d52013-09-17 19:14:29 +00003877 if (!Args.hasArg(options::OPT_fno_objc_arc, options::OPT_fobjc_arc)) {
Argyrios Kyrtzidisc44b93d2011-07-07 04:00:39 +00003878 if (const Arg *A = Args.getLastArg(options::OPT_ccc_arcmt_check,
Argyrios Kyrtzidis7fbd97f2011-07-09 20:00:58 +00003879 options::OPT_ccc_arcmt_modify,
3880 options::OPT_ccc_arcmt_migrate)) {
Ted Kremenekf7639e12012-03-06 20:06:33 +00003881 ARCMTEnabled = true;
John McCalld70fb982011-06-15 23:25:17 +00003882 switch (A->getOption().getID()) {
3883 default:
3884 llvm_unreachable("missed a case");
Argyrios Kyrtzidisc44b93d2011-07-07 04:00:39 +00003885 case options::OPT_ccc_arcmt_check:
John McCalld70fb982011-06-15 23:25:17 +00003886 CmdArgs.push_back("-arcmt-check");
3887 break;
Argyrios Kyrtzidisc44b93d2011-07-07 04:00:39 +00003888 case options::OPT_ccc_arcmt_modify:
John McCalld70fb982011-06-15 23:25:17 +00003889 CmdArgs.push_back("-arcmt-modify");
3890 break;
Argyrios Kyrtzidis7fbd97f2011-07-09 20:00:58 +00003891 case options::OPT_ccc_arcmt_migrate:
3892 CmdArgs.push_back("-arcmt-migrate");
Ted Kremenekf7639e12012-03-06 20:06:33 +00003893 CmdArgs.push_back("-mt-migrate-directory");
Richard Smithbd55daf2012-11-01 04:30:05 +00003894 CmdArgs.push_back(A->getValue());
Argyrios Kyrtzidisd5713632011-07-19 17:20:03 +00003895
3896 Args.AddLastArg(CmdArgs, options::OPT_arcmt_migrate_report_output);
3897 Args.AddLastArg(CmdArgs, options::OPT_arcmt_migrate_emit_arc_errors);
Argyrios Kyrtzidis7fbd97f2011-07-09 20:00:58 +00003898 break;
John McCalld70fb982011-06-15 23:25:17 +00003899 }
3900 }
Argyrios Kyrtzidisb11a1922013-06-24 19:01:18 +00003901 } else {
3902 Args.ClaimAllArgs(options::OPT_ccc_arcmt_check);
3903 Args.ClaimAllArgs(options::OPT_ccc_arcmt_modify);
3904 Args.ClaimAllArgs(options::OPT_ccc_arcmt_migrate);
John McCalld70fb982011-06-15 23:25:17 +00003905 }
Eric Christopher84fbdb42011-08-19 00:30:14 +00003906
Ted Kremenekf7639e12012-03-06 20:06:33 +00003907 if (const Arg *A = Args.getLastArg(options::OPT_ccc_objcmt_migrate)) {
3908 if (ARCMTEnabled) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003909 D.Diag(diag::err_drv_argument_not_allowed_with) << A->getAsString(Args)
3910 << "-ccc-arcmt-migrate";
Ted Kremenekf7639e12012-03-06 20:06:33 +00003911 }
3912 CmdArgs.push_back("-mt-migrate-directory");
Richard Smithbd55daf2012-11-01 04:30:05 +00003913 CmdArgs.push_back(A->getValue());
Ted Kremenekf7639e12012-03-06 20:06:33 +00003914
3915 if (!Args.hasArg(options::OPT_objcmt_migrate_literals,
Fariborz Jahaniand83ef842013-07-09 16:59:14 +00003916 options::OPT_objcmt_migrate_subscripting,
3917 options::OPT_objcmt_migrate_property)) {
Ted Kremenekf7639e12012-03-06 20:06:33 +00003918 // None specified, means enable them all.
3919 CmdArgs.push_back("-objcmt-migrate-literals");
3920 CmdArgs.push_back("-objcmt-migrate-subscripting");
Fariborz Jahaniand83ef842013-07-09 16:59:14 +00003921 CmdArgs.push_back("-objcmt-migrate-property");
Ted Kremenekf7639e12012-03-06 20:06:33 +00003922 } else {
3923 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_literals);
3924 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_subscripting);
Fariborz Jahaniand83ef842013-07-09 16:59:14 +00003925 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_property);
Ted Kremenekf7639e12012-03-06 20:06:33 +00003926 }
Argyrios Kyrtzidis55ecf992013-11-13 23:38:20 +00003927 } else {
3928 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_literals);
3929 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_subscripting);
3930 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_property);
3931 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_all);
3932 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_readonly_property);
3933 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_readwrite_property);
Fariborz Jahanian773fa2c2015-03-03 17:15:38 +00003934 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_property_dot_syntax);
Argyrios Kyrtzidis55ecf992013-11-13 23:38:20 +00003935 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_annotation);
3936 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_instancetype);
3937 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_nsmacros);
3938 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_protocol_conformance);
3939 Args.AddLastArg(CmdArgs, options::OPT_objcmt_atomic_property);
3940 Args.AddLastArg(CmdArgs, options::OPT_objcmt_returns_innerpointer_property);
3941 Args.AddLastArg(CmdArgs, options::OPT_objcmt_ns_nonatomic_iosonly);
Argyrios Kyrtzidis74aa02562013-12-11 01:29:48 +00003942 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_designated_init);
Argyrios Kyrtzidisd5ba86b2013-12-10 18:36:53 +00003943 Args.AddLastArg(CmdArgs, options::OPT_objcmt_whitelist_dir_path);
Ted Kremenekf7639e12012-03-06 20:06:33 +00003944 }
3945
Daniel Dunbard067f7f2009-04-08 23:54:23 +00003946 // Add preprocessing options like -I, -D, etc. if we are using the
3947 // preprocessor.
3948 //
3949 // FIXME: Support -fpreprocessed
Daniel Dunbard067f7f2009-04-08 23:54:23 +00003950 if (types::getPreprocessedType(InputType) != types::TY_INVALID)
Chad Rosier633dcdc2013-01-24 19:14:47 +00003951 AddPreprocessingOptions(C, JA, D, Args, CmdArgs, Output, Inputs);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003952
Rafael Espindolaa7431922011-07-21 23:40:37 +00003953 // Don't warn about "clang -c -DPIC -fPIC test.i" because libtool.m4 assumes
3954 // that "The compiler can only warn and ignore the option if not recognized".
3955 // When building with ccache, it will pass -D options to clang even on
3956 // preprocessed inputs and configure concludes that -fPIC is not supported.
3957 Args.ClaimAllArgs(options::OPT_D);
3958
Alp Toker7874bdc2013-11-15 20:40:58 +00003959 // Manually translate -O4 to -O3; let clang reject others.
Rafael Espindolaad70d962013-08-27 16:58:15 +00003960 if (Arg *A = Args.getLastArg(options::OPT_O_Group)) {
3961 if (A->getOption().matches(options::OPT_O4)) {
3962 CmdArgs.push_back("-O3");
3963 D.Diag(diag::warn_O4_is_O3);
3964 } else {
3965 A->render(Args, CmdArgs);
3966 }
3967 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003968
Sylvestre Ledru2fe501e2014-07-11 11:43:57 +00003969 // Warn about ignored options to clang.
Sean Silva14facf32015-06-09 01:57:17 +00003970 for (const Arg *A :
3971 Args.filtered(options::OPT_clang_ignored_gcc_optimization_f_Group)) {
3972 D.Diag(diag::warn_ignored_gcc_optimization) << A->getAsString(Args);
Douglas Katzman8b50e012015-08-05 18:03:47 +00003973 A->claim();
Sylvestre Ledru2fe501e2014-07-11 11:43:57 +00003974 }
3975
Rafael Espindola577637a2015-01-03 00:06:04 +00003976 claimNoWarnArgs(Args);
Chad Rosier86b82082012-12-12 20:06:31 +00003977
Richard Smith3be1cb22014-08-07 00:24:21 +00003978 Args.AddAllArgs(CmdArgs, options::OPT_R_Group);
Daniel Dunbar945577c2009-10-29 02:24:45 +00003979 Args.AddAllArgs(CmdArgs, options::OPT_W_Group);
Ted Kremenekb22ea2a2012-07-07 05:53:30 +00003980 if (Args.hasFlag(options::OPT_pedantic, options::OPT_no_pedantic, false))
3981 CmdArgs.push_back("-pedantic");
Daniel Dunbar945577c2009-10-29 02:24:45 +00003982 Args.AddLastArg(CmdArgs, options::OPT_pedantic_errors);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003983 Args.AddLastArg(CmdArgs, options::OPT_w);
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00003984
3985 // Handle -{std, ansi, trigraphs} -- take the last of -{std, ansi}
Hans Wennborgec993822013-07-31 16:57:56 +00003986 // (-ansi is equivalent to -std=c89 or -std=c++98).
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00003987 //
3988 // If a std is supplied, only add -trigraphs if it follows the
3989 // option.
David Majnemer8db91762015-05-18 04:49:30 +00003990 bool ImplyVCPPCXXVer = false;
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00003991 if (Arg *Std = Args.getLastArg(options::OPT_std_EQ, options::OPT_ansi)) {
3992 if (Std->getOption().matches(options::OPT_ansi))
Nuno Lopes275225d2009-10-16 14:28:06 +00003993 if (types::isCXX(InputType))
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00003994 CmdArgs.push_back("-std=c++98");
Nuno Lopes275225d2009-10-16 14:28:06 +00003995 else
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00003996 CmdArgs.push_back("-std=c89");
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00003997 else
3998 Std->render(Args, CmdArgs);
3999
Nico Weber00721502014-12-23 22:32:37 +00004000 // If -f(no-)trigraphs appears after the language standard flag, honor it.
Daniel Dunbar3f1a1ff2010-06-14 21:23:08 +00004001 if (Arg *A = Args.getLastArg(options::OPT_std_EQ, options::OPT_ansi,
Nico Weber00721502014-12-23 22:32:37 +00004002 options::OPT_ftrigraphs,
4003 options::OPT_fno_trigraphs))
Daniel Dunbar3f1a1ff2010-06-14 21:23:08 +00004004 if (A != Std)
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004005 A->render(Args, CmdArgs);
Daniel Dunbar72a60902009-04-26 01:10:38 +00004006 } else {
4007 // Honor -std-default.
Daniel Dunbar12998192010-01-29 21:03:02 +00004008 //
4009 // FIXME: Clang doesn't correctly handle -std= when the input language
4010 // doesn't match. For the time being just ignore this for C++ inputs;
4011 // eventually we want to do all the standard defaulting here instead of
4012 // splitting it between the driver and clang -cc1.
4013 if (!types::isCXX(InputType))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004014 Args.AddAllArgsTranslated(CmdArgs, options::OPT_std_default_EQ, "-std=",
4015 /*Joined=*/true);
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00004016 else if (IsWindowsMSVC)
David Majnemer8db91762015-05-18 04:49:30 +00004017 ImplyVCPPCXXVer = true;
Nico Weber723b4f02012-08-30 02:08:31 +00004018
Nico Weber00721502014-12-23 22:32:37 +00004019 Args.AddLastArg(CmdArgs, options::OPT_ftrigraphs,
4020 options::OPT_fno_trigraphs);
Daniel Dunbar72a60902009-04-26 01:10:38 +00004021 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004022
Richard Smith282b4492013-09-04 22:50:31 +00004023 // GCC's behavior for -Wwrite-strings is a bit strange:
4024 // * In C, this "warning flag" changes the types of string literals from
4025 // 'char[N]' to 'const char[N]', and thus triggers an unrelated warning
4026 // for the discarded qualifier.
4027 // * In C++, this is just a normal warning flag.
4028 //
4029 // Implementing this warning correctly in C is hard, so we follow GCC's
4030 // behavior for now. FIXME: Directly diagnose uses of a string literal as
4031 // a non-const char* in C, rather than using this crude hack.
4032 if (!types::isCXX(InputType)) {
Argyrios Kyrtzidis25f2afde2014-02-07 08:33:28 +00004033 // FIXME: This should behave just like a warning flag, and thus should also
4034 // respect -Weverything, -Wno-everything, -Werror=write-strings, and so on.
4035 Arg *WriteStrings =
4036 Args.getLastArg(options::OPT_Wwrite_strings,
4037 options::OPT_Wno_write_strings, options::OPT_w);
4038 if (WriteStrings &&
4039 WriteStrings->getOption().matches(options::OPT_Wwrite_strings))
Richard Smith282b4492013-09-04 22:50:31 +00004040 CmdArgs.push_back("-fconst-strings");
Chandler Carruthb009b142011-04-23 06:30:43 +00004041 }
4042
Chandler Carruth61fbf622011-04-23 09:27:53 +00004043 // GCC provides a macro definition '__DEPRECATED' when -Wdeprecated is active
Chandler Carruth30483fb2011-04-23 19:48:40 +00004044 // during C++ compilation, which it is by default. GCC keeps this define even
4045 // in the presence of '-w', match this behavior bug-for-bug.
4046 if (types::isCXX(InputType) &&
4047 Args.hasFlag(options::OPT_Wdeprecated, options::OPT_Wno_deprecated,
4048 true)) {
4049 CmdArgs.push_back("-fdeprecated-macro");
Chandler Carruth61fbf622011-04-23 09:27:53 +00004050 }
4051
Chandler Carruthe0391482010-05-22 02:21:53 +00004052 // Translate GCC's misnamer '-fasm' arguments to '-fgnu-keywords'.
4053 if (Arg *Asm = Args.getLastArg(options::OPT_fasm, options::OPT_fno_asm)) {
4054 if (Asm->getOption().matches(options::OPT_fasm))
4055 CmdArgs.push_back("-fgnu-keywords");
4056 else
4057 CmdArgs.push_back("-fno-gnu-keywords");
4058 }
4059
Nick Lewycky1d617ac2011-10-17 23:05:52 +00004060 if (ShouldDisableDwarfDirectory(Args, getToolChain()))
4061 CmdArgs.push_back("-fno-dwarf-directory-asm");
4062
Daniel Dunbare246fbe2013-04-16 18:21:19 +00004063 if (ShouldDisableAutolink(Args, getToolChain()))
4064 CmdArgs.push_back("-fno-autolink");
4065
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00004066 // Add in -fdebug-compilation-dir if necessary.
4067 addDebugCompDirArg(Args, CmdArgs);
Nick Lewyckyba743b72011-10-21 02:32:14 +00004068
Richard Smith9a568822011-11-21 19:36:32 +00004069 if (Arg *A = Args.getLastArg(options::OPT_ftemplate_depth_,
4070 options::OPT_ftemplate_depth_EQ)) {
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004071 CmdArgs.push_back("-ftemplate-depth");
Richard Smithbd55daf2012-11-01 04:30:05 +00004072 CmdArgs.push_back(A->getValue());
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004073 }
4074
Richard Smith79c927b2013-11-06 19:31:51 +00004075 if (Arg *A = Args.getLastArg(options::OPT_foperator_arrow_depth_EQ)) {
4076 CmdArgs.push_back("-foperator-arrow-depth");
4077 CmdArgs.push_back(A->getValue());
4078 }
4079
Richard Smith9a568822011-11-21 19:36:32 +00004080 if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_depth_EQ)) {
4081 CmdArgs.push_back("-fconstexpr-depth");
Richard Smithbd55daf2012-11-01 04:30:05 +00004082 CmdArgs.push_back(A->getValue());
Richard Smith9a568822011-11-21 19:36:32 +00004083 }
4084
Richard Smitha3d3bd22013-05-08 02:12:03 +00004085 if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_steps_EQ)) {
4086 CmdArgs.push_back("-fconstexpr-steps");
4087 CmdArgs.push_back(A->getValue());
4088 }
4089
Richard Smithb3a14522013-02-22 01:59:51 +00004090 if (Arg *A = Args.getLastArg(options::OPT_fbracket_depth_EQ)) {
4091 CmdArgs.push_back("-fbracket-depth");
4092 CmdArgs.push_back(A->getValue());
4093 }
4094
Argyrios Kyrtzidisef6c8da2010-11-18 00:20:36 +00004095 if (Arg *A = Args.getLastArg(options::OPT_Wlarge_by_value_copy_EQ,
4096 options::OPT_Wlarge_by_value_copy_def)) {
Jean-Daniel Dupas73d801c2012-05-04 08:08:37 +00004097 if (A->getNumValues()) {
Richard Smithbd55daf2012-11-01 04:30:05 +00004098 StringRef bytes = A->getValue();
Jean-Daniel Dupas73d801c2012-05-04 08:08:37 +00004099 CmdArgs.push_back(Args.MakeArgString("-Wlarge-by-value-copy=" + bytes));
4100 } else
4101 CmdArgs.push_back("-Wlarge-by-value-copy=64"); // default value
Argyrios Kyrtzidisaf84ec02010-11-17 23:11:54 +00004102 }
4103
Michael J. Spencer929fccd2012-10-22 22:13:48 +00004104 if (Args.hasArg(options::OPT_relocatable_pch))
Daniel Dunbar8bed86c2009-11-20 22:21:36 +00004105 CmdArgs.push_back("-relocatable-pch");
Mike Stump11289f42009-09-09 15:08:12 +00004106
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004107 if (Arg *A = Args.getLastArg(options::OPT_fconstant_string_class_EQ)) {
4108 CmdArgs.push_back("-fconstant-string-class");
Richard Smithbd55daf2012-11-01 04:30:05 +00004109 CmdArgs.push_back(A->getValue());
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004110 }
David Chisnall5778fce2009-08-31 16:41:57 +00004111
Chris Lattnere23003d2010-01-09 21:54:33 +00004112 if (Arg *A = Args.getLastArg(options::OPT_ftabstop_EQ)) {
4113 CmdArgs.push_back("-ftabstop");
Richard Smithbd55daf2012-11-01 04:30:05 +00004114 CmdArgs.push_back(A->getValue());
Chris Lattnere23003d2010-01-09 21:54:33 +00004115 }
4116
Chris Lattnerb35583d2010-04-07 20:49:23 +00004117 CmdArgs.push_back("-ferror-limit");
4118 if (Arg *A = Args.getLastArg(options::OPT_ferror_limit_EQ))
Richard Smithbd55daf2012-11-01 04:30:05 +00004119 CmdArgs.push_back(A->getValue());
Chris Lattnerb35583d2010-04-07 20:49:23 +00004120 else
4121 CmdArgs.push_back("19");
Douglas Gregorffed1cb2010-04-20 07:18:24 +00004122
Chandler Carrutha77a7272010-05-06 04:55:18 +00004123 if (Arg *A = Args.getLastArg(options::OPT_fmacro_backtrace_limit_EQ)) {
4124 CmdArgs.push_back("-fmacro-backtrace-limit");
Richard Smithbd55daf2012-11-01 04:30:05 +00004125 CmdArgs.push_back(A->getValue());
Chandler Carrutha77a7272010-05-06 04:55:18 +00004126 }
4127
4128 if (Arg *A = Args.getLastArg(options::OPT_ftemplate_backtrace_limit_EQ)) {
4129 CmdArgs.push_back("-ftemplate-backtrace-limit");
Richard Smithbd55daf2012-11-01 04:30:05 +00004130 CmdArgs.push_back(A->getValue());
Chandler Carrutha77a7272010-05-06 04:55:18 +00004131 }
4132
Richard Smithf6f003a2011-12-16 19:06:07 +00004133 if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_backtrace_limit_EQ)) {
4134 CmdArgs.push_back("-fconstexpr-backtrace-limit");
Richard Smithbd55daf2012-11-01 04:30:05 +00004135 CmdArgs.push_back(A->getValue());
Richard Smithf6f003a2011-12-16 19:06:07 +00004136 }
4137
Nick Lewycky24653262014-12-16 21:39:02 +00004138 if (Arg *A = Args.getLastArg(options::OPT_fspell_checking_limit_EQ)) {
4139 CmdArgs.push_back("-fspell-checking-limit");
4140 CmdArgs.push_back(A->getValue());
4141 }
4142
Daniel Dunbar2c978472009-11-04 06:24:47 +00004143 // Pass -fmessage-length=.
Daniel Dunbar84bb7932009-11-30 08:40:54 +00004144 CmdArgs.push_back("-fmessage-length");
Daniel Dunbar2c978472009-11-04 06:24:47 +00004145 if (Arg *A = Args.getLastArg(options::OPT_fmessage_length_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00004146 CmdArgs.push_back(A->getValue());
Daniel Dunbar2c978472009-11-04 06:24:47 +00004147 } else {
4148 // If -fmessage-length=N was not specified, determine whether this is a
4149 // terminal and, if so, implicitly define -fmessage-length appropriately.
4150 unsigned N = llvm::sys::Process::StandardErrColumns();
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004151 CmdArgs.push_back(Args.MakeArgString(Twine(N)));
Daniel Dunbar2c978472009-11-04 06:24:47 +00004152 }
4153
John McCallb4a99d32013-02-19 01:57:35 +00004154 // -fvisibility= and -fvisibility-ms-compat are of a piece.
4155 if (const Arg *A = Args.getLastArg(options::OPT_fvisibility_EQ,
4156 options::OPT_fvisibility_ms_compat)) {
4157 if (A->getOption().matches(options::OPT_fvisibility_EQ)) {
4158 CmdArgs.push_back("-fvisibility");
4159 CmdArgs.push_back(A->getValue());
4160 } else {
4161 assert(A->getOption().matches(options::OPT_fvisibility_ms_compat));
4162 CmdArgs.push_back("-fvisibility");
4163 CmdArgs.push_back("hidden");
4164 CmdArgs.push_back("-ftype-visibility");
4165 CmdArgs.push_back("default");
4166 }
Daniel Dunbare357d562009-12-03 18:42:11 +00004167 }
4168
Douglas Gregor08329632010-06-15 17:05:35 +00004169 Args.AddLastArg(CmdArgs, options::OPT_fvisibility_inlines_hidden);
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00004170
Hans Wennborgf60f6af2012-06-28 08:01:44 +00004171 Args.AddLastArg(CmdArgs, options::OPT_ftlsmodel_EQ);
4172
Daniel Dunbare46b52a2010-03-20 04:52:14 +00004173 // -fhosted is default.
Chad Rosier4fab82c2012-03-26 22:04:46 +00004174 if (Args.hasFlag(options::OPT_ffreestanding, options::OPT_fhosted, false) ||
4175 KernelOrKext)
Daniel Dunbare46b52a2010-03-20 04:52:14 +00004176 CmdArgs.push_back("-ffreestanding");
4177
Daniel Dunbare357d562009-12-03 18:42:11 +00004178 // Forward -f (flag) options which we can pass directly.
Daniel Dunbar3a148f22009-04-07 21:51:40 +00004179 Args.AddLastArg(CmdArgs, options::OPT_femit_all_decls);
Daniel Dunbar3a148f22009-04-07 21:51:40 +00004180 Args.AddLastArg(CmdArgs, options::OPT_fheinous_gnu_extensions);
Adrian Prantla7634472014-01-07 01:19:08 +00004181 Args.AddLastArg(CmdArgs, options::OPT_fstandalone_debug);
4182 Args.AddLastArg(CmdArgs, options::OPT_fno_standalone_debug);
Eric Christopher86050822011-10-25 07:13:06 +00004183 Args.AddLastArg(CmdArgs, options::OPT_fno_operator_names);
Chih-Hung Hsieh2c656c92015-07-28 16:27:56 +00004184 // Emulated TLS is enabled by default on Android, and can be enabled manually
4185 // with -femulated-tls.
4186 bool EmulatedTLSDefault = Triple.getEnvironment() == llvm::Triple::Android;
4187 if (Args.hasFlag(options::OPT_femulated_tls, options::OPT_fno_emulated_tls,
4188 EmulatedTLSDefault))
4189 CmdArgs.push_back("-femulated-tls");
Ulrich Weigand3c5038a2015-07-30 14:08:36 +00004190 // AltiVec-like language extensions aren't relevant for assembling.
4191 if (!isa<PreprocessJobAction>(JA) || Output.getType() != types::TY_PP_Asm) {
Bill Schmidtb3b804e2013-07-03 15:36:02 +00004192 Args.AddLastArg(CmdArgs, options::OPT_faltivec);
Ulrich Weigand3c5038a2015-07-30 14:08:36 +00004193 Args.AddLastArg(CmdArgs, options::OPT_fzvector);
4194 }
Richard Trieu91844232012-06-26 18:18:47 +00004195 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_show_template_tree);
4196 Args.AddLastArg(CmdArgs, options::OPT_fno_elide_type);
Chad Rosier864dfe12012-03-13 23:45:51 +00004197
Alexey Bataevdb390212015-05-20 04:24:19 +00004198 // Forward flags for OpenMP
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00004199 if (Args.hasFlag(options::OPT_fopenmp, options::OPT_fopenmp_EQ,
4200 options::OPT_fno_openmp, false))
4201 switch (getOpenMPRuntime(getToolChain(), Args)) {
4202 case OMPRT_OMP:
4203 case OMPRT_IOMP5:
4204 // Clang can generate useful OpenMP code for these two runtime libraries.
4205 CmdArgs.push_back("-fopenmp");
Samuel Antaof8b50122015-07-13 22:54:53 +00004206
4207 // If no option regarding the use of TLS in OpenMP codegeneration is
4208 // given, decide a default based on the target. Otherwise rely on the
4209 // options and pass the right information to the frontend.
4210 if (!Args.hasFlag(options::OPT_fopenmp_use_tls,
Alexey Bataev6a43c002015-09-10 12:06:58 +00004211 options::OPT_fnoopenmp_use_tls, /*Default=*/true))
Samuel Antaof8b50122015-07-13 22:54:53 +00004212 CmdArgs.push_back("-fnoopenmp-use-tls");
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00004213 break;
4214 default:
4215 // By default, if Clang doesn't know how to generate useful OpenMP code
4216 // for a specific runtime library, we just don't pass the '-fopenmp' flag
4217 // down to the actual compilation.
4218 // FIXME: It would be better to have a mode which *only* omits IR
4219 // generation based on the OpenMP support so that we get consistent
4220 // semantic analysis, etc.
4221 break;
4222 }
Alexey Bataevdb390212015-05-20 04:24:19 +00004223
Peter Collingbourne32701642013-11-01 18:16:25 +00004224 const SanitizerArgs &Sanitize = getToolChain().getSanitizerArgs();
Peter Collingbourne581f4382015-07-02 01:48:12 +00004225 Sanitize.addArgs(getToolChain(), Args, CmdArgs, InputType);
Richard Smith52be6192012-11-05 22:04:41 +00004226
Eric Christopher459d2712013-02-19 06:16:53 +00004227 // Report an error for -faltivec on anything other than PowerPC.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00004228 if (const Arg *A = Args.getLastArg(options::OPT_faltivec)) {
4229 const llvm::Triple::ArchType Arch = getToolChain().getArch();
4230 if (!(Arch == llvm::Triple::ppc || Arch == llvm::Triple::ppc64 ||
4231 Arch == llvm::Triple::ppc64le))
4232 D.Diag(diag::err_drv_argument_only_allowed_with) << A->getAsString(Args)
4233 << "ppc/ppc64/ppc64le";
4234 }
Chad Rosier864dfe12012-03-13 23:45:51 +00004235
Ulrich Weigand3c5038a2015-07-30 14:08:36 +00004236 // -fzvector is incompatible with -faltivec.
4237 if (Arg *A = Args.getLastArg(options::OPT_fzvector))
4238 if (Args.hasArg(options::OPT_faltivec))
4239 D.Diag(diag::err_drv_argument_not_allowed_with) << A->getAsString(Args)
4240 << "-faltivec";
4241
Daniel Dunbar733b0f82011-03-01 18:49:30 +00004242 if (getToolChain().SupportsProfiling())
4243 Args.AddLastArg(CmdArgs, options::OPT_pg);
Daniel Dunbar35621a92010-03-16 16:57:46 +00004244
4245 // -flax-vector-conversions is default.
4246 if (!Args.hasFlag(options::OPT_flax_vector_conversions,
4247 options::OPT_fno_lax_vector_conversions))
4248 CmdArgs.push_back("-fno-lax-vector-conversions");
4249
John Brawna7b4ec02015-08-10 11:11:28 +00004250 if (Args.getLastArg(options::OPT_fapple_kext) ||
4251 (Args.hasArg(options::OPT_mkernel) && types::isCXX(InputType)))
Fariborz Jahaniana4cfff82011-01-07 01:05:02 +00004252 CmdArgs.push_back("-fapple-kext");
4253
Fariborz Jahaniana4404f22009-05-22 20:17:16 +00004254 Args.AddLastArg(CmdArgs, options::OPT_fobjc_sender_dependent_dispatch);
Chris Lattner69686412009-04-21 05:34:31 +00004255 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_print_source_range_info);
Douglas Gregoreec975c2010-08-19 20:24:43 +00004256 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_parseable_fixits);
Daniel Dunbar3a148f22009-04-07 21:51:40 +00004257 Args.AddLastArg(CmdArgs, options::OPT_ftime_report);
4258 Args.AddLastArg(CmdArgs, options::OPT_ftrapv);
David Chisnalldd84ef12010-09-17 18:29:54 +00004259
4260 if (Arg *A = Args.getLastArg(options::OPT_ftrapv_handler_EQ)) {
4261 CmdArgs.push_back("-ftrapv-handler");
Richard Smithbd55daf2012-11-01 04:30:05 +00004262 CmdArgs.push_back(A->getValue());
David Chisnalldd84ef12010-09-17 18:29:54 +00004263 }
4264
Bob Wilson14adb362012-02-03 06:27:22 +00004265 Args.AddLastArg(CmdArgs, options::OPT_ftrap_function_EQ);
Evan Cheng04c94292011-04-08 21:37:45 +00004266
Chandler Carruth6e501032011-03-27 00:04:55 +00004267 // -fno-strict-overflow implies -fwrapv if it isn't disabled, but
4268 // -fstrict-overflow won't turn off an explicitly enabled -fwrapv.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004269 if (Arg *A = Args.getLastArg(options::OPT_fwrapv, options::OPT_fno_wrapv)) {
Chandler Carruth6e501032011-03-27 00:04:55 +00004270 if (A->getOption().matches(options::OPT_fwrapv))
4271 CmdArgs.push_back("-fwrapv");
4272 } else if (Arg *A = Args.getLastArg(options::OPT_fstrict_overflow,
4273 options::OPT_fno_strict_overflow)) {
4274 if (A->getOption().matches(options::OPT_fno_strict_overflow))
4275 CmdArgs.push_back("-fwrapv");
4276 }
Hal Finkelce0697f2013-11-17 16:03:29 +00004277
4278 if (Arg *A = Args.getLastArg(options::OPT_freroll_loops,
4279 options::OPT_fno_reroll_loops))
4280 if (A->getOption().matches(options::OPT_freroll_loops))
4281 CmdArgs.push_back("-freroll-loops");
4282
Daniel Dunbar3a148f22009-04-07 21:51:40 +00004283 Args.AddLastArg(CmdArgs, options::OPT_fwritable_strings);
Chandler Carruth54c29102013-08-08 08:34:35 +00004284 Args.AddLastArg(CmdArgs, options::OPT_funroll_loops,
4285 options::OPT_fno_unroll_loops);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004286
Daniel Dunbara77eaeb2009-09-03 04:54:28 +00004287 Args.AddLastArg(CmdArgs, options::OPT_pthread);
4288
Daniel Dunbar4930e332009-11-17 08:07:36 +00004289 // -stack-protector=0 is default.
4290 unsigned StackProtectorLevel = 0;
Peter Collingbournec4122c12015-06-15 21:08:13 +00004291 if (getToolChain().getSanitizerArgs().needsSafeStackRt()) {
4292 Args.ClaimAllArgs(options::OPT_fno_stack_protector);
4293 Args.ClaimAllArgs(options::OPT_fstack_protector_all);
4294 Args.ClaimAllArgs(options::OPT_fstack_protector_strong);
4295 Args.ClaimAllArgs(options::OPT_fstack_protector);
4296 } else if (Arg *A = Args.getLastArg(options::OPT_fno_stack_protector,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004297 options::OPT_fstack_protector_all,
4298 options::OPT_fstack_protector_strong,
4299 options::OPT_fstack_protector)) {
Rafael Espindolace5c6092014-05-22 22:57:39 +00004300 if (A->getOption().matches(options::OPT_fstack_protector)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004301 StackProtectorLevel = std::max<unsigned>(
4302 LangOptions::SSPOn,
4303 getToolChain().GetDefaultStackProtectorLevel(KernelOrKext));
Rafael Espindolace5c6092014-05-22 22:57:39 +00004304 } else if (A->getOption().matches(options::OPT_fstack_protector_strong))
Josh Mageee0fc1a82014-02-11 01:35:14 +00004305 StackProtectorLevel = LangOptions::SSPStrong;
Daniel Dunbar4930e332009-11-17 08:07:36 +00004306 else if (A->getOption().matches(options::OPT_fstack_protector_all))
Josh Mageee0fc1a82014-02-11 01:35:14 +00004307 StackProtectorLevel = LangOptions::SSPReq;
Nico Weberdd473632011-08-23 07:38:27 +00004308 } else {
4309 StackProtectorLevel =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004310 getToolChain().GetDefaultStackProtectorLevel(KernelOrKext);
Nico Weberdd473632011-08-23 07:38:27 +00004311 }
Daniel Dunbar4930e332009-11-17 08:07:36 +00004312 if (StackProtectorLevel) {
4313 CmdArgs.push_back("-stack-protector");
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004314 CmdArgs.push_back(Args.MakeArgString(Twine(StackProtectorLevel)));
Joerg Sonnenberger85e2bbc2012-09-12 13:51:14 +00004315 }
Chad Rosierdb3da832012-08-21 16:16:06 +00004316
Joerg Sonnenberger85e2bbc2012-09-12 13:51:14 +00004317 // --param ssp-buffer-size=
Sean Silva14facf32015-06-09 01:57:17 +00004318 for (const Arg *A : Args.filtered(options::OPT__param)) {
4319 StringRef Str(A->getValue());
Joerg Sonnenberger85e2bbc2012-09-12 13:51:14 +00004320 if (Str.startswith("ssp-buffer-size=")) {
4321 if (StackProtectorLevel) {
Chad Rosierdb3da832012-08-21 16:16:06 +00004322 CmdArgs.push_back("-stack-protector-buffer-size");
4323 // FIXME: Verify the argument is a valid integer.
4324 CmdArgs.push_back(Args.MakeArgString(Str.drop_front(16)));
Chad Rosierdb3da832012-08-21 16:16:06 +00004325 }
Sean Silva14facf32015-06-09 01:57:17 +00004326 A->claim();
Chad Rosierdb3da832012-08-21 16:16:06 +00004327 }
Bill Wendlingd63bbad2009-06-28 07:36:13 +00004328 }
4329
Nick Lewyckyf4d3f7a2011-12-06 03:33:03 +00004330 // Translate -mstackrealign
4331 if (Args.hasFlag(options::OPT_mstackrealign, options::OPT_mno_stackrealign,
Akira Hatanakaaecca042015-09-11 18:55:09 +00004332 false))
Nick Lewyckyf4d3f7a2011-12-06 03:33:03 +00004333 CmdArgs.push_back(Args.MakeArgString("-mstackrealign"));
Nick Lewyckyf4d3f7a2011-12-06 03:33:03 +00004334
Joerg Sonnenbergerdb66ed02011-12-05 23:05:23 +00004335 if (Args.hasArg(options::OPT_mstack_alignment)) {
4336 StringRef alignment = Args.getLastArgValue(options::OPT_mstack_alignment);
4337 CmdArgs.push_back(Args.MakeArgString("-mstack-alignment=" + alignment));
Eric Christopherd5c45f62011-05-02 21:18:22 +00004338 }
Eric Christopher84fbdb42011-08-19 00:30:14 +00004339
Hans Wennborg77dc2362015-01-20 19:45:50 +00004340 if (Args.hasArg(options::OPT_mstack_probe_size)) {
4341 StringRef Size = Args.getLastArgValue(options::OPT_mstack_probe_size);
4342
4343 if (!Size.empty())
4344 CmdArgs.push_back(Args.MakeArgString("-mstack-probe-size=" + Size));
4345 else
4346 CmdArgs.push_back("-mstack-probe-size=0");
4347 }
4348
Oliver Stannarddc2854c2015-09-03 12:40:58 +00004349 switch (getToolChain().getArch()) {
4350 case llvm::Triple::aarch64:
4351 case llvm::Triple::aarch64_be:
4352 case llvm::Triple::arm:
4353 case llvm::Triple::armeb:
4354 case llvm::Triple::thumb:
4355 case llvm::Triple::thumbeb:
Oliver Stannarded8ecc82014-08-27 16:31:57 +00004356 CmdArgs.push_back("-fallow-half-arguments-and-returns");
Oliver Stannarddc2854c2015-09-03 12:40:58 +00004357 break;
4358
4359 default:
4360 break;
4361 }
Oliver Stannarded8ecc82014-08-27 16:31:57 +00004362
Weiming Zhao580dcfb2013-11-13 18:31:23 +00004363 if (Arg *A = Args.getLastArg(options::OPT_mrestrict_it,
4364 options::OPT_mno_restrict_it)) {
4365 if (A->getOption().matches(options::OPT_mrestrict_it)) {
4366 CmdArgs.push_back("-backend-option");
4367 CmdArgs.push_back("-arm-restrict-it");
4368 } else {
4369 CmdArgs.push_back("-backend-option");
4370 CmdArgs.push_back("-arm-no-restrict-it");
4371 }
James Y Knight2db38f32015-08-15 03:45:25 +00004372 } else if (Triple.isOSWindows() &&
4373 (Triple.getArch() == llvm::Triple::arm ||
4374 Triple.getArch() == llvm::Triple::thumb)) {
Saleem Abdulrasool6deb8162014-05-18 06:42:02 +00004375 // Windows on ARM expects restricted IT blocks
4376 CmdArgs.push_back("-backend-option");
4377 CmdArgs.push_back("-arm-restrict-it");
Weiming Zhao580dcfb2013-11-13 18:31:23 +00004378 }
4379
Daniel Dunbard18049a2009-04-07 21:16:11 +00004380 // Forward -f options with positive and negative forms; we translate
4381 // these by hand.
Diego Novillo5c297052013-11-13 12:22:39 +00004382 if (Arg *A = Args.getLastArg(options::OPT_fprofile_sample_use_EQ)) {
4383 StringRef fname = A->getValue();
4384 if (!llvm::sys::fs::exists(fname))
4385 D.Diag(diag::err_drv_no_such_file) << fname;
4386 else
4387 A->render(Args, CmdArgs);
4388 }
Daniel Dunbard18049a2009-04-07 21:16:11 +00004389
John Brawna7b4ec02015-08-10 11:11:28 +00004390 // -fbuiltin is default unless -mkernel is used
4391 if (!Args.hasFlag(options::OPT_fbuiltin, options::OPT_fno_builtin,
4392 !Args.hasArg(options::OPT_mkernel)))
Daniel Dunbar484afa22009-11-19 04:55:23 +00004393 CmdArgs.push_back("-fno-builtin");
Daniel Dunbard18049a2009-04-07 21:16:11 +00004394
Nuno Lopes13c88c72009-12-16 16:59:22 +00004395 if (!Args.hasFlag(options::OPT_fassume_sane_operator_new,
4396 options::OPT_fno_assume_sane_operator_new))
4397 CmdArgs.push_back("-fno-assume-sane-operator-new");
4398
Daniel Dunbar4930e332009-11-17 08:07:36 +00004399 // -fblocks=0 is default.
4400 if (Args.hasFlag(options::OPT_fblocks, options::OPT_fno_blocks,
David Chisnallda209912011-02-28 17:11:43 +00004401 getToolChain().IsBlocksDefault()) ||
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004402 (Args.hasArg(options::OPT_fgnu_runtime) &&
4403 Args.hasArg(options::OPT_fobjc_nonfragile_abi) &&
4404 !Args.hasArg(options::OPT_fno_blocks))) {
Daniel Dunbar4930e332009-11-17 08:07:36 +00004405 CmdArgs.push_back("-fblocks");
John McCall7959fee2011-09-09 20:41:01 +00004406
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004407 if (!Args.hasArg(options::OPT_fgnu_runtime) &&
John McCall7959fee2011-09-09 20:41:01 +00004408 !getToolChain().hasBlocksRuntime())
4409 CmdArgs.push_back("-fblocks-runtime-optional");
David Chisnall950a9512009-11-17 19:33:30 +00004410 }
Daniel Dunbard18049a2009-04-07 21:16:11 +00004411
Richard Smith47972af2015-06-16 00:08:24 +00004412 // -fmodules enables the use of precompiled modules (off by default).
Richard Smithffb65082014-09-30 23:10:19 +00004413 // Users can pass -fno-cxx-modules to turn off modules support for
Richard Smith47972af2015-06-16 00:08:24 +00004414 // C++/Objective-C++ programs.
Douglas Gregorc60437f2013-01-16 01:23:41 +00004415 bool HaveModules = false;
Douglas Gregor226173a2012-01-18 15:19:58 +00004416 if (Args.hasFlag(options::OPT_fmodules, options::OPT_fno_modules, false)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004417 bool AllowedInCXX = Args.hasFlag(options::OPT_fcxx_modules,
4418 options::OPT_fno_cxx_modules, true);
Douglas Gregorc60437f2013-01-16 01:23:41 +00004419 if (AllowedInCXX || !types::isCXX(InputType)) {
Douglas Gregor226173a2012-01-18 15:19:58 +00004420 CmdArgs.push_back("-fmodules");
Douglas Gregorc60437f2013-01-16 01:23:41 +00004421 HaveModules = true;
4422 }
4423 }
4424
Richard Smith47972af2015-06-16 00:08:24 +00004425 // -fmodule-maps enables implicit reading of module map files. By default,
4426 // this is enabled if we are using precompiled modules.
Richard Smithcf18b792015-06-16 00:20:23 +00004427 if (Args.hasFlag(options::OPT_fimplicit_module_maps,
4428 options::OPT_fno_implicit_module_maps, HaveModules)) {
Richard Smith47972af2015-06-16 00:08:24 +00004429 CmdArgs.push_back("-fimplicit-module-maps");
Daniel Jasper07e6c402013-08-05 20:26:17 +00004430 }
4431
Daniel Jasperac42b752013-10-21 06:34:34 +00004432 // -fmodules-decluse checks that modules used are declared so (off by
4433 // default).
Daniel Jasperba7f2f72013-09-24 09:14:14 +00004434 if (Args.hasFlag(options::OPT_fmodules_decluse,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004435 options::OPT_fno_modules_decluse, false)) {
Daniel Jasper6e16d542013-09-29 12:40:54 +00004436 CmdArgs.push_back("-fmodules-decluse");
Daniel Jasperba7f2f72013-09-24 09:14:14 +00004437 }
4438
Daniel Jasper962b38e2014-04-11 11:47:45 +00004439 // -fmodules-strict-decluse is like -fmodule-decluse, but also checks that
4440 // all #included headers are part of modules.
4441 if (Args.hasFlag(options::OPT_fmodules_strict_decluse,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004442 options::OPT_fno_modules_strict_decluse, false)) {
Daniel Jasper962b38e2014-04-11 11:47:45 +00004443 CmdArgs.push_back("-fmodules-strict-decluse");
4444 }
4445
Manuel Klimekd2e8b042015-02-20 11:44:41 +00004446 // -fno-implicit-modules turns off implicitly compiling modules on demand.
4447 if (!Args.hasFlag(options::OPT_fimplicit_modules,
4448 options::OPT_fno_implicit_modules)) {
4449 CmdArgs.push_back("-fno-implicit-modules");
4450 }
4451
Daniel Jasperac42b752013-10-21 06:34:34 +00004452 // -fmodule-name specifies the module that is currently being built (or
4453 // used for header checking by -fmodule-maps).
Richard Smith9887d792014-10-17 01:42:53 +00004454 Args.AddLastArg(CmdArgs, options::OPT_fmodule_name);
Daniel Jasperac42b752013-10-21 06:34:34 +00004455
Richard Smith9887d792014-10-17 01:42:53 +00004456 // -fmodule-map-file can be used to specify files containing module
Daniel Jasperac42b752013-10-21 06:34:34 +00004457 // definitions.
Richard Smith9887d792014-10-17 01:42:53 +00004458 Args.AddAllArgs(CmdArgs, options::OPT_fmodule_map_file);
Daniel Jasperac42b752013-10-21 06:34:34 +00004459
Richard Smithe842a472014-10-22 02:05:46 +00004460 // -fmodule-file can be used to specify files containing precompiled modules.
Richard Smith7acebe42015-09-11 03:58:07 +00004461 if (HaveModules)
4462 Args.AddAllArgs(CmdArgs, options::OPT_fmodule_file);
4463 else
4464 Args.ClaimAllArgs(options::OPT_fmodule_file);
Richard Smithe842a472014-10-22 02:05:46 +00004465
4466 // -fmodule-cache-path specifies where our implicitly-built module files
4467 // should be written.
Diego Novilloa0545962015-07-10 18:00:07 +00004468 SmallString<128> Path;
Justin Bognera88f0122014-06-20 22:59:50 +00004469 if (Arg *A = Args.getLastArg(options::OPT_fmodules_cache_path))
Daniel Jasper7450f912015-07-10 08:25:54 +00004470 Path = A->getValue();
Justin Bognera88f0122014-06-20 22:59:50 +00004471 if (HaveModules) {
4472 if (C.isForDiagnostics()) {
4473 // When generating crash reports, we want to emit the modules along with
4474 // the reproduction sources, so we ignore any provided module path.
Daniel Jasper7450f912015-07-10 08:25:54 +00004475 Path = Output.getFilename();
4476 llvm::sys::path::replace_extension(Path, ".cache");
4477 llvm::sys::path::append(Path, "modules");
4478 } else if (Path.empty()) {
Justin Bognera88f0122014-06-20 22:59:50 +00004479 // No module path was provided: use the default.
Renato Golin7c542b42015-07-27 23:44:45 +00004480 llvm::sys::path::system_temp_directory(/*erasedOnReboot=*/false, Path);
Daniel Jasper7450f912015-07-10 08:25:54 +00004481 llvm::sys::path::append(Path, "org.llvm.clang.");
4482 appendUserToPath(Path);
4483 llvm::sys::path::append(Path, "ModuleCache");
Justin Bognera88f0122014-06-20 22:59:50 +00004484 }
Douglas Gregor4bedb492013-02-07 22:59:12 +00004485 const char Arg[] = "-fmodules-cache-path=";
Daniel Jasper7450f912015-07-10 08:25:54 +00004486 Path.insert(Path.begin(), Arg, Arg + strlen(Arg));
4487 CmdArgs.push_back(Args.MakeArgString(Path));
Justin Bognera88f0122014-06-20 22:59:50 +00004488 }
4489
4490 // When building modules and generating crashdumps, we need to dump a module
4491 // dependency VFS alongside the output.
4492 if (HaveModules && C.isForDiagnostics()) {
4493 SmallString<128> VFSDir(Output.getFilename());
4494 llvm::sys::path::replace_extension(VFSDir, ".cache");
Justin Bogner659ecc32014-10-20 22:47:23 +00004495 // Add the cache directory as a temp so the crash diagnostics pick it up.
4496 C.addTempFile(Args.MakeArgString(VFSDir));
4497
Justin Bognera88f0122014-06-20 22:59:50 +00004498 llvm::sys::path::append(VFSDir, "vfs");
4499 CmdArgs.push_back("-module-dependency-dir");
4500 CmdArgs.push_back(Args.MakeArgString(VFSDir));
Douglas Gregor35b04d62013-02-07 19:01:24 +00004501 }
4502
Richard Smith9887d792014-10-17 01:42:53 +00004503 if (HaveModules)
4504 Args.AddLastArg(CmdArgs, options::OPT_fmodules_user_build_path);
Argyrios Kyrtzidis1594c152014-03-03 08:12:05 +00004505
Douglas Gregor35b04d62013-02-07 19:01:24 +00004506 // Pass through all -fmodules-ignore-macro arguments.
4507 Args.AddAllArgs(CmdArgs, options::OPT_fmodules_ignore_macro);
Douglas Gregor527b1c92013-03-25 21:19:16 +00004508 Args.AddLastArg(CmdArgs, options::OPT_fmodules_prune_interval);
4509 Args.AddLastArg(CmdArgs, options::OPT_fmodules_prune_after);
Douglas Gregor35b04d62013-02-07 19:01:24 +00004510
Dmitri Gribenkof430da42014-02-12 10:33:14 +00004511 Args.AddLastArg(CmdArgs, options::OPT_fbuild_session_timestamp);
4512
Ben Langmuir19e6acb2014-08-01 22:12:21 +00004513 if (Arg *A = Args.getLastArg(options::OPT_fbuild_session_file)) {
4514 if (Args.hasArg(options::OPT_fbuild_session_timestamp))
4515 D.Diag(diag::err_drv_argument_not_allowed_with)
4516 << A->getAsString(Args) << "-fbuild-session-timestamp";
4517
4518 llvm::sys::fs::file_status Status;
4519 if (llvm::sys::fs::status(A->getValue(), Status))
4520 D.Diag(diag::err_drv_no_such_file) << A->getValue();
Benjamin Kramer320fc262015-02-14 18:19:55 +00004521 CmdArgs.push_back(Args.MakeArgString(
4522 "-fbuild-session-timestamp=" +
4523 Twine((uint64_t)Status.getLastModificationTime().toEpochTime())));
Ben Langmuir19e6acb2014-08-01 22:12:21 +00004524 }
4525
Dmitri Gribenkof430da42014-02-12 10:33:14 +00004526 if (Args.getLastArg(options::OPT_fmodules_validate_once_per_build_session)) {
Ben Langmuir19e6acb2014-08-01 22:12:21 +00004527 if (!Args.getLastArg(options::OPT_fbuild_session_timestamp,
4528 options::OPT_fbuild_session_file))
Dmitri Gribenkof430da42014-02-12 10:33:14 +00004529 D.Diag(diag::err_drv_modules_validate_once_requires_timestamp);
4530
4531 Args.AddLastArg(CmdArgs,
4532 options::OPT_fmodules_validate_once_per_build_session);
4533 }
4534
Ben Langmuirdcf73862014-03-12 00:06:17 +00004535 Args.AddLastArg(CmdArgs, options::OPT_fmodules_validate_system_headers);
4536
John McCalldfea9982010-04-09 19:12:06 +00004537 // -faccess-control is default.
John McCall3155f572010-04-09 19:03:51 +00004538 if (Args.hasFlag(options::OPT_fno_access_control,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004539 options::OPT_faccess_control, false))
John McCall3155f572010-04-09 19:03:51 +00004540 CmdArgs.push_back("-fno-access-control");
John McCall59bb1d42010-03-17 01:32:13 +00004541
Anders Carlssond470fef2010-11-21 00:09:52 +00004542 // -felide-constructors is the default.
4543 if (Args.hasFlag(options::OPT_fno_elide_constructors,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004544 options::OPT_felide_constructors, false))
Anders Carlssond470fef2010-11-21 00:09:52 +00004545 CmdArgs.push_back("-fno-elide-constructors");
4546
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00004547 ToolChain::RTTIMode RTTIMode = getToolChain().getRTTIMode();
Filipe Cabecinhas28f353c2015-01-29 23:56:43 +00004548
Filipe Cabecinhasc4732552015-03-20 23:51:15 +00004549 if (KernelOrKext || (types::isCXX(InputType) &&
4550 (RTTIMode == ToolChain::RM_DisabledExplicitly ||
4551 RTTIMode == ToolChain::RM_DisabledImplicitly)))
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00004552 CmdArgs.push_back("-fno-rtti");
Richard Smith52be6192012-11-05 22:04:41 +00004553
Tony Linthicum76329bf2011-12-12 21:14:55 +00004554 // -fshort-enums=0 is default for all architectures except Hexagon.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004555 if (Args.hasFlag(options::OPT_fshort_enums, options::OPT_fno_short_enums,
4556 getToolChain().getArch() == llvm::Triple::hexagon))
Argyrios Kyrtzidis74825bc2010-10-08 00:25:19 +00004557 CmdArgs.push_back("-fshort-enums");
4558
Daniel Dunbard609b7b2009-11-17 06:37:03 +00004559 // -fsigned-char is default.
David Majnemerc3658d22015-05-23 18:48:37 +00004560 if (Arg *A = Args.getLastArg(
4561 options::OPT_fsigned_char, options::OPT_fno_signed_char,
4562 options::OPT_funsigned_char, options::OPT_fno_unsigned_char)) {
4563 if (A->getOption().matches(options::OPT_funsigned_char) ||
4564 A->getOption().matches(options::OPT_fno_signed_char)) {
4565 CmdArgs.push_back("-fno-signed-char");
4566 }
4567 } else if (!isSignedCharDefault(getToolChain().getTriple())) {
Daniel Dunbar5fe08662009-11-29 02:39:08 +00004568 CmdArgs.push_back("-fno-signed-char");
David Majnemerc3658d22015-05-23 18:48:37 +00004569 }
Eli Friedman327f0b52009-06-05 07:21:14 +00004570
Daniel Dunbarfe06df42010-03-20 04:15:41 +00004571 // -fuse-cxa-atexit is default.
Vasileios Kalintiris712f0882015-10-02 14:38:23 +00004572 if (!Args.hasFlag(
4573 options::OPT_fuse_cxa_atexit, options::OPT_fno_use_cxa_atexit,
4574 !IsWindowsCygnus && !IsWindowsGNU &&
4575 getToolChain().getTriple().getOS() != llvm::Triple::Solaris &&
4576 getToolChain().getArch() != llvm::Triple::hexagon &&
4577 getToolChain().getArch() != llvm::Triple::xcore &&
4578 getToolChain().getArch() != llvm::Triple::xcore &&
4579 ((getToolChain().getTriple().getVendor() !=
4580 llvm::Triple::MipsTechnologies) ||
4581 getToolChain().getTriple().hasEnvironment())) ||
Chad Rosier4fab82c2012-03-26 22:04:46 +00004582 KernelOrKext)
Daniel Dunbarfe06df42010-03-20 04:15:41 +00004583 CmdArgs.push_back("-fno-use-cxa-atexit");
4584
Daniel Dunbar0730e4f2009-11-17 07:06:20 +00004585 // -fms-extensions=0 is default.
Daniel Dunbar5bdd2992009-11-25 10:14:30 +00004586 if (Args.hasFlag(options::OPT_fms_extensions, options::OPT_fno_ms_extensions,
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00004587 IsWindowsMSVC))
Daniel Dunbar0730e4f2009-11-17 07:06:20 +00004588 CmdArgs.push_back("-fms-extensions");
4589
Reid Kleckner1df0fea2015-02-26 00:17:25 +00004590 // -fno-use-line-directives is default.
4591 if (Args.hasFlag(options::OPT_fuse_line_directives,
4592 options::OPT_fno_use_line_directives, false))
4593 CmdArgs.push_back("-fuse-line-directives");
4594
Francois Pichet1b4f1632011-09-17 04:32:15 +00004595 // -fms-compatibility=0 is default.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004596 if (Args.hasFlag(options::OPT_fms_compatibility,
Douglas Gregor2b4907e2011-10-24 15:49:38 +00004597 options::OPT_fno_ms_compatibility,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004598 (IsWindowsMSVC &&
4599 Args.hasFlag(options::OPT_fms_extensions,
4600 options::OPT_fno_ms_extensions, true))))
Francois Pichet1b4f1632011-09-17 04:32:15 +00004601 CmdArgs.push_back("-fms-compatibility");
4602
David Majnemerc371ff02015-03-22 08:39:22 +00004603 // -fms-compatibility-version=18.00 is default.
David Majnemere11d3732015-06-08 00:22:46 +00004604 VersionTuple MSVT = visualstudio::getMSVCVersion(
4605 &D, getToolChain().getTriple(), Args, IsWindowsMSVC);
4606 if (!MSVT.empty())
David Majnemerc371ff02015-03-22 08:39:22 +00004607 CmdArgs.push_back(
4608 Args.MakeArgString("-fms-compatibility-version=" + MSVT.getAsString()));
Michael J. Spencer4992ca4b2010-10-21 05:21:48 +00004609
David Majnemer8db91762015-05-18 04:49:30 +00004610 bool IsMSVC2015Compatible = MSVT.getMajor() >= 19;
4611 if (ImplyVCPPCXXVer) {
4612 if (IsMSVC2015Compatible)
4613 CmdArgs.push_back("-std=c++14");
4614 else
4615 CmdArgs.push_back("-std=c++11");
4616 }
4617
Eric Christopher5ecce122013-02-18 00:38:31 +00004618 // -fno-borland-extensions is default.
Dawn Perchik68bb1b42010-09-02 23:59:25 +00004619 if (Args.hasFlag(options::OPT_fborland_extensions,
4620 options::OPT_fno_borland_extensions, false))
4621 CmdArgs.push_back("-fborland-extensions");
4622
David Majnemerc371ff02015-03-22 08:39:22 +00004623 // -fthreadsafe-static is default, except for MSVC compatibility versions less
4624 // than 19.
4625 if (!Args.hasFlag(options::OPT_fthreadsafe_statics,
4626 options::OPT_fno_threadsafe_statics,
David Majnemer8db91762015-05-18 04:49:30 +00004627 !IsWindowsMSVC || IsMSVC2015Compatible))
David Majnemerc371ff02015-03-22 08:39:22 +00004628 CmdArgs.push_back("-fno-threadsafe-statics");
4629
Francois Pichet02744872011-09-01 16:38:08 +00004630 // -fno-delayed-template-parsing is default, except for Windows where MSVC STL
4631 // needs it.
Francois Pichet1c229c02011-04-22 22:18:13 +00004632 if (Args.hasFlag(options::OPT_fdelayed_template_parsing,
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00004633 options::OPT_fno_delayed_template_parsing, IsWindowsMSVC))
Francois Pichet35bc5de2011-08-26 00:22:34 +00004634 CmdArgs.push_back("-fdelayed-template-parsing");
Francois Pichet1c229c02011-04-22 22:18:13 +00004635
Chandler Carruthe03aa552010-04-17 20:17:31 +00004636 // -fgnu-keywords default varies depending on language; only pass if
4637 // specified.
4638 if (Arg *A = Args.getLastArg(options::OPT_fgnu_keywords,
Daniel Dunbardb059592010-04-24 17:56:39 +00004639 options::OPT_fno_gnu_keywords))
4640 A->render(Args, CmdArgs);
Chandler Carruthe03aa552010-04-17 20:17:31 +00004641
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004642 if (Args.hasFlag(options::OPT_fgnu89_inline, options::OPT_fno_gnu89_inline,
Rafael Espindola922a6242011-06-02 17:30:53 +00004643 false))
Rafael Espindolafb2af642011-06-02 16:13:27 +00004644 CmdArgs.push_back("-fgnu89-inline");
4645
Chad Rosier9c76d242012-03-15 22:31:42 +00004646 if (Args.hasArg(options::OPT_fno_inline))
4647 CmdArgs.push_back("-fno-inline");
4648
Chad Rosier64d6be92012-03-06 21:17:19 +00004649 if (Args.hasArg(options::OPT_fno_inline_functions))
4650 CmdArgs.push_back("-fno-inline-functions");
Chad Rosier80603182012-03-06 18:49:20 +00004651
John McCall5fb5df92012-06-20 06:18:46 +00004652 ObjCRuntime objcRuntime = AddObjCRuntimeArgs(Args, CmdArgs, rewriteKind);
John McCall24fc0de2011-07-06 00:26:06 +00004653
John McCall5fb5df92012-06-20 06:18:46 +00004654 // -fobjc-dispatch-method is only relevant with the nonfragile-abi, and
Fariborz Jahanian15f60cb2014-01-20 19:32:33 +00004655 // legacy is the default. Except for deployment taget of 10.5,
4656 // next runtime is always legacy dispatch and -fno-objc-legacy-dispatch
4657 // gets ignored silently.
4658 if (objcRuntime.isNonFragile()) {
David Chisnall3154e682011-09-30 13:32:35 +00004659 if (!Args.hasFlag(options::OPT_fobjc_legacy_dispatch,
4660 options::OPT_fno_objc_legacy_dispatch,
David Chisnallda225352012-07-04 11:52:24 +00004661 objcRuntime.isLegacyDispatchDefaultForArch(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004662 getToolChain().getArch()))) {
David Chisnall3154e682011-09-30 13:32:35 +00004663 if (getToolChain().UseObjCMixedDispatch())
4664 CmdArgs.push_back("-fobjc-dispatch-method=mixed");
4665 else
4666 CmdArgs.push_back("-fobjc-dispatch-method=non-legacy");
4667 }
4668 }
Rafael Espindolab44676c2013-11-12 04:33:56 +00004669
Fariborz Jahanianfd4ce192013-11-12 17:08:46 +00004670 // When ObjectiveC legacy runtime is in effect on MacOSX,
4671 // turn on the option to do Array/Dictionary subscripting
4672 // by default.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00004673 if (getToolChain().getArch() == llvm::Triple::x86 &&
Fariborz Jahanianff6c97c2013-11-12 20:50:26 +00004674 getToolChain().getTriple().isMacOSX() &&
4675 !getToolChain().getTriple().isMacOSXVersionLT(10, 7) &&
4676 objcRuntime.getKind() == ObjCRuntime::FragileMacOSX &&
Fariborz Jahanianfd4ce192013-11-12 17:08:46 +00004677 objcRuntime.isNeXTFamily())
4678 CmdArgs.push_back("-fobjc-subscripting-legacy-runtime");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004679
Fariborz Jahanian0e3043b2012-11-15 19:02:45 +00004680 // -fencode-extended-block-signature=1 is default.
4681 if (getToolChain().IsEncodeExtendedBlockSignatureDefault()) {
4682 CmdArgs.push_back("-fencode-extended-block-signature");
4683 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004684
John McCall24fc0de2011-07-06 00:26:06 +00004685 // Allow -fno-objc-arr to trump -fobjc-arr/-fobjc-arc.
4686 // NOTE: This logic is duplicated in ToolChains.cpp.
4687 bool ARC = isObjCAutoRefCount(Args);
4688 if (ARC) {
John McCall3deb1ad2012-08-21 02:47:43 +00004689 getToolChain().CheckObjCARC();
Argyrios Kyrtzidis3dbeb552012-02-29 03:43:52 +00004690
John McCall24fc0de2011-07-06 00:26:06 +00004691 CmdArgs.push_back("-fobjc-arc");
4692
Chandler Carruth491db322011-11-04 07:34:47 +00004693 // FIXME: It seems like this entire block, and several around it should be
4694 // wrapped in isObjC, but for now we just use it here as this is where it
4695 // was being used previously.
4696 if (types::isCXX(InputType) && types::isObjC(InputType)) {
4697 if (getToolChain().GetCXXStdlibType(Args) == ToolChain::CST_Libcxx)
4698 CmdArgs.push_back("-fobjc-arc-cxxlib=libc++");
4699 else
4700 CmdArgs.push_back("-fobjc-arc-cxxlib=libstdc++");
4701 }
4702
John McCall24fc0de2011-07-06 00:26:06 +00004703 // Allow the user to enable full exceptions code emission.
4704 // We define off for Objective-CC, on for Objective-C++.
4705 if (Args.hasFlag(options::OPT_fobjc_arc_exceptions,
4706 options::OPT_fno_objc_arc_exceptions,
4707 /*default*/ types::isCXX(InputType)))
4708 CmdArgs.push_back("-fobjc-arc-exceptions");
4709 }
4710
4711 // -fobjc-infer-related-result-type is the default, except in the Objective-C
4712 // rewriter.
John McCall5fb5df92012-06-20 06:18:46 +00004713 if (rewriteKind != RK_None)
John McCall24fc0de2011-07-06 00:26:06 +00004714 CmdArgs.push_back("-fno-objc-infer-related-result-type");
Eric Christopher84fbdb42011-08-19 00:30:14 +00004715
John McCall24fc0de2011-07-06 00:26:06 +00004716 // Handle -fobjc-gc and -fobjc-gc-only. They are exclusive, and -fobjc-gc-only
4717 // takes precedence.
4718 const Arg *GCArg = Args.getLastArg(options::OPT_fobjc_gc_only);
4719 if (!GCArg)
4720 GCArg = Args.getLastArg(options::OPT_fobjc_gc);
4721 if (GCArg) {
4722 if (ARC) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004723 D.Diag(diag::err_drv_objc_gc_arr) << GCArg->getAsString(Args);
John McCall24fc0de2011-07-06 00:26:06 +00004724 } else if (getToolChain().SupportsObjCGC()) {
4725 GCArg->render(Args, CmdArgs);
4726 } else {
4727 // FIXME: We should move this to a hard error.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004728 D.Diag(diag::warn_drv_objc_gc_unsupported) << GCArg->getAsString(Args);
John McCall24fc0de2011-07-06 00:26:06 +00004729 }
4730 }
4731
Bob Wilsonb111ec92015-03-02 19:01:14 +00004732 if (Args.hasFlag(options::OPT_fapplication_extension,
4733 options::OPT_fno_application_extension, false))
4734 CmdArgs.push_back("-fapplication-extension");
4735
Reid Klecknerc542d372014-06-27 17:02:02 +00004736 // Handle GCC-style exception args.
4737 if (!C.getDriver().IsCLMode())
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004738 addExceptionArgs(Args, InputType, getToolChain(), KernelOrKext, objcRuntime,
4739 CmdArgs);
John McCallb5f652e2011-06-22 00:53:57 +00004740
4741 if (getToolChain().UseSjLjExceptions())
4742 CmdArgs.push_back("-fsjlj-exceptions");
4743
4744 // C++ "sane" operator new.
Daniel Dunbar2e3f2c82010-02-01 21:07:25 +00004745 if (!Args.hasFlag(options::OPT_fassume_sane_operator_new,
4746 options::OPT_fno_assume_sane_operator_new))
4747 CmdArgs.push_back("-fno-assume-sane-operator-new");
4748
Reid Kleckner7ffc3fb2015-03-20 00:31:07 +00004749 // -fsized-deallocation is off by default, as it is an ABI-breaking change for
4750 // most platforms.
4751 if (Args.hasFlag(options::OPT_fsized_deallocation,
4752 options::OPT_fno_sized_deallocation, false))
4753 CmdArgs.push_back("-fsized-deallocation");
4754
Daniel Dunbar34d7a992010-04-27 15:34:57 +00004755 // -fconstant-cfstrings is default, and may be subject to argument translation
4756 // on Darwin.
4757 if (!Args.hasFlag(options::OPT_fconstant_cfstrings,
4758 options::OPT_fno_constant_cfstrings) ||
4759 !Args.hasFlag(options::OPT_mconstant_cfstrings,
4760 options::OPT_mno_constant_cfstrings))
4761 CmdArgs.push_back("-fno-constant-cfstrings");
4762
John Thompsoned4e2952009-11-05 20:14:16 +00004763 // -fshort-wchar default varies depending on platform; only
4764 // pass if specified.
Richard Bartonc9b5f352014-02-24 18:43:28 +00004765 if (Arg *A = Args.getLastArg(options::OPT_fshort_wchar,
4766 options::OPT_fno_short_wchar))
Daniel Dunbar2cb4e7a2010-04-27 15:35:03 +00004767 A->render(Args, CmdArgs);
John Thompsoned4e2952009-11-05 20:14:16 +00004768
Hans Wennborg28c96312013-07-31 23:39:13 +00004769 // -fno-pascal-strings is default, only pass non-default.
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004770 if (Args.hasFlag(options::OPT_fpascal_strings,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004771 options::OPT_fno_pascal_strings, false))
Daniel Dunbard18049a2009-04-07 21:16:11 +00004772 CmdArgs.push_back("-fpascal-strings");
NAKAMURA Takumi029d74b2011-02-17 08:50:50 +00004773
Daniel Dunbar096ed292011-10-05 21:04:55 +00004774 // Honor -fpack-struct= and -fpack-struct, if given. Note that
4775 // -fno-pack-struct doesn't apply to -fpack-struct=.
4776 if (Arg *A = Args.getLastArg(options::OPT_fpack_struct_EQ)) {
James Molloycebf75e2012-05-02 07:56:14 +00004777 std::string PackStructStr = "-fpack-struct=";
Richard Smithbd55daf2012-11-01 04:30:05 +00004778 PackStructStr += A->getValue();
James Molloycebf75e2012-05-02 07:56:14 +00004779 CmdArgs.push_back(Args.MakeArgString(PackStructStr));
Daniel Dunbar096ed292011-10-05 21:04:55 +00004780 } else if (Args.hasFlag(options::OPT_fpack_struct,
4781 options::OPT_fno_pack_struct, false)) {
James Molloycebf75e2012-05-02 07:56:14 +00004782 CmdArgs.push_back("-fpack-struct=1");
Daniel Dunbar096ed292011-10-05 21:04:55 +00004783 }
4784
Fariborz Jahanianbcd82af2014-08-05 18:37:48 +00004785 // Handle -fmax-type-align=N and -fno-type-align
4786 bool SkipMaxTypeAlign = Args.hasArg(options::OPT_fno_max_type_align);
4787 if (Arg *A = Args.getLastArg(options::OPT_fmax_type_align_EQ)) {
4788 if (!SkipMaxTypeAlign) {
4789 std::string MaxTypeAlignStr = "-fmax-type-align=";
4790 MaxTypeAlignStr += A->getValue();
4791 CmdArgs.push_back(Args.MakeArgString(MaxTypeAlignStr));
4792 }
4793 } else if (getToolChain().getTriple().isOSDarwin()) {
4794 if (!SkipMaxTypeAlign) {
4795 std::string MaxTypeAlignStr = "-fmax-type-align=16";
4796 CmdArgs.push_back(Args.MakeArgString(MaxTypeAlignStr));
4797 }
4798 }
4799
John Brawna7b4ec02015-08-10 11:11:28 +00004800 // -fcommon is the default unless compiling kernel code or the target says so
4801 bool NoCommonDefault =
4802 KernelOrKext || isNoCommonDefault(getToolChain().getTriple());
4803 if (!Args.hasFlag(options::OPT_fcommon, options::OPT_fno_common,
4804 !NoCommonDefault))
Daniel Dunbard18049a2009-04-07 21:16:11 +00004805 CmdArgs.push_back("-fno-common");
4806
Daniel Dunbar2edd9232009-04-15 02:37:43 +00004807 // -fsigned-bitfields is default, and clang doesn't yet support
Daniel Dunbar6358d682010-10-15 22:30:42 +00004808 // -funsigned-bitfields.
Mike Stump11289f42009-09-09 15:08:12 +00004809 if (!Args.hasFlag(options::OPT_fsigned_bitfields,
Daniel Dunbar2edd9232009-04-15 02:37:43 +00004810 options::OPT_funsigned_bitfields))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004811 D.Diag(diag::warn_drv_clang_unsupported)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004812 << Args.getLastArg(options::OPT_funsigned_bitfields)->getAsString(Args);
Daniel Dunbar2edd9232009-04-15 02:37:43 +00004813
Daniel Dunbar6358d682010-10-15 22:30:42 +00004814 // -fsigned-bitfields is default, and clang doesn't support -fno-for-scope.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004815 if (!Args.hasFlag(options::OPT_ffor_scope, options::OPT_fno_for_scope))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004816 D.Diag(diag::err_drv_clang_unsupported)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004817 << Args.getLastArg(options::OPT_fno_for_scope)->getAsString(Args);
Daniel Dunbar6358d682010-10-15 22:30:42 +00004818
Sylvestre Ledru91f380a2014-07-01 17:24:27 +00004819 // -finput_charset=UTF-8 is default. Reject others
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004820 if (Arg *inputCharset = Args.getLastArg(options::OPT_finput_charset_EQ)) {
4821 StringRef value = inputCharset->getValue();
4822 if (value != "UTF-8")
4823 D.Diag(diag::err_drv_invalid_value) << inputCharset->getAsString(Args)
4824 << value;
Sylvestre Ledru91f380a2014-07-01 17:24:27 +00004825 }
4826
Sylvestre Ledrub8198f0222014-08-11 18:09:03 +00004827 // -fexec_charset=UTF-8 is default. Reject others
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004828 if (Arg *execCharset = Args.getLastArg(options::OPT_fexec_charset_EQ)) {
4829 StringRef value = execCharset->getValue();
4830 if (value != "UTF-8")
4831 D.Diag(diag::err_drv_invalid_value) << execCharset->getAsString(Args)
4832 << value;
Sylvestre Ledrub8198f0222014-08-11 18:09:03 +00004833 }
4834
Jeffrey Yasskin460aa542010-06-08 04:56:20 +00004835 // -fcaret-diagnostics is default.
4836 if (!Args.hasFlag(options::OPT_fcaret_diagnostics,
4837 options::OPT_fno_caret_diagnostics, true))
4838 CmdArgs.push_back("-fno-caret-diagnostics");
4839
Daniel Dunbar8281bde2009-04-19 21:09:34 +00004840 // -fdiagnostics-fixit-info is default, only pass non-default.
Mike Stump11289f42009-09-09 15:08:12 +00004841 if (!Args.hasFlag(options::OPT_fdiagnostics_fixit_info,
Daniel Dunbar8281bde2009-04-19 21:09:34 +00004842 options::OPT_fno_diagnostics_fixit_info))
4843 CmdArgs.push_back("-fno-diagnostics-fixit-info");
Eric Christopher84fbdb42011-08-19 00:30:14 +00004844
Daniel Dunbar092f0cc2009-04-16 06:32:38 +00004845 // Enable -fdiagnostics-show-option by default.
Mike Stump11289f42009-09-09 15:08:12 +00004846 if (Args.hasFlag(options::OPT_fdiagnostics_show_option,
Daniel Dunbar092f0cc2009-04-16 06:32:38 +00004847 options::OPT_fno_diagnostics_show_option))
4848 CmdArgs.push_back("-fdiagnostics-show-option");
Daniel Dunbar5ec95022009-11-04 06:24:57 +00004849
Chris Lattnerbf6fac82010-05-04 21:55:25 +00004850 if (const Arg *A =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004851 Args.getLastArg(options::OPT_fdiagnostics_show_category_EQ)) {
Chris Lattnerbf6fac82010-05-04 21:55:25 +00004852 CmdArgs.push_back("-fdiagnostics-show-category");
Richard Smithbd55daf2012-11-01 04:30:05 +00004853 CmdArgs.push_back(A->getValue());
Chris Lattnerbf6fac82010-05-04 21:55:25 +00004854 }
Daniel Dunbarfe6c97b2010-08-24 16:47:49 +00004855
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004856 if (const Arg *A = Args.getLastArg(options::OPT_fdiagnostics_format_EQ)) {
Douglas Gregor643c9222011-05-21 17:07:29 +00004857 CmdArgs.push_back("-fdiagnostics-format");
Richard Smithbd55daf2012-11-01 04:30:05 +00004858 CmdArgs.push_back(A->getValue());
Douglas Gregor643c9222011-05-21 17:07:29 +00004859 }
4860
Chandler Carruthb6766f02011-03-27 01:50:55 +00004861 if (Arg *A = Args.getLastArg(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004862 options::OPT_fdiagnostics_show_note_include_stack,
4863 options::OPT_fno_diagnostics_show_note_include_stack)) {
Chandler Carruthb6766f02011-03-27 01:50:55 +00004864 if (A->getOption().matches(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004865 options::OPT_fdiagnostics_show_note_include_stack))
Chandler Carruthb6766f02011-03-27 01:50:55 +00004866 CmdArgs.push_back("-fdiagnostics-show-note-include-stack");
4867 else
4868 CmdArgs.push_back("-fno-diagnostics-show-note-include-stack");
4869 }
4870
Daniel Dunbar5ec95022009-11-04 06:24:57 +00004871 // Color diagnostics are the default, unless the terminal doesn't support
4872 // them.
Nico Weber7e2da792013-04-17 21:52:44 +00004873 // Support both clang's -f[no-]color-diagnostics and gcc's
4874 // -f[no-]diagnostics-colors[=never|always|auto].
4875 enum { Colors_On, Colors_Off, Colors_Auto } ShowColors = Colors_Auto;
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00004876 for (const auto &Arg : Args) {
4877 const Option &O = Arg->getOption();
Nico Weber7e2da792013-04-17 21:52:44 +00004878 if (!O.matches(options::OPT_fcolor_diagnostics) &&
4879 !O.matches(options::OPT_fdiagnostics_color) &&
4880 !O.matches(options::OPT_fno_color_diagnostics) &&
4881 !O.matches(options::OPT_fno_diagnostics_color) &&
4882 !O.matches(options::OPT_fdiagnostics_color_EQ))
4883 continue;
4884
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00004885 Arg->claim();
Nico Weber7e2da792013-04-17 21:52:44 +00004886 if (O.matches(options::OPT_fcolor_diagnostics) ||
4887 O.matches(options::OPT_fdiagnostics_color)) {
4888 ShowColors = Colors_On;
4889 } else if (O.matches(options::OPT_fno_color_diagnostics) ||
4890 O.matches(options::OPT_fno_diagnostics_color)) {
4891 ShowColors = Colors_Off;
4892 } else {
4893 assert(O.matches(options::OPT_fdiagnostics_color_EQ));
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00004894 StringRef value(Arg->getValue());
Nico Weber7e2da792013-04-17 21:52:44 +00004895 if (value == "always")
4896 ShowColors = Colors_On;
4897 else if (value == "never")
4898 ShowColors = Colors_Off;
4899 else if (value == "auto")
4900 ShowColors = Colors_Auto;
4901 else
4902 getToolChain().getDriver().Diag(diag::err_drv_clang_unsupported)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004903 << ("-fdiagnostics-color=" + value).str();
Nico Weber7e2da792013-04-17 21:52:44 +00004904 }
4905 }
4906 if (ShowColors == Colors_On ||
4907 (ShowColors == Colors_Auto && llvm::sys::Process::StandardErrHasColors()))
Daniel Dunbar5ec95022009-11-04 06:24:57 +00004908 CmdArgs.push_back("-fcolor-diagnostics");
4909
Nico Rieck7857d462013-09-11 00:38:02 +00004910 if (Args.hasArg(options::OPT_fansi_escape_codes))
4911 CmdArgs.push_back("-fansi-escape-codes");
4912
Daniel Dunbardb097022009-06-08 21:13:54 +00004913 if (!Args.hasFlag(options::OPT_fshow_source_location,
4914 options::OPT_fno_show_source_location))
4915 CmdArgs.push_back("-fno-show-source-location");
Daniel Dunbar092f0cc2009-04-16 06:32:38 +00004916
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004917 if (!Args.hasFlag(options::OPT_fshow_column, options::OPT_fno_show_column,
Douglas Gregor643c9222011-05-21 17:07:29 +00004918 true))
4919 CmdArgs.push_back("-fno-show-column");
4920
Douglas Gregor8ed0c0b2010-07-09 17:35:33 +00004921 if (!Args.hasFlag(options::OPT_fspell_checking,
4922 options::OPT_fno_spell_checking))
4923 CmdArgs.push_back("-fno-spell-checking");
Daniel Dunbarfe6c97b2010-08-24 16:47:49 +00004924
Chad Rosierc8e56e82012-12-05 21:08:21 +00004925 // -fno-asm-blocks is default.
4926 if (Args.hasFlag(options::OPT_fasm_blocks, options::OPT_fno_asm_blocks,
4927 false))
4928 CmdArgs.push_back("-fasm-blocks");
Daniel Dunbar473f8a62010-10-18 22:49:46 +00004929
Steven Wucb0d13f2015-01-16 23:05:28 +00004930 // -fgnu-inline-asm is default.
4931 if (!Args.hasFlag(options::OPT_fgnu_inline_asm,
4932 options::OPT_fno_gnu_inline_asm, true))
4933 CmdArgs.push_back("-fno-gnu-inline-asm");
4934
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00004935 // Enable vectorization per default according to the optimization level
4936 // selected. For optimization levels that want vectorization we use the alias
4937 // option to simplify the hasFlag logic.
Chad Rosier3ba81bd2014-05-02 18:41:57 +00004938 bool EnableVec = shouldEnableVectorizerAtOLevel(Args, false);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004939 OptSpecifier VectorizeAliasOption =
4940 EnableVec ? options::OPT_O_Group : options::OPT_fvectorize;
Chad Rosier679b0752013-04-24 18:29:59 +00004941 if (Args.hasFlag(options::OPT_fvectorize, VectorizeAliasOption,
Hal Finkel108c46a2013-08-28 05:21:45 +00004942 options::OPT_fno_vectorize, EnableVec))
Chad Rosier0d3ed6f2012-12-11 17:12:28 +00004943 CmdArgs.push_back("-vectorize-loops");
Chad Rosier0d3ed6f2012-12-11 17:12:28 +00004944
Chad Rosier136d67d2014-04-28 19:30:57 +00004945 // -fslp-vectorize is enabled based on the optimization level selected.
Chad Rosier3ba81bd2014-05-02 18:41:57 +00004946 bool EnableSLPVec = shouldEnableVectorizerAtOLevel(Args, true);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004947 OptSpecifier SLPVectAliasOption =
4948 EnableSLPVec ? options::OPT_O_Group : options::OPT_fslp_vectorize;
Chad Rosier136d67d2014-04-28 19:30:57 +00004949 if (Args.hasFlag(options::OPT_fslp_vectorize, SLPVectAliasOption,
Chad Rosier3ba81bd2014-05-02 18:41:57 +00004950 options::OPT_fno_slp_vectorize, EnableSLPVec))
Nadav Rotem0a2604d2013-04-15 04:57:18 +00004951 CmdArgs.push_back("-vectorize-slp");
Hal Finkel061f1652012-12-11 19:59:32 +00004952
Nadav Rotem6a0dd6b2013-04-15 05:38:41 +00004953 // -fno-slp-vectorize-aggressive is default.
4954 if (Args.hasFlag(options::OPT_fslp_vectorize_aggressive,
Nick Lewyckyd3f3e4f2013-06-25 01:49:44 +00004955 options::OPT_fno_slp_vectorize_aggressive, false))
Nadav Rotem6a0dd6b2013-04-15 05:38:41 +00004956 CmdArgs.push_back("-vectorize-slp-aggressive");
Nadav Rotem6a0dd6b2013-04-15 05:38:41 +00004957
Jeffrey Yasskin2b99c6f2010-06-11 05:57:47 +00004958 if (Arg *A = Args.getLastArg(options::OPT_fshow_overloads_EQ))
4959 A->render(Args, CmdArgs);
4960
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00004961 // -fdollars-in-identifiers default varies depending on platform and
4962 // language; only pass if specified.
Mike Stump11289f42009-09-09 15:08:12 +00004963 if (Arg *A = Args.getLastArg(options::OPT_fdollars_in_identifiers,
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00004964 options::OPT_fno_dollars_in_identifiers)) {
4965 if (A->getOption().matches(options::OPT_fdollars_in_identifiers))
Daniel Dunbar15cef0e2009-12-16 20:10:18 +00004966 CmdArgs.push_back("-fdollars-in-identifiers");
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00004967 else
Daniel Dunbar15cef0e2009-12-16 20:10:18 +00004968 CmdArgs.push_back("-fno-dollars-in-identifiers");
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00004969 }
4970
Daniel Dunbaradeeb052009-05-22 19:02:20 +00004971 // -funit-at-a-time is default, and we don't support -fno-unit-at-a-time for
4972 // practical purposes.
Mike Stump11289f42009-09-09 15:08:12 +00004973 if (Arg *A = Args.getLastArg(options::OPT_funit_at_a_time,
Daniel Dunbaradeeb052009-05-22 19:02:20 +00004974 options::OPT_fno_unit_at_a_time)) {
4975 if (A->getOption().matches(options::OPT_fno_unit_at_a_time))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004976 D.Diag(diag::warn_drv_clang_unsupported) << A->getAsString(Args);
Daniel Dunbaradeeb052009-05-22 19:02:20 +00004977 }
Eli Friedmanbb0d9a52009-07-14 21:58:17 +00004978
Eli Friedman055c9702011-11-02 01:53:16 +00004979 if (Args.hasFlag(options::OPT_fapple_pragma_pack,
4980 options::OPT_fno_apple_pragma_pack, false))
4981 CmdArgs.push_back("-fapple-pragma-pack");
4982
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004983 // le32-specific flags:
Eli Benderskyc95cfe82013-07-24 18:20:14 +00004984 // -fno-math-builtin: clang should not convert math builtins to intrinsics
4985 // by default.
4986 if (getToolChain().getArch() == llvm::Triple::le32) {
4987 CmdArgs.push_back("-fno-math-builtin");
4988 }
4989
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004990// Default to -fno-builtin-str{cat,cpy} on Darwin for ARM.
4991//
4992// FIXME: This is disabled until clang -cc1 supports -fno-builtin-foo. PR4941.
Daniel Dunbar4fa08112009-09-10 04:57:27 +00004993#if 0
Bob Wilson6524dd32011-10-14 05:03:44 +00004994 if (getToolChain().getTriple().isOSDarwin() &&
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00004995 (getToolChain().getArch() == llvm::Triple::arm ||
4996 getToolChain().getArch() == llvm::Triple::thumb)) {
Daniel Dunbar2ffe0292009-09-10 03:37:02 +00004997 if (!Args.hasArg(options::OPT_fbuiltin_strcat))
4998 CmdArgs.push_back("-fno-builtin-strcat");
4999 if (!Args.hasArg(options::OPT_fbuiltin_strcpy))
5000 CmdArgs.push_back("-fno-builtin-strcpy");
5001 }
Daniel Dunbar4fa08112009-09-10 04:57:27 +00005002#endif
Daniel Dunbar2ffe0292009-09-10 03:37:02 +00005003
Justin Bognera88f0122014-06-20 22:59:50 +00005004 // Enable rewrite includes if the user's asked for it or if we're generating
5005 // diagnostics.
5006 // TODO: Once -module-dependency-dir works with -frewrite-includes it'd be
5007 // nice to enable this when doing a crashdump for modules as well.
Justin Bogner332a5e52014-06-20 22:16:00 +00005008 if (Args.hasFlag(options::OPT_frewrite_includes,
5009 options::OPT_fno_rewrite_includes, false) ||
Justin Bognera88f0122014-06-20 22:59:50 +00005010 (C.isForDiagnostics() && !HaveModules))
Justin Bogner332a5e52014-06-20 22:16:00 +00005011 CmdArgs.push_back("-frewrite-includes");
5012
Daniel Dunbar8c3d7352011-03-18 21:23:40 +00005013 // Only allow -traditional or -traditional-cpp outside in preprocessing modes.
Mike Stump11289f42009-09-09 15:08:12 +00005014 if (Arg *A = Args.getLastArg(options::OPT_traditional,
Daniel Dunbar8c3d7352011-03-18 21:23:40 +00005015 options::OPT_traditional_cpp)) {
5016 if (isa<PreprocessJobAction>(JA))
5017 CmdArgs.push_back("-traditional-cpp");
Eric Christopher84fbdb42011-08-19 00:30:14 +00005018 else
Chris Lattner0e62c1c2011-07-23 10:55:15 +00005019 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
Daniel Dunbar8c3d7352011-03-18 21:23:40 +00005020 }
Eli Friedmanbb0d9a52009-07-14 21:58:17 +00005021
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005022 Args.AddLastArg(CmdArgs, options::OPT_dM);
Chris Lattnercac63f32009-04-12 01:56:53 +00005023 Args.AddLastArg(CmdArgs, options::OPT_dD);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005024
Ted Kremeneke73d9ed2011-11-11 00:07:43 +00005025 // Handle serialized diagnostics.
5026 if (Arg *A = Args.getLastArg(options::OPT__serialize_diags)) {
5027 CmdArgs.push_back("-serialize-diagnostic-file");
Richard Smithbd55daf2012-11-01 04:30:05 +00005028 CmdArgs.push_back(Args.MakeArgString(A->getValue()));
Ted Kremeneke73d9ed2011-11-11 00:07:43 +00005029 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005030
Ted Kremenekb47e6bc2012-09-13 06:41:18 +00005031 if (Args.hasArg(options::OPT_fretain_comments_from_system_headers))
5032 CmdArgs.push_back("-fretain-comments-from-system-headers");
5033
Dmitri Gribenkoacf2e782013-02-22 14:21:27 +00005034 // Forward -fcomment-block-commands to -cc1.
5035 Args.AddAllArgs(CmdArgs, options::OPT_fcomment_block_commands);
Dmitri Gribenkoa7d16ce2013-04-10 15:35:17 +00005036 // Forward -fparse-all-comments to -cc1.
5037 Args.AddAllArgs(CmdArgs, options::OPT_fparse_all_comments);
Dmitri Gribenkoacf2e782013-02-22 14:21:27 +00005038
John Brawnad31ace2015-09-23 13:55:40 +00005039 // Turn -fplugin=name.so into -load name.so
5040 for (const Arg *A : Args.filtered(options::OPT_fplugin_EQ)) {
5041 CmdArgs.push_back("-load");
5042 CmdArgs.push_back(A->getValue());
5043 A->claim();
5044 }
5045
Daniel Dunbar76fa8402010-04-15 06:09:03 +00005046 // Forward -Xclang arguments to -cc1, and -mllvm arguments to the LLVM option
5047 // parser.
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005048 Args.AddAllArgValues(CmdArgs, options::OPT_Xclang);
Sean Silva14facf32015-06-09 01:57:17 +00005049 for (const Arg *A : Args.filtered(options::OPT_mllvm)) {
5050 A->claim();
Daniel Dunbar88534f42010-04-17 06:10:00 +00005051
Daniel Dunbar76fa8402010-04-15 06:09:03 +00005052 // We translate this by hand to the -cc1 argument, since nightly test uses
5053 // it and developers have been trained to spell it with -mllvm.
Sean Silva14facf32015-06-09 01:57:17 +00005054 if (StringRef(A->getValue(0)) == "-disable-llvm-optzns") {
Daniel Dunbar76fa8402010-04-15 06:09:03 +00005055 CmdArgs.push_back("-disable-llvm-optzns");
Bob Wilson23a55f12014-12-21 07:00:00 +00005056 } else
Sean Silva14facf32015-06-09 01:57:17 +00005057 A->render(Args, CmdArgs);
Daniel Dunbar76fa8402010-04-15 06:09:03 +00005058 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005059
Bob Wilson23a55f12014-12-21 07:00:00 +00005060 // With -save-temps, we want to save the unoptimized bitcode output from the
Steven Wu546a1962015-07-17 20:09:56 +00005061 // CompileJobAction, use -disable-llvm-passes to get pristine IR generated
5062 // by the frontend.
5063 if (C.getDriver().isSaveTempsEnabled() && isa<CompileJobAction>(JA))
5064 CmdArgs.push_back("-disable-llvm-passes");
Bob Wilson23a55f12014-12-21 07:00:00 +00005065
Daniel Dunbard67a3222009-03-30 06:36:42 +00005066 if (Output.getType() == types::TY_Dependencies) {
5067 // Handled with other dependency code.
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005068 } else if (Output.isFilename()) {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005069 CmdArgs.push_back("-o");
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005070 CmdArgs.push_back(Output.getFilename());
5071 } else {
5072 assert(Output.isNothing() && "Invalid output.");
Daniel Dunbara3246a02009-03-18 08:07:30 +00005073 }
5074
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005075 addDashXForInput(Args, Input, CmdArgs);
Ben Langmuir2cb4a782014-02-05 22:21:15 +00005076
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005077 if (Input.isFilename())
5078 CmdArgs.push_back(Input.getFilename());
5079 else
5080 Input.getInputArg().renderAsInput(Args, CmdArgs);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00005081
Chris Lattnere9d7d782009-11-03 19:50:27 +00005082 Args.AddAllArgs(CmdArgs, options::OPT_undef);
5083
Daniel Dunbarb31b76f2010-07-18 21:16:15 +00005084 const char *Exec = getToolChain().getDriver().getClangProgramPath();
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005085
5086 // Optionally embed the -cc1 level arguments into the debug info, for build
5087 // analysis.
5088 if (getToolChain().UseDwarfDebugFlags()) {
Daniel Dunbar7f3d9502010-06-04 18:47:06 +00005089 ArgStringList OriginalArgs;
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005090 for (const auto &Arg : Args)
5091 Arg->render(Args, OriginalArgs);
Daniel Dunbarfe6c97b2010-08-24 16:47:49 +00005092
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +00005093 SmallString<256> Flags;
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005094 Flags += Exec;
Douglas Katzman6bbffc42015-06-25 18:51:37 +00005095 for (const char *OriginalArg : OriginalArgs) {
Bob Wilsond5aad2a2014-11-04 22:28:48 +00005096 SmallString<128> EscapedArg;
Douglas Katzman6bbffc42015-06-25 18:51:37 +00005097 EscapeSpacesAndBackslashes(OriginalArg, EscapedArg);
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005098 Flags += " ";
Bob Wilsond5aad2a2014-11-04 22:28:48 +00005099 Flags += EscapedArg;
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005100 }
5101 CmdArgs.push_back("-dwarf-debug-flags");
Yaron Keren92e1b622015-03-18 10:17:07 +00005102 CmdArgs.push_back(Args.MakeArgString(Flags));
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005103 }
5104
Eric Christopherd3804002013-02-22 20:12:52 +00005105 // Add the split debug info name to the command lines here so we
5106 // can propagate it to the backend.
David Blaikiece3e7a62015-07-30 21:42:22 +00005107 bool SplitDwarf = SplitDwarfArg && getToolChain().getTriple().isOSLinux() &&
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005108 (isa<AssembleJobAction>(JA) || isa<CompileJobAction>(JA) ||
5109 isa<BackendJobAction>(JA));
Eric Christopherd3804002013-02-22 20:12:52 +00005110 const char *SplitDwarfOut;
5111 if (SplitDwarf) {
5112 CmdArgs.push_back("-split-dwarf-file");
Artem Belevichba558952015-05-06 18:20:23 +00005113 SplitDwarfOut = SplitDebugName(Args, Input);
Eric Christopherd3804002013-02-22 20:12:52 +00005114 CmdArgs.push_back(SplitDwarfOut);
5115 }
5116
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005117 // Host-side cuda compilation receives device-side outputs as Inputs[1...].
5118 // Include them with -fcuda-include-gpubinary.
5119 if (IsCuda && Inputs.size() > 1)
Artem Belevich5bde4e02015-07-20 20:02:54 +00005120 for (auto I = std::next(Inputs.begin()), E = Inputs.end(); I != E; ++I) {
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005121 CmdArgs.push_back("-fcuda-include-gpubinary");
Artem Belevich5bde4e02015-07-20 20:02:54 +00005122 CmdArgs.push_back(I->getFilename());
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005123 }
5124
Eric Christopherd3804002013-02-22 20:12:52 +00005125 // Finally add the compile command to the compilation.
Hans Wennborg859422a2014-01-13 22:24:42 +00005126 if (Args.hasArg(options::OPT__SLASH_fallback) &&
Hans Wennborg26a44302014-04-25 16:44:17 +00005127 Output.getType() == types::TY_Object &&
5128 (InputType == types::TY_C || InputType == types::TY_CXX)) {
David Blaikiec11bf802014-09-04 16:04:28 +00005129 auto CLCommand =
5130 getCLFallback()->GetCommand(C, JA, Output, Inputs, Args, LinkingOutput);
Justin Bognerd3371d82015-07-17 03:35:54 +00005131 C.addCommand(llvm::make_unique<FallbackCommand>(
5132 JA, *this, Exec, CmdArgs, Inputs, std::move(CLCommand)));
Hans Wennborg87cfa712013-09-19 20:32:16 +00005133 } else {
Justin Bognerd3371d82015-07-17 03:35:54 +00005134 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Hans Wennborg87cfa712013-09-19 20:32:16 +00005135 }
5136
Eric Christopherf1545832013-02-22 23:50:16 +00005137 // Handle the debug info splitting at object creation time if we're
5138 // creating an object.
Eric Christopher248357f2013-02-21 22:35:01 +00005139 // TODO: Currently only works on linux with newer objcopy.
Bob Wilson23a55f12014-12-21 07:00:00 +00005140 if (SplitDwarf && !isa<CompileJobAction>(JA) && !isa<BackendJobAction>(JA))
Eric Christopherd3804002013-02-22 20:12:52 +00005141 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output, SplitDwarfOut);
Eric Christopher248357f2013-02-21 22:35:01 +00005142
Roman Divacky178e01602011-02-10 16:52:03 +00005143 if (Arg *A = Args.getLastArg(options::OPT_pg))
5144 if (Args.hasArg(options::OPT_fomit_frame_pointer))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005145 D.Diag(diag::err_drv_argument_not_allowed_with) << "-fomit-frame-pointer"
5146 << A->getAsString(Args);
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00005147
Daniel Dunbarc2a71892009-04-03 20:51:31 +00005148 // Claim some arguments which clang supports automatically.
5149
Daniel Dunbar3e0cac62010-04-15 06:18:42 +00005150 // -fpch-preprocess is used with gcc to add a special marker in the output to
5151 // include the PCH file. Clang's PTH solution is completely transparent, so we
5152 // do not need to deal with it at all.
Daniel Dunbarc2a71892009-04-03 20:51:31 +00005153 Args.ClaimAllArgs(options::OPT_fpch_preprocess);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00005154
Daniel Dunbar17731772009-03-23 19:03:36 +00005155 // Claim some arguments which clang doesn't support, but we don't
5156 // care to warn the user about.
Daniel Dunbar44b36ee2009-11-25 11:53:23 +00005157 Args.ClaimAllArgs(options::OPT_clang_ignored_f_Group);
5158 Args.ClaimAllArgs(options::OPT_clang_ignored_m_Group);
Rafael Espindola22f603032011-02-28 23:29:45 +00005159
Rafael Espindolab0092d72013-09-04 19:37:35 +00005160 // Disable warnings for clang -E -emit-llvm foo.c
Rafael Espindolad95a8122011-03-01 05:25:27 +00005161 Args.ClaimAllArgs(options::OPT_emit_llvm);
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005162}
5163
John McCall5fb5df92012-06-20 06:18:46 +00005164/// Add options related to the Objective-C runtime/ABI.
5165///
5166/// Returns true if the runtime is non-fragile.
5167ObjCRuntime Clang::AddObjCRuntimeArgs(const ArgList &args,
5168 ArgStringList &cmdArgs,
5169 RewriteKind rewriteKind) const {
5170 // Look for the controlling runtime option.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005171 Arg *runtimeArg =
5172 args.getLastArg(options::OPT_fnext_runtime, options::OPT_fgnu_runtime,
5173 options::OPT_fobjc_runtime_EQ);
John McCall5fb5df92012-06-20 06:18:46 +00005174
5175 // Just forward -fobjc-runtime= to the frontend. This supercedes
5176 // options about fragility.
5177 if (runtimeArg &&
5178 runtimeArg->getOption().matches(options::OPT_fobjc_runtime_EQ)) {
5179 ObjCRuntime runtime;
Richard Smithbd55daf2012-11-01 04:30:05 +00005180 StringRef value = runtimeArg->getValue();
John McCall5fb5df92012-06-20 06:18:46 +00005181 if (runtime.tryParse(value)) {
5182 getToolChain().getDriver().Diag(diag::err_drv_unknown_objc_runtime)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005183 << value;
John McCall5fb5df92012-06-20 06:18:46 +00005184 }
5185
5186 runtimeArg->render(args, cmdArgs);
5187 return runtime;
5188 }
5189
5190 // Otherwise, we'll need the ABI "version". Version numbers are
5191 // slightly confusing for historical reasons:
5192 // 1 - Traditional "fragile" ABI
5193 // 2 - Non-fragile ABI, version 1
5194 // 3 - Non-fragile ABI, version 2
5195 unsigned objcABIVersion = 1;
5196 // If -fobjc-abi-version= is present, use that to set the version.
5197 if (Arg *abiArg = args.getLastArg(options::OPT_fobjc_abi_version_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00005198 StringRef value = abiArg->getValue();
John McCall5fb5df92012-06-20 06:18:46 +00005199 if (value == "1")
5200 objcABIVersion = 1;
5201 else if (value == "2")
5202 objcABIVersion = 2;
5203 else if (value == "3")
5204 objcABIVersion = 3;
5205 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005206 getToolChain().getDriver().Diag(diag::err_drv_clang_unsupported) << value;
John McCall5fb5df92012-06-20 06:18:46 +00005207 } else {
5208 // Otherwise, determine if we are using the non-fragile ABI.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005209 bool nonFragileABIIsDefault =
5210 (rewriteKind == RK_NonFragile ||
5211 (rewriteKind == RK_None &&
5212 getToolChain().IsObjCNonFragileABIDefault()));
John McCall5fb5df92012-06-20 06:18:46 +00005213 if (args.hasFlag(options::OPT_fobjc_nonfragile_abi,
5214 options::OPT_fno_objc_nonfragile_abi,
5215 nonFragileABIIsDefault)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005216// Determine the non-fragile ABI version to use.
John McCall5fb5df92012-06-20 06:18:46 +00005217#ifdef DISABLE_DEFAULT_NONFRAGILEABI_TWO
5218 unsigned nonFragileABIVersion = 1;
5219#else
5220 unsigned nonFragileABIVersion = 2;
5221#endif
5222
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005223 if (Arg *abiArg =
5224 args.getLastArg(options::OPT_fobjc_nonfragile_abi_version_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00005225 StringRef value = abiArg->getValue();
John McCall5fb5df92012-06-20 06:18:46 +00005226 if (value == "1")
5227 nonFragileABIVersion = 1;
5228 else if (value == "2")
5229 nonFragileABIVersion = 2;
5230 else
5231 getToolChain().getDriver().Diag(diag::err_drv_clang_unsupported)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005232 << value;
John McCall5fb5df92012-06-20 06:18:46 +00005233 }
5234
5235 objcABIVersion = 1 + nonFragileABIVersion;
5236 } else {
5237 objcABIVersion = 1;
5238 }
5239 }
5240
5241 // We don't actually care about the ABI version other than whether
5242 // it's non-fragile.
5243 bool isNonFragile = objcABIVersion != 1;
5244
5245 // If we have no runtime argument, ask the toolchain for its default runtime.
5246 // However, the rewriter only really supports the Mac runtime, so assume that.
5247 ObjCRuntime runtime;
5248 if (!runtimeArg) {
5249 switch (rewriteKind) {
5250 case RK_None:
5251 runtime = getToolChain().getDefaultObjCRuntime(isNonFragile);
5252 break;
5253 case RK_Fragile:
5254 runtime = ObjCRuntime(ObjCRuntime::FragileMacOSX, VersionTuple());
5255 break;
5256 case RK_NonFragile:
5257 runtime = ObjCRuntime(ObjCRuntime::MacOSX, VersionTuple());
5258 break;
5259 }
5260
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005261 // -fnext-runtime
John McCall5fb5df92012-06-20 06:18:46 +00005262 } else if (runtimeArg->getOption().matches(options::OPT_fnext_runtime)) {
5263 // On Darwin, make this use the default behavior for the toolchain.
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00005264 if (getToolChain().getTriple().isOSDarwin()) {
John McCall5fb5df92012-06-20 06:18:46 +00005265 runtime = getToolChain().getDefaultObjCRuntime(isNonFragile);
5266
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005267 // Otherwise, build for a generic macosx port.
John McCall5fb5df92012-06-20 06:18:46 +00005268 } else {
5269 runtime = ObjCRuntime(ObjCRuntime::MacOSX, VersionTuple());
5270 }
5271
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005272 // -fgnu-runtime
John McCall5fb5df92012-06-20 06:18:46 +00005273 } else {
5274 assert(runtimeArg->getOption().matches(options::OPT_fgnu_runtime));
David Chisnall314896c2012-07-04 10:37:03 +00005275 // Legacy behaviour is to target the gnustep runtime if we are i
5276 // non-fragile mode or the GCC runtime in fragile mode.
5277 if (isNonFragile)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005278 runtime = ObjCRuntime(ObjCRuntime::GNUstep, VersionTuple(1, 6));
David Chisnall314896c2012-07-04 10:37:03 +00005279 else
5280 runtime = ObjCRuntime(ObjCRuntime::GCC, VersionTuple());
John McCall5fb5df92012-06-20 06:18:46 +00005281 }
5282
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005283 cmdArgs.push_back(
5284 args.MakeArgString("-fobjc-runtime=" + runtime.getAsString()));
John McCall5fb5df92012-06-20 06:18:46 +00005285 return runtime;
5286}
5287
Reid Klecknerc542d372014-06-27 17:02:02 +00005288static bool maybeConsumeDash(const std::string &EH, size_t &I) {
5289 bool HaveDash = (I + 1 < EH.size() && EH[I + 1] == '-');
5290 I += HaveDash;
5291 return !HaveDash;
Chandler Carruth095b6962014-06-29 22:42:51 +00005292}
Reid Klecknerc542d372014-06-27 17:02:02 +00005293
5294struct EHFlags {
5295 EHFlags() : Synch(false), Asynch(false), NoExceptC(false) {}
5296 bool Synch;
5297 bool Asynch;
5298 bool NoExceptC;
5299};
5300
5301/// /EH controls whether to run destructor cleanups when exceptions are
5302/// thrown. There are three modifiers:
5303/// - s: Cleanup after "synchronous" exceptions, aka C++ exceptions.
5304/// - a: Cleanup after "asynchronous" exceptions, aka structured exceptions.
5305/// The 'a' modifier is unimplemented and fundamentally hard in LLVM IR.
5306/// - c: Assume that extern "C" functions are implicitly noexcept. This
5307/// modifier is an optimization, so we ignore it for now.
5308/// The default is /EHs-c-, meaning cleanups are disabled.
5309static EHFlags parseClangCLEHFlags(const Driver &D, const ArgList &Args) {
5310 EHFlags EH;
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00005311
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005312 std::vector<std::string> EHArgs =
5313 Args.getAllArgValues(options::OPT__SLASH_EH);
Reid Klecknerc542d372014-06-27 17:02:02 +00005314 for (auto EHVal : EHArgs) {
5315 for (size_t I = 0, E = EHVal.size(); I != E; ++I) {
5316 switch (EHVal[I]) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005317 case 'a':
5318 EH.Asynch = maybeConsumeDash(EHVal, I);
5319 continue;
5320 case 'c':
5321 EH.NoExceptC = maybeConsumeDash(EHVal, I);
5322 continue;
5323 case 's':
5324 EH.Synch = maybeConsumeDash(EHVal, I);
5325 continue;
5326 default:
5327 break;
Reid Klecknerc542d372014-06-27 17:02:02 +00005328 }
5329 D.Diag(clang::diag::err_drv_invalid_value) << "/EH" << EHVal;
5330 break;
5331 }
5332 }
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00005333
Reid Kleckner5c6efed2015-07-14 18:16:48 +00005334 // FIXME: Disable C++ EH completely, until it becomes more reliable. Users
5335 // can use -Xclang to manually enable C++ EH until then.
5336 EH = EHFlags();
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00005337
Reid Klecknerc542d372014-06-27 17:02:02 +00005338 return EH;
5339}
5340
Hans Wennborg75958c42013-08-08 00:17:41 +00005341void Clang::AddClangCLArgs(const ArgList &Args, ArgStringList &CmdArgs) const {
5342 unsigned RTOptionID = options::OPT__SLASH_MT;
5343
Hans Wennborgf1a74252013-09-10 20:18:04 +00005344 if (Args.hasArg(options::OPT__SLASH_LDd))
5345 // The /LDd option implies /MTd. The dependent lib part can be overridden,
5346 // but defining _DEBUG is sticky.
5347 RTOptionID = options::OPT__SLASH_MTd;
5348
Hans Wennborg9cb7d9ba2013-09-18 22:26:39 +00005349 if (Arg *A = Args.getLastArg(options::OPT__SLASH_M_Group))
Hans Wennborg75958c42013-08-08 00:17:41 +00005350 RTOptionID = A->getOption().getID();
Hans Wennborgd9ad0682013-09-11 16:38:41 +00005351
David Majnemere2afb472015-07-24 06:49:13 +00005352 StringRef FlagForCRT;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005353 switch (RTOptionID) {
5354 case options::OPT__SLASH_MD:
5355 if (Args.hasArg(options::OPT__SLASH_LDd))
Hans Wennborg75958c42013-08-08 00:17:41 +00005356 CmdArgs.push_back("-D_DEBUG");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005357 CmdArgs.push_back("-D_MT");
5358 CmdArgs.push_back("-D_DLL");
David Majnemere2afb472015-07-24 06:49:13 +00005359 FlagForCRT = "--dependent-lib=msvcrt";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005360 break;
5361 case options::OPT__SLASH_MDd:
5362 CmdArgs.push_back("-D_DEBUG");
5363 CmdArgs.push_back("-D_MT");
5364 CmdArgs.push_back("-D_DLL");
David Majnemere2afb472015-07-24 06:49:13 +00005365 FlagForCRT = "--dependent-lib=msvcrtd";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005366 break;
5367 case options::OPT__SLASH_MT:
5368 if (Args.hasArg(options::OPT__SLASH_LDd))
Hans Wennborg75958c42013-08-08 00:17:41 +00005369 CmdArgs.push_back("-D_DEBUG");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005370 CmdArgs.push_back("-D_MT");
David Majnemere2afb472015-07-24 06:49:13 +00005371 FlagForCRT = "--dependent-lib=libcmt";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005372 break;
5373 case options::OPT__SLASH_MTd:
5374 CmdArgs.push_back("-D_DEBUG");
5375 CmdArgs.push_back("-D_MT");
David Majnemere2afb472015-07-24 06:49:13 +00005376 FlagForCRT = "--dependent-lib=libcmtd";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005377 break;
5378 default:
5379 llvm_unreachable("Unexpected option ID.");
Hans Wennborg75958c42013-08-08 00:17:41 +00005380 }
5381
David Majnemere2afb472015-07-24 06:49:13 +00005382 if (Args.hasArg(options::OPT__SLASH_Zl)) {
5383 CmdArgs.push_back("-D_VC_NODEFAULTLIB");
5384 } else {
5385 CmdArgs.push_back(FlagForCRT.data());
5386
5387 // This provides POSIX compatibility (maps 'open' to '_open'), which most
5388 // users want. The /Za flag to cl.exe turns this off, but it's not
5389 // implemented in clang.
5390 CmdArgs.push_back("--dependent-lib=oldnames");
5391 }
Hans Wennborg614f7072013-08-08 19:54:30 +00005392
Hans Wennborg8858a032014-07-21 23:42:07 +00005393 // Both /showIncludes and /E (and /EP) write to stdout. Allowing both
5394 // would produce interleaved output, so ignore /showIncludes in such cases.
5395 if (!Args.hasArg(options::OPT_E) && !Args.hasArg(options::OPT__SLASH_EP))
5396 if (Arg *A = Args.getLastArg(options::OPT_show_includes))
5397 A->render(Args, CmdArgs);
Hans Wennborg81f74482013-09-10 01:07:07 +00005398
David Majnemerf6072342014-07-01 22:24:56 +00005399 // This controls whether or not we emit RTTI data for polymorphic types.
5400 if (Args.hasFlag(options::OPT__SLASH_GR_, options::OPT__SLASH_GR,
5401 /*default=*/false))
5402 CmdArgs.push_back("-fno-rtti-data");
Hans Wennborg7b0dcef2014-02-25 18:36:22 +00005403
Reid Kleckner124955a2015-08-05 18:51:13 +00005404 // Emit CodeView if -Z7 is present.
5405 bool EmitCodeView = Args.hasArg(options::OPT__SLASH_Z7);
5406 bool EmitDwarf = Args.hasArg(options::OPT_gdwarf);
5407 // If we are emitting CV but not DWARF, don't build information that LLVM
5408 // can't yet process.
5409 if (EmitCodeView && !EmitDwarf)
5410 CmdArgs.push_back("-gline-tables-only");
5411 if (EmitCodeView)
5412 CmdArgs.push_back("-gcodeview");
5413
Reid Klecknerc542d372014-06-27 17:02:02 +00005414 const Driver &D = getToolChain().getDriver();
5415 EHFlags EH = parseClangCLEHFlags(D, Args);
5416 // FIXME: Do something with NoExceptC.
Reid Klecknerdeeddec2015-02-05 18:56:03 +00005417 if (EH.Synch || EH.Asynch) {
Reid Klecknerc542d372014-06-27 17:02:02 +00005418 CmdArgs.push_back("-fcxx-exceptions");
Reid Klecknerdeeddec2015-02-05 18:56:03 +00005419 CmdArgs.push_back("-fexceptions");
5420 }
Reid Klecknerc542d372014-06-27 17:02:02 +00005421
Hans Wennborge50cec32014-06-13 20:59:54 +00005422 // /EP should expand to -E -P.
5423 if (Args.hasArg(options::OPT__SLASH_EP)) {
5424 CmdArgs.push_back("-E");
5425 CmdArgs.push_back("-P");
5426 }
5427
David Majnemera5b195a2015-02-14 01:35:12 +00005428 unsigned VolatileOptionID;
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00005429 if (getToolChain().getArch() == llvm::Triple::x86_64 ||
5430 getToolChain().getArch() == llvm::Triple::x86)
David Majnemera5b195a2015-02-14 01:35:12 +00005431 VolatileOptionID = options::OPT__SLASH_volatile_ms;
5432 else
5433 VolatileOptionID = options::OPT__SLASH_volatile_iso;
5434
5435 if (Arg *A = Args.getLastArg(options::OPT__SLASH_volatile_Group))
5436 VolatileOptionID = A->getOption().getID();
5437
5438 if (VolatileOptionID == options::OPT__SLASH_volatile_ms)
5439 CmdArgs.push_back("-fms-volatile");
5440
David Majnemer86c318f2014-02-11 21:05:00 +00005441 Arg *MostGeneralArg = Args.getLastArg(options::OPT__SLASH_vmg);
5442 Arg *BestCaseArg = Args.getLastArg(options::OPT__SLASH_vmb);
5443 if (MostGeneralArg && BestCaseArg)
5444 D.Diag(clang::diag::err_drv_argument_not_allowed_with)
5445 << MostGeneralArg->getAsString(Args) << BestCaseArg->getAsString(Args);
5446
5447 if (MostGeneralArg) {
5448 Arg *SingleArg = Args.getLastArg(options::OPT__SLASH_vms);
5449 Arg *MultipleArg = Args.getLastArg(options::OPT__SLASH_vmm);
5450 Arg *VirtualArg = Args.getLastArg(options::OPT__SLASH_vmv);
5451
5452 Arg *FirstConflict = SingleArg ? SingleArg : MultipleArg;
5453 Arg *SecondConflict = VirtualArg ? VirtualArg : MultipleArg;
5454 if (FirstConflict && SecondConflict && FirstConflict != SecondConflict)
5455 D.Diag(clang::diag::err_drv_argument_not_allowed_with)
5456 << FirstConflict->getAsString(Args)
5457 << SecondConflict->getAsString(Args);
5458
5459 if (SingleArg)
5460 CmdArgs.push_back("-fms-memptr-rep=single");
5461 else if (MultipleArg)
5462 CmdArgs.push_back("-fms-memptr-rep=multiple");
5463 else
5464 CmdArgs.push_back("-fms-memptr-rep=virtual");
5465 }
5466
Reid Klecknerc0dca6d2014-02-12 23:50:26 +00005467 if (Arg *A = Args.getLastArg(options::OPT_vtordisp_mode_EQ))
5468 A->render(Args, CmdArgs);
5469
Hans Wennborg81f74482013-09-10 01:07:07 +00005470 if (!Args.hasArg(options::OPT_fdiagnostics_format_EQ)) {
5471 CmdArgs.push_back("-fdiagnostics-format");
Hans Wennborgf4aee182013-09-24 00:08:55 +00005472 if (Args.hasArg(options::OPT__SLASH_fallback))
5473 CmdArgs.push_back("msvc-fallback");
5474 else
5475 CmdArgs.push_back("msvc");
Hans Wennborg81f74482013-09-10 01:07:07 +00005476 }
Hans Wennborg75958c42013-08-08 00:17:41 +00005477}
5478
Douglas Katzman95354292015-06-23 20:42:09 +00005479visualstudio::Compiler *Clang::getCLFallback() const {
Hans Wennborg1da044a2014-06-26 19:59:02 +00005480 if (!CLFallback)
Douglas Katzman95354292015-06-23 20:42:09 +00005481 CLFallback.reset(new visualstudio::Compiler(getToolChain()));
Hans Wennborg1da044a2014-06-26 19:59:02 +00005482 return CLFallback.get();
5483}
5484
Daniel Sanders7f933f42015-01-30 17:35:23 +00005485void ClangAs::AddMIPSTargetArgs(const ArgList &Args,
5486 ArgStringList &CmdArgs) const {
5487 StringRef CPUName;
5488 StringRef ABIName;
5489 const llvm::Triple &Triple = getToolChain().getTriple();
5490 mips::getMipsCPUAndABI(Args, Triple, CPUName, ABIName);
5491
5492 CmdArgs.push_back("-target-abi");
5493 CmdArgs.push_back(ABIName.data());
5494}
5495
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005496void ClangAs::ConstructJob(Compilation &C, const JobAction &JA,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005497 const InputInfo &Output, const InputInfoList &Inputs,
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005498 const ArgList &Args,
5499 const char *LinkingOutput) const {
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005500 ArgStringList CmdArgs;
5501
5502 assert(Inputs.size() == 1 && "Unexpected number of inputs.");
5503 const InputInfo &Input = Inputs[0];
5504
James Y Knight2db38f32015-08-15 03:45:25 +00005505 std::string TripleStr =
5506 getToolChain().ComputeEffectiveClangTriple(Args, Input.getType());
5507 const llvm::Triple Triple(TripleStr);
5508
Rafael Espindolacfaadda2010-11-17 22:13:25 +00005509 // Don't warn about "clang -w -c foo.s"
5510 Args.ClaimAllArgs(options::OPT_w);
Rafael Espindolad95a8122011-03-01 05:25:27 +00005511 // and "clang -emit-llvm -c foo.s"
5512 Args.ClaimAllArgs(options::OPT_emit_llvm);
Rafael Espindolacfaadda2010-11-17 22:13:25 +00005513
Rafael Espindola577637a2015-01-03 00:06:04 +00005514 claimNoWarnArgs(Args);
Rafael Espindola16042fc2015-01-02 23:23:52 +00005515
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005516 // Invoke ourselves in -cc1as mode.
5517 //
5518 // FIXME: Implement custom jobs for internal actions.
5519 CmdArgs.push_back("-cc1as");
5520
5521 // Add the "effective" target triple.
5522 CmdArgs.push_back("-triple");
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005523 CmdArgs.push_back(Args.MakeArgString(TripleStr));
5524
5525 // Set the output mode, we currently only expect to be used as a real
5526 // assembler.
5527 CmdArgs.push_back("-filetype");
5528 CmdArgs.push_back("obj");
5529
Eric Christopher45f2e712012-12-18 00:31:10 +00005530 // Set the main file name, so that debug info works even with
5531 // -save-temps or preprocessed assembly.
5532 CmdArgs.push_back("-main-file-name");
Artem Belevichba558952015-05-06 18:20:23 +00005533 CmdArgs.push_back(Clang::getBaseInputName(Args, Input));
Eric Christopher45f2e712012-12-18 00:31:10 +00005534
Rafael Espindola22ce34a2013-08-20 22:12:08 +00005535 // Add the target cpu
Renato Golin7c542b42015-07-27 23:44:45 +00005536 std::string CPU = getCPUName(Args, Triple, /*FromAs*/ true);
Rafael Espindola22ce34a2013-08-20 22:12:08 +00005537 if (!CPU.empty()) {
5538 CmdArgs.push_back("-target-cpu");
5539 CmdArgs.push_back(Args.MakeArgString(CPU));
5540 }
5541
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00005542 // Add the target features
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00005543 getTargetFeatures(getToolChain(), Triple, Args, CmdArgs, true);
Jim Grosbach576452b2012-02-10 20:37:10 +00005544
Daniel Dunbar1d733e22011-03-17 17:37:29 +00005545 // Ignore explicit -force_cpusubtype_ALL option.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005546 (void)Args.hasArg(options::OPT_force__cpusubtype__ALL);
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005547
Jim Grosbachc78c2bc2015-06-23 18:20:13 +00005548 // Pass along any -I options so we get proper .include search paths.
5549 Args.AddAllArgs(CmdArgs, options::OPT_I_Group);
5550
Eric Christopherfc3ee562012-01-10 00:38:01 +00005551 // Determine the original source input.
5552 const Action *SourceAction = &JA;
5553 while (SourceAction->getKind() != Action::InputClass) {
5554 assert(!SourceAction->getInputs().empty() && "unexpected root action!");
5555 SourceAction = SourceAction->getInputs()[0];
5556 }
5557
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00005558 // Forward -g and handle debug info related flags, assuming we are dealing
5559 // with an actual assembly file.
Eric Christopherfc3ee562012-01-10 00:38:01 +00005560 if (SourceAction->getType() == types::TY_Asm ||
5561 SourceAction->getType() == types::TY_PP_Asm) {
5562 Args.ClaimAllArgs(options::OPT_g_Group);
5563 if (Arg *A = Args.getLastArg(options::OPT_g_Group))
5564 if (!A->getOption().matches(options::OPT_g0))
5565 CmdArgs.push_back("-g");
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00005566
Douglas Katzman553927a2015-09-14 20:31:28 +00005567 if (Arg *A = Args.getLastArg(options::OPT_gdwarf_2, options::OPT_gdwarf_3,
5568 options::OPT_gdwarf_4))
5569 A->render(Args, CmdArgs);
Oliver Stannard9b2a7d42014-05-19 13:39:13 +00005570
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00005571 // Add the -fdebug-compilation-dir flag if needed.
5572 addDebugCompDirArg(Args, CmdArgs);
Kevin Enderbyae2ec472013-01-17 21:38:06 +00005573
5574 // Set the AT_producer to the clang version when using the integrated
5575 // assembler on assembly source files.
5576 CmdArgs.push_back("-dwarf-debug-producer");
5577 CmdArgs.push_back(Args.MakeArgString(getClangFullVersion()));
Renato Golina74bbc72015-07-22 15:32:36 +00005578
5579 // And pass along -I options
5580 Args.AddAllArgs(CmdArgs, options::OPT_I);
Eric Christopherfc3ee562012-01-10 00:38:01 +00005581 }
Kevin Enderby292dc082011-12-22 19:31:58 +00005582
James Y Knight5bdf7ab2015-08-19 15:12:02 +00005583 // Handle -fPIC et al -- the relocation-model affects the assembler
5584 // for some targets.
5585 llvm::Reloc::Model RelocationModel;
5586 unsigned PICLevel;
5587 bool IsPIE;
5588 std::tie(RelocationModel, PICLevel, IsPIE) =
5589 ParsePICArgs(getToolChain(), Triple, Args);
5590
5591 const char *RMName = RelocationModelName(RelocationModel);
5592 if (RMName) {
5593 CmdArgs.push_back("-mrelocation-model");
5594 CmdArgs.push_back(RMName);
5595 }
5596
Kevin Enderby292dc082011-12-22 19:31:58 +00005597 // Optionally embed the -cc1as level arguments into the debug info, for build
5598 // analysis.
5599 if (getToolChain().UseDwarfDebugFlags()) {
5600 ArgStringList OriginalArgs;
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005601 for (const auto &Arg : Args)
5602 Arg->render(Args, OriginalArgs);
Kevin Enderby292dc082011-12-22 19:31:58 +00005603
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +00005604 SmallString<256> Flags;
Kevin Enderby292dc082011-12-22 19:31:58 +00005605 const char *Exec = getToolChain().getDriver().getClangProgramPath();
5606 Flags += Exec;
Douglas Katzman6bbffc42015-06-25 18:51:37 +00005607 for (const char *OriginalArg : OriginalArgs) {
Bob Wilsond5aad2a2014-11-04 22:28:48 +00005608 SmallString<128> EscapedArg;
Douglas Katzman6bbffc42015-06-25 18:51:37 +00005609 EscapeSpacesAndBackslashes(OriginalArg, EscapedArg);
Kevin Enderby292dc082011-12-22 19:31:58 +00005610 Flags += " ";
Bob Wilsond5aad2a2014-11-04 22:28:48 +00005611 Flags += EscapedArg;
Kevin Enderby292dc082011-12-22 19:31:58 +00005612 }
5613 CmdArgs.push_back("-dwarf-debug-flags");
Yaron Keren92e1b622015-03-18 10:17:07 +00005614 CmdArgs.push_back(Args.MakeArgString(Flags));
Kevin Enderby292dc082011-12-22 19:31:58 +00005615 }
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005616
5617 // FIXME: Add -static support, once we have it.
5618
Daniel Sanders7f933f42015-01-30 17:35:23 +00005619 // Add target specific flags.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005620 switch (getToolChain().getArch()) {
Daniel Sanders7f933f42015-01-30 17:35:23 +00005621 default:
5622 break;
5623
5624 case llvm::Triple::mips:
5625 case llvm::Triple::mipsel:
5626 case llvm::Triple::mips64:
5627 case llvm::Triple::mips64el:
5628 AddMIPSTargetArgs(Args, CmdArgs);
5629 break;
5630 }
5631
David Blaikie372d9502014-01-17 03:17:40 +00005632 // Consume all the warning flags. Usually this would be handled more
5633 // gracefully by -cc1 (warning about unknown warning flags, etc) but -cc1as
5634 // doesn't handle that so rather than warning about unused flags that are
5635 // actually used, we'll lie by omission instead.
5636 // FIXME: Stop lying and consume only the appropriate driver flags
Sean Silva14facf32015-06-09 01:57:17 +00005637 for (const Arg *A : Args.filtered(options::OPT_W_Group))
5638 A->claim();
David Blaikie372d9502014-01-17 03:17:40 +00005639
David Blaikie9260ed62013-07-25 21:19:01 +00005640 CollectArgsForIntegratedAssembler(C, Args, CmdArgs,
5641 getToolChain().getDriver());
5642
Daniel Dunbar252e8f92011-04-29 17:53:18 +00005643 Args.AddAllArgs(CmdArgs, options::OPT_mllvm);
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005644
5645 assert(Output.isFilename() && "Unexpected lipo output.");
5646 CmdArgs.push_back("-o");
5647 CmdArgs.push_back(Output.getFilename());
5648
Daniel Dunbarb440f562010-08-02 02:38:21 +00005649 assert(Input.isFilename() && "Invalid input.");
5650 CmdArgs.push_back(Input.getFilename());
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005651
Daniel Dunbarb31b76f2010-07-18 21:16:15 +00005652 const char *Exec = getToolChain().getDriver().getClangProgramPath();
Justin Bognerd3371d82015-07-17 03:35:54 +00005653 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eric Christophera75018a2013-04-10 21:30:40 +00005654
5655 // Handle the debug info splitting at object creation time if we're
5656 // creating an object.
5657 // TODO: Currently only works on linux with newer objcopy.
5658 if (Args.hasArg(options::OPT_gsplit_dwarf) &&
Cameron Esfahani556d91e2013-09-14 01:09:11 +00005659 getToolChain().getTriple().isOSLinux())
Eric Christophera75018a2013-04-10 21:30:40 +00005660 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output,
Artem Belevichba558952015-05-06 18:20:23 +00005661 SplitDebugName(Args, Input));
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005662}
5663
Reid Kleckner0290c9c2014-09-15 17:45:39 +00005664void GnuTool::anchor() {}
5665
Daniel Dunbara3246a02009-03-18 08:07:30 +00005666void gcc::Common::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbara3246a02009-03-18 08:07:30 +00005667 const InputInfo &Output,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005668 const InputInfoList &Inputs, const ArgList &Args,
Daniel Dunbara3246a02009-03-18 08:07:30 +00005669 const char *LinkingOutput) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00005670 const Driver &D = getToolChain().getDriver();
Daniel Dunbara3246a02009-03-18 08:07:30 +00005671 ArgStringList CmdArgs;
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005672
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005673 for (const auto &A : Args) {
Michael J. Spencer66e2b202012-10-19 22:37:06 +00005674 if (forwardToGCC(A->getOption())) {
Daniel Dunbar939c1212010-08-03 16:14:14 +00005675 // Don't forward any -g arguments to assembly steps.
5676 if (isa<AssembleJobAction>(JA) &&
5677 A->getOption().matches(options::OPT_g_Group))
5678 continue;
5679
NAKAMURA Takumi053704f2013-08-19 11:51:51 +00005680 // Don't forward any -W arguments to assembly and link steps.
5681 if ((isa<AssembleJobAction>(JA) || isa<LinkJobAction>(JA)) &&
5682 A->getOption().matches(options::OPT_W_Group))
5683 continue;
5684
Daniel Dunbar2da02722009-03-19 07:55:12 +00005685 // It is unfortunate that we have to claim here, as this means
5686 // we will basically never report anything interesting for
Daniel Dunbar5716d872009-05-02 21:41:52 +00005687 // platforms using a generic gcc, even if we are just using gcc
5688 // to get to the assembler.
Daniel Dunbar2da02722009-03-19 07:55:12 +00005689 A->claim();
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005690 A->render(Args, CmdArgs);
Daniel Dunbar2da02722009-03-19 07:55:12 +00005691 }
Daniel Dunbara3246a02009-03-18 08:07:30 +00005692 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00005693
Daniel Dunbar4e295052010-01-25 22:35:08 +00005694 RenderExtraToolArgs(JA, CmdArgs);
Daniel Dunbara3246a02009-03-18 08:07:30 +00005695
5696 // If using a driver driver, force the arch.
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00005697 if (getToolChain().getTriple().isOSDarwin()) {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005698 CmdArgs.push_back("-arch");
Rafael Espindolaed1233e2014-08-28 21:23:05 +00005699 CmdArgs.push_back(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005700 Args.MakeArgString(getToolChain().getDefaultUniversalArchName()));
Daniel Dunbara3246a02009-03-18 08:07:30 +00005701 }
5702
Daniel Dunbar5716d872009-05-02 21:41:52 +00005703 // Try to force gcc to match the tool chain we want, if we recognize
5704 // the arch.
Daniel Dunbar5bbebfe2009-05-22 02:21:04 +00005705 //
5706 // FIXME: The triple class should directly provide the information we want
5707 // here.
Douglas Katzman38857552015-08-20 18:32:26 +00005708 switch (getToolChain().getArch()) {
5709 default:
5710 break;
5711 case llvm::Triple::x86:
5712 case llvm::Triple::ppc:
Daniel Dunbar5716d872009-05-02 21:41:52 +00005713 CmdArgs.push_back("-m32");
Douglas Katzman38857552015-08-20 18:32:26 +00005714 break;
5715 case llvm::Triple::x86_64:
5716 case llvm::Triple::ppc64:
5717 case llvm::Triple::ppc64le:
Daniel Dunbar5716d872009-05-02 21:41:52 +00005718 CmdArgs.push_back("-m64");
Douglas Katzman38857552015-08-20 18:32:26 +00005719 break;
5720 case llvm::Triple::sparcel:
5721 CmdArgs.push_back("-EL");
5722 break;
5723 }
Daniel Dunbar5716d872009-05-02 21:41:52 +00005724
Daniel Dunbarb440f562010-08-02 02:38:21 +00005725 if (Output.isFilename()) {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005726 CmdArgs.push_back("-o");
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005727 CmdArgs.push_back(Output.getFilename());
5728 } else {
5729 assert(Output.isNothing() && "Unexpected output");
Daniel Dunbara3246a02009-03-18 08:07:30 +00005730 CmdArgs.push_back("-fsyntax-only");
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005731 }
Daniel Dunbara3246a02009-03-18 08:07:30 +00005732
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005733 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbara3246a02009-03-18 08:07:30 +00005734
5735 // Only pass -x if gcc will understand it; otherwise hope gcc
5736 // understands the suffix correctly. The main use case this would go
5737 // wrong in is for linker inputs if they happened to have an odd
5738 // suffix; really the only way to get this to happen is a command
5739 // like '-x foobar a.c' which will treat a.c like a linker input.
5740 //
5741 // FIXME: For the linker case specifically, can we safely convert
5742 // inputs into '-Wl,' options?
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005743 for (const auto &II : Inputs) {
Daniel Dunbar6cdf83c2009-09-01 16:57:46 +00005744 // Don't try to pass LLVM or AST inputs to a generic gcc.
Daniel Dunbar24e52992010-06-07 23:28:45 +00005745 if (II.getType() == types::TY_LLVM_IR || II.getType() == types::TY_LTO_IR ||
5746 II.getType() == types::TY_LLVM_BC || II.getType() == types::TY_LTO_BC)
Chris Lattner0e62c1c2011-07-23 10:55:15 +00005747 D.Diag(diag::err_drv_no_linker_llvm_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005748 << getToolChain().getTripleString();
Daniel Dunbar6cdf83c2009-09-01 16:57:46 +00005749 else if (II.getType() == types::TY_AST)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005750 D.Diag(diag::err_drv_no_ast_support) << getToolChain().getTripleString();
Douglas Gregorbf7fc9c2013-03-27 16:47:18 +00005751 else if (II.getType() == types::TY_ModuleFile)
5752 D.Diag(diag::err_drv_no_module_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005753 << getToolChain().getTripleString();
Daniel Dunbare3e263f2009-05-02 20:14:53 +00005754
Daniel Dunbara3246a02009-03-18 08:07:30 +00005755 if (types::canTypeBeUserSpecified(II.getType())) {
5756 CmdArgs.push_back("-x");
5757 CmdArgs.push_back(types::getTypeName(II.getType()));
5758 }
5759
Daniel Dunbarb440f562010-08-02 02:38:21 +00005760 if (II.isFilename())
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005761 CmdArgs.push_back(II.getFilename());
Daniel Dunbarf2476752010-09-25 18:10:05 +00005762 else {
5763 const Arg &A = II.getInputArg();
5764
5765 // Reverse translate some rewritten options.
5766 if (A.getOption().matches(options::OPT_Z_reserved_lib_stdcxx)) {
5767 CmdArgs.push_back("-lstdc++");
5768 continue;
5769 }
5770
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005771 // Don't render as input, we need gcc to do the translations.
Daniel Dunbarf2476752010-09-25 18:10:05 +00005772 A.render(Args, CmdArgs);
5773 }
Daniel Dunbara3246a02009-03-18 08:07:30 +00005774 }
5775
Dylan Noblesmith70e73a32011-04-09 13:31:59 +00005776 const std::string customGCCName = D.getCCCGenericGCCName();
5777 const char *GCCName;
5778 if (!customGCCName.empty())
5779 GCCName = customGCCName.c_str();
Hans Wennborg70850d82013-07-18 20:29:38 +00005780 else if (D.CCCIsCXX()) {
Dylan Noblesmith70e73a32011-04-09 13:31:59 +00005781 GCCName = "g++";
Dylan Noblesmith70e73a32011-04-09 13:31:59 +00005782 } else
5783 GCCName = "gcc";
5784
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005785 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath(GCCName));
Justin Bognerd3371d82015-07-17 03:35:54 +00005786 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005787}
5788
Douglas Katzman95354292015-06-23 20:42:09 +00005789void gcc::Preprocessor::RenderExtraToolArgs(const JobAction &JA,
5790 ArgStringList &CmdArgs) const {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005791 CmdArgs.push_back("-E");
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005792}
5793
Douglas Katzman95354292015-06-23 20:42:09 +00005794void gcc::Compiler::RenderExtraToolArgs(const JobAction &JA,
5795 ArgStringList &CmdArgs) const {
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00005796 const Driver &D = getToolChain().getDriver();
5797
Eric Christophercc7ff502015-01-29 00:56:17 +00005798 switch (JA.getType()) {
Daniel Dunbar4e295052010-01-25 22:35:08 +00005799 // If -flto, etc. are present then make sure not to force assembly output.
Eric Christophercc7ff502015-01-29 00:56:17 +00005800 case types::TY_LLVM_IR:
5801 case types::TY_LTO_IR:
5802 case types::TY_LLVM_BC:
5803 case types::TY_LTO_BC:
Daniel Dunbar4e295052010-01-25 22:35:08 +00005804 CmdArgs.push_back("-c");
Eric Christophercc7ff502015-01-29 00:56:17 +00005805 break;
5806 case types::TY_PP_Asm:
Daniel Dunbar4e295052010-01-25 22:35:08 +00005807 CmdArgs.push_back("-S");
Eric Christopher58c21992015-01-30 18:22:23 +00005808 break;
Eric Christophercc7ff502015-01-29 00:56:17 +00005809 case types::TY_Nothing:
5810 CmdArgs.push_back("-fsyntax-only");
5811 break;
5812 default:
5813 D.Diag(diag::err_drv_invalid_gcc_output_type) << getTypeName(JA.getType());
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00005814 }
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005815}
5816
Douglas Katzman95354292015-06-23 20:42:09 +00005817void gcc::Linker::RenderExtraToolArgs(const JobAction &JA,
5818 ArgStringList &CmdArgs) const {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005819 // The types are (hopefully) good enough.
5820}
5821
Tony Linthicum76329bf2011-12-12 21:14:55 +00005822// Hexagon tools start.
Douglas Katzman95354292015-06-23 20:42:09 +00005823void hexagon::Assembler::RenderExtraToolArgs(const JobAction &JA,
5824 ArgStringList &CmdArgs) const {}
5825void hexagon::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
5826 const InputInfo &Output,
5827 const InputInfoList &Inputs,
5828 const ArgList &Args,
5829 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00005830 claimNoWarnArgs(Args);
Tony Linthicum76329bf2011-12-12 21:14:55 +00005831
5832 const Driver &D = getToolChain().getDriver();
5833 ArgStringList CmdArgs;
5834
5835 std::string MarchString = "-march=";
Douglas Katzman54366072015-07-27 16:53:08 +00005836 MarchString += toolchains::HexagonToolChain::GetTargetCPU(Args);
Tony Linthicum76329bf2011-12-12 21:14:55 +00005837 CmdArgs.push_back(Args.MakeArgString(MarchString));
5838
5839 RenderExtraToolArgs(JA, CmdArgs);
5840
5841 if (Output.isFilename()) {
5842 CmdArgs.push_back("-o");
5843 CmdArgs.push_back(Output.getFilename());
5844 } else {
5845 assert(Output.isNothing() && "Unexpected output");
5846 CmdArgs.push_back("-fsyntax-only");
5847 }
5848
Douglas Katzman54366072015-07-27 16:53:08 +00005849 if (const char *v = toolchains::HexagonToolChain::GetSmallDataThreshold(Args))
Ikhlas Ajbar522e6192015-05-14 13:52:08 +00005850 CmdArgs.push_back(Args.MakeArgString(std::string("-G") + v));
Tony Linthicum76329bf2011-12-12 21:14:55 +00005851
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005852 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Matthew Curtise5df3812012-12-07 17:23:04 +00005853
Tony Linthicum76329bf2011-12-12 21:14:55 +00005854 // Only pass -x if gcc will understand it; otherwise hope gcc
5855 // understands the suffix correctly. The main use case this would go
5856 // wrong in is for linker inputs if they happened to have an odd
5857 // suffix; really the only way to get this to happen is a command
5858 // like '-x foobar a.c' which will treat a.c like a linker input.
5859 //
5860 // FIXME: For the linker case specifically, can we safely convert
5861 // inputs into '-Wl,' options?
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005862 for (const auto &II : Inputs) {
Tony Linthicum76329bf2011-12-12 21:14:55 +00005863 // Don't try to pass LLVM or AST inputs to a generic gcc.
5864 if (II.getType() == types::TY_LLVM_IR || II.getType() == types::TY_LTO_IR ||
5865 II.getType() == types::TY_LLVM_BC || II.getType() == types::TY_LTO_BC)
5866 D.Diag(clang::diag::err_drv_no_linker_llvm_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005867 << getToolChain().getTripleString();
Tony Linthicum76329bf2011-12-12 21:14:55 +00005868 else if (II.getType() == types::TY_AST)
5869 D.Diag(clang::diag::err_drv_no_ast_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005870 << getToolChain().getTripleString();
Douglas Gregorbf7fc9c2013-03-27 16:47:18 +00005871 else if (II.getType() == types::TY_ModuleFile)
5872 D.Diag(diag::err_drv_no_module_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005873 << getToolChain().getTripleString();
Tony Linthicum76329bf2011-12-12 21:14:55 +00005874
5875 if (II.isFilename())
5876 CmdArgs.push_back(II.getFilename());
5877 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005878 // Don't render as input, we need gcc to do the translations.
5879 // FIXME: Pranav: What is this ?
Tony Linthicum76329bf2011-12-12 21:14:55 +00005880 II.getInputArg().render(Args, CmdArgs);
5881 }
5882
5883 const char *GCCName = "hexagon-as";
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005884 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath(GCCName));
Justin Bognerd3371d82015-07-17 03:35:54 +00005885 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Tony Linthicum76329bf2011-12-12 21:14:55 +00005886}
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005887
Douglas Katzman95354292015-06-23 20:42:09 +00005888void hexagon::Linker::RenderExtraToolArgs(const JobAction &JA,
5889 ArgStringList &CmdArgs) const {
Tony Linthicum76329bf2011-12-12 21:14:55 +00005890 // The types are (hopefully) good enough.
5891}
5892
Douglas Katzman54366072015-07-27 16:53:08 +00005893static void
5894constructHexagonLinkArgs(Compilation &C, const JobAction &JA,
5895 const toolchains::HexagonToolChain &ToolChain,
5896 const InputInfo &Output, const InputInfoList &Inputs,
5897 const ArgList &Args, ArgStringList &CmdArgs,
5898 const char *LinkingOutput) {
Tony Linthicum76329bf2011-12-12 21:14:55 +00005899
Matthew Curtise689b052012-12-06 15:46:07 +00005900 const Driver &D = ToolChain.getDriver();
5901
Matthew Curtise689b052012-12-06 15:46:07 +00005902 //----------------------------------------------------------------------------
5903 //
5904 //----------------------------------------------------------------------------
5905 bool hasStaticArg = Args.hasArg(options::OPT_static);
5906 bool buildingLib = Args.hasArg(options::OPT_shared);
Matthew Curtise8f80a12012-12-06 17:49:03 +00005907 bool buildPIE = Args.hasArg(options::OPT_pie);
Matthew Curtise689b052012-12-06 15:46:07 +00005908 bool incStdLib = !Args.hasArg(options::OPT_nostdlib);
5909 bool incStartFiles = !Args.hasArg(options::OPT_nostartfiles);
5910 bool incDefLibs = !Args.hasArg(options::OPT_nodefaultlibs);
Ikhlas Ajbar522e6192015-05-14 13:52:08 +00005911 bool useG0 = false;
Matthew Curtise689b052012-12-06 15:46:07 +00005912 bool useShared = buildingLib && !hasStaticArg;
Tony Linthicum76329bf2011-12-12 21:14:55 +00005913
Matthew Curtise689b052012-12-06 15:46:07 +00005914 //----------------------------------------------------------------------------
5915 // Silence warnings for various options
5916 //----------------------------------------------------------------------------
Tony Linthicum76329bf2011-12-12 21:14:55 +00005917
Matthew Curtise689b052012-12-06 15:46:07 +00005918 Args.ClaimAllArgs(options::OPT_g_Group);
5919 Args.ClaimAllArgs(options::OPT_emit_llvm);
5920 Args.ClaimAllArgs(options::OPT_w); // Other warning options are already
5921 // handled somewhere else.
5922 Args.ClaimAllArgs(options::OPT_static_libgcc);
5923
5924 //----------------------------------------------------------------------------
5925 //
5926 //----------------------------------------------------------------------------
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005927 for (const auto &Opt : ToolChain.ExtraOpts)
5928 CmdArgs.push_back(Opt.c_str());
Tony Linthicum76329bf2011-12-12 21:14:55 +00005929
Douglas Katzman54366072015-07-27 16:53:08 +00005930 std::string MarchString = toolchains::HexagonToolChain::GetTargetCPU(Args);
Matthew Curtisf10a5952012-12-06 14:16:43 +00005931 CmdArgs.push_back(Args.MakeArgString("-m" + MarchString));
Sebastian Pop86500282012-01-13 20:37:10 +00005932
Matthew Curtise689b052012-12-06 15:46:07 +00005933 if (buildingLib) {
5934 CmdArgs.push_back("-shared");
5935 CmdArgs.push_back("-call_shared"); // should be the default, but doing as
5936 // hexagon-gcc does
Tony Linthicum76329bf2011-12-12 21:14:55 +00005937 }
5938
Matthew Curtise689b052012-12-06 15:46:07 +00005939 if (hasStaticArg)
5940 CmdArgs.push_back("-static");
Tony Linthicum76329bf2011-12-12 21:14:55 +00005941
Matthew Curtise8f80a12012-12-06 17:49:03 +00005942 if (buildPIE && !buildingLib)
5943 CmdArgs.push_back("-pie");
5944
Douglas Katzman54366072015-07-27 16:53:08 +00005945 if (const char *v =
5946 toolchains::HexagonToolChain::GetSmallDataThreshold(Args)) {
Ikhlas Ajbar522e6192015-05-14 13:52:08 +00005947 CmdArgs.push_back(Args.MakeArgString(std::string("-G") + v));
Douglas Katzman54366072015-07-27 16:53:08 +00005948 useG0 = toolchains::HexagonToolChain::UsesG0(v);
Matthew Curtise8f80a12012-12-06 17:49:03 +00005949 }
5950
Matthew Curtise689b052012-12-06 15:46:07 +00005951 //----------------------------------------------------------------------------
5952 //
5953 //----------------------------------------------------------------------------
5954 CmdArgs.push_back("-o");
5955 CmdArgs.push_back(Output.getFilename());
Tony Linthicum76329bf2011-12-12 21:14:55 +00005956
Matthew Curtise689b052012-12-06 15:46:07 +00005957 const std::string MarchSuffix = "/" + MarchString;
5958 const std::string G0Suffix = "/G0";
5959 const std::string MarchG0Suffix = MarchSuffix + G0Suffix;
Samuel Antaoc909c992014-11-07 17:48:03 +00005960 const std::string RootDir =
Douglas Katzman54366072015-07-27 16:53:08 +00005961 toolchains::HexagonToolChain::GetGnuDir(D.InstalledDir, Args) + "/";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005962 const std::string StartFilesDir =
5963 RootDir + "hexagon/lib" + (useG0 ? MarchG0Suffix : MarchSuffix);
Matthew Curtise689b052012-12-06 15:46:07 +00005964
5965 //----------------------------------------------------------------------------
5966 // moslib
5967 //----------------------------------------------------------------------------
5968 std::vector<std::string> oslibs;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005969 bool hasStandalone = false;
Matthew Curtise689b052012-12-06 15:46:07 +00005970
Sean Silva14facf32015-06-09 01:57:17 +00005971 for (const Arg *A : Args.filtered(options::OPT_moslib_EQ)) {
5972 A->claim();
5973 oslibs.emplace_back(A->getValue());
Matthew Curtise689b052012-12-06 15:46:07 +00005974 hasStandalone = hasStandalone || (oslibs.back() == "standalone");
Tony Linthicum76329bf2011-12-12 21:14:55 +00005975 }
Matthew Curtise689b052012-12-06 15:46:07 +00005976 if (oslibs.empty()) {
5977 oslibs.push_back("standalone");
5978 hasStandalone = true;
5979 }
Tony Linthicum76329bf2011-12-12 21:14:55 +00005980
Matthew Curtise689b052012-12-06 15:46:07 +00005981 //----------------------------------------------------------------------------
5982 // Start Files
5983 //----------------------------------------------------------------------------
5984 if (incStdLib && incStartFiles) {
5985
5986 if (!buildingLib) {
5987 if (hasStandalone) {
5988 CmdArgs.push_back(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005989 Args.MakeArgString(StartFilesDir + "/crt0_standalone.o"));
Matthew Curtise689b052012-12-06 15:46:07 +00005990 }
5991 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crt0.o"));
5992 }
5993 std::string initObj = useShared ? "/initS.o" : "/init.o";
5994 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + initObj));
5995 }
5996
5997 //----------------------------------------------------------------------------
5998 // Library Search Paths
5999 //----------------------------------------------------------------------------
6000 const ToolChain::path_list &LibPaths = ToolChain.getFilePaths();
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006001 for (const auto &LibPath : LibPaths)
6002 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + LibPath));
Matthew Curtise689b052012-12-06 15:46:07 +00006003
6004 //----------------------------------------------------------------------------
6005 //
6006 //----------------------------------------------------------------------------
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00006007 Args.AddAllArgs(CmdArgs,
6008 {options::OPT_T_Group, options::OPT_e, options::OPT_s,
6009 options::OPT_t, options::OPT_u_Group});
Matthew Curtise689b052012-12-06 15:46:07 +00006010
6011 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
6012
6013 //----------------------------------------------------------------------------
6014 // Libraries
6015 //----------------------------------------------------------------------------
6016 if (incStdLib && incDefLibs) {
Hans Wennborg70850d82013-07-18 20:29:38 +00006017 if (D.CCCIsCXX()) {
Matthew Curtise689b052012-12-06 15:46:07 +00006018 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
6019 CmdArgs.push_back("-lm");
6020 }
6021
6022 CmdArgs.push_back("--start-group");
6023
6024 if (!buildingLib) {
Douglas Katzman2675d012015-06-29 19:12:56 +00006025 for (const std::string &Lib : oslibs)
6026 CmdArgs.push_back(Args.MakeArgString("-l" + Lib));
Matthew Curtise689b052012-12-06 15:46:07 +00006027 CmdArgs.push_back("-lc");
6028 }
6029 CmdArgs.push_back("-lgcc");
6030
6031 CmdArgs.push_back("--end-group");
6032 }
6033
6034 //----------------------------------------------------------------------------
6035 // End files
6036 //----------------------------------------------------------------------------
6037 if (incStdLib && incStartFiles) {
6038 std::string finiObj = useShared ? "/finiS.o" : "/fini.o";
6039 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + finiObj));
6040 }
Ikhlas Ajbar71d19f32015-05-09 02:13:25 +00006041}
6042
Douglas Katzman95354292015-06-23 20:42:09 +00006043void hexagon::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6044 const InputInfo &Output,
6045 const InputInfoList &Inputs,
6046 const ArgList &Args,
6047 const char *LinkingOutput) const {
Ikhlas Ajbar71d19f32015-05-09 02:13:25 +00006048
Douglas Katzman54366072015-07-27 16:53:08 +00006049 const toolchains::HexagonToolChain &ToolChain =
6050 static_cast<const toolchains::HexagonToolChain &>(getToolChain());
Ikhlas Ajbar71d19f32015-05-09 02:13:25 +00006051
6052 ArgStringList CmdArgs;
6053 constructHexagonLinkArgs(C, JA, ToolChain, Output, Inputs, Args, CmdArgs,
6054 LinkingOutput);
Matthew Curtise689b052012-12-06 15:46:07 +00006055
6056 std::string Linker = ToolChain.GetProgramPath("hexagon-ld");
David Blaikiec11bf802014-09-04 16:04:28 +00006057 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Linker),
Justin Bognerd3371d82015-07-17 03:35:54 +00006058 CmdArgs, Inputs));
Tony Linthicum76329bf2011-12-12 21:14:55 +00006059}
6060// Hexagon tools end.
6061
Tom Stellard8fa33092015-07-18 01:49:05 +00006062void amdgpu::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6063 const InputInfo &Output,
6064 const InputInfoList &Inputs,
6065 const ArgList &Args,
6066 const char *LinkingOutput) const {
6067
6068 std::string Linker = getToolChain().GetProgramPath(getShortName());
6069 ArgStringList CmdArgs;
6070 CmdArgs.push_back("-flavor");
6071 CmdArgs.push_back("gnu");
6072 CmdArgs.push_back("-target");
Tom Stellard1de69e82015-07-18 02:11:07 +00006073 CmdArgs.push_back(Args.MakeArgString(getToolChain().getTripleString()));
Tom Stellard8fa33092015-07-18 01:49:05 +00006074 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
6075 CmdArgs.push_back("-o");
6076 CmdArgs.push_back(Output.getFilename());
6077 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Linker),
6078 CmdArgs, Inputs));
6079}
6080// AMDGPU tools end.
6081
Renato Golin7c542b42015-07-27 23:44:45 +00006082const std::string arm::getARMArch(StringRef Arch, const llvm::Triple &Triple) {
Gabor Ballabascebcb3b2015-06-11 12:29:56 +00006083 std::string MArch;
Renato Goline17c5802015-07-27 23:44:42 +00006084 if (!Arch.empty())
6085 MArch = Arch;
6086 else
Bernard Ogden31561762013-12-12 13:27:11 +00006087 MArch = Triple.getArchName();
Gabor Ballabascebcb3b2015-06-11 12:29:56 +00006088 MArch = StringRef(MArch).lower();
John Brawn94fd9632015-05-21 12:19:49 +00006089
6090 // Handle -march=native.
6091 if (MArch == "native") {
6092 std::string CPU = llvm::sys::getHostCPUName();
6093 if (CPU != "generic") {
6094 // Translate the native cpu into the architecture suffix for that CPU.
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006095 StringRef Suffix = arm::getLLVMArchSuffixForARM(CPU, MArch, Triple);
John Brawn94fd9632015-05-21 12:19:49 +00006096 // If there is no valid architecture suffix for this CPU we don't know how
6097 // to handle it, so return no architecture.
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006098 if (Suffix.empty())
John Brawn94fd9632015-05-21 12:19:49 +00006099 MArch = "";
6100 else
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006101 MArch = std::string("arm") + Suffix.str();
John Brawn94fd9632015-05-21 12:19:49 +00006102 }
6103 }
6104
Vladimir Sukharevc6dab752015-05-14 08:25:18 +00006105 return MArch;
6106}
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006107
Vladimir Sukharevc6dab752015-05-14 08:25:18 +00006108/// Get the (LLVM) name of the minimum ARM CPU for the arch we are targeting.
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006109StringRef arm::getARMCPUForMArch(StringRef Arch, const llvm::Triple &Triple) {
Renato Goline17c5802015-07-27 23:44:42 +00006110 std::string MArch = getARMArch(Arch, Triple);
John Brawn94fd9632015-05-21 12:19:49 +00006111 // getARMCPUForArch defaults to the triple if MArch is empty, but empty MArch
6112 // here means an -march=native that we can't handle, so instead return no CPU.
6113 if (MArch.empty())
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006114 return StringRef();
Bernard Ogden31561762013-12-12 13:27:11 +00006115
John Brawna95c1a82015-05-08 12:52:18 +00006116 // We need to return an empty string here on invalid MArch values as the
6117 // various places that call this function can't cope with a null result.
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006118 return Triple.getARMCPUForArch(MArch);
Bernard Ogden31561762013-12-12 13:27:11 +00006119}
6120
6121/// getARMTargetCPU - Get the (LLVM) name of the ARM cpu we are targeting.
Renato Golin7c542b42015-07-27 23:44:45 +00006122std::string arm::getARMTargetCPU(StringRef CPU, StringRef Arch,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006123 const llvm::Triple &Triple) {
Bernard Ogden31561762013-12-12 13:27:11 +00006124 // FIXME: Warn on inconsistent use of -mcpu and -march.
6125 // If we have -mcpu=, use that.
Renato Goline17c5802015-07-27 23:44:42 +00006126 if (!CPU.empty()) {
6127 std::string MCPU = StringRef(CPU).lower();
Bernard Ogden31561762013-12-12 13:27:11 +00006128 // Handle -mcpu=native.
6129 if (MCPU == "native")
Rafael Espindola9c5ef122013-12-12 15:39:05 +00006130 return llvm::sys::getHostCPUName();
Bernard Ogden31561762013-12-12 13:27:11 +00006131 else
Rafael Espindola80d333b2013-12-12 15:48:19 +00006132 return MCPU;
Bernard Ogden31561762013-12-12 13:27:11 +00006133 }
6134
Renato Goline17c5802015-07-27 23:44:42 +00006135 return getARMCPUForMArch(Arch, Triple);
Bernard Ogden31561762013-12-12 13:27:11 +00006136}
6137
6138/// getLLVMArchSuffixForARM - Get the LLVM arch name to use for a particular
Vladimir Sukharevc6dab752015-05-14 08:25:18 +00006139/// CPU (or Arch, if CPU is generic).
Bernard Ogden31561762013-12-12 13:27:11 +00006140// FIXME: This is redundant with -mcpu, why does LLVM use this.
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006141StringRef arm::getLLVMArchSuffixForARM(StringRef CPU, StringRef Arch,
6142 const llvm::Triple &Triple) {
6143 unsigned ArchKind;
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006144 if (CPU == "generic") {
Vladimir Sukhareva317dfb2015-09-24 10:06:44 +00006145 std::string ARMArch = tools::arm::getARMArch(Arch, Triple);
Vladimir Sukharev2eef4b52015-09-24 09:55:08 +00006146 ArchKind = llvm::ARM::parseArch(ARMArch);
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006147 if (ArchKind == llvm::ARM::AK_INVALID)
6148 // In case of generic Arch, i.e. "arm",
6149 // extract arch from default cpu of the Triple
Vladimir Sukharev2eef4b52015-09-24 09:55:08 +00006150 ArchKind = llvm::ARM::parseCPUArch(Triple.getARMCPUForArch(ARMArch));
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006151 } else {
6152 ArchKind = llvm::ARM::parseCPUArch(CPU);
6153 }
Renato Golin3c007252015-05-28 15:05:53 +00006154 if (ArchKind == llvm::ARM::AK_INVALID)
6155 return "";
Chandler Carruthaa0caeb2015-08-30 02:16:36 +00006156 return llvm::ARM::getSubArch(ArchKind);
Bernard Ogden31561762013-12-12 13:27:11 +00006157}
6158
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006159void arm::appendEBLinkFlags(const ArgList &Args, ArgStringList &CmdArgs,
Vladimir Sukharevc6dab752015-05-14 08:25:18 +00006160 const llvm::Triple &Triple) {
Joerg Sonnenberger1689d3f2015-01-28 23:30:39 +00006161 if (Args.hasArg(options::OPT_r))
6162 return;
6163
John Brawn94fd9632015-05-21 12:19:49 +00006164 // ARMv7 (and later) and ARMv6-M do not support BE-32, so instruct the linker
6165 // to generate BE-8 executables.
6166 if (getARMSubArchVersionNumber(Triple) >= 7 || isARMMProfile(Triple))
6167 CmdArgs.push_back("--be8");
Joerg Sonnenberger1689d3f2015-01-28 23:30:39 +00006168}
6169
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00006170mips::NanEncoding mips::getSupportedNanEncoding(StringRef &CPU) {
Daniel Sanderse0395a72015-09-24 10:22:17 +00006171 // Strictly speaking, mips32r2 and mips64r2 are NanLegacy-only since Nan2008
6172 // was first introduced in Release 3. However, other compilers have
6173 // traditionally allowed it for Release 2 so we should do the same.
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00006174 return (NanEncoding)llvm::StringSwitch<int>(CPU)
6175 .Case("mips1", NanLegacy)
6176 .Case("mips2", NanLegacy)
6177 .Case("mips3", NanLegacy)
6178 .Case("mips4", NanLegacy)
6179 .Case("mips5", NanLegacy)
6180 .Case("mips32", NanLegacy)
Daniel Sanderse0395a72015-09-24 10:22:17 +00006181 .Case("mips32r2", NanLegacy | Nan2008)
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00006182 .Case("mips32r3", NanLegacy | Nan2008)
6183 .Case("mips32r5", NanLegacy | Nan2008)
6184 .Case("mips32r6", Nan2008)
6185 .Case("mips64", NanLegacy)
Daniel Sanderse0395a72015-09-24 10:22:17 +00006186 .Case("mips64r2", NanLegacy | Nan2008)
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00006187 .Case("mips64r3", NanLegacy | Nan2008)
6188 .Case("mips64r5", NanLegacy | Nan2008)
6189 .Case("mips64r6", Nan2008)
6190 .Default(NanLegacy);
6191}
6192
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00006193bool mips::hasMipsAbiArg(const ArgList &Args, const char *Value) {
6194 Arg *A = Args.getLastArg(options::OPT_mabi_EQ);
6195 return A && (A->getValue() == StringRef(Value));
6196}
6197
Simon Atanasyand95c67d2014-08-13 14:34:14 +00006198bool mips::isUCLibc(const ArgList &Args) {
6199 Arg *A = Args.getLastArg(options::OPT_m_libc_Group);
Rafael Espindolad3d657c2014-08-13 17:15:42 +00006200 return A && A->getOption().matches(options::OPT_muclibc);
Simon Atanasyand95c67d2014-08-13 14:34:14 +00006201}
6202
Daniel Sanders2bf13662014-07-10 14:40:57 +00006203bool mips::isNaN2008(const ArgList &Args, const llvm::Triple &Triple) {
Daniel Sanders3b92c5b2014-06-24 15:04:16 +00006204 if (Arg *NaNArg = Args.getLastArg(options::OPT_mnan_EQ))
6205 return llvm::StringSwitch<bool>(NaNArg->getValue())
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006206 .Case("2008", true)
6207 .Case("legacy", false)
6208 .Default(false);
Daniel Sanders3b92c5b2014-06-24 15:04:16 +00006209
6210 // NaN2008 is the default for MIPS32r6/MIPS64r6.
Daniel Sanders2bf13662014-07-10 14:40:57 +00006211 return llvm::StringSwitch<bool>(getCPUName(Args, Triple))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006212 .Cases("mips32r6", "mips64r6", true)
6213 .Default(false);
Daniel Sanders3b92c5b2014-06-24 15:04:16 +00006214
6215 return false;
6216}
6217
Daniel Sanders379d44b2014-07-16 11:52:23 +00006218bool mips::isFPXXDefault(const llvm::Triple &Triple, StringRef CPUName,
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00006219 StringRef ABIName, mips::FloatABI FloatABI) {
Daniel Sanders379d44b2014-07-16 11:52:23 +00006220 if (Triple.getVendor() != llvm::Triple::ImaginationTechnologies &&
Daniel Sanders492beb12014-07-18 15:05:38 +00006221 Triple.getVendor() != llvm::Triple::MipsTechnologies)
Daniel Sanders379d44b2014-07-16 11:52:23 +00006222 return false;
6223
6224 if (ABIName != "32")
6225 return false;
6226
Toma Tabacu94ea6862015-06-16 13:54:13 +00006227 // FPXX shouldn't be used if either -msoft-float or -mfloat-abi=soft is
6228 // present.
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00006229 if (FloatABI == mips::FloatABI::Soft)
Toma Tabacu94ea6862015-06-16 13:54:13 +00006230 return false;
6231
Daniel Sanders379d44b2014-07-16 11:52:23 +00006232 return llvm::StringSwitch<bool>(CPUName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006233 .Cases("mips2", "mips3", "mips4", "mips5", true)
6234 .Cases("mips32", "mips32r2", "mips32r3", "mips32r5", true)
6235 .Cases("mips64", "mips64r2", "mips64r3", "mips64r5", true)
6236 .Default(false);
Daniel Sanders379d44b2014-07-16 11:52:23 +00006237}
6238
Toma Tabacu94ea6862015-06-16 13:54:13 +00006239bool mips::shouldUseFPXX(const ArgList &Args, const llvm::Triple &Triple,
6240 StringRef CPUName, StringRef ABIName,
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00006241 mips::FloatABI FloatABI) {
Toma Tabacu94ea6862015-06-16 13:54:13 +00006242 bool UseFPXX = isFPXXDefault(Triple, CPUName, ABIName, FloatABI);
6243
6244 // FPXX shouldn't be used if -msingle-float is present.
6245 if (Arg *A = Args.getLastArg(options::OPT_msingle_float,
6246 options::OPT_mdouble_float))
6247 if (A->getOption().matches(options::OPT_msingle_float))
6248 UseFPXX = false;
6249
6250 return UseFPXX;
6251}
6252
Tim Northover157d9112014-01-16 08:48:16 +00006253llvm::Triple::ArchType darwin::getArchTypeForMachOArchName(StringRef Str) {
Rafael Espindoladcbf6982012-10-31 18:51:07 +00006254 // See arch(3) and llvm-gcc's driver-driver.c. We don't implement support for
6255 // archs which Darwin doesn't use.
6256
6257 // The matching this routine does is fairly pointless, since it is neither the
6258 // complete architecture list, nor a reasonable subset. The problem is that
6259 // historically the driver driver accepts this and also ties its -march=
6260 // handling to the architecture name, so we need to be careful before removing
6261 // support for it.
6262
6263 // This code must be kept in sync with Clang's Darwin specific argument
6264 // translation.
6265
6266 return llvm::StringSwitch<llvm::Triple::ArchType>(Str)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006267 .Cases("ppc", "ppc601", "ppc603", "ppc604", "ppc604e", llvm::Triple::ppc)
6268 .Cases("ppc750", "ppc7400", "ppc7450", "ppc970", llvm::Triple::ppc)
6269 .Case("ppc64", llvm::Triple::ppc64)
6270 .Cases("i386", "i486", "i486SX", "i586", "i686", llvm::Triple::x86)
6271 .Cases("pentium", "pentpro", "pentIIm3", "pentIIm5", "pentium4",
6272 llvm::Triple::x86)
6273 .Cases("x86_64", "x86_64h", llvm::Triple::x86_64)
6274 // This is derived from the driver driver.
6275 .Cases("arm", "armv4t", "armv5", "armv6", "armv6m", llvm::Triple::arm)
6276 .Cases("armv7", "armv7em", "armv7k", "armv7m", llvm::Triple::arm)
6277 .Cases("armv7s", "xscale", llvm::Triple::arm)
6278 .Case("arm64", llvm::Triple::aarch64)
6279 .Case("r600", llvm::Triple::r600)
6280 .Case("amdgcn", llvm::Triple::amdgcn)
6281 .Case("nvptx", llvm::Triple::nvptx)
6282 .Case("nvptx64", llvm::Triple::nvptx64)
6283 .Case("amdil", llvm::Triple::amdil)
6284 .Case("spir", llvm::Triple::spir)
6285 .Default(llvm::Triple::UnknownArch);
Rafael Espindoladcbf6982012-10-31 18:51:07 +00006286}
Tony Linthicum76329bf2011-12-12 21:14:55 +00006287
Tim Northover157d9112014-01-16 08:48:16 +00006288void darwin::setTripleTypeForMachOArchName(llvm::Triple &T, StringRef Str) {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00006289 const llvm::Triple::ArchType Arch = getArchTypeForMachOArchName(Str);
Tim Northover157d9112014-01-16 08:48:16 +00006290 T.setArch(Arch);
6291
6292 if (Str == "x86_64h")
6293 T.setArchName(Str);
6294 else if (Str == "armv6m" || Str == "armv7m" || Str == "armv7em") {
6295 T.setOS(llvm::Triple::UnknownOS);
Saleem Abdulrasool29b82b62014-03-06 20:47:19 +00006296 T.setObjectFormat(llvm::Triple::MachO);
Tim Northover157d9112014-01-16 08:48:16 +00006297 }
6298}
6299
Bob Wilsondecc03e2012-11-23 06:14:39 +00006300const char *Clang::getBaseInputName(const ArgList &Args,
Artem Belevichba558952015-05-06 18:20:23 +00006301 const InputInfo &Input) {
6302 return Args.MakeArgString(llvm::sys::path::filename(Input.getBaseInput()));
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006303}
6304
Bob Wilsondecc03e2012-11-23 06:14:39 +00006305const char *Clang::getBaseInputStem(const ArgList &Args,
6306 const InputInfoList &Inputs) {
Artem Belevichba558952015-05-06 18:20:23 +00006307 const char *Str = getBaseInputName(Args, Inputs[0]);
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006308
Chris Lattner906bb902011-01-16 08:14:11 +00006309 if (const char *End = strrchr(Str, '.'))
Daniel Dunbar1c28f1e2009-09-09 22:32:48 +00006310 return Args.MakeArgString(std::string(Str, End));
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006311
6312 return Str;
6313}
6314
Bob Wilsondecc03e2012-11-23 06:14:39 +00006315const char *Clang::getDependencyFileName(const ArgList &Args,
6316 const InputInfoList &Inputs) {
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006317 // FIXME: Think about this more.
6318 std::string Res;
6319
6320 if (Arg *OutputOpt = Args.getLastArg(options::OPT_o)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00006321 std::string Str(OutputOpt->getValue());
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006322 Res = Str.substr(0, Str.rfind('.'));
Chad Rosier6fdf38b2011-08-17 23:08:45 +00006323 } else {
Bob Wilsondecc03e2012-11-23 06:14:39 +00006324 Res = getBaseInputStem(Args, Inputs);
Chad Rosier6fdf38b2011-08-17 23:08:45 +00006325 }
Daniel Dunbar1c28f1e2009-09-09 22:32:48 +00006326 return Args.MakeArgString(Res + ".d");
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006327}
6328
Douglas Katzman95354292015-06-23 20:42:09 +00006329void cloudabi::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6330 const InputInfo &Output,
6331 const InputInfoList &Inputs,
6332 const ArgList &Args,
6333 const char *LinkingOutput) const {
Ed Schouten3c3e58c2015-03-26 11:13:44 +00006334 const ToolChain &ToolChain = getToolChain();
6335 const Driver &D = ToolChain.getDriver();
6336 ArgStringList CmdArgs;
6337
6338 // Silence warning for "clang -g foo.o -o foo"
6339 Args.ClaimAllArgs(options::OPT_g_Group);
6340 // and "clang -emit-llvm foo.o -o foo"
6341 Args.ClaimAllArgs(options::OPT_emit_llvm);
6342 // and for "clang -w foo.o -o foo". Other warning options are already
6343 // handled somewhere else.
6344 Args.ClaimAllArgs(options::OPT_w);
6345
6346 if (!D.SysRoot.empty())
6347 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
6348
6349 // CloudABI only supports static linkage.
6350 CmdArgs.push_back("-Bstatic");
6351 CmdArgs.push_back("--eh-frame-hdr");
6352 CmdArgs.push_back("--gc-sections");
6353
6354 if (Output.isFilename()) {
6355 CmdArgs.push_back("-o");
6356 CmdArgs.push_back(Output.getFilename());
6357 } else {
6358 assert(Output.isNothing() && "Invalid output.");
6359 }
6360
6361 if (!Args.hasArg(options::OPT_nostdlib) &&
6362 !Args.hasArg(options::OPT_nostartfiles)) {
6363 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crt0.o")));
6364 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtbegin.o")));
6365 }
6366
6367 Args.AddAllArgs(CmdArgs, options::OPT_L);
6368 const ToolChain::path_list &Paths = ToolChain.getFilePaths();
6369 for (const auto &Path : Paths)
6370 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00006371 Args.AddAllArgs(CmdArgs,
6372 {options::OPT_T_Group, options::OPT_e, options::OPT_s,
6373 options::OPT_t, options::OPT_Z_Flag, options::OPT_r});
Ed Schouten3c3e58c2015-03-26 11:13:44 +00006374
Alexey Samsonov907880e2015-06-19 19:57:46 +00006375 if (D.IsUsingLTO(Args))
Ed Schouten3c3e58c2015-03-26 11:13:44 +00006376 AddGoldPlugin(ToolChain, Args, CmdArgs);
6377
6378 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
6379
6380 if (!Args.hasArg(options::OPT_nostdlib) &&
6381 !Args.hasArg(options::OPT_nodefaultlibs)) {
6382 if (D.CCCIsCXX())
6383 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
6384 CmdArgs.push_back("-lc");
6385 CmdArgs.push_back("-lcompiler_rt");
6386 }
6387
6388 if (!Args.hasArg(options::OPT_nostdlib) &&
6389 !Args.hasArg(options::OPT_nostartfiles))
6390 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtend.o")));
6391
6392 const char *Exec = Args.MakeArgString(ToolChain.GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00006393 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Ed Schouten3c3e58c2015-03-26 11:13:44 +00006394}
6395
Douglas Katzman95354292015-06-23 20:42:09 +00006396void darwin::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
6397 const InputInfo &Output,
6398 const InputInfoList &Inputs,
6399 const ArgList &Args,
6400 const char *LinkingOutput) const {
Daniel Dunbarbe220842009-03-20 16:06:39 +00006401 ArgStringList CmdArgs;
6402
6403 assert(Inputs.size() == 1 && "Unexpected number of inputs.");
6404 const InputInfo &Input = Inputs[0];
6405
Daniel Dunbardc8355e2011-04-12 23:59:20 +00006406 // Determine the original source input.
6407 const Action *SourceAction = &JA;
6408 while (SourceAction->getKind() != Action::InputClass) {
6409 assert(!SourceAction->getInputs().empty() && "unexpected root action!");
6410 SourceAction = SourceAction->getInputs()[0];
6411 }
6412
Saleem Abdulrasoolcfeb90d2014-02-23 00:40:30 +00006413 // If -fno_integrated_as is used add -Q to the darwin assember driver to make
Kevin Enderby319baa42013-11-18 23:30:29 +00006414 // sure it runs its system assembler not clang's integrated assembler.
David Fang073a7c92013-12-10 22:51:25 +00006415 // Applicable to darwin11+ and Xcode 4+. darwin<10 lacked integrated-as.
6416 // FIXME: at run-time detect assembler capabilities or rely on version
6417 // information forwarded by -target-assembler-version (future)
Saleem Abdulrasoolcfeb90d2014-02-23 00:40:30 +00006418 if (Args.hasArg(options::OPT_fno_integrated_as)) {
David Fangadcdde02013-12-10 23:13:11 +00006419 const llvm::Triple &T(getToolChain().getTriple());
6420 if (!(T.isMacOSX() && T.isMacOSXVersionLT(10, 7)))
David Fang073a7c92013-12-10 22:51:25 +00006421 CmdArgs.push_back("-Q");
6422 }
Kevin Enderby319baa42013-11-18 23:30:29 +00006423
Daniel Dunbardc8355e2011-04-12 23:59:20 +00006424 // Forward -g, assuming we are dealing with an actual assembly file.
Eric Christopher84fbdb42011-08-19 00:30:14 +00006425 if (SourceAction->getType() == types::TY_Asm ||
Daniel Dunbardc8355e2011-04-12 23:59:20 +00006426 SourceAction->getType() == types::TY_PP_Asm) {
Daniel Dunbar5c9c1182009-04-01 00:27:44 +00006427 if (Args.hasArg(options::OPT_gstabs))
6428 CmdArgs.push_back("--gstabs");
6429 else if (Args.hasArg(options::OPT_g_Group))
Bob Wilson126c4912011-11-02 05:10:45 +00006430 CmdArgs.push_back("-g");
Daniel Dunbar5c9c1182009-04-01 00:27:44 +00006431 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006432
Daniel Dunbarbe220842009-03-20 16:06:39 +00006433 // Derived from asm spec.
Tim Northover157d9112014-01-16 08:48:16 +00006434 AddMachOArch(Args, CmdArgs);
Daniel Dunbarbe220842009-03-20 16:06:39 +00006435
Daniel Dunbar6d484762010-07-22 01:47:22 +00006436 // Use -force_cpusubtype_ALL on x86 by default.
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00006437 if (getToolChain().getArch() == llvm::Triple::x86 ||
6438 getToolChain().getArch() == llvm::Triple::x86_64 ||
Daniel Dunbar3571dd92009-09-09 18:36:27 +00006439 Args.hasArg(options::OPT_force__cpusubtype__ALL))
6440 CmdArgs.push_back("-force_cpusubtype_ALL");
6441
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00006442 if (getToolChain().getArch() != llvm::Triple::x86_64 &&
Daniel Dunbarbd847cc2012-10-15 22:23:53 +00006443 (((Args.hasArg(options::OPT_mkernel) ||
Eric Christopher248357f2013-02-21 22:35:01 +00006444 Args.hasArg(options::OPT_fapple_kext)) &&
Tim Northover157d9112014-01-16 08:48:16 +00006445 getMachOToolChain().isKernelStatic()) ||
Daniel Dunbarbd847cc2012-10-15 22:23:53 +00006446 Args.hasArg(options::OPT_static)))
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006447 CmdArgs.push_back("-static");
6448
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006449 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbarbe220842009-03-20 16:06:39 +00006450
6451 assert(Output.isFilename() && "Unexpected lipo output.");
6452 CmdArgs.push_back("-o");
6453 CmdArgs.push_back(Output.getFilename());
6454
Daniel Dunbarb440f562010-08-02 02:38:21 +00006455 assert(Input.isFilename() && "Invalid input.");
6456 CmdArgs.push_back(Input.getFilename());
Daniel Dunbarbe220842009-03-20 16:06:39 +00006457
6458 // asm_final spec is empty.
6459
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006460 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00006461 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbarbe220842009-03-20 16:06:39 +00006462}
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006463
Tim Northover157d9112014-01-16 08:48:16 +00006464void darwin::MachOTool::anchor() {}
David Blaikie68e081d2011-12-20 02:48:34 +00006465
Tim Northover157d9112014-01-16 08:48:16 +00006466void darwin::MachOTool::AddMachOArch(const ArgList &Args,
6467 ArgStringList &CmdArgs) const {
6468 StringRef ArchName = getMachOToolChain().getMachOArchName(Args);
Daniel Dunbardcc3b652010-01-22 02:04:58 +00006469
Daniel Dunbarc1964212009-03-26 16:23:12 +00006470 // Derived from darwin_arch spec.
6471 CmdArgs.push_back("-arch");
Daniel Dunbardcc3b652010-01-22 02:04:58 +00006472 CmdArgs.push_back(Args.MakeArgString(ArchName));
Daniel Dunbar91dbfd62009-09-04 18:35:31 +00006473
Daniel Dunbardcc3b652010-01-22 02:04:58 +00006474 // FIXME: Is this needed anymore?
6475 if (ArchName == "arm")
Daniel Dunbar91dbfd62009-09-04 18:35:31 +00006476 CmdArgs.push_back("-force_cpusubtype_ALL");
Daniel Dunbarc1964212009-03-26 16:23:12 +00006477}
6478
Douglas Katzman95354292015-06-23 20:42:09 +00006479bool darwin::Linker::NeedsTempPath(const InputInfoList &Inputs) const {
Bill Wendling3b2000f2012-10-02 18:02:50 +00006480 // We only need to generate a temp path for LTO if we aren't compiling object
6481 // files. When compiling source files, we run 'dsymutil' after linking. We
6482 // don't run 'dsymutil' when compiling object files.
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006483 for (const auto &Input : Inputs)
6484 if (Input.getType() != types::TY_Object)
Bill Wendling3b2000f2012-10-02 18:02:50 +00006485 return true;
6486
6487 return false;
6488}
6489
Douglas Katzman95354292015-06-23 20:42:09 +00006490void darwin::Linker::AddLinkArgs(Compilation &C, const ArgList &Args,
6491 ArgStringList &CmdArgs,
6492 const InputInfoList &Inputs) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00006493 const Driver &D = getToolChain().getDriver();
Tim Northover157d9112014-01-16 08:48:16 +00006494 const toolchains::MachO &MachOTC = getMachOToolChain();
Daniel Dunbarc1964212009-03-26 16:23:12 +00006495
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006496 unsigned Version[3] = {0, 0, 0};
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00006497 if (Arg *A = Args.getLastArg(options::OPT_mlinker_version_EQ)) {
6498 bool HadExtra;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006499 if (!Driver::GetReleaseVersion(A->getValue(), Version[0], Version[1],
6500 Version[2], HadExtra) ||
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00006501 HadExtra)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006502 D.Diag(diag::err_drv_invalid_version_number) << A->getAsString(Args);
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00006503 }
6504
Bob Wilson5a4f3ea2014-01-14 01:56:31 +00006505 // Newer linkers support -demangle. Pass it if supported and not disabled by
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00006506 // the user.
Bob Wilson5a4f3ea2014-01-14 01:56:31 +00006507 if (Version[0] >= 100 && !Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
6508 CmdArgs.push_back("-demangle");
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00006509
Bob Wilson3d27dad2013-08-02 22:25:34 +00006510 if (Args.hasArg(options::OPT_rdynamic) && Version[0] >= 137)
6511 CmdArgs.push_back("-export_dynamic");
6512
Bob Wilsonb111ec92015-03-02 19:01:14 +00006513 // If we are using App Extension restrictions, pass a flag to the linker
6514 // telling it that the compiled code has been audited.
6515 if (Args.hasFlag(options::OPT_fapplication_extension,
6516 options::OPT_fno_application_extension, false))
6517 CmdArgs.push_back("-application_extension");
6518
Bruno Cardoso Lopesf3742a72015-09-30 20:11:02 +00006519 // If we are using LTO, then automatically create a temporary file path for
6520 // the linker to use, so that it's lifetime will extend past a possible
6521 // dsymutil step.
6522 if (Version[0] >= 116 && D.IsUsingLTO(Args) && NeedsTempPath(Inputs)) {
6523 const char *TmpPath = C.getArgs().MakeArgString(
6524 D.GetTemporaryPath("cc", types::getTypeTempSuffix(types::TY_Object)));
6525 C.addTempFile(TmpPath);
6526 CmdArgs.push_back("-object_path_lto");
6527 CmdArgs.push_back(TmpPath);
Daniel Dunbaref889c72011-06-21 20:55:11 +00006528 }
6529
Daniel Dunbarc1964212009-03-26 16:23:12 +00006530 // Derived from the "link" spec.
6531 Args.AddAllArgs(CmdArgs, options::OPT_static);
6532 if (!Args.hasArg(options::OPT_static))
6533 CmdArgs.push_back("-dynamic");
6534 if (Args.hasArg(options::OPT_fgnu_runtime)) {
6535 // FIXME: gcc replaces -lobjc in forward args with -lobjc-gnu
6536 // here. How do we wish to handle such things?
6537 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006538
Daniel Dunbarc1964212009-03-26 16:23:12 +00006539 if (!Args.hasArg(options::OPT_dynamiclib)) {
Tim Northover157d9112014-01-16 08:48:16 +00006540 AddMachOArch(Args, CmdArgs);
Daniel Dunbara48823f2010-01-22 02:04:52 +00006541 // FIXME: Why do this only on this path?
Daniel Dunbar93d7acf2010-01-22 03:37:33 +00006542 Args.AddLastArg(CmdArgs, options::OPT_force__cpusubtype__ALL);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006543
6544 Args.AddLastArg(CmdArgs, options::OPT_bundle);
6545 Args.AddAllArgs(CmdArgs, options::OPT_bundle__loader);
6546 Args.AddAllArgs(CmdArgs, options::OPT_client__name);
6547
6548 Arg *A;
6549 if ((A = Args.getLastArg(options::OPT_compatibility__version)) ||
6550 (A = Args.getLastArg(options::OPT_current__version)) ||
6551 (A = Args.getLastArg(options::OPT_install__name)))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006552 D.Diag(diag::err_drv_argument_only_allowed_with) << A->getAsString(Args)
6553 << "-dynamiclib";
Daniel Dunbarc1964212009-03-26 16:23:12 +00006554
6555 Args.AddLastArg(CmdArgs, options::OPT_force__flat__namespace);
6556 Args.AddLastArg(CmdArgs, options::OPT_keep__private__externs);
6557 Args.AddLastArg(CmdArgs, options::OPT_private__bundle);
6558 } else {
6559 CmdArgs.push_back("-dylib");
6560
6561 Arg *A;
6562 if ((A = Args.getLastArg(options::OPT_bundle)) ||
6563 (A = Args.getLastArg(options::OPT_bundle__loader)) ||
6564 (A = Args.getLastArg(options::OPT_client__name)) ||
6565 (A = Args.getLastArg(options::OPT_force__flat__namespace)) ||
6566 (A = Args.getLastArg(options::OPT_keep__private__externs)) ||
6567 (A = Args.getLastArg(options::OPT_private__bundle)))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006568 D.Diag(diag::err_drv_argument_not_allowed_with) << A->getAsString(Args)
6569 << "-dynamiclib";
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006570
Daniel Dunbarc1964212009-03-26 16:23:12 +00006571 Args.AddAllArgsTranslated(CmdArgs, options::OPT_compatibility__version,
6572 "-dylib_compatibility_version");
6573 Args.AddAllArgsTranslated(CmdArgs, options::OPT_current__version,
6574 "-dylib_current_version");
6575
Tim Northover157d9112014-01-16 08:48:16 +00006576 AddMachOArch(Args, CmdArgs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006577
6578 Args.AddAllArgsTranslated(CmdArgs, options::OPT_install__name,
6579 "-dylib_install_name");
6580 }
6581
6582 Args.AddLastArg(CmdArgs, options::OPT_all__load);
6583 Args.AddAllArgs(CmdArgs, options::OPT_allowable__client);
6584 Args.AddLastArg(CmdArgs, options::OPT_bind__at__load);
Tim Northover157d9112014-01-16 08:48:16 +00006585 if (MachOTC.isTargetIOSBased())
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00006586 Args.AddLastArg(CmdArgs, options::OPT_arch__errors__fatal);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006587 Args.AddLastArg(CmdArgs, options::OPT_dead__strip);
6588 Args.AddLastArg(CmdArgs, options::OPT_no__dead__strip__inits__and__terms);
6589 Args.AddAllArgs(CmdArgs, options::OPT_dylib__file);
6590 Args.AddLastArg(CmdArgs, options::OPT_dynamic);
6591 Args.AddAllArgs(CmdArgs, options::OPT_exported__symbols__list);
6592 Args.AddLastArg(CmdArgs, options::OPT_flat__namespace);
Daniel Dunbar044a3902011-06-28 20:16:02 +00006593 Args.AddAllArgs(CmdArgs, options::OPT_force__load);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006594 Args.AddAllArgs(CmdArgs, options::OPT_headerpad__max__install__names);
6595 Args.AddAllArgs(CmdArgs, options::OPT_image__base);
6596 Args.AddAllArgs(CmdArgs, options::OPT_init);
6597
Daniel Dunbarc44d3132011-04-28 21:23:41 +00006598 // Add the deployment target.
Tim Northover157d9112014-01-16 08:48:16 +00006599 MachOTC.addMinVersionArgs(Args, CmdArgs);
Daniel Dunbarc44d3132011-04-28 21:23:41 +00006600
Daniel Dunbarc1964212009-03-26 16:23:12 +00006601 Args.AddLastArg(CmdArgs, options::OPT_nomultidefs);
6602 Args.AddLastArg(CmdArgs, options::OPT_multi__module);
6603 Args.AddLastArg(CmdArgs, options::OPT_single__module);
6604 Args.AddAllArgs(CmdArgs, options::OPT_multiply__defined);
6605 Args.AddAllArgs(CmdArgs, options::OPT_multiply__defined__unused);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006606
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006607 if (const Arg *A =
6608 Args.getLastArg(options::OPT_fpie, options::OPT_fPIE,
6609 options::OPT_fno_pie, options::OPT_fno_PIE)) {
Daniel Dunbaraf68a882010-07-13 23:31:40 +00006610 if (A->getOption().matches(options::OPT_fpie) ||
6611 A->getOption().matches(options::OPT_fPIE))
6612 CmdArgs.push_back("-pie");
6613 else
6614 CmdArgs.push_back("-no_pie");
6615 }
Daniel Dunbarc1964212009-03-26 16:23:12 +00006616
6617 Args.AddLastArg(CmdArgs, options::OPT_prebind);
6618 Args.AddLastArg(CmdArgs, options::OPT_noprebind);
6619 Args.AddLastArg(CmdArgs, options::OPT_nofixprebinding);
6620 Args.AddLastArg(CmdArgs, options::OPT_prebind__all__twolevel__modules);
6621 Args.AddLastArg(CmdArgs, options::OPT_read__only__relocs);
6622 Args.AddAllArgs(CmdArgs, options::OPT_sectcreate);
6623 Args.AddAllArgs(CmdArgs, options::OPT_sectorder);
6624 Args.AddAllArgs(CmdArgs, options::OPT_seg1addr);
6625 Args.AddAllArgs(CmdArgs, options::OPT_segprot);
6626 Args.AddAllArgs(CmdArgs, options::OPT_segaddr);
6627 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__only__addr);
6628 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__write__addr);
6629 Args.AddAllArgs(CmdArgs, options::OPT_seg__addr__table);
6630 Args.AddAllArgs(CmdArgs, options::OPT_seg__addr__table__filename);
6631 Args.AddAllArgs(CmdArgs, options::OPT_sub__library);
6632 Args.AddAllArgs(CmdArgs, options::OPT_sub__umbrella);
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00006633
Daniel Dunbar84384642011-05-02 21:03:47 +00006634 // Give --sysroot= preference, over the Apple specific behavior to also use
6635 // --isysroot as the syslibroot.
Sebastian Pop980920a2012-04-16 04:16:43 +00006636 StringRef sysroot = C.getSysRoot();
6637 if (sysroot != "") {
Daniel Dunbar84384642011-05-02 21:03:47 +00006638 CmdArgs.push_back("-syslibroot");
Sebastian Pop980920a2012-04-16 04:16:43 +00006639 CmdArgs.push_back(C.getArgs().MakeArgString(sysroot));
Daniel Dunbar84384642011-05-02 21:03:47 +00006640 } else if (const Arg *A = Args.getLastArg(options::OPT_isysroot)) {
6641 CmdArgs.push_back("-syslibroot");
Richard Smithbd55daf2012-11-01 04:30:05 +00006642 CmdArgs.push_back(A->getValue());
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00006643 }
6644
Daniel Dunbarc1964212009-03-26 16:23:12 +00006645 Args.AddLastArg(CmdArgs, options::OPT_twolevel__namespace);
6646 Args.AddLastArg(CmdArgs, options::OPT_twolevel__namespace__hints);
6647 Args.AddAllArgs(CmdArgs, options::OPT_umbrella);
6648 Args.AddAllArgs(CmdArgs, options::OPT_undefined);
6649 Args.AddAllArgs(CmdArgs, options::OPT_unexported__symbols__list);
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00006650 Args.AddAllArgs(CmdArgs, options::OPT_weak__reference__mismatches);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006651 Args.AddLastArg(CmdArgs, options::OPT_X_Flag);
6652 Args.AddAllArgs(CmdArgs, options::OPT_y);
6653 Args.AddLastArg(CmdArgs, options::OPT_w);
6654 Args.AddAllArgs(CmdArgs, options::OPT_pagezero__size);
6655 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__);
6656 Args.AddLastArg(CmdArgs, options::OPT_seglinkedit);
6657 Args.AddLastArg(CmdArgs, options::OPT_noseglinkedit);
6658 Args.AddAllArgs(CmdArgs, options::OPT_sectalign);
6659 Args.AddAllArgs(CmdArgs, options::OPT_sectobjectsymbols);
6660 Args.AddAllArgs(CmdArgs, options::OPT_segcreate);
6661 Args.AddLastArg(CmdArgs, options::OPT_whyload);
6662 Args.AddLastArg(CmdArgs, options::OPT_whatsloaded);
6663 Args.AddAllArgs(CmdArgs, options::OPT_dylinker__install__name);
6664 Args.AddLastArg(CmdArgs, options::OPT_dylinker);
6665 Args.AddLastArg(CmdArgs, options::OPT_Mach);
6666}
6667
Douglas Katzman95354292015-06-23 20:42:09 +00006668void darwin::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6669 const InputInfo &Output,
6670 const InputInfoList &Inputs,
6671 const ArgList &Args,
6672 const char *LinkingOutput) const {
Daniel Dunbarc1964212009-03-26 16:23:12 +00006673 assert(Output.getType() == types::TY_Image && "Invalid linker output type.");
Daniel Dunbarc09988d2009-09-08 16:39:16 +00006674
Reid Kleckner0290c9c2014-09-15 17:45:39 +00006675 // If the number of arguments surpasses the system limits, we will encode the
6676 // input files in a separate file, shortening the command line. To this end,
6677 // build a list of input file names that can be passed via a file with the
6678 // -filelist linker option.
6679 llvm::opt::ArgStringList InputFileList;
6680
Daniel Dunbarc1964212009-03-26 16:23:12 +00006681 // The logic here is derived from gcc's behavior; most of which
6682 // comes from specs (starting with link_command). Consult gcc for
6683 // more information.
Daniel Dunbarc1964212009-03-26 16:23:12 +00006684 ArgStringList CmdArgs;
6685
Argyrios Kyrtzidis741fab12011-10-07 22:58:08 +00006686 /// Hack(tm) to ignore linking errors when we are doing ARC migration.
6687 if (Args.hasArg(options::OPT_ccc_arcmt_check,
6688 options::OPT_ccc_arcmt_migrate)) {
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006689 for (const auto &Arg : Args)
6690 Arg->claim();
Argyrios Kyrtzidis741fab12011-10-07 22:58:08 +00006691 const char *Exec =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006692 Args.MakeArgString(getToolChain().GetProgramPath("touch"));
Argyrios Kyrtzidis741fab12011-10-07 22:58:08 +00006693 CmdArgs.push_back(Output.getFilename());
Justin Bognerd3371d82015-07-17 03:35:54 +00006694 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, None));
Argyrios Kyrtzidis741fab12011-10-07 22:58:08 +00006695 return;
6696 }
6697
Daniel Dunbarc1964212009-03-26 16:23:12 +00006698 // I'm not sure why this particular decomposition exists in gcc, but
6699 // we follow suite for ease of comparison.
Bill Wendling3b2000f2012-10-02 18:02:50 +00006700 AddLinkArgs(C, Args, CmdArgs, Inputs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006701
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00006702 // It seems that the 'e' option is completely ignored for dynamic executables
6703 // (the default), and with static executables, the last one wins, as expected.
6704 Args.AddAllArgs(CmdArgs, {options::OPT_d_Flag, options::OPT_s, options::OPT_t,
6705 options::OPT_Z_Flag, options::OPT_u_Group,
6706 options::OPT_e, options::OPT_r});
Daniel Dunbarc1964212009-03-26 16:23:12 +00006707
Daniel Dunbar767bbab2010-10-18 22:08:36 +00006708 // Forward -ObjC when either -ObjC or -ObjC++ is used, to force loading
6709 // members of static archive libraries which implement Objective-C classes or
6710 // categories.
6711 if (Args.hasArg(options::OPT_ObjC) || Args.hasArg(options::OPT_ObjCXX))
6712 CmdArgs.push_back("-ObjC");
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00006713
Daniel Dunbarc1964212009-03-26 16:23:12 +00006714 CmdArgs.push_back("-o");
6715 CmdArgs.push_back(Output.getFilename());
6716
Chad Rosier06fd3c62012-05-16 23:45:12 +00006717 if (!Args.hasArg(options::OPT_nostdlib) &&
Tim Northover157d9112014-01-16 08:48:16 +00006718 !Args.hasArg(options::OPT_nostartfiles))
6719 getMachOToolChain().addStartObjectFileArgs(Args, CmdArgs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006720
Peter Collingbournec4122c12015-06-15 21:08:13 +00006721 // SafeStack requires its own runtime libraries
6722 // These libraries should be linked first, to make sure the
6723 // __safestack_init constructor executes before everything else
6724 if (getToolChain().getSanitizerArgs().needsSafeStackRt()) {
6725 getMachOToolChain().AddLinkRuntimeLib(Args, CmdArgs,
6726 "libclang_rt.safestack_osx.a",
6727 /*AlwaysLink=*/true);
6728 }
6729
Daniel Dunbarc1964212009-03-26 16:23:12 +00006730 Args.AddAllArgs(CmdArgs, options::OPT_L);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006731
Douglas Gregor9295df02012-05-15 21:00:27 +00006732 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Reid Kleckner0290c9c2014-09-15 17:45:39 +00006733 // Build the input file for -filelist (list of linker input files) in case we
6734 // need it later
6735 for (const auto &II : Inputs) {
6736 if (!II.isFilename()) {
6737 // This is a linker input argument.
6738 // We cannot mix input arguments and file names in a -filelist input, thus
6739 // we prematurely stop our list (remaining files shall be passed as
6740 // arguments).
6741 if (InputFileList.size() > 0)
6742 break;
6743
6744 continue;
6745 }
6746
6747 InputFileList.push_back(II.getFilename());
6748 }
6749
Joerg Sonnenberger5c3f9d52015-09-23 20:07:56 +00006750 if (!Args.hasArg(options::OPT_nostdlib) &&
6751 !Args.hasArg(options::OPT_nodefaultlibs))
6752 addOpenMPRuntime(CmdArgs, getToolChain(), Args);
6753
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006754 if (isObjCRuntimeLinked(Args) && !Args.hasArg(options::OPT_nostdlib) &&
Bob Wilson16d93952012-05-15 18:57:39 +00006755 !Args.hasArg(options::OPT_nodefaultlibs)) {
Tim Northover157d9112014-01-16 08:48:16 +00006756 // We use arclite library for both ARC and subscripting support.
6757 getMachOToolChain().AddLinkARCArgs(Args, CmdArgs);
6758
Bob Wilson7dda0cd2012-04-21 00:21:42 +00006759 CmdArgs.push_back("-framework");
6760 CmdArgs.push_back("Foundation");
Ted Kremeneke65b0862012-03-06 20:05:56 +00006761 // Link libobj.
6762 CmdArgs.push_back("-lobjc");
John McCall24fc0de2011-07-06 00:26:06 +00006763 }
John McCall31168b02011-06-15 23:02:42 +00006764
Daniel Dunbarc1964212009-03-26 16:23:12 +00006765 if (LinkingOutput) {
6766 CmdArgs.push_back("-arch_multiple");
6767 CmdArgs.push_back("-final_output");
6768 CmdArgs.push_back(LinkingOutput);
6769 }
6770
Daniel Dunbarc1964212009-03-26 16:23:12 +00006771 if (Args.hasArg(options::OPT_fnested_functions))
6772 CmdArgs.push_back("-allow_stack_execute");
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006773
Justin Bognerc7701242015-05-12 05:44:36 +00006774 // TODO: It would be nice to use addProfileRT() here, but darwin's compiler-rt
6775 // paths are different enough from other toolchains that this needs a fair
6776 // amount of refactoring done first.
6777 getMachOToolChain().addProfileRTLibs(Args, CmdArgs);
6778
Daniel Dunbarc1964212009-03-26 16:23:12 +00006779 if (!Args.hasArg(options::OPT_nostdlib) &&
6780 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00006781 if (getToolChain().getDriver().CCCIsCXX())
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00006782 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Daniel Dunbarad0f62b2009-04-08 06:06:21 +00006783
Daniel Dunbarc1964212009-03-26 16:23:12 +00006784 // link_ssp spec is empty.
6785
Daniel Dunbar26d482a2009-09-18 08:15:03 +00006786 // Let the tool chain choose which runtime library to link.
Tim Northover157d9112014-01-16 08:48:16 +00006787 getMachOToolChain().AddLinkRuntimeLibArgs(Args, CmdArgs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006788 }
6789
Chad Rosier06fd3c62012-05-16 23:45:12 +00006790 if (!Args.hasArg(options::OPT_nostdlib) &&
Daniel Dunbarc1964212009-03-26 16:23:12 +00006791 !Args.hasArg(options::OPT_nostartfiles)) {
6792 // endfile_spec is empty.
6793 }
6794
6795 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
6796 Args.AddAllArgs(CmdArgs, options::OPT_F);
6797
Steven Wu3ffb61b2015-02-06 18:08:29 +00006798 // -iframework should be forwarded as -F.
Sean Silva14facf32015-06-09 01:57:17 +00006799 for (const Arg *A : Args.filtered(options::OPT_iframework))
6800 CmdArgs.push_back(Args.MakeArgString(std::string("-F") + A->getValue()));
Steven Wu3ffb61b2015-02-06 18:08:29 +00006801
Michael Zolotukhind0cf6c82015-03-17 22:13:05 +00006802 if (!Args.hasArg(options::OPT_nostdlib) &&
6803 !Args.hasArg(options::OPT_nodefaultlibs)) {
6804 if (Arg *A = Args.getLastArg(options::OPT_fveclib)) {
6805 if (A->getValue() == StringRef("Accelerate")) {
6806 CmdArgs.push_back("-framework");
6807 CmdArgs.push_back("Accelerate");
6808 }
6809 }
6810 }
6811
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006812 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Reid Kleckner0290c9c2014-09-15 17:45:39 +00006813 std::unique_ptr<Command> Cmd =
Justin Bognerd3371d82015-07-17 03:35:54 +00006814 llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs);
Reid Kleckner0290c9c2014-09-15 17:45:39 +00006815 Cmd->setInputFileList(std::move(InputFileList));
6816 C.addCommand(std::move(Cmd));
Daniel Dunbarc1964212009-03-26 16:23:12 +00006817}
6818
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006819void darwin::Lipo::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00006820 const InputInfo &Output,
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006821 const InputInfoList &Inputs,
6822 const ArgList &Args,
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006823 const char *LinkingOutput) const {
6824 ArgStringList CmdArgs;
6825
6826 CmdArgs.push_back("-create");
6827 assert(Output.isFilename() && "Unexpected lipo output.");
Daniel Dunbar06686ab2009-03-24 00:24:37 +00006828
6829 CmdArgs.push_back("-output");
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006830 CmdArgs.push_back(Output.getFilename());
Daniel Dunbar06686ab2009-03-24 00:24:37 +00006831
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006832 for (const auto &II : Inputs) {
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006833 assert(II.isFilename() && "Unexpected lipo input.");
6834 CmdArgs.push_back(II.getFilename());
6835 }
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006836
6837 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("lipo"));
Justin Bognerd3371d82015-07-17 03:35:54 +00006838 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006839}
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00006840
Daniel Dunbar88299622010-06-04 18:28:36 +00006841void darwin::Dsymutil::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00006842 const InputInfo &Output,
Daniel Dunbar88299622010-06-04 18:28:36 +00006843 const InputInfoList &Inputs,
6844 const ArgList &Args,
6845 const char *LinkingOutput) const {
6846 ArgStringList CmdArgs;
6847
Daniel Dunbareb86b042011-05-09 17:23:16 +00006848 CmdArgs.push_back("-o");
6849 CmdArgs.push_back(Output.getFilename());
6850
Daniel Dunbar88299622010-06-04 18:28:36 +00006851 assert(Inputs.size() == 1 && "Unable to handle multiple inputs.");
6852 const InputInfo &Input = Inputs[0];
6853 assert(Input.isFilename() && "Unexpected dsymutil input.");
6854 CmdArgs.push_back(Input.getFilename());
6855
Daniel Dunbar88299622010-06-04 18:28:36 +00006856 const char *Exec =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006857 Args.MakeArgString(getToolChain().GetProgramPath("dsymutil"));
Justin Bognerd3371d82015-07-17 03:35:54 +00006858 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar88299622010-06-04 18:28:36 +00006859}
6860
Eric Christopher551ef452011-08-23 17:56:55 +00006861void darwin::VerifyDebug::ConstructJob(Compilation &C, const JobAction &JA,
Eric Christopher45f2e712012-12-18 00:31:10 +00006862 const InputInfo &Output,
6863 const InputInfoList &Inputs,
6864 const ArgList &Args,
6865 const char *LinkingOutput) const {
Eric Christopher551ef452011-08-23 17:56:55 +00006866 ArgStringList CmdArgs;
6867 CmdArgs.push_back("--verify");
Eric Christopher36222212012-02-06 19:13:09 +00006868 CmdArgs.push_back("--debug-info");
6869 CmdArgs.push_back("--eh-frame");
Eric Christopher65c05fa2012-02-06 19:43:51 +00006870 CmdArgs.push_back("--quiet");
Eric Christopher551ef452011-08-23 17:56:55 +00006871
6872 assert(Inputs.size() == 1 && "Unable to handle multiple inputs.");
6873 const InputInfo &Input = Inputs[0];
6874 assert(Input.isFilename() && "Unexpected verify input");
6875
6876 // Grabbing the output of the earlier dsymutil run.
6877 CmdArgs.push_back(Input.getFilename());
6878
6879 const char *Exec =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006880 Args.MakeArgString(getToolChain().GetProgramPath("dwarfdump"));
Justin Bognerd3371d82015-07-17 03:35:54 +00006881 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eric Christopher551ef452011-08-23 17:56:55 +00006882}
6883
Douglas Katzman95354292015-06-23 20:42:09 +00006884void solaris::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
David Chisnallf571cde2012-02-15 13:39:01 +00006885 const InputInfo &Output,
6886 const InputInfoList &Inputs,
6887 const ArgList &Args,
6888 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00006889 claimNoWarnArgs(Args);
David Chisnallf571cde2012-02-15 13:39:01 +00006890 ArgStringList CmdArgs;
6891
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006892 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
David Chisnallf571cde2012-02-15 13:39:01 +00006893
6894 CmdArgs.push_back("-o");
6895 CmdArgs.push_back(Output.getFilename());
6896
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006897 for (const auto &II : Inputs)
David Chisnallf571cde2012-02-15 13:39:01 +00006898 CmdArgs.push_back(II.getFilename());
David Chisnallf571cde2012-02-15 13:39:01 +00006899
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006900 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00006901 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
David Chisnallf571cde2012-02-15 13:39:01 +00006902}
6903
Douglas Katzman95354292015-06-23 20:42:09 +00006904void solaris::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6905 const InputInfo &Output,
6906 const InputInfoList &Inputs,
6907 const ArgList &Args,
6908 const char *LinkingOutput) const {
David Chisnallf571cde2012-02-15 13:39:01 +00006909 ArgStringList CmdArgs;
6910
David Chisnall272a0712012-02-29 15:06:12 +00006911 // Demangle C++ names in errors
6912 CmdArgs.push_back("-C");
6913
David Chisnallf571cde2012-02-15 13:39:01 +00006914 if ((!Args.hasArg(options::OPT_nostdlib)) &&
6915 (!Args.hasArg(options::OPT_shared))) {
6916 CmdArgs.push_back("-e");
6917 CmdArgs.push_back("_start");
6918 }
6919
6920 if (Args.hasArg(options::OPT_static)) {
6921 CmdArgs.push_back("-Bstatic");
6922 CmdArgs.push_back("-dn");
6923 } else {
6924 CmdArgs.push_back("-Bdynamic");
6925 if (Args.hasArg(options::OPT_shared)) {
6926 CmdArgs.push_back("-shared");
6927 } else {
6928 CmdArgs.push_back("--dynamic-linker");
Rafael Espindolac53c5b12015-08-31 19:17:51 +00006929 CmdArgs.push_back(
6930 Args.MakeArgString(getToolChain().GetFilePath("ld.so.1")));
David Chisnallf571cde2012-02-15 13:39:01 +00006931 }
6932 }
6933
6934 if (Output.isFilename()) {
6935 CmdArgs.push_back("-o");
6936 CmdArgs.push_back(Output.getFilename());
6937 } else {
6938 assert(Output.isNothing() && "Invalid output.");
6939 }
6940
6941 if (!Args.hasArg(options::OPT_nostdlib) &&
6942 !Args.hasArg(options::OPT_nostartfiles)) {
Rafael Espindolac53c5b12015-08-31 19:17:51 +00006943 if (!Args.hasArg(options::OPT_shared))
6944 CmdArgs.push_back(
6945 Args.MakeArgString(getToolChain().GetFilePath("crt1.o")));
6946
6947 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
6948 CmdArgs.push_back(
6949 Args.MakeArgString(getToolChain().GetFilePath("values-Xa.o")));
6950 CmdArgs.push_back(
6951 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
David Chisnallf571cde2012-02-15 13:39:01 +00006952 }
6953
Rafael Espindolac53c5b12015-08-31 19:17:51 +00006954 const ToolChain::path_list &Paths = getToolChain().getFilePaths();
6955 for (const auto &Path : Paths)
6956 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
David Chisnallf571cde2012-02-15 13:39:01 +00006957
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00006958 Args.AddAllArgs(CmdArgs, {options::OPT_L, options::OPT_T_Group,
6959 options::OPT_e, options::OPT_r});
David Chisnallf571cde2012-02-15 13:39:01 +00006960
6961 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
6962
6963 if (!Args.hasArg(options::OPT_nostdlib) &&
6964 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00006965 if (getToolChain().getDriver().CCCIsCXX())
David Chisnall3d127c72012-04-10 11:49:50 +00006966 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
David Chisnall1026fb02012-02-15 18:24:31 +00006967 CmdArgs.push_back("-lgcc_s");
Rafael Espindola8d4d9d2f2015-09-14 19:30:53 +00006968 CmdArgs.push_back("-lc");
David Chisnall0c52c0f2012-02-28 17:10:04 +00006969 if (!Args.hasArg(options::OPT_shared)) {
6970 CmdArgs.push_back("-lgcc");
David Chisnallc73fb892012-02-28 20:06:45 +00006971 CmdArgs.push_back("-lm");
David Chisnall0c52c0f2012-02-28 17:10:04 +00006972 }
David Chisnallf571cde2012-02-15 13:39:01 +00006973 }
6974
6975 if (!Args.hasArg(options::OPT_nostdlib) &&
6976 !Args.hasArg(options::OPT_nostartfiles)) {
Rafael Espindolac53c5b12015-08-31 19:17:51 +00006977 CmdArgs.push_back(
6978 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
David Chisnallf571cde2012-02-15 13:39:01 +00006979 }
Rafael Espindolac53c5b12015-08-31 19:17:51 +00006980 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
David Chisnallf571cde2012-02-15 13:39:01 +00006981
Alexey Samsonov7811d192014-02-20 13:57:37 +00006982 addProfileRT(getToolChain(), Args, CmdArgs);
David Chisnallf571cde2012-02-15 13:39:01 +00006983
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006984 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00006985 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
David Chisnallf571cde2012-02-15 13:39:01 +00006986}
6987
Douglas Katzman95354292015-06-23 20:42:09 +00006988void openbsd::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
6989 const InputInfo &Output,
6990 const InputInfoList &Inputs,
6991 const ArgList &Args,
6992 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00006993 claimNoWarnArgs(Args);
Daniel Dunbar10de9e62009-06-29 20:52:51 +00006994 ArgStringList CmdArgs;
Rafael Espindolacc126272014-02-28 01:55:21 +00006995 bool NeedsKPIC = false;
Daniel Dunbar10de9e62009-06-29 20:52:51 +00006996
Rafael Espindolacc126272014-02-28 01:55:21 +00006997 switch (getToolChain().getArch()) {
6998 case llvm::Triple::x86:
6999 // When building 32-bit code on OpenBSD/amd64, we have to explicitly
7000 // instruct as in the base system to assemble 32-bit code.
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007001 CmdArgs.push_back("--32");
Rafael Espindolacc126272014-02-28 01:55:21 +00007002 break;
7003
7004 case llvm::Triple::ppc:
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007005 CmdArgs.push_back("-mppc");
7006 CmdArgs.push_back("-many");
Rafael Espindolacc126272014-02-28 01:55:21 +00007007 break;
7008
7009 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00007010 case llvm::Triple::sparcel:
Rafael Espindolacc126272014-02-28 01:55:21 +00007011 CmdArgs.push_back("-32");
7012 NeedsKPIC = true;
7013 break;
7014
7015 case llvm::Triple::sparcv9:
7016 CmdArgs.push_back("-64");
7017 CmdArgs.push_back("-Av9a");
7018 NeedsKPIC = true;
7019 break;
7020
7021 case llvm::Triple::mips64:
7022 case llvm::Triple::mips64el: {
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007023 StringRef CPUName;
7024 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00007025 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007026
7027 CmdArgs.push_back("-mabi");
7028 CmdArgs.push_back(getGnuCompatibleMipsABIName(ABIName).data());
7029
7030 if (getToolChain().getArch() == llvm::Triple::mips64)
7031 CmdArgs.push_back("-EB");
7032 else
7033 CmdArgs.push_back("-EL");
7034
Rafael Espindolacc126272014-02-28 01:55:21 +00007035 NeedsKPIC = true;
7036 break;
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007037 }
7038
Rafael Espindolacc126272014-02-28 01:55:21 +00007039 default:
7040 break;
7041 }
7042
7043 if (NeedsKPIC)
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007044 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Rafael Espindolacc126272014-02-28 01:55:21 +00007045
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007046 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007047
7048 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00007049 CmdArgs.push_back(Output.getFilename());
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007050
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007051 for (const auto &II : Inputs)
Daniel Dunbarb440f562010-08-02 02:38:21 +00007052 CmdArgs.push_back(II.getFilename());
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007053
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007054 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00007055 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007056}
7057
Douglas Katzman95354292015-06-23 20:42:09 +00007058void openbsd::Linker::ConstructJob(Compilation &C, const JobAction &JA,
7059 const InputInfo &Output,
7060 const InputInfoList &Inputs,
7061 const ArgList &Args,
7062 const char *LinkingOutput) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00007063 const Driver &D = getToolChain().getDriver();
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007064 ArgStringList CmdArgs;
7065
Rafael Espindolaaadd30e2012-12-31 22:41:36 +00007066 // Silence warning for "clang -g foo.o -o foo"
7067 Args.ClaimAllArgs(options::OPT_g_Group);
7068 // and "clang -emit-llvm foo.o -o foo"
7069 Args.ClaimAllArgs(options::OPT_emit_llvm);
7070 // and for "clang -w foo.o -o foo". Other warning options are already
7071 // handled somewhere else.
7072 Args.ClaimAllArgs(options::OPT_w);
7073
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007074 if (getToolChain().getArch() == llvm::Triple::mips64)
7075 CmdArgs.push_back("-EB");
7076 else if (getToolChain().getArch() == llvm::Triple::mips64el)
7077 CmdArgs.push_back("-EL");
7078
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007079 if ((!Args.hasArg(options::OPT_nostdlib)) &&
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00007080 (!Args.hasArg(options::OPT_shared))) {
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007081 CmdArgs.push_back("-e");
7082 CmdArgs.push_back("__start");
7083 }
7084
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007085 if (Args.hasArg(options::OPT_static)) {
7086 CmdArgs.push_back("-Bstatic");
7087 } else {
Rafael Espindola7ba97af2010-11-11 02:17:51 +00007088 if (Args.hasArg(options::OPT_rdynamic))
7089 CmdArgs.push_back("-export-dynamic");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007090 CmdArgs.push_back("--eh-frame-hdr");
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007091 CmdArgs.push_back("-Bdynamic");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007092 if (Args.hasArg(options::OPT_shared)) {
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007093 CmdArgs.push_back("-shared");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007094 } else {
7095 CmdArgs.push_back("-dynamic-linker");
7096 CmdArgs.push_back("/usr/libexec/ld.so");
7097 }
7098 }
7099
Rafael Espindola044f7832013-06-05 04:28:55 +00007100 if (Args.hasArg(options::OPT_nopie))
7101 CmdArgs.push_back("-nopie");
7102
Daniel Dunbarb440f562010-08-02 02:38:21 +00007103 if (Output.isFilename()) {
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007104 CmdArgs.push_back("-o");
7105 CmdArgs.push_back(Output.getFilename());
7106 } else {
7107 assert(Output.isNothing() && "Invalid output.");
7108 }
7109
7110 if (!Args.hasArg(options::OPT_nostdlib) &&
7111 !Args.hasArg(options::OPT_nostartfiles)) {
7112 if (!Args.hasArg(options::OPT_shared)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007113 if (Args.hasArg(options::OPT_pg))
7114 CmdArgs.push_back(
7115 Args.MakeArgString(getToolChain().GetFilePath("gcrt0.o")));
Eli Friedman3715d1f2011-12-15 02:15:56 +00007116 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007117 CmdArgs.push_back(
7118 Args.MakeArgString(getToolChain().GetFilePath("crt0.o")));
7119 CmdArgs.push_back(
7120 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007121 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007122 CmdArgs.push_back(
7123 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007124 }
7125 }
7126
Edward O'Callaghan5c521462009-10-28 15:13:08 +00007127 std::string Triple = getToolChain().getTripleString();
7128 if (Triple.substr(0, 6) == "x86_64")
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00007129 Triple.replace(0, 6, "amd64");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007130 CmdArgs.push_back(
7131 Args.MakeArgString("-L/usr/lib/gcc-lib/" + Triple + "/4.2.1"));
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007132
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00007133 Args.AddAllArgs(CmdArgs, {options::OPT_L, options::OPT_T_Group,
7134 options::OPT_e, options::OPT_s, options::OPT_t,
7135 options::OPT_Z_Flag, options::OPT_r});
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007136
Daniel Dunbar54423b22010-09-17 00:24:54 +00007137 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007138
7139 if (!Args.hasArg(options::OPT_nostdlib) &&
7140 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00007141 if (D.CCCIsCXX()) {
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00007142 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007143 if (Args.hasArg(options::OPT_pg))
Eli Friedman3715d1f2011-12-15 02:15:56 +00007144 CmdArgs.push_back("-lm_p");
7145 else
7146 CmdArgs.push_back("-lm");
Daniel Dunbarea3813f2010-08-01 23:13:54 +00007147 }
7148
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007149 // FIXME: For some reason GCC passes -lgcc before adding
7150 // the default system libraries. Just mimic this for now.
7151 CmdArgs.push_back("-lgcc");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007152
Eric Christopher17674ec2012-09-13 06:32:34 +00007153 if (Args.hasArg(options::OPT_pthread)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007154 if (!Args.hasArg(options::OPT_shared) && Args.hasArg(options::OPT_pg))
7155 CmdArgs.push_back("-lpthread_p");
Eric Christopher17674ec2012-09-13 06:32:34 +00007156 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007157 CmdArgs.push_back("-lpthread");
Eric Christopher17674ec2012-09-13 06:32:34 +00007158 }
7159
Chandler Carruth45661652011-12-17 22:32:42 +00007160 if (!Args.hasArg(options::OPT_shared)) {
Eric Christopher17674ec2012-09-13 06:32:34 +00007161 if (Args.hasArg(options::OPT_pg))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007162 CmdArgs.push_back("-lc_p");
Eli Friedman3715d1f2011-12-15 02:15:56 +00007163 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007164 CmdArgs.push_back("-lc");
Chandler Carruth45661652011-12-17 22:32:42 +00007165 }
Eric Christopher17674ec2012-09-13 06:32:34 +00007166
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007167 CmdArgs.push_back("-lgcc");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007168 }
7169
7170 if (!Args.hasArg(options::OPT_nostdlib) &&
7171 !Args.hasArg(options::OPT_nostartfiles)) {
7172 if (!Args.hasArg(options::OPT_shared))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007173 CmdArgs.push_back(
7174 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007175 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007176 CmdArgs.push_back(
7177 Args.MakeArgString(getToolChain().GetFilePath("crtendS.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007178 }
7179
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007180 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007181 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007182}
Ed Schoutene33194b2009-04-02 19:13:12 +00007183
Douglas Katzman95354292015-06-23 20:42:09 +00007184void bitrig::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
7185 const InputInfo &Output,
7186 const InputInfoList &Inputs,
7187 const ArgList &Args,
7188 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007189 claimNoWarnArgs(Args);
Eli Friedman9fa28852012-08-08 23:57:20 +00007190 ArgStringList CmdArgs;
7191
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007192 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Eli Friedman9fa28852012-08-08 23:57:20 +00007193
7194 CmdArgs.push_back("-o");
7195 CmdArgs.push_back(Output.getFilename());
7196
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007197 for (const auto &II : Inputs)
Eli Friedman9fa28852012-08-08 23:57:20 +00007198 CmdArgs.push_back(II.getFilename());
Eli Friedman9fa28852012-08-08 23:57:20 +00007199
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007200 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00007201 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eli Friedman9fa28852012-08-08 23:57:20 +00007202}
7203
Douglas Katzman95354292015-06-23 20:42:09 +00007204void bitrig::Linker::ConstructJob(Compilation &C, const JobAction &JA,
7205 const InputInfo &Output,
7206 const InputInfoList &Inputs,
7207 const ArgList &Args,
7208 const char *LinkingOutput) const {
Eli Friedman9fa28852012-08-08 23:57:20 +00007209 const Driver &D = getToolChain().getDriver();
7210 ArgStringList CmdArgs;
7211
7212 if ((!Args.hasArg(options::OPT_nostdlib)) &&
7213 (!Args.hasArg(options::OPT_shared))) {
7214 CmdArgs.push_back("-e");
7215 CmdArgs.push_back("__start");
7216 }
7217
7218 if (Args.hasArg(options::OPT_static)) {
7219 CmdArgs.push_back("-Bstatic");
7220 } else {
7221 if (Args.hasArg(options::OPT_rdynamic))
7222 CmdArgs.push_back("-export-dynamic");
7223 CmdArgs.push_back("--eh-frame-hdr");
7224 CmdArgs.push_back("-Bdynamic");
7225 if (Args.hasArg(options::OPT_shared)) {
7226 CmdArgs.push_back("-shared");
7227 } else {
7228 CmdArgs.push_back("-dynamic-linker");
7229 CmdArgs.push_back("/usr/libexec/ld.so");
7230 }
7231 }
7232
7233 if (Output.isFilename()) {
7234 CmdArgs.push_back("-o");
7235 CmdArgs.push_back(Output.getFilename());
7236 } else {
7237 assert(Output.isNothing() && "Invalid output.");
7238 }
7239
7240 if (!Args.hasArg(options::OPT_nostdlib) &&
7241 !Args.hasArg(options::OPT_nostartfiles)) {
7242 if (!Args.hasArg(options::OPT_shared)) {
7243 if (Args.hasArg(options::OPT_pg))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007244 CmdArgs.push_back(
7245 Args.MakeArgString(getToolChain().GetFilePath("gcrt0.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00007246 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007247 CmdArgs.push_back(
7248 Args.MakeArgString(getToolChain().GetFilePath("crt0.o")));
7249 CmdArgs.push_back(
7250 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00007251 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007252 CmdArgs.push_back(
7253 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00007254 }
7255 }
7256
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00007257 Args.AddAllArgs(CmdArgs,
7258 {options::OPT_L, options::OPT_T_Group, options::OPT_e});
Eli Friedman9fa28852012-08-08 23:57:20 +00007259
7260 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
7261
7262 if (!Args.hasArg(options::OPT_nostdlib) &&
7263 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00007264 if (D.CCCIsCXX()) {
Eli Friedman9fa28852012-08-08 23:57:20 +00007265 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
7266 if (Args.hasArg(options::OPT_pg))
7267 CmdArgs.push_back("-lm_p");
7268 else
7269 CmdArgs.push_back("-lm");
7270 }
7271
Rafael Espindola1ad26f02012-10-23 17:07:31 +00007272 if (Args.hasArg(options::OPT_pthread)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007273 if (!Args.hasArg(options::OPT_shared) && Args.hasArg(options::OPT_pg))
Rafael Espindola1ad26f02012-10-23 17:07:31 +00007274 CmdArgs.push_back("-lpthread_p");
7275 else
7276 CmdArgs.push_back("-lpthread");
7277 }
7278
Eli Friedman9fa28852012-08-08 23:57:20 +00007279 if (!Args.hasArg(options::OPT_shared)) {
7280 if (Args.hasArg(options::OPT_pg))
7281 CmdArgs.push_back("-lc_p");
7282 else
7283 CmdArgs.push_back("-lc");
7284 }
7285
Benjamin Kramerb2ccade2013-10-21 12:33:55 +00007286 StringRef MyArch;
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007287 switch (getToolChain().getArch()) {
Benjamin Kramerb2ccade2013-10-21 12:33:55 +00007288 case llvm::Triple::arm:
7289 MyArch = "arm";
7290 break;
7291 case llvm::Triple::x86:
7292 MyArch = "i386";
7293 break;
7294 case llvm::Triple::x86_64:
7295 MyArch = "amd64";
7296 break;
7297 default:
7298 llvm_unreachable("Unsupported architecture");
7299 }
7300 CmdArgs.push_back(Args.MakeArgString("-lclang_rt." + MyArch));
Eli Friedman9fa28852012-08-08 23:57:20 +00007301 }
7302
7303 if (!Args.hasArg(options::OPT_nostdlib) &&
7304 !Args.hasArg(options::OPT_nostartfiles)) {
7305 if (!Args.hasArg(options::OPT_shared))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007306 CmdArgs.push_back(
7307 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00007308 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007309 CmdArgs.push_back(
7310 Args.MakeArgString(getToolChain().GetFilePath("crtendS.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00007311 }
Eli Friedman5bb2ba02012-08-09 22:42:04 +00007312
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007313 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007314 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eli Friedman9fa28852012-08-08 23:57:20 +00007315}
7316
Douglas Katzman95354292015-06-23 20:42:09 +00007317void freebsd::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
7318 const InputInfo &Output,
7319 const InputInfoList &Inputs,
7320 const ArgList &Args,
7321 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007322 claimNoWarnArgs(Args);
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007323 ArgStringList CmdArgs;
7324
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007325 // When building 32-bit code on FreeBSD/amd64, we have to explicitly
7326 // instruct as in the base system to assemble 32-bit code.
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007327 if (getToolChain().getArch() == llvm::Triple::x86)
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007328 CmdArgs.push_back("--32");
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007329 else if (getToolChain().getArch() == llvm::Triple::ppc)
Roman Divacky00859c22011-06-04 07:37:31 +00007330 CmdArgs.push_back("-a32");
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007331 else if (getToolChain().getArch() == llvm::Triple::mips ||
7332 getToolChain().getArch() == llvm::Triple::mipsel ||
7333 getToolChain().getArch() == llvm::Triple::mips64 ||
7334 getToolChain().getArch() == llvm::Triple::mips64el) {
7335 StringRef CPUName;
7336 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00007337 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00007338
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007339 CmdArgs.push_back("-march");
7340 CmdArgs.push_back(CPUName.data());
7341
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007342 CmdArgs.push_back("-mabi");
Simon Atanasyan0da400c2013-02-27 14:55:49 +00007343 CmdArgs.push_back(getGnuCompatibleMipsABIName(ABIName).data());
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007344
7345 if (getToolChain().getArch() == llvm::Triple::mips ||
7346 getToolChain().getArch() == llvm::Triple::mips64)
7347 CmdArgs.push_back("-EB");
7348 else
7349 CmdArgs.push_back("-EL");
7350
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007351 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Rafael Espindola0f207ed2012-12-13 04:17:14 +00007352 } else if (getToolChain().getArch() == llvm::Triple::arm ||
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00007353 getToolChain().getArch() == llvm::Triple::armeb ||
7354 getToolChain().getArch() == llvm::Triple::thumb ||
7355 getToolChain().getArch() == llvm::Triple::thumbeb) {
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00007356 arm::FloatABI ABI = arm::getARMFloatABI(getToolChain(), Args);
Renato Golinf4421f72014-02-19 10:44:07 +00007357
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +00007358 if (ABI == arm::FloatABI::Hard)
Renato Golinf4421f72014-02-19 10:44:07 +00007359 CmdArgs.push_back("-mfpu=vfp");
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +00007360 else
Renato Golinf4421f72014-02-19 10:44:07 +00007361 CmdArgs.push_back("-mfpu=softvfp");
Renato Golinf4421f72014-02-19 10:44:07 +00007362
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007363 switch (getToolChain().getTriple().getEnvironment()) {
Renato Golinf4421f72014-02-19 10:44:07 +00007364 case llvm::Triple::GNUEABIHF:
Rafael Espindola0f207ed2012-12-13 04:17:14 +00007365 case llvm::Triple::GNUEABI:
7366 case llvm::Triple::EABI:
Anton Korobeynikov2bed8472013-03-18 07:59:20 +00007367 CmdArgs.push_back("-meabi=5");
Rafael Espindola0f207ed2012-12-13 04:17:14 +00007368 break;
7369
7370 default:
7371 CmdArgs.push_back("-matpcs");
7372 }
Roman Divacky47f4ff82014-01-02 15:13:18 +00007373 } else if (getToolChain().getArch() == llvm::Triple::sparc ||
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00007374 getToolChain().getArch() == llvm::Triple::sparcel ||
Roman Divackyfeb5e632014-01-02 15:34:59 +00007375 getToolChain().getArch() == llvm::Triple::sparcv9) {
Roman Divacky9f779402014-02-25 18:45:49 +00007376 if (getToolChain().getArch() == llvm::Triple::sparc)
7377 CmdArgs.push_back("-Av8plusa");
7378 else
7379 CmdArgs.push_back("-Av9a");
7380
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007381 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007382 }
Eric Christopher0b26a612010-03-02 02:41:08 +00007383
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007384 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007385
7386 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00007387 CmdArgs.push_back(Output.getFilename());
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007388
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007389 for (const auto &II : Inputs)
Daniel Dunbarb440f562010-08-02 02:38:21 +00007390 CmdArgs.push_back(II.getFilename());
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007391
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007392 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00007393 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007394}
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007395
Douglas Katzman95354292015-06-23 20:42:09 +00007396void freebsd::Linker::ConstructJob(Compilation &C, const JobAction &JA,
7397 const InputInfo &Output,
7398 const InputInfoList &Inputs,
7399 const ArgList &Args,
7400 const char *LinkingOutput) const {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007401 const toolchains::FreeBSD &ToolChain =
7402 static_cast<const toolchains::FreeBSD &>(getToolChain());
Roman Divackyafe2f232012-08-28 15:09:03 +00007403 const Driver &D = ToolChain.getDriver();
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007404 const llvm::Triple::ArchType Arch = ToolChain.getArch();
Alexey Samsonove65ceb92014-02-25 13:26:03 +00007405 const bool IsPIE =
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007406 !Args.hasArg(options::OPT_shared) &&
7407 (Args.hasArg(options::OPT_pie) || ToolChain.isPIEDefault());
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007408 ArgStringList CmdArgs;
David Chisnall5f99f482012-07-29 15:24:44 +00007409
7410 // Silence warning for "clang -g foo.o -o foo"
7411 Args.ClaimAllArgs(options::OPT_g_Group);
7412 // and "clang -emit-llvm foo.o -o foo"
7413 Args.ClaimAllArgs(options::OPT_emit_llvm);
7414 // and for "clang -w foo.o -o foo". Other warning options are already
7415 // handled somewhere else.
7416 Args.ClaimAllArgs(options::OPT_w);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007417
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00007418 if (!D.SysRoot.empty())
7419 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
7420
Alexey Samsonove65ceb92014-02-25 13:26:03 +00007421 if (IsPIE)
Roman Divackyafe2f232012-08-28 15:09:03 +00007422 CmdArgs.push_back("-pie");
7423
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007424 if (Args.hasArg(options::OPT_static)) {
7425 CmdArgs.push_back("-Bstatic");
7426 } else {
Rafael Espindola7ba97af2010-11-11 02:17:51 +00007427 if (Args.hasArg(options::OPT_rdynamic))
7428 CmdArgs.push_back("-export-dynamic");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007429 CmdArgs.push_back("--eh-frame-hdr");
7430 if (Args.hasArg(options::OPT_shared)) {
7431 CmdArgs.push_back("-Bshareable");
7432 } else {
7433 CmdArgs.push_back("-dynamic-linker");
7434 CmdArgs.push_back("/libexec/ld-elf.so.1");
7435 }
Roman Divackyafe2f232012-08-28 15:09:03 +00007436 if (ToolChain.getTriple().getOSMajorVersion() >= 9) {
David Chisnall5f99f482012-07-29 15:24:44 +00007437 if (Arch == llvm::Triple::arm || Arch == llvm::Triple::sparc ||
7438 Arch == llvm::Triple::x86 || Arch == llvm::Triple::x86_64) {
7439 CmdArgs.push_back("--hash-style=both");
7440 }
7441 }
7442 CmdArgs.push_back("--enable-new-dtags");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007443 }
7444
7445 // When building 32-bit code on FreeBSD/amd64, we have to explicitly
7446 // instruct ld in the base system to link 32-bit code.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007447 if (Arch == llvm::Triple::x86) {
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007448 CmdArgs.push_back("-m");
7449 CmdArgs.push_back("elf_i386_fbsd");
7450 }
7451
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007452 if (Arch == llvm::Triple::ppc) {
Roman Divacky5e300b82011-06-04 07:40:24 +00007453 CmdArgs.push_back("-m");
Roman Divackyd150ad32011-11-21 16:50:32 +00007454 CmdArgs.push_back("elf32ppc_fbsd");
Roman Divacky5e300b82011-06-04 07:40:24 +00007455 }
7456
Daniel Dunbarb440f562010-08-02 02:38:21 +00007457 if (Output.isFilename()) {
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007458 CmdArgs.push_back("-o");
7459 CmdArgs.push_back(Output.getFilename());
7460 } else {
7461 assert(Output.isNothing() && "Invalid output.");
7462 }
7463
7464 if (!Args.hasArg(options::OPT_nostdlib) &&
7465 !Args.hasArg(options::OPT_nostartfiles)) {
Craig Topper92fc2df2014-05-17 16:56:41 +00007466 const char *crt1 = nullptr;
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007467 if (!Args.hasArg(options::OPT_shared)) {
Roman Divacky66f22762011-02-10 16:59:40 +00007468 if (Args.hasArg(options::OPT_pg))
Roman Divackyafe2f232012-08-28 15:09:03 +00007469 crt1 = "gcrt1.o";
Alexey Samsonove65ceb92014-02-25 13:26:03 +00007470 else if (IsPIE)
Roman Divackyafe2f232012-08-28 15:09:03 +00007471 crt1 = "Scrt1.o";
7472 else
7473 crt1 = "crt1.o";
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007474 }
Roman Divackyafe2f232012-08-28 15:09:03 +00007475 if (crt1)
7476 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crt1)));
7477
7478 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
7479
Craig Topper92fc2df2014-05-17 16:56:41 +00007480 const char *crtbegin = nullptr;
Roman Divackyafe2f232012-08-28 15:09:03 +00007481 if (Args.hasArg(options::OPT_static))
7482 crtbegin = "crtbeginT.o";
Alexey Samsonove65ceb92014-02-25 13:26:03 +00007483 else if (Args.hasArg(options::OPT_shared) || IsPIE)
Roman Divackyafe2f232012-08-28 15:09:03 +00007484 crtbegin = "crtbeginS.o";
7485 else
7486 crtbegin = "crtbegin.o";
7487
7488 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtbegin)));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007489 }
7490
7491 Args.AddAllArgs(CmdArgs, options::OPT_L);
Benjamin Kramer22c68ef2014-09-11 14:13:49 +00007492 const ToolChain::path_list &Paths = ToolChain.getFilePaths();
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007493 for (const auto &Path : Paths)
7494 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007495 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
7496 Args.AddAllArgs(CmdArgs, options::OPT_e);
David Chisnall589a4942010-08-15 22:58:12 +00007497 Args.AddAllArgs(CmdArgs, options::OPT_s);
7498 Args.AddAllArgs(CmdArgs, options::OPT_t);
7499 Args.AddAllArgs(CmdArgs, options::OPT_Z_Flag);
7500 Args.AddAllArgs(CmdArgs, options::OPT_r);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007501
Alexey Samsonov907880e2015-06-19 19:57:46 +00007502 if (D.IsUsingLTO(Args))
Alp Tokerce365ca2013-12-02 12:43:03 +00007503 AddGoldPlugin(ToolChain, Args, CmdArgs);
Roman Divackyf0d7f942013-11-10 09:31:43 +00007504
Alexey Samsonov52550342014-09-15 19:58:40 +00007505 bool NeedsSanitizerDeps = addSanitizerRuntimes(ToolChain, Args, CmdArgs);
Roman Divackyafe2f232012-08-28 15:09:03 +00007506 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007507
7508 if (!Args.hasArg(options::OPT_nostdlib) &&
7509 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00007510 if (D.CCCIsCXX()) {
Roman Divackyafe2f232012-08-28 15:09:03 +00007511 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
Roman Divacky66f22762011-02-10 16:59:40 +00007512 if (Args.hasArg(options::OPT_pg))
7513 CmdArgs.push_back("-lm_p");
7514 else
7515 CmdArgs.push_back("-lm");
Daniel Dunbar4b8ef282010-02-17 08:07:51 +00007516 }
Alexey Samsonov52550342014-09-15 19:58:40 +00007517 if (NeedsSanitizerDeps)
7518 linkSanitizerRuntimeDeps(ToolChain, CmdArgs);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007519 // FIXME: For some reason GCC passes -lgcc and -lgcc_s before adding
7520 // the default system libraries. Just mimic this for now.
Roman Divacky66f22762011-02-10 16:59:40 +00007521 if (Args.hasArg(options::OPT_pg))
7522 CmdArgs.push_back("-lgcc_p");
7523 else
7524 CmdArgs.push_back("-lgcc");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007525 if (Args.hasArg(options::OPT_static)) {
7526 CmdArgs.push_back("-lgcc_eh");
Roman Divacky66f22762011-02-10 16:59:40 +00007527 } else if (Args.hasArg(options::OPT_pg)) {
7528 CmdArgs.push_back("-lgcc_eh_p");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007529 } else {
7530 CmdArgs.push_back("--as-needed");
7531 CmdArgs.push_back("-lgcc_s");
7532 CmdArgs.push_back("--no-as-needed");
7533 }
7534
Matt Beaumont-Gay1fe49152011-02-10 20:35:01 +00007535 if (Args.hasArg(options::OPT_pthread)) {
Roman Divacky66f22762011-02-10 16:59:40 +00007536 if (Args.hasArg(options::OPT_pg))
7537 CmdArgs.push_back("-lpthread_p");
7538 else
7539 CmdArgs.push_back("-lpthread");
Matt Beaumont-Gay1fe49152011-02-10 20:35:01 +00007540 }
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007541
Roman Divacky66f22762011-02-10 16:59:40 +00007542 if (Args.hasArg(options::OPT_pg)) {
7543 if (Args.hasArg(options::OPT_shared))
7544 CmdArgs.push_back("-lc");
7545 else
7546 CmdArgs.push_back("-lc_p");
7547 CmdArgs.push_back("-lgcc_p");
7548 } else {
7549 CmdArgs.push_back("-lc");
7550 CmdArgs.push_back("-lgcc");
7551 }
7552
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007553 if (Args.hasArg(options::OPT_static)) {
7554 CmdArgs.push_back("-lgcc_eh");
Roman Divacky66f22762011-02-10 16:59:40 +00007555 } else if (Args.hasArg(options::OPT_pg)) {
7556 CmdArgs.push_back("-lgcc_eh_p");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007557 } else {
7558 CmdArgs.push_back("--as-needed");
7559 CmdArgs.push_back("-lgcc_s");
7560 CmdArgs.push_back("--no-as-needed");
7561 }
7562 }
7563
7564 if (!Args.hasArg(options::OPT_nostdlib) &&
7565 !Args.hasArg(options::OPT_nostartfiles)) {
Alexey Samsonove65ceb92014-02-25 13:26:03 +00007566 if (Args.hasArg(options::OPT_shared) || IsPIE)
Roman Divackyafe2f232012-08-28 15:09:03 +00007567 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtendS.o")));
Roman Divackya3c50242012-09-07 13:36:21 +00007568 else
7569 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtend.o")));
Roman Divackyafe2f232012-08-28 15:09:03 +00007570 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007571 }
7572
Alexey Samsonov7811d192014-02-20 13:57:37 +00007573 addProfileRT(ToolChain, Args, CmdArgs);
Nick Lewycky82fe5f42011-05-24 21:54:59 +00007574
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007575 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007576 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007577}
Daniel Dunbarcc912342009-05-02 18:28:39 +00007578
Douglas Katzman95354292015-06-23 20:42:09 +00007579void netbsd::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007580 const InputInfo &Output,
7581 const InputInfoList &Inputs,
7582 const ArgList &Args,
7583 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007584 claimNoWarnArgs(Args);
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007585 ArgStringList CmdArgs;
7586
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007587 // GNU as needs different flags for creating the correct output format
7588 // on architectures with different ABIs or optional feature sets.
7589 switch (getToolChain().getArch()) {
7590 case llvm::Triple::x86:
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007591 CmdArgs.push_back("--32");
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007592 break;
7593 case llvm::Triple::arm:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00007594 case llvm::Triple::armeb:
7595 case llvm::Triple::thumb:
7596 case llvm::Triple::thumbeb: {
Renato Goline17c5802015-07-27 23:44:42 +00007597 StringRef MArch, MCPU;
Renato Golin7c542b42015-07-27 23:44:45 +00007598 getARMArchCPUFromArgs(Args, MArch, MCPU, /*FromAs*/ true);
7599 std::string Arch =
7600 arm::getARMTargetCPU(MCPU, MArch, getToolChain().getTriple());
Renato Goline17c5802015-07-27 23:44:42 +00007601 CmdArgs.push_back(Args.MakeArgString("-mcpu=" + Arch));
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007602 break;
Joerg Sonnenberger1f94da52013-12-05 21:07:29 +00007603 }
7604
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007605 case llvm::Triple::mips:
7606 case llvm::Triple::mipsel:
7607 case llvm::Triple::mips64:
7608 case llvm::Triple::mips64el: {
Joerg Sonnenberger21baded2013-12-08 13:54:58 +00007609 StringRef CPUName;
7610 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00007611 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Joerg Sonnenberger21baded2013-12-08 13:54:58 +00007612
7613 CmdArgs.push_back("-march");
7614 CmdArgs.push_back(CPUName.data());
7615
7616 CmdArgs.push_back("-mabi");
7617 CmdArgs.push_back(getGnuCompatibleMipsABIName(ABIName).data());
7618
7619 if (getToolChain().getArch() == llvm::Triple::mips ||
7620 getToolChain().getArch() == llvm::Triple::mips64)
7621 CmdArgs.push_back("-EB");
7622 else
7623 CmdArgs.push_back("-EL");
7624
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007625 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007626 break;
7627 }
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00007628
7629 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00007630 case llvm::Triple::sparcel:
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00007631 CmdArgs.push_back("-32");
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007632 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00007633 break;
7634
7635 case llvm::Triple::sparcv9:
7636 CmdArgs.push_back("-64");
7637 CmdArgs.push_back("-Av9");
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007638 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00007639 break;
7640
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007641 default:
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007642 break;
Joerg Sonnenberger21baded2013-12-08 13:54:58 +00007643 }
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007644
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007645 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007646
7647 CmdArgs.push_back("-o");
7648 CmdArgs.push_back(Output.getFilename());
7649
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007650 for (const auto &II : Inputs)
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007651 CmdArgs.push_back(II.getFilename());
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007652
David Chisnallddbd68f2011-09-27 22:03:18 +00007653 const char *Exec = Args.MakeArgString((getToolChain().GetProgramPath("as")));
Justin Bognerd3371d82015-07-17 03:35:54 +00007654 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007655}
7656
Douglas Katzman95354292015-06-23 20:42:09 +00007657void netbsd::Linker::ConstructJob(Compilation &C, const JobAction &JA,
7658 const InputInfo &Output,
7659 const InputInfoList &Inputs,
7660 const ArgList &Args,
7661 const char *LinkingOutput) const {
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007662 const Driver &D = getToolChain().getDriver();
7663 ArgStringList CmdArgs;
7664
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00007665 if (!D.SysRoot.empty())
7666 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
7667
Joerg Sonnenberger52be0b42014-03-13 00:42:01 +00007668 CmdArgs.push_back("--eh-frame-hdr");
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007669 if (Args.hasArg(options::OPT_static)) {
7670 CmdArgs.push_back("-Bstatic");
7671 } else {
7672 if (Args.hasArg(options::OPT_rdynamic))
7673 CmdArgs.push_back("-export-dynamic");
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007674 if (Args.hasArg(options::OPT_shared)) {
7675 CmdArgs.push_back("-Bshareable");
7676 } else {
7677 CmdArgs.push_back("-dynamic-linker");
7678 CmdArgs.push_back("/libexec/ld.elf_so");
7679 }
7680 }
7681
Joerg Sonnenberger6cd7deb2014-02-02 22:50:34 +00007682 // Many NetBSD architectures support more than one ABI.
7683 // Determine the correct emulation for ld.
7684 switch (getToolChain().getArch()) {
7685 case llvm::Triple::x86:
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007686 CmdArgs.push_back("-m");
7687 CmdArgs.push_back("elf_i386");
Joerg Sonnenberger6cd7deb2014-02-02 22:50:34 +00007688 break;
7689 case llvm::Triple::arm:
7690 case llvm::Triple::thumb:
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00007691 CmdArgs.push_back("-m");
7692 switch (getToolChain().getTriple().getEnvironment()) {
7693 case llvm::Triple::EABI:
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00007694 case llvm::Triple::GNUEABI:
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00007695 CmdArgs.push_back("armelf_nbsd_eabi");
7696 break;
Joerg Sonnenberger83a33c02014-02-06 21:04:32 +00007697 case llvm::Triple::EABIHF:
7698 case llvm::Triple::GNUEABIHF:
7699 CmdArgs.push_back("armelf_nbsd_eabihf");
7700 break;
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00007701 default:
7702 CmdArgs.push_back("armelf_nbsd");
7703 break;
7704 }
Joerg Sonnenberger6cd7deb2014-02-02 22:50:34 +00007705 break;
Joerg Sonnenbergerb7045342014-08-14 19:12:41 +00007706 case llvm::Triple::armeb:
7707 case llvm::Triple::thumbeb:
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007708 arm::appendEBLinkFlags(
7709 Args, CmdArgs,
John Brawn94fd9632015-05-21 12:19:49 +00007710 llvm::Triple(getToolChain().ComputeEffectiveClangTriple(Args)));
Joerg Sonnenbergerb7045342014-08-14 19:12:41 +00007711 CmdArgs.push_back("-m");
7712 switch (getToolChain().getTriple().getEnvironment()) {
7713 case llvm::Triple::EABI:
7714 case llvm::Triple::GNUEABI:
7715 CmdArgs.push_back("armelfb_nbsd_eabi");
7716 break;
7717 case llvm::Triple::EABIHF:
7718 case llvm::Triple::GNUEABIHF:
7719 CmdArgs.push_back("armelfb_nbsd_eabihf");
7720 break;
7721 default:
7722 CmdArgs.push_back("armelfb_nbsd");
7723 break;
7724 }
7725 break;
Joerg Sonnenbergere7f97592014-02-02 22:59:16 +00007726 case llvm::Triple::mips64:
7727 case llvm::Triple::mips64el:
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00007728 if (mips::hasMipsAbiArg(Args, "32")) {
Joerg Sonnenbergere7f97592014-02-02 22:59:16 +00007729 CmdArgs.push_back("-m");
7730 if (getToolChain().getArch() == llvm::Triple::mips64)
7731 CmdArgs.push_back("elf32btsmip");
7732 else
7733 CmdArgs.push_back("elf32ltsmip");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007734 } else if (mips::hasMipsAbiArg(Args, "64")) {
7735 CmdArgs.push_back("-m");
7736 if (getToolChain().getArch() == llvm::Triple::mips64)
7737 CmdArgs.push_back("elf64btsmip");
7738 else
7739 CmdArgs.push_back("elf64ltsmip");
7740 }
7741 break;
Joerg Sonnenbergerdd13b302014-08-13 14:17:32 +00007742 case llvm::Triple::ppc:
7743 CmdArgs.push_back("-m");
7744 CmdArgs.push_back("elf32ppc_nbsd");
7745 break;
7746
7747 case llvm::Triple::ppc64:
7748 case llvm::Triple::ppc64le:
7749 CmdArgs.push_back("-m");
7750 CmdArgs.push_back("elf64ppc");
7751 break;
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00007752
7753 case llvm::Triple::sparc:
7754 CmdArgs.push_back("-m");
7755 CmdArgs.push_back("elf32_sparc");
7756 break;
7757
7758 case llvm::Triple::sparcv9:
7759 CmdArgs.push_back("-m");
7760 CmdArgs.push_back("elf64_sparc");
7761 break;
7762
Joerg Sonnenberger6cd7deb2014-02-02 22:50:34 +00007763 default:
7764 break;
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00007765 }
7766
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007767 if (Output.isFilename()) {
7768 CmdArgs.push_back("-o");
7769 CmdArgs.push_back(Output.getFilename());
7770 } else {
7771 assert(Output.isNothing() && "Invalid output.");
7772 }
7773
7774 if (!Args.hasArg(options::OPT_nostdlib) &&
7775 !Args.hasArg(options::OPT_nostartfiles)) {
7776 if (!Args.hasArg(options::OPT_shared)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007777 CmdArgs.push_back(
7778 Args.MakeArgString(getToolChain().GetFilePath("crt0.o")));
7779 CmdArgs.push_back(
7780 Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
7781 CmdArgs.push_back(
7782 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007783 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007784 CmdArgs.push_back(
7785 Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
7786 CmdArgs.push_back(
7787 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.o")));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007788 }
7789 }
7790
7791 Args.AddAllArgs(CmdArgs, options::OPT_L);
7792 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
7793 Args.AddAllArgs(CmdArgs, options::OPT_e);
7794 Args.AddAllArgs(CmdArgs, options::OPT_s);
7795 Args.AddAllArgs(CmdArgs, options::OPT_t);
7796 Args.AddAllArgs(CmdArgs, options::OPT_Z_Flag);
7797 Args.AddAllArgs(CmdArgs, options::OPT_r);
7798
7799 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
7800
Joerg Sonnenbergera4435632013-10-14 20:13:05 +00007801 unsigned Major, Minor, Micro;
7802 getToolChain().getTriple().getOSVersion(Major, Minor, Micro);
7803 bool useLibgcc = true;
Joerg Sonnenbergerc8887572014-07-25 20:57:24 +00007804 if (Major >= 7 || (Major == 6 && Minor == 99 && Micro >= 49) || Major == 0) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007805 switch (getToolChain().getArch()) {
Joerg Sonnenberger323cea92014-08-09 18:28:36 +00007806 case llvm::Triple::aarch64:
Joerg Sonnenberger1ea66472014-05-07 08:45:26 +00007807 case llvm::Triple::arm:
7808 case llvm::Triple::armeb:
7809 case llvm::Triple::thumb:
7810 case llvm::Triple::thumbeb:
Joerg Sonnenbergerc8887572014-07-25 20:57:24 +00007811 case llvm::Triple::ppc:
Joerg Sonnenbergerdd13b302014-08-13 14:17:32 +00007812 case llvm::Triple::ppc64:
7813 case llvm::Triple::ppc64le:
Joerg Sonnenbergerd769a1e2014-01-18 00:50:49 +00007814 case llvm::Triple::x86:
7815 case llvm::Triple::x86_64:
Joerg Sonnenbergera4435632013-10-14 20:13:05 +00007816 useLibgcc = false;
Joerg Sonnenbergerd769a1e2014-01-18 00:50:49 +00007817 break;
7818 default:
7819 break;
7820 }
Joerg Sonnenbergera4435632013-10-14 20:13:05 +00007821 }
7822
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007823 if (!Args.hasArg(options::OPT_nostdlib) &&
7824 !Args.hasArg(options::OPT_nodefaultlibs)) {
Joerg Sonnenberger27a69a22015-09-23 20:11:00 +00007825 addOpenMPRuntime(CmdArgs, getToolChain(), Args);
Hans Wennborg70850d82013-07-18 20:29:38 +00007826 if (D.CCCIsCXX()) {
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007827 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
7828 CmdArgs.push_back("-lm");
7829 }
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007830 if (Args.hasArg(options::OPT_pthread))
7831 CmdArgs.push_back("-lpthread");
7832 CmdArgs.push_back("-lc");
7833
Joerg Sonnenbergera4435632013-10-14 20:13:05 +00007834 if (useLibgcc) {
7835 if (Args.hasArg(options::OPT_static)) {
7836 // libgcc_eh depends on libc, so resolve as much as possible,
7837 // pull in any new requirements from libc and then get the rest
7838 // of libgcc.
7839 CmdArgs.push_back("-lgcc_eh");
7840 CmdArgs.push_back("-lc");
7841 CmdArgs.push_back("-lgcc");
7842 } else {
7843 CmdArgs.push_back("-lgcc");
7844 CmdArgs.push_back("--as-needed");
7845 CmdArgs.push_back("-lgcc_s");
7846 CmdArgs.push_back("--no-as-needed");
7847 }
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007848 }
7849 }
7850
7851 if (!Args.hasArg(options::OPT_nostdlib) &&
7852 !Args.hasArg(options::OPT_nostartfiles)) {
7853 if (!Args.hasArg(options::OPT_shared))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007854 CmdArgs.push_back(
7855 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007856 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007857 CmdArgs.push_back(
7858 Args.MakeArgString(getToolChain().GetFilePath("crtendS.o")));
7859 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007860 }
7861
Alexey Samsonov7811d192014-02-20 13:57:37 +00007862 addProfileRT(getToolChain(), Args, CmdArgs);
Nick Lewycky82fe5f42011-05-24 21:54:59 +00007863
Logan Chieneb9162f2014-06-26 14:23:45 +00007864 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007865 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007866}
7867
Douglas Katzman95354292015-06-23 20:42:09 +00007868void gnutools::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
7869 const InputInfo &Output,
7870 const InputInfoList &Inputs,
7871 const ArgList &Args,
7872 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007873 claimNoWarnArgs(Args);
7874
James Y Knight2db38f32015-08-15 03:45:25 +00007875 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
7876 llvm::Triple Triple = llvm::Triple(TripleStr);
7877
Rafael Espindola92b00932010-08-10 00:25:48 +00007878 ArgStringList CmdArgs;
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00007879 bool NeedsKPIC = false;
Rafael Espindola92b00932010-08-10 00:25:48 +00007880
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007881 llvm::Reloc::Model RelocationModel;
7882 unsigned PICLevel;
7883 bool IsPIE;
7884 std::tie(RelocationModel, PICLevel, IsPIE) =
7885 ParsePICArgs(getToolChain(), Triple, Args);
7886
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007887 switch (getToolChain().getArch()) {
7888 default:
7889 break;
Rafael Espindola92b00932010-08-10 00:25:48 +00007890 // Add --32/--64 to make sure we get the format we want.
7891 // This is incomplete
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007892 case llvm::Triple::x86:
Rafael Espindola92b00932010-08-10 00:25:48 +00007893 CmdArgs.push_back("--32");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007894 break;
7895 case llvm::Triple::x86_64:
Zinovy Nis1db95732014-07-10 15:27:19 +00007896 if (getToolChain().getTriple().getEnvironment() == llvm::Triple::GNUX32)
7897 CmdArgs.push_back("--x32");
7898 else
7899 CmdArgs.push_back("--64");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007900 break;
7901 case llvm::Triple::ppc:
Eli Friedman4a4932c2011-11-28 23:46:52 +00007902 CmdArgs.push_back("-a32");
7903 CmdArgs.push_back("-mppc");
7904 CmdArgs.push_back("-many");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007905 break;
7906 case llvm::Triple::ppc64:
Eli Friedman4a4932c2011-11-28 23:46:52 +00007907 CmdArgs.push_back("-a64");
7908 CmdArgs.push_back("-mppc64");
7909 CmdArgs.push_back("-many");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007910 break;
7911 case llvm::Triple::ppc64le:
Bill Schmidt778d3872013-07-26 01:36:11 +00007912 CmdArgs.push_back("-a64");
Will Schmidtc1fc1902014-03-24 17:10:37 +00007913 CmdArgs.push_back("-mppc64");
Bill Schmidt778d3872013-07-26 01:36:11 +00007914 CmdArgs.push_back("-many");
Will Schmidtc1fc1902014-03-24 17:10:37 +00007915 CmdArgs.push_back("-mlittle-endian");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007916 break;
7917 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00007918 case llvm::Triple::sparcel:
Jakob Stoklund Olesen2490e552014-01-10 03:51:29 +00007919 CmdArgs.push_back("-32");
Jakob Stoklund Olesen58801bf2014-01-11 18:25:01 +00007920 CmdArgs.push_back("-Av8plusa");
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00007921 NeedsKPIC = true;
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007922 break;
7923 case llvm::Triple::sparcv9:
Jakob Stoklund Olesen2490e552014-01-10 03:51:29 +00007924 CmdArgs.push_back("-64");
Jakob Stoklund Olesen58801bf2014-01-11 18:25:01 +00007925 CmdArgs.push_back("-Av9a");
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00007926 NeedsKPIC = true;
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007927 break;
7928 case llvm::Triple::arm:
7929 case llvm::Triple::armeb:
7930 case llvm::Triple::thumb:
7931 case llvm::Triple::thumbeb: {
James Y Knight2db38f32015-08-15 03:45:25 +00007932 const llvm::Triple &Triple2 = getToolChain().getTriple();
7933 switch (Triple2.getSubArch()) {
Scott Douglass3205f522015-03-23 10:54:24 +00007934 case llvm::Triple::ARMSubArch_v7:
Rafael Espindola92b00932010-08-10 00:25:48 +00007935 CmdArgs.push_back("-mfpu=neon");
Scott Douglass3205f522015-03-23 10:54:24 +00007936 break;
7937 case llvm::Triple::ARMSubArch_v8:
Bernard Ogdena58ef052013-10-24 18:32:41 +00007938 CmdArgs.push_back("-mfpu=crypto-neon-fp-armv8");
Scott Douglass3205f522015-03-23 10:54:24 +00007939 break;
7940 default:
7941 break;
7942 }
Evgeniy Stepanoved943f62012-04-20 09:03:40 +00007943
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00007944 switch (arm::getARMFloatABI(getToolChain(), Args)) {
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +00007945 case arm::FloatABI::Invalid: llvm_unreachable("must have an ABI!");
7946 case arm::FloatABI::Soft:
7947 CmdArgs.push_back(Args.MakeArgString("-mfloat-abi=soft"));
7948 break;
7949 case arm::FloatABI::SoftFP:
7950 CmdArgs.push_back(Args.MakeArgString("-mfloat-abi=softfp"));
7951 break;
7952 case arm::FloatABI::Hard:
7953 CmdArgs.push_back(Args.MakeArgString("-mfloat-abi=hard"));
7954 break;
7955 }
Evgeniy Stepanov582911a2012-04-24 09:05:31 +00007956
7957 Args.AddLastArg(CmdArgs, options::OPT_march_EQ);
Ana Pazosdd6068d2013-12-06 22:43:17 +00007958
7959 // FIXME: remove krait check when GNU tools support krait cpu
7960 // for now replace it with -march=armv7-a to avoid a lower
7961 // march from being picked in the absence of a cpu flag.
7962 Arg *A;
7963 if ((A = Args.getLastArg(options::OPT_mcpu_EQ)) &&
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007964 StringRef(A->getValue()).lower() == "krait")
7965 CmdArgs.push_back("-march=armv7-a");
Ana Pazosdd6068d2013-12-06 22:43:17 +00007966 else
7967 Args.AddLastArg(CmdArgs, options::OPT_mcpu_EQ);
Evgeniy Stepanov582911a2012-04-24 09:05:31 +00007968 Args.AddLastArg(CmdArgs, options::OPT_mfpu_EQ);
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007969 break;
7970 }
7971 case llvm::Triple::mips:
7972 case llvm::Triple::mipsel:
7973 case llvm::Triple::mips64:
7974 case llvm::Triple::mips64el: {
Simon Atanasyan571d7bd2012-04-07 22:31:29 +00007975 StringRef CPUName;
7976 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00007977 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Daniel Sanders379d44b2014-07-16 11:52:23 +00007978 ABIName = getGnuCompatibleMipsABIName(ABIName);
Akira Hatanaka5e9dde32011-11-30 19:31:38 +00007979
Simon Atanasyan571d7bd2012-04-07 22:31:29 +00007980 CmdArgs.push_back("-march");
7981 CmdArgs.push_back(CPUName.data());
7982
Simon Atanasyan571d7bd2012-04-07 22:31:29 +00007983 CmdArgs.push_back("-mabi");
Daniel Sanders379d44b2014-07-16 11:52:23 +00007984 CmdArgs.push_back(ABIName.data());
7985
Daniel Sanders54d8ee62014-07-23 12:06:13 +00007986 // -mno-shared should be emitted unless -fpic, -fpie, -fPIC, -fPIE,
7987 // or -mshared (not implemented) is in effect.
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007988 if (RelocationModel == llvm::Reloc::Static)
Daniel Sanders54d8ee62014-07-23 12:06:13 +00007989 CmdArgs.push_back("-mno-shared");
7990
Daniel Sanders379d44b2014-07-16 11:52:23 +00007991 // LLVM doesn't support -mplt yet and acts as if it is always given.
7992 // However, -mplt has no effect with the N64 ABI.
7993 CmdArgs.push_back(ABIName == "64" ? "-KPIC" : "-call_nonpic");
Simon Atanasyan2390aa12012-04-06 19:15:24 +00007994
7995 if (getToolChain().getArch() == llvm::Triple::mips ||
7996 getToolChain().getArch() == llvm::Triple::mips64)
7997 CmdArgs.push_back("-EB");
7998 else
7999 CmdArgs.push_back("-EL");
Simon Atanasyan217dc2d2012-05-29 19:07:33 +00008000
Simon Atanasyan22127ce2013-09-24 09:09:16 +00008001 if (Arg *A = Args.getLastArg(options::OPT_mnan_EQ)) {
8002 if (StringRef(A->getValue()) == "2008")
8003 CmdArgs.push_back(Args.MakeArgString("-mnan=2008"));
8004 }
8005
Daniel Sanders379d44b2014-07-16 11:52:23 +00008006 // Add the last -mfp32/-mfpxx/-mfp64 or -mfpxx if it is enabled by default.
8007 if (Arg *A = Args.getLastArg(options::OPT_mfp32, options::OPT_mfpxx,
8008 options::OPT_mfp64)) {
8009 A->claim();
8010 A->render(Args, CmdArgs);
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00008011 } else if (mips::shouldUseFPXX(
8012 Args, getToolChain().getTriple(), CPUName, ABIName,
8013 getMipsFloatABI(getToolChain().getDriver(), Args)))
Daniel Sanders379d44b2014-07-16 11:52:23 +00008014 CmdArgs.push_back("-mfpxx");
8015
8016 // Pass on -mmips16 or -mno-mips16. However, the assembler equivalent of
8017 // -mno-mips16 is actually -no-mips16.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008018 if (Arg *A =
8019 Args.getLastArg(options::OPT_mips16, options::OPT_mno_mips16)) {
Daniel Sanders379d44b2014-07-16 11:52:23 +00008020 if (A->getOption().matches(options::OPT_mips16)) {
8021 A->claim();
8022 A->render(Args, CmdArgs);
8023 } else {
8024 A->claim();
8025 CmdArgs.push_back("-no-mips16");
8026 }
8027 }
8028
Simon Atanasyan036d16d2013-04-30 07:47:13 +00008029 Args.AddLastArg(CmdArgs, options::OPT_mmicromips,
8030 options::OPT_mno_micromips);
8031 Args.AddLastArg(CmdArgs, options::OPT_mdsp, options::OPT_mno_dsp);
8032 Args.AddLastArg(CmdArgs, options::OPT_mdspr2, options::OPT_mno_dspr2);
8033
Simon Atanasyanbd986632013-11-26 11:58:04 +00008034 if (Arg *A = Args.getLastArg(options::OPT_mmsa, options::OPT_mno_msa)) {
8035 // Do not use AddLastArg because not all versions of MIPS assembler
8036 // support -mmsa / -mno-msa options.
8037 if (A->getOption().matches(options::OPT_mmsa))
8038 CmdArgs.push_back(Args.MakeArgString("-mmsa"));
8039 }
8040
Daniel Sanders379d44b2014-07-16 11:52:23 +00008041 Args.AddLastArg(CmdArgs, options::OPT_mhard_float,
8042 options::OPT_msoft_float);
8043
Toma Tabacub36d6102015-06-11 12:13:18 +00008044 Args.AddLastArg(CmdArgs, options::OPT_mdouble_float,
8045 options::OPT_msingle_float);
8046
Daniel Sanders379d44b2014-07-16 11:52:23 +00008047 Args.AddLastArg(CmdArgs, options::OPT_modd_spreg,
8048 options::OPT_mno_odd_spreg);
8049
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00008050 NeedsKPIC = true;
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008051 break;
8052 }
8053 case llvm::Triple::systemz: {
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00008054 // Always pass an -march option, since our default of z10 is later
8055 // than the GNU assembler's default.
8056 StringRef CPUName = getSystemZTargetCPU(Args);
8057 CmdArgs.push_back(Args.MakeArgString("-march=" + CPUName));
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008058 break;
8059 }
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00008060 }
8061
James Y Knight5bdf7ab2015-08-19 15:12:02 +00008062 if (NeedsKPIC) {
8063 if (RelocationModel != llvm::Reloc::Static)
8064 CmdArgs.push_back("-KPIC");
8065 }
Rafael Espindola92b00932010-08-10 00:25:48 +00008066
Renato Golina74bbc72015-07-22 15:32:36 +00008067 Args.AddAllArgs(CmdArgs, options::OPT_I);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008068 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Rafael Espindola92b00932010-08-10 00:25:48 +00008069
8070 CmdArgs.push_back("-o");
8071 CmdArgs.push_back(Output.getFilename());
8072
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008073 for (const auto &II : Inputs)
Rafael Espindola92b00932010-08-10 00:25:48 +00008074 CmdArgs.push_back(II.getFilename());
Rafael Espindola92b00932010-08-10 00:25:48 +00008075
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008076 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00008077 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eric Christopher30aa6b62013-06-05 23:58:15 +00008078
8079 // Handle the debug info splitting at object creation time if we're
8080 // creating an object.
8081 // TODO: Currently only works on linux with newer objcopy.
8082 if (Args.hasArg(options::OPT_gsplit_dwarf) &&
Cameron Esfahani556d91e2013-09-14 01:09:11 +00008083 getToolChain().getTriple().isOSLinux())
Eric Christopher30aa6b62013-06-05 23:58:15 +00008084 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output,
Artem Belevichba558952015-05-06 18:20:23 +00008085 SplitDebugName(Args, Inputs[0]));
Rafael Espindola92b00932010-08-10 00:25:48 +00008086}
8087
Benjamin Kramer9299637dc2014-03-04 19:31:42 +00008088static void AddLibgcc(const llvm::Triple &Triple, const Driver &D,
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008089 ArgStringList &CmdArgs, const ArgList &Args) {
Logan Chienc6fd8202012-09-02 09:30:11 +00008090 bool isAndroid = Triple.getEnvironment() == llvm::Triple::Android;
Reid Kleckner0213a472015-07-22 16:01:38 +00008091 bool isCygMing = Triple.isOSCygMing();
Chandler Carruth58d6eb62013-03-04 02:07:55 +00008092 bool StaticLibgcc = Args.hasArg(options::OPT_static_libgcc) ||
8093 Args.hasArg(options::OPT_static);
Hans Wennborg70850d82013-07-18 20:29:38 +00008094 if (!D.CCCIsCXX())
Rafael Espindolacc354322011-10-17 21:39:04 +00008095 CmdArgs.push_back("-lgcc");
8096
Logan Chien3d3373c2012-11-19 12:04:11 +00008097 if (StaticLibgcc || isAndroid) {
Hans Wennborg70850d82013-07-18 20:29:38 +00008098 if (D.CCCIsCXX())
Rafael Espindolacc354322011-10-17 21:39:04 +00008099 CmdArgs.push_back("-lgcc");
8100 } else {
Reid Kleckner0213a472015-07-22 16:01:38 +00008101 if (!D.CCCIsCXX() && !isCygMing)
Rafael Espindolacc354322011-10-17 21:39:04 +00008102 CmdArgs.push_back("--as-needed");
8103 CmdArgs.push_back("-lgcc_s");
Reid Kleckner0213a472015-07-22 16:01:38 +00008104 if (!D.CCCIsCXX() && !isCygMing)
Rafael Espindolacc354322011-10-17 21:39:04 +00008105 CmdArgs.push_back("--no-as-needed");
8106 }
8107
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008108 if (StaticLibgcc && !isAndroid)
Rafael Espindolacc354322011-10-17 21:39:04 +00008109 CmdArgs.push_back("-lgcc_eh");
Hans Wennborg70850d82013-07-18 20:29:38 +00008110 else if (!Args.hasArg(options::OPT_shared) && D.CCCIsCXX())
Rafael Espindolacc354322011-10-17 21:39:04 +00008111 CmdArgs.push_back("-lgcc");
Logan Chien3d3373c2012-11-19 12:04:11 +00008112
8113 // According to Android ABI, we have to link with libdl if we are
8114 // linking with non-static libgcc.
8115 //
8116 // NOTE: This fixes a link error on Android MIPS as well. The non-static
8117 // libgcc for MIPS relies on _Unwind_Find_FDE and dl_iterate_phdr from libdl.
8118 if (isAndroid && !StaticLibgcc)
8119 CmdArgs.push_back("-ldl");
Rafael Espindolacc354322011-10-17 21:39:04 +00008120}
8121
Simon Atanasyan2c590ff2014-08-04 12:57:52 +00008122static std::string getLinuxDynamicLinker(const ArgList &Args,
8123 const toolchains::Linux &ToolChain) {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008124 const llvm::Triple::ArchType Arch = ToolChain.getArch();
8125
Alexey Bataevcf7ae302014-01-23 09:08:32 +00008126 if (ToolChain.getTriple().getEnvironment() == llvm::Triple::Android) {
8127 if (ToolChain.getTriple().isArch64Bit())
8128 return "/system/bin/linker64";
8129 else
8130 return "/system/bin/linker";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008131 } else if (Arch == llvm::Triple::x86 || Arch == llvm::Triple::sparc ||
8132 Arch == llvm::Triple::sparcel)
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008133 return "/lib/ld-linux.so.2";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008134 else if (Arch == llvm::Triple::aarch64)
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008135 return "/lib/ld-linux-aarch64.so.1";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008136 else if (Arch == llvm::Triple::aarch64_be)
Christian Pirkera74c7912014-03-14 12:15:45 +00008137 return "/lib/ld-linux-aarch64_be.so.1";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008138 else if (Arch == llvm::Triple::arm || Arch == llvm::Triple::thumb) {
Renato Golin24ba3e92015-07-27 09:56:37 +00008139 if (ToolChain.getTriple().getEnvironment() == llvm::Triple::GNUEABIHF ||
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00008140 arm::getARMFloatABI(ToolChain, Args) == arm::FloatABI::Hard)
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008141 return "/lib/ld-linux-armhf.so.3";
8142 else
8143 return "/lib/ld-linux.so.3";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008144 } else if (Arch == llvm::Triple::armeb || Arch == llvm::Triple::thumbeb) {
8145 // TODO: check which dynamic linker name.
Renato Golin24ba3e92015-07-27 09:56:37 +00008146 if (ToolChain.getTriple().getEnvironment() == llvm::Triple::GNUEABIHF ||
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00008147 arm::getARMFloatABI(ToolChain, Args) == arm::FloatABI::Hard)
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008148 return "/lib/ld-linux-armhf.so.3";
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00008149 else
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008150 return "/lib/ld-linux.so.3";
8151 } else if (Arch == llvm::Triple::mips || Arch == llvm::Triple::mipsel ||
8152 Arch == llvm::Triple::mips64 || Arch == llvm::Triple::mips64el) {
Vasileios Kalintiris712f0882015-10-02 14:38:23 +00008153 std::string LibDir =
8154 "/lib" + mips::getMipsABILibSuffix(Args, ToolChain.getTriple());
Simon Atanasyand95c67d2014-08-13 14:34:14 +00008155 StringRef LibName;
Vasileios Kalintiris712f0882015-10-02 14:38:23 +00008156 bool IsNaN2008 = mips::isNaN2008(Args, ToolChain.getTriple());
Simon Atanasyand95c67d2014-08-13 14:34:14 +00008157 if (mips::isUCLibc(Args))
8158 LibName = IsNaN2008 ? "ld-uClibc-mipsn8.so.0" : "ld-uClibc.so.0";
Vasileios Kalintiris712f0882015-10-02 14:38:23 +00008159 else if (!ToolChain.getTriple().hasEnvironment()) {
8160 bool LE = (ToolChain.getTriple().getArch() == llvm::Triple::mipsel) ||
8161 (ToolChain.getTriple().getArch() == llvm::Triple::mips64el);
8162 LibName = LE ? "ld-musl-mipsel.so.1" : "ld-musl-mips.so.1";
8163 } else
Simon Atanasyand95c67d2014-08-13 14:34:14 +00008164 LibName = IsNaN2008 ? "ld-linux-mipsn8.so.1" : "ld.so.1";
Simon Atanasyan2c590ff2014-08-04 12:57:52 +00008165
8166 return (LibDir + "/" + LibName).str();
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008167 } else if (Arch == llvm::Triple::ppc)
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008168 return "/lib/ld.so.1";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008169 else if (Arch == llvm::Triple::ppc64) {
Ulrich Weigand8afad612014-07-28 13:17:52 +00008170 if (ppc::hasPPCAbiArg(Args, "elfv2"))
8171 return "/lib64/ld64.so.2";
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008172 return "/lib64/ld64.so.1";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008173 } else if (Arch == llvm::Triple::ppc64le) {
Ulrich Weigand8afad612014-07-28 13:17:52 +00008174 if (ppc::hasPPCAbiArg(Args, "elfv1"))
8175 return "/lib64/ld64.so.1";
Ulrich Weigand68e902c2014-06-20 14:19:02 +00008176 return "/lib64/ld64.so.2";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008177 } else if (Arch == llvm::Triple::systemz)
Sylvestre Ledruc0babf22015-08-28 12:26:09 +00008178 return "/lib/ld64.so.1";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008179 else if (Arch == llvm::Triple::sparcv9)
Jakob Stoklund Olesen73cb84c2014-01-10 08:18:34 +00008180 return "/lib64/ld-linux.so.2";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008181 else if (Arch == llvm::Triple::x86_64 &&
Zinovy Nis1db95732014-07-10 15:27:19 +00008182 ToolChain.getTriple().getEnvironment() == llvm::Triple::GNUX32)
8183 return "/libx32/ld-linux-x32.so.2";
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008184 else
8185 return "/lib64/ld-linux-x86-64.so.2";
8186}
8187
Renato Golinc4b49242014-02-13 10:01:16 +00008188static void AddRunTimeLibs(const ToolChain &TC, const Driver &D,
Saleem Abdulrasool2e46ebe2014-12-30 22:52:06 +00008189 ArgStringList &CmdArgs, const ArgList &Args) {
Renato Golinc4b49242014-02-13 10:01:16 +00008190 // Make use of compiler-rt if --rtlib option is used
8191 ToolChain::RuntimeLibType RLT = TC.GetRuntimeLibType(Args);
8192
Saleem Abdulrasool8d7ade72014-12-30 02:10:36 +00008193 switch (RLT) {
Renato Golinc4b49242014-02-13 10:01:16 +00008194 case ToolChain::RLT_CompilerRT:
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00008195 switch (TC.getTriple().getOS()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008196 default:
8197 llvm_unreachable("unsupported OS");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00008198 case llvm::Triple::Win32:
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00008199 case llvm::Triple::Linux:
Saleem Abdulrasool8d7ade72014-12-30 02:10:36 +00008200 addClangRT(TC, Args, CmdArgs);
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00008201 break;
8202 }
Renato Golinc4b49242014-02-13 10:01:16 +00008203 break;
8204 case ToolChain::RLT_Libgcc:
8205 AddLibgcc(TC.getTriple(), D, CmdArgs, Args);
8206 break;
Renato Golinc4b49242014-02-13 10:01:16 +00008207 }
8208}
8209
Rafael Espindola1e085772014-08-15 17:14:35 +00008210static const char *getLDMOption(const llvm::Triple &T, const ArgList &Args) {
8211 switch (T.getArch()) {
8212 case llvm::Triple::x86:
8213 return "elf_i386";
8214 case llvm::Triple::aarch64:
8215 return "aarch64linux";
8216 case llvm::Triple::aarch64_be:
8217 return "aarch64_be_linux";
8218 case llvm::Triple::arm:
8219 case llvm::Triple::thumb:
8220 return "armelf_linux_eabi";
8221 case llvm::Triple::armeb:
8222 case llvm::Triple::thumbeb:
8223 return "armebelf_linux_eabi"; /* TODO: check which NAME. */
8224 case llvm::Triple::ppc:
8225 return "elf32ppclinux";
8226 case llvm::Triple::ppc64:
8227 return "elf64ppc";
8228 case llvm::Triple::ppc64le:
8229 return "elf64lppc";
8230 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00008231 case llvm::Triple::sparcel:
Rafael Espindola1e085772014-08-15 17:14:35 +00008232 return "elf32_sparc";
8233 case llvm::Triple::sparcv9:
8234 return "elf64_sparc";
8235 case llvm::Triple::mips:
8236 return "elf32btsmip";
8237 case llvm::Triple::mipsel:
8238 return "elf32ltsmip";
8239 case llvm::Triple::mips64:
8240 if (mips::hasMipsAbiArg(Args, "n32"))
8241 return "elf32btsmipn32";
8242 return "elf64btsmip";
8243 case llvm::Triple::mips64el:
8244 if (mips::hasMipsAbiArg(Args, "n32"))
8245 return "elf32ltsmipn32";
8246 return "elf64ltsmip";
8247 case llvm::Triple::systemz:
8248 return "elf64_s390";
8249 case llvm::Triple::x86_64:
8250 if (T.getEnvironment() == llvm::Triple::GNUX32)
8251 return "elf32_x86_64";
8252 return "elf_x86_64";
8253 default:
8254 llvm_unreachable("Unexpected arch");
8255 }
8256}
8257
Douglas Katzman95354292015-06-23 20:42:09 +00008258void gnutools::Linker::ConstructJob(Compilation &C, const JobAction &JA,
8259 const InputInfo &Output,
8260 const InputInfoList &Inputs,
8261 const ArgList &Args,
8262 const char *LinkingOutput) const {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008263 const toolchains::Linux &ToolChain =
8264 static_cast<const toolchains::Linux &>(getToolChain());
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008265 const Driver &D = ToolChain.getDriver();
James Y Knight2db38f32015-08-15 03:45:25 +00008266
8267 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
8268 llvm::Triple Triple = llvm::Triple(TripleStr);
8269
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008270 const llvm::Triple::ArchType Arch = ToolChain.getArch();
NAKAMURA Takumi557fb622014-06-29 16:00:11 +00008271 const bool isAndroid =
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008272 ToolChain.getTriple().getEnvironment() == llvm::Triple::Android;
Peter Collingbourne54d770c2013-04-09 04:35:11 +00008273 const bool IsPIE =
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008274 !Args.hasArg(options::OPT_shared) && !Args.hasArg(options::OPT_static) &&
8275 (Args.hasArg(options::OPT_pie) || ToolChain.isPIEDefault());
Vasileios Kalintiris712f0882015-10-02 14:38:23 +00008276 const bool HasCRTBeginEndFiles =
8277 ToolChain.getTriple().hasEnvironment() ||
8278 (ToolChain.getTriple().getVendor() != llvm::Triple::MipsTechnologies);
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008279
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008280 ArgStringList CmdArgs;
8281
Rafael Espindolad1002f62010-11-15 18:28:16 +00008282 // Silence warning for "clang -g foo.o -o foo"
8283 Args.ClaimAllArgs(options::OPT_g_Group);
Rafael Espindolad95a8122011-03-01 05:25:27 +00008284 // and "clang -emit-llvm foo.o -o foo"
8285 Args.ClaimAllArgs(options::OPT_emit_llvm);
David Chisnall5f99f482012-07-29 15:24:44 +00008286 // and for "clang -w foo.o -o foo". Other warning options are already
Rafael Espindolaf92614c2010-11-17 20:37:10 +00008287 // handled somewhere else.
8288 Args.ClaimAllArgs(options::OPT_w);
Rafael Espindolad1002f62010-11-15 18:28:16 +00008289
Vasileios Kalintiris712f0882015-10-02 14:38:23 +00008290 if (llvm::sys::path::filename(ToolChain.Linker) == "lld") {
8291 CmdArgs.push_back("-flavor");
8292 CmdArgs.push_back("gnu");
8293 CmdArgs.push_back("-target");
8294 CmdArgs.push_back(Args.MakeArgString(getToolChain().getTripleString()));
8295 }
8296
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00008297 if (!D.SysRoot.empty())
8298 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008299
Peter Collingbourne54d770c2013-04-09 04:35:11 +00008300 if (IsPIE)
Rafael Espindolad47ac232010-11-17 22:26:15 +00008301 CmdArgs.push_back("-pie");
8302
Rafael Espindola1c76c592010-11-07 22:57:16 +00008303 if (Args.hasArg(options::OPT_rdynamic))
8304 CmdArgs.push_back("-export-dynamic");
8305
Rafael Espindola34d77dc2010-11-11 19:34:42 +00008306 if (Args.hasArg(options::OPT_s))
8307 CmdArgs.push_back("-s");
8308
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008309 if (Arch == llvm::Triple::armeb || Arch == llvm::Triple::thumbeb)
James Y Knight2db38f32015-08-15 03:45:25 +00008310 arm::appendEBLinkFlags(Args, CmdArgs, Triple);
Joerg Sonnenberger1689d3f2015-01-28 23:30:39 +00008311
NAKAMURA Takumi557fb622014-06-29 16:00:11 +00008312 for (const auto &Opt : ToolChain.ExtraOpts)
8313 CmdArgs.push_back(Opt.c_str());
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008314
8315 if (!Args.hasArg(options::OPT_static)) {
8316 CmdArgs.push_back("--eh-frame-hdr");
8317 }
8318
8319 CmdArgs.push_back("-m");
Rafael Espindola1e085772014-08-15 17:14:35 +00008320 CmdArgs.push_back(getLDMOption(ToolChain.getTriple(), Args));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008321
8322 if (Args.hasArg(options::OPT_static)) {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008323 if (Arch == llvm::Triple::arm || Arch == llvm::Triple::armeb ||
8324 Arch == llvm::Triple::thumb || Arch == llvm::Triple::thumbeb)
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008325 CmdArgs.push_back("-Bstatic");
8326 else
8327 CmdArgs.push_back("-static");
8328 } else if (Args.hasArg(options::OPT_shared)) {
8329 CmdArgs.push_back("-shared");
8330 }
8331
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008332 if (Arch == llvm::Triple::arm || Arch == llvm::Triple::armeb ||
8333 Arch == llvm::Triple::thumb || Arch == llvm::Triple::thumbeb ||
NAKAMURA Takumi557fb622014-06-29 16:00:11 +00008334 (!Args.hasArg(options::OPT_static) &&
8335 !Args.hasArg(options::OPT_shared))) {
8336 CmdArgs.push_back("-dynamic-linker");
8337 CmdArgs.push_back(Args.MakeArgString(
8338 D.DyldPrefix + getLinuxDynamicLinker(Args, ToolChain)));
8339 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008340
8341 CmdArgs.push_back("-o");
8342 CmdArgs.push_back(Output.getFilename());
8343
Rafael Espindola81937ec2010-12-01 01:52:43 +00008344 if (!Args.hasArg(options::OPT_nostdlib) &&
8345 !Args.hasArg(options::OPT_nostartfiles)) {
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008346 if (!isAndroid) {
Craig Topper92fc2df2014-05-17 16:56:41 +00008347 const char *crt1 = nullptr;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008348 if (!Args.hasArg(options::OPT_shared)) {
Eric Christopherac021742013-06-07 23:25:01 +00008349 if (Args.hasArg(options::OPT_pg))
8350 crt1 = "gcrt1.o";
8351 else if (IsPIE)
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008352 crt1 = "Scrt1.o";
8353 else
8354 crt1 = "crt1.o";
8355 }
8356 if (crt1)
8357 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crt1)));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008358
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008359 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
8360 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008361
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008362 const char *crtbegin;
8363 if (Args.hasArg(options::OPT_static))
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008364 crtbegin = isAndroid ? "crtbegin_static.o" : "crtbeginT.o";
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00008365 else if (Args.hasArg(options::OPT_shared))
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008366 crtbegin = isAndroid ? "crtbegin_so.o" : "crtbeginS.o";
Peter Collingbourne54d770c2013-04-09 04:35:11 +00008367 else if (IsPIE)
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00008368 crtbegin = isAndroid ? "crtbegin_dynamic.o" : "crtbeginS.o";
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008369 else
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008370 crtbegin = isAndroid ? "crtbegin_dynamic.o" : "crtbegin.o";
Vasileios Kalintiris712f0882015-10-02 14:38:23 +00008371
8372 if (HasCRTBeginEndFiles)
8373 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtbegin)));
Benjamin Kramer058666a2012-10-04 19:42:20 +00008374
8375 // Add crtfastmath.o if available and fast math is enabled.
8376 ToolChain.AddFastMathRuntimeIfAvailable(Args, CmdArgs);
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008377 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008378
8379 Args.AddAllArgs(CmdArgs, options::OPT_L);
Reid Kleckner69071442014-06-26 01:08:54 +00008380 Args.AddAllArgs(CmdArgs, options::OPT_u);
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008381
Benjamin Kramer22c68ef2014-09-11 14:13:49 +00008382 const ToolChain::path_list &Paths = ToolChain.getFilePaths();
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008383
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008384 for (const auto &Path : Paths)
8385 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008386
Alexey Samsonov907880e2015-06-19 19:57:46 +00008387 if (D.IsUsingLTO(Args))
Alp Tokerce365ca2013-12-02 12:43:03 +00008388 AddGoldPlugin(ToolChain, Args, CmdArgs);
Chandler Carruth953fb082013-01-13 11:46:33 +00008389
Nick Lewycky2fe6aab2012-08-17 03:39:16 +00008390 if (Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
8391 CmdArgs.push_back("--no-demangle");
8392
Alexey Samsonov52550342014-09-15 19:58:40 +00008393 bool NeedsSanitizerDeps = addSanitizerRuntimes(ToolChain, Args, CmdArgs);
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008394 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
Chandler Carruthe4458b32013-06-24 09:38:45 +00008395 // The profile runtime also needs access to system libraries.
Alexey Samsonov7811d192014-02-20 13:57:37 +00008396 addProfileRT(getToolChain(), Args, CmdArgs);
Chandler Carruthe4458b32013-06-24 09:38:45 +00008397
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008398 if (D.CCCIsCXX() && !Args.hasArg(options::OPT_nostdlib) &&
Chandler Carruth94a32012012-05-14 18:31:18 +00008399 !Args.hasArg(options::OPT_nodefaultlibs)) {
Rafael Espindola70b8d762011-10-17 22:14:51 +00008400 bool OnlyLibstdcxxStatic = Args.hasArg(options::OPT_static_libstdcxx) &&
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008401 !Args.hasArg(options::OPT_static);
Rafael Espindola70b8d762011-10-17 22:14:51 +00008402 if (OnlyLibstdcxxStatic)
8403 CmdArgs.push_back("-Bstatic");
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008404 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
Rafael Espindola70b8d762011-10-17 22:14:51 +00008405 if (OnlyLibstdcxxStatic)
8406 CmdArgs.push_back("-Bdynamic");
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008407 CmdArgs.push_back("-lm");
8408 }
Chandler Carruth7e7dd472015-03-07 10:01:29 +00008409 // Silence warnings when linking C code with a C++ '-stdlib' argument.
8410 Args.ClaimAllArgs(options::OPT_stdlib_EQ);
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008411
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008412 if (!Args.hasArg(options::OPT_nostdlib)) {
Chandler Carruth94a32012012-05-14 18:31:18 +00008413 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
8414 if (Args.hasArg(options::OPT_static))
8415 CmdArgs.push_back("--start-group");
Nick Lewycky97864da2011-06-04 06:27:06 +00008416
Alexey Samsonov52550342014-09-15 19:58:40 +00008417 if (NeedsSanitizerDeps)
8418 linkSanitizerRuntimeDeps(ToolChain, CmdArgs);
8419
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00008420 bool WantPthread = Args.hasArg(options::OPT_pthread) ||
8421 Args.hasArg(options::OPT_pthreads);
8422
8423 if (Args.hasFlag(options::OPT_fopenmp, options::OPT_fopenmp_EQ,
8424 options::OPT_fno_openmp, false)) {
8425 // OpenMP runtimes implies pthreads when using the GNU toolchain.
8426 // FIXME: Does this really make sense for all GNU toolchains?
8427 WantPthread = true;
8428
8429 // Also link the particular OpenMP runtimes.
8430 switch (getOpenMPRuntime(ToolChain, Args)) {
8431 case OMPRT_OMP:
8432 CmdArgs.push_back("-lomp");
8433 break;
8434 case OMPRT_GOMP:
Richard Smith31d1de22015-05-20 22:48:44 +00008435 CmdArgs.push_back("-lgomp");
8436
8437 // FIXME: Exclude this for platforms with libgomp that don't require
8438 // librt. Most modern Linux platforms require it, but some may not.
8439 CmdArgs.push_back("-lrt");
8440 break;
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00008441 case OMPRT_IOMP5:
Richard Smith31d1de22015-05-20 22:48:44 +00008442 CmdArgs.push_back("-liomp5");
8443 break;
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00008444 case OMPRT_Unknown:
8445 // Already diagnosed.
Richard Smith31d1de22015-05-20 22:48:44 +00008446 break;
8447 }
Chandler Carruth01538002013-01-17 13:19:29 +00008448 }
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00008449
Renato Golinc4b49242014-02-13 10:01:16 +00008450 AddRunTimeLibs(ToolChain, D, CmdArgs, Args);
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008451
Richard Smith31d1de22015-05-20 22:48:44 +00008452 if (WantPthread && !isAndroid)
Chandler Carruth94a32012012-05-14 18:31:18 +00008453 CmdArgs.push_back("-lpthread");
8454
8455 CmdArgs.push_back("-lc");
8456
8457 if (Args.hasArg(options::OPT_static))
8458 CmdArgs.push_back("--end-group");
8459 else
Renato Golinc4b49242014-02-13 10:01:16 +00008460 AddRunTimeLibs(ToolChain, D, CmdArgs, Args);
Chandler Carruth94a32012012-05-14 18:31:18 +00008461 }
Rafael Espindolad47ac232010-11-17 22:26:15 +00008462
Rafael Espindola81937ec2010-12-01 01:52:43 +00008463 if (!Args.hasArg(options::OPT_nostartfiles)) {
8464 const char *crtend;
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00008465 if (Args.hasArg(options::OPT_shared))
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008466 crtend = isAndroid ? "crtend_so.o" : "crtendS.o";
Peter Collingbourne54d770c2013-04-09 04:35:11 +00008467 else if (IsPIE)
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00008468 crtend = isAndroid ? "crtend_android.o" : "crtendS.o";
Rafael Espindola81937ec2010-12-01 01:52:43 +00008469 else
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008470 crtend = isAndroid ? "crtend_android.o" : "crtend.o";
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008471
Vasileios Kalintiris712f0882015-10-02 14:38:23 +00008472 if (HasCRTBeginEndFiles)
8473 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtend)));
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008474 if (!isAndroid)
8475 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
Rafael Espindola81937ec2010-12-01 01:52:43 +00008476 }
Vasileios Kalintiris712f0882015-10-02 14:38:23 +00008477 } else if (Args.hasArg(options::OPT_rtlib_EQ))
8478 AddRunTimeLibs(ToolChain, D, CmdArgs, Args);
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008479
Justin Bognerd3371d82015-07-17 03:35:54 +00008480 C.addCommand(llvm::make_unique<Command>(JA, *this, ToolChain.Linker.c_str(),
8481 CmdArgs, Inputs));
Saleem Abdulrasoola4a474b2014-06-29 06:11:14 +00008482}
8483
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008484// NaCl ARM assembly (inline or standalone) can be written with a set of macros
8485// for the various SFI requirements like register masking. The assembly tool
8486// inserts the file containing the macros as an input into all the assembly
8487// jobs.
Douglas Katzman95354292015-06-23 20:42:09 +00008488void nacltools::AssemblerARM::ConstructJob(Compilation &C, const JobAction &JA,
8489 const InputInfo &Output,
8490 const InputInfoList &Inputs,
8491 const ArgList &Args,
8492 const char *LinkingOutput) const {
Douglas Katzman54366072015-07-27 16:53:08 +00008493 const toolchains::NaClToolChain &ToolChain =
8494 static_cast<const toolchains::NaClToolChain &>(getToolChain());
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008495 InputInfo NaClMacros(ToolChain.GetNaClArmMacrosPath(), types::TY_PP_Asm,
8496 "nacl-arm-macros.s");
8497 InputInfoList NewInputs;
8498 NewInputs.push_back(NaClMacros);
8499 NewInputs.append(Inputs.begin(), Inputs.end());
Douglas Katzman95354292015-06-23 20:42:09 +00008500 gnutools::Assembler::ConstructJob(C, JA, Output, NewInputs, Args,
8501 LinkingOutput);
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008502}
8503
Douglas Katzman750cfc52015-06-29 18:42:16 +00008504// This is quite similar to gnutools::Linker::ConstructJob with changes that
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008505// we use static by default, do not yet support sanitizers or LTO, and a few
8506// others. Eventually we can support more of that and hopefully migrate back
Douglas Katzman750cfc52015-06-29 18:42:16 +00008507// to gnutools::Linker.
Douglas Katzman95354292015-06-23 20:42:09 +00008508void nacltools::Linker::ConstructJob(Compilation &C, const JobAction &JA,
8509 const InputInfo &Output,
8510 const InputInfoList &Inputs,
8511 const ArgList &Args,
8512 const char *LinkingOutput) const {
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008513
Douglas Katzman54366072015-07-27 16:53:08 +00008514 const toolchains::NaClToolChain &ToolChain =
8515 static_cast<const toolchains::NaClToolChain &>(getToolChain());
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008516 const Driver &D = ToolChain.getDriver();
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008517 const llvm::Triple::ArchType Arch = ToolChain.getArch();
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008518 const bool IsStatic =
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008519 !Args.hasArg(options::OPT_dynamic) && !Args.hasArg(options::OPT_shared);
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008520
8521 ArgStringList CmdArgs;
8522
8523 // Silence warning for "clang -g foo.o -o foo"
8524 Args.ClaimAllArgs(options::OPT_g_Group);
8525 // and "clang -emit-llvm foo.o -o foo"
8526 Args.ClaimAllArgs(options::OPT_emit_llvm);
8527 // and for "clang -w foo.o -o foo". Other warning options are already
8528 // handled somewhere else.
8529 Args.ClaimAllArgs(options::OPT_w);
8530
8531 if (!D.SysRoot.empty())
8532 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
8533
8534 if (Args.hasArg(options::OPT_rdynamic))
8535 CmdArgs.push_back("-export-dynamic");
8536
8537 if (Args.hasArg(options::OPT_s))
8538 CmdArgs.push_back("-s");
8539
Douglas Katzman54366072015-07-27 16:53:08 +00008540 // NaClToolChain doesn't have ExtraOpts like Linux; the only relevant flag
8541 // from there is --build-id, which we do want.
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008542 CmdArgs.push_back("--build-id");
8543
8544 if (!IsStatic)
8545 CmdArgs.push_back("--eh-frame-hdr");
8546
8547 CmdArgs.push_back("-m");
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008548 if (Arch == llvm::Triple::x86)
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008549 CmdArgs.push_back("elf_i386_nacl");
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008550 else if (Arch == llvm::Triple::arm)
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008551 CmdArgs.push_back("armelf_nacl");
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008552 else if (Arch == llvm::Triple::x86_64)
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008553 CmdArgs.push_back("elf_x86_64_nacl");
Petar Jovanovic26a4a402015-07-08 13:07:31 +00008554 else if (Arch == llvm::Triple::mipsel)
8555 CmdArgs.push_back("mipselelf_nacl");
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008556 else
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008557 D.Diag(diag::err_target_unsupported_arch) << ToolChain.getArchName()
8558 << "Native Client";
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008559
8560 if (IsStatic)
8561 CmdArgs.push_back("-static");
8562 else if (Args.hasArg(options::OPT_shared))
8563 CmdArgs.push_back("-shared");
8564
8565 CmdArgs.push_back("-o");
8566 CmdArgs.push_back(Output.getFilename());
8567 if (!Args.hasArg(options::OPT_nostdlib) &&
8568 !Args.hasArg(options::OPT_nostartfiles)) {
8569 if (!Args.hasArg(options::OPT_shared))
8570 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crt1.o")));
8571 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
8572
8573 const char *crtbegin;
8574 if (IsStatic)
8575 crtbegin = "crtbeginT.o";
8576 else if (Args.hasArg(options::OPT_shared))
8577 crtbegin = "crtbeginS.o";
8578 else
8579 crtbegin = "crtbegin.o";
8580 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtbegin)));
8581 }
8582
8583 Args.AddAllArgs(CmdArgs, options::OPT_L);
8584 Args.AddAllArgs(CmdArgs, options::OPT_u);
8585
8586 const ToolChain::path_list &Paths = ToolChain.getFilePaths();
8587
8588 for (const auto &Path : Paths)
8589 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
8590
8591 if (Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
8592 CmdArgs.push_back("--no-demangle");
8593
8594 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
8595
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008596 if (D.CCCIsCXX() && !Args.hasArg(options::OPT_nostdlib) &&
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008597 !Args.hasArg(options::OPT_nodefaultlibs)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008598 bool OnlyLibstdcxxStatic =
8599 Args.hasArg(options::OPT_static_libstdcxx) && !IsStatic;
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008600 if (OnlyLibstdcxxStatic)
8601 CmdArgs.push_back("-Bstatic");
8602 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
8603 if (OnlyLibstdcxxStatic)
8604 CmdArgs.push_back("-Bdynamic");
8605 CmdArgs.push_back("-lm");
8606 }
8607
8608 if (!Args.hasArg(options::OPT_nostdlib)) {
8609 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
8610 // Always use groups, since it has no effect on dynamic libraries.
8611 CmdArgs.push_back("--start-group");
8612 CmdArgs.push_back("-lc");
8613 // NaCl's libc++ currently requires libpthread, so just always include it
8614 // in the group for C++.
8615 if (Args.hasArg(options::OPT_pthread) ||
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008616 Args.hasArg(options::OPT_pthreads) || D.CCCIsCXX()) {
Petar Jovanovic26a4a402015-07-08 13:07:31 +00008617 // Gold, used by Mips, handles nested groups differently than ld, and
8618 // without '-lnacl' it prefers symbols from libpthread.a over libnacl.a,
8619 // which is not a desired behaviour here.
8620 // See https://sourceware.org/ml/binutils/2015-03/msg00034.html
8621 if (getToolChain().getArch() == llvm::Triple::mipsel)
8622 CmdArgs.push_back("-lnacl");
8623
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008624 CmdArgs.push_back("-lpthread");
8625 }
8626
8627 CmdArgs.push_back("-lgcc");
8628 CmdArgs.push_back("--as-needed");
8629 if (IsStatic)
8630 CmdArgs.push_back("-lgcc_eh");
8631 else
8632 CmdArgs.push_back("-lgcc_s");
8633 CmdArgs.push_back("--no-as-needed");
Petar Jovanovic26a4a402015-07-08 13:07:31 +00008634
8635 // Mips needs to create and use pnacl_legacy library that contains
8636 // definitions from bitcode/pnaclmm.c and definitions for
8637 // __nacl_tp_tls_offset() and __nacl_tp_tdb_offset().
8638 if (getToolChain().getArch() == llvm::Triple::mipsel)
8639 CmdArgs.push_back("-lpnacl_legacy");
8640
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008641 CmdArgs.push_back("--end-group");
8642 }
8643
8644 if (!Args.hasArg(options::OPT_nostartfiles)) {
8645 const char *crtend;
8646 if (Args.hasArg(options::OPT_shared))
8647 crtend = "crtendS.o";
8648 else
8649 crtend = "crtend.o";
8650
8651 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtend)));
8652 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
8653 }
8654 }
8655
Justin Bognerd3371d82015-07-17 03:35:54 +00008656 C.addCommand(llvm::make_unique<Command>(JA, *this, ToolChain.Linker.c_str(),
8657 CmdArgs, Inputs));
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008658}
8659
Douglas Katzman95354292015-06-23 20:42:09 +00008660void minix::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
8661 const InputInfo &Output,
8662 const InputInfoList &Inputs,
8663 const ArgList &Args,
8664 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00008665 claimNoWarnArgs(Args);
Chris Lattner3e2ee142010-07-07 16:01:42 +00008666 ArgStringList CmdArgs;
8667
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008668 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Chris Lattner3e2ee142010-07-07 16:01:42 +00008669
8670 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00008671 CmdArgs.push_back(Output.getFilename());
Chris Lattner3e2ee142010-07-07 16:01:42 +00008672
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008673 for (const auto &II : Inputs)
Daniel Dunbarb440f562010-08-02 02:38:21 +00008674 CmdArgs.push_back(II.getFilename());
Chris Lattner3e2ee142010-07-07 16:01:42 +00008675
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008676 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00008677 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Chris Lattner3e2ee142010-07-07 16:01:42 +00008678}
8679
Douglas Katzman95354292015-06-23 20:42:09 +00008680void minix::Linker::ConstructJob(Compilation &C, const JobAction &JA,
8681 const InputInfo &Output,
8682 const InputInfoList &Inputs,
8683 const ArgList &Args,
8684 const char *LinkingOutput) const {
Chris Lattner3e2ee142010-07-07 16:01:42 +00008685 const Driver &D = getToolChain().getDriver();
8686 ArgStringList CmdArgs;
8687
Daniel Dunbarb440f562010-08-02 02:38:21 +00008688 if (Output.isFilename()) {
Chris Lattner3e2ee142010-07-07 16:01:42 +00008689 CmdArgs.push_back("-o");
8690 CmdArgs.push_back(Output.getFilename());
8691 } else {
8692 assert(Output.isNothing() && "Invalid output.");
8693 }
8694
8695 if (!Args.hasArg(options::OPT_nostdlib) &&
Eli Friedman83de5132011-12-08 23:54:21 +00008696 !Args.hasArg(options::OPT_nostartfiles)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008697 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crt1.o")));
8698 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
8699 CmdArgs.push_back(
8700 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
8701 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
Eli Friedman83de5132011-12-08 23:54:21 +00008702 }
Chris Lattner3e2ee142010-07-07 16:01:42 +00008703
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00008704 Args.AddAllArgs(CmdArgs,
8705 {options::OPT_L, options::OPT_T_Group, options::OPT_e});
Chris Lattner3e2ee142010-07-07 16:01:42 +00008706
Daniel Dunbar54423b22010-09-17 00:24:54 +00008707 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Chris Lattner3e2ee142010-07-07 16:01:42 +00008708
Alexey Samsonov7811d192014-02-20 13:57:37 +00008709 addProfileRT(getToolChain(), Args, CmdArgs);
Eli Friedman83de5132011-12-08 23:54:21 +00008710
Chris Lattner3e2ee142010-07-07 16:01:42 +00008711 if (!Args.hasArg(options::OPT_nostdlib) &&
8712 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00008713 if (D.CCCIsCXX()) {
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00008714 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Chris Lattner3e2ee142010-07-07 16:01:42 +00008715 CmdArgs.push_back("-lm");
8716 }
Chris Lattner3e2ee142010-07-07 16:01:42 +00008717 }
8718
8719 if (!Args.hasArg(options::OPT_nostdlib) &&
8720 !Args.hasArg(options::OPT_nostartfiles)) {
Eli Friedman83de5132011-12-08 23:54:21 +00008721 if (Args.hasArg(options::OPT_pthread))
8722 CmdArgs.push_back("-lpthread");
8723 CmdArgs.push_back("-lc");
8724 CmdArgs.push_back("-lCompilerRT-Generic");
8725 CmdArgs.push_back("-L/usr/pkg/compiler-rt/lib");
8726 CmdArgs.push_back(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008727 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Chris Lattner3e2ee142010-07-07 16:01:42 +00008728 }
8729
Logan Chieneb9162f2014-06-26 14:23:45 +00008730 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00008731 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Chris Lattner3e2ee142010-07-07 16:01:42 +00008732}
8733
Daniel Dunbarcc912342009-05-02 18:28:39 +00008734/// DragonFly Tools
8735
8736// For now, DragonFly Assemble does just about the same as for
8737// FreeBSD, but this may change soon.
Douglas Katzman95354292015-06-23 20:42:09 +00008738void dragonfly::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
8739 const InputInfo &Output,
8740 const InputInfoList &Inputs,
8741 const ArgList &Args,
8742 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00008743 claimNoWarnArgs(Args);
Daniel Dunbarcc912342009-05-02 18:28:39 +00008744 ArgStringList CmdArgs;
8745
8746 // When building 32-bit code on DragonFly/pc64, we have to explicitly
8747 // instruct as in the base system to assemble 32-bit code.
Rafael Espindola35ca7d92012-10-07 04:44:33 +00008748 if (getToolChain().getArch() == llvm::Triple::x86)
Daniel Dunbarcc912342009-05-02 18:28:39 +00008749 CmdArgs.push_back("--32");
8750
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008751 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbarcc912342009-05-02 18:28:39 +00008752
8753 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00008754 CmdArgs.push_back(Output.getFilename());
Daniel Dunbarcc912342009-05-02 18:28:39 +00008755
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008756 for (const auto &II : Inputs)
Daniel Dunbarb440f562010-08-02 02:38:21 +00008757 CmdArgs.push_back(II.getFilename());
Daniel Dunbarcc912342009-05-02 18:28:39 +00008758
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008759 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00008760 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbarcc912342009-05-02 18:28:39 +00008761}
8762
Douglas Katzman95354292015-06-23 20:42:09 +00008763void dragonfly::Linker::ConstructJob(Compilation &C, const JobAction &JA,
8764 const InputInfo &Output,
8765 const InputInfoList &Inputs,
8766 const ArgList &Args,
8767 const char *LinkingOutput) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00008768 const Driver &D = getToolChain().getDriver();
Daniel Dunbarcc912342009-05-02 18:28:39 +00008769 ArgStringList CmdArgs;
Rafael Espindola611505f2014-09-11 18:10:13 +00008770 bool UseGCC47 = llvm::sys::fs::exists("/usr/lib/gcc47");
John McCall65b8da02013-04-11 22:55:55 +00008771
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00008772 if (!D.SysRoot.empty())
8773 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
8774
John McCall65b8da02013-04-11 22:55:55 +00008775 CmdArgs.push_back("--eh-frame-hdr");
Daniel Dunbarcc912342009-05-02 18:28:39 +00008776 if (Args.hasArg(options::OPT_static)) {
8777 CmdArgs.push_back("-Bstatic");
8778 } else {
John McCall65b8da02013-04-11 22:55:55 +00008779 if (Args.hasArg(options::OPT_rdynamic))
8780 CmdArgs.push_back("-export-dynamic");
Daniel Dunbarcc912342009-05-02 18:28:39 +00008781 if (Args.hasArg(options::OPT_shared))
8782 CmdArgs.push_back("-Bshareable");
8783 else {
8784 CmdArgs.push_back("-dynamic-linker");
8785 CmdArgs.push_back("/usr/libexec/ld-elf.so.2");
8786 }
John McCall65b8da02013-04-11 22:55:55 +00008787 CmdArgs.push_back("--hash-style=both");
Daniel Dunbarcc912342009-05-02 18:28:39 +00008788 }
8789
8790 // When building 32-bit code on DragonFly/pc64, we have to explicitly
8791 // instruct ld in the base system to link 32-bit code.
Rafael Espindola35ca7d92012-10-07 04:44:33 +00008792 if (getToolChain().getArch() == llvm::Triple::x86) {
Daniel Dunbarcc912342009-05-02 18:28:39 +00008793 CmdArgs.push_back("-m");
8794 CmdArgs.push_back("elf_i386");
8795 }
8796
Daniel Dunbarb440f562010-08-02 02:38:21 +00008797 if (Output.isFilename()) {
Daniel Dunbarcc912342009-05-02 18:28:39 +00008798 CmdArgs.push_back("-o");
8799 CmdArgs.push_back(Output.getFilename());
8800 } else {
8801 assert(Output.isNothing() && "Invalid output.");
8802 }
8803
8804 if (!Args.hasArg(options::OPT_nostdlib) &&
8805 !Args.hasArg(options::OPT_nostartfiles)) {
8806 if (!Args.hasArg(options::OPT_shared)) {
John McCall65b8da02013-04-11 22:55:55 +00008807 if (Args.hasArg(options::OPT_pg))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008808 CmdArgs.push_back(
8809 Args.MakeArgString(getToolChain().GetFilePath("gcrt1.o")));
John McCall65b8da02013-04-11 22:55:55 +00008810 else {
8811 if (Args.hasArg(options::OPT_pie))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008812 CmdArgs.push_back(
8813 Args.MakeArgString(getToolChain().GetFilePath("Scrt1.o")));
John McCall65b8da02013-04-11 22:55:55 +00008814 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008815 CmdArgs.push_back(
8816 Args.MakeArgString(getToolChain().GetFilePath("crt1.o")));
John McCall65b8da02013-04-11 22:55:55 +00008817 }
Daniel Dunbarcc912342009-05-02 18:28:39 +00008818 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008819 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
John McCall65b8da02013-04-11 22:55:55 +00008820 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_pie))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008821 CmdArgs.push_back(
8822 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.o")));
John McCall65b8da02013-04-11 22:55:55 +00008823 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008824 CmdArgs.push_back(
8825 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
Daniel Dunbarcc912342009-05-02 18:28:39 +00008826 }
8827
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00008828 Args.AddAllArgs(CmdArgs,
8829 {options::OPT_L, options::OPT_T_Group, options::OPT_e});
Daniel Dunbarcc912342009-05-02 18:28:39 +00008830
Daniel Dunbar54423b22010-09-17 00:24:54 +00008831 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Daniel Dunbarcc912342009-05-02 18:28:39 +00008832
8833 if (!Args.hasArg(options::OPT_nostdlib) &&
8834 !Args.hasArg(options::OPT_nodefaultlibs)) {
8835 // FIXME: GCC passes on -lgcc, -lgcc_pic and a whole lot of
8836 // rpaths
John McCall65b8da02013-04-11 22:55:55 +00008837 if (UseGCC47)
8838 CmdArgs.push_back("-L/usr/lib/gcc47");
8839 else
8840 CmdArgs.push_back("-L/usr/lib/gcc44");
Daniel Dunbarcc912342009-05-02 18:28:39 +00008841
8842 if (!Args.hasArg(options::OPT_static)) {
John McCall65b8da02013-04-11 22:55:55 +00008843 if (UseGCC47) {
8844 CmdArgs.push_back("-rpath");
8845 CmdArgs.push_back("/usr/lib/gcc47");
8846 } else {
8847 CmdArgs.push_back("-rpath");
8848 CmdArgs.push_back("/usr/lib/gcc44");
8849 }
Daniel Dunbarcc912342009-05-02 18:28:39 +00008850 }
8851
Hans Wennborg70850d82013-07-18 20:29:38 +00008852 if (D.CCCIsCXX()) {
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00008853 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Rafael Espindola38360b32010-07-20 12:59:03 +00008854 CmdArgs.push_back("-lm");
8855 }
8856
Daniel Dunbarcc912342009-05-02 18:28:39 +00008857 if (Args.hasArg(options::OPT_pthread))
Mike Stump0a65b632009-10-31 20:11:46 +00008858 CmdArgs.push_back("-lpthread");
Daniel Dunbarcc912342009-05-02 18:28:39 +00008859
8860 if (!Args.hasArg(options::OPT_nolibc)) {
8861 CmdArgs.push_back("-lc");
8862 }
8863
John McCall65b8da02013-04-11 22:55:55 +00008864 if (UseGCC47) {
8865 if (Args.hasArg(options::OPT_static) ||
8866 Args.hasArg(options::OPT_static_libgcc)) {
8867 CmdArgs.push_back("-lgcc");
8868 CmdArgs.push_back("-lgcc_eh");
8869 } else {
8870 if (Args.hasArg(options::OPT_shared_libgcc)) {
8871 CmdArgs.push_back("-lgcc_pic");
8872 if (!Args.hasArg(options::OPT_shared))
8873 CmdArgs.push_back("-lgcc");
8874 } else {
8875 CmdArgs.push_back("-lgcc");
8876 CmdArgs.push_back("--as-needed");
8877 CmdArgs.push_back("-lgcc_pic");
8878 CmdArgs.push_back("--no-as-needed");
8879 }
8880 }
Daniel Dunbarcc912342009-05-02 18:28:39 +00008881 } else {
John McCall65b8da02013-04-11 22:55:55 +00008882 if (Args.hasArg(options::OPT_shared)) {
8883 CmdArgs.push_back("-lgcc_pic");
8884 } else {
8885 CmdArgs.push_back("-lgcc");
8886 }
Daniel Dunbarcc912342009-05-02 18:28:39 +00008887 }
8888 }
8889
8890 if (!Args.hasArg(options::OPT_nostdlib) &&
8891 !Args.hasArg(options::OPT_nostartfiles)) {
John McCall65b8da02013-04-11 22:55:55 +00008892 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_pie))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008893 CmdArgs.push_back(
8894 Args.MakeArgString(getToolChain().GetFilePath("crtendS.o")));
John McCall65b8da02013-04-11 22:55:55 +00008895 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008896 CmdArgs.push_back(
8897 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
8898 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
Daniel Dunbarcc912342009-05-02 18:28:39 +00008899 }
8900
Alexey Samsonov7811d192014-02-20 13:57:37 +00008901 addProfileRT(getToolChain(), Args, CmdArgs);
Nick Lewycky82fe5f42011-05-24 21:54:59 +00008902
Logan Chieneb9162f2014-06-26 14:23:45 +00008903 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00008904 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbarcc912342009-05-02 18:28:39 +00008905}
Michael J. Spencerb186bc32010-08-21 21:55:07 +00008906
Zachary Turner0eaf8fc2014-10-22 20:40:28 +00008907// Try to find Exe from a Visual Studio distribution. This first tries to find
8908// an installed copy of Visual Studio and, failing that, looks in the PATH,
8909// making sure that whatever executable that's found is not a same-named exe
8910// from clang itself to prevent clang from falling back to itself.
8911static std::string FindVisualStudioExecutable(const ToolChain &TC,
8912 const char *Exe,
8913 const char *ClangProgramPath) {
8914 const auto &MSVC = static_cast<const toolchains::MSVCToolChain &>(TC);
8915 std::string visualStudioBinDir;
8916 if (MSVC.getVisualStudioBinariesFolder(ClangProgramPath,
8917 visualStudioBinDir)) {
8918 SmallString<128> FilePath(visualStudioBinDir);
8919 llvm::sys::path::append(FilePath, Exe);
8920 if (llvm::sys::fs::can_execute(FilePath.c_str()))
8921 return FilePath.str();
8922 }
8923
8924 return Exe;
8925}
8926
Douglas Katzman95354292015-06-23 20:42:09 +00008927void visualstudio::Linker::ConstructJob(Compilation &C, const JobAction &JA,
8928 const InputInfo &Output,
8929 const InputInfoList &Inputs,
8930 const ArgList &Args,
8931 const char *LinkingOutput) const {
Michael J. Spencerb186bc32010-08-21 21:55:07 +00008932 ArgStringList CmdArgs;
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00008933 const ToolChain &TC = getToolChain();
Michael J. Spencerb186bc32010-08-21 21:55:07 +00008934
Saleem Abdulrasool9a215462014-12-19 23:56:31 +00008935 assert((Output.isFilename() || Output.isNothing()) && "invalid output");
8936 if (Output.isFilename())
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008937 CmdArgs.push_back(
8938 Args.MakeArgString(std::string("-out:") + Output.getFilename()));
Michael J. Spencerb186bc32010-08-21 21:55:07 +00008939
8940 if (!Args.hasArg(options::OPT_nostdlib) &&
Saleem Abdulrasool9a215462014-12-19 23:56:31 +00008941 !Args.hasArg(options::OPT_nostartfiles) && !C.getDriver().IsCLMode())
Michael J. Spencerb186bc32010-08-21 21:55:07 +00008942 CmdArgs.push_back("-defaultlib:libcmt");
Michael J. Spencerb186bc32010-08-21 21:55:07 +00008943
Zachary Turner10d75b22014-10-22 20:40:43 +00008944 if (!llvm::sys::Process::GetEnv("LIB")) {
8945 // If the VC environment hasn't been configured (perhaps because the user
8946 // did not run vcvarsall), try to build a consistent link environment. If
Nico Webere93bcd12015-03-11 00:05:26 +00008947 // the environment variable is set however, assume the user knows what
8948 // they're doing.
Zachary Turner10d75b22014-10-22 20:40:43 +00008949 std::string VisualStudioDir;
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00008950 const auto &MSVC = static_cast<const toolchains::MSVCToolChain &>(TC);
Zachary Turner10d75b22014-10-22 20:40:43 +00008951 if (MSVC.getVisualStudioInstallDir(VisualStudioDir)) {
8952 SmallString<128> LibDir(VisualStudioDir);
8953 llvm::sys::path::append(LibDir, "VC", "lib");
8954 switch (MSVC.getArch()) {
8955 case llvm::Triple::x86:
8956 // x86 just puts the libraries directly in lib
8957 break;
8958 case llvm::Triple::x86_64:
8959 llvm::sys::path::append(LibDir, "amd64");
8960 break;
8961 case llvm::Triple::arm:
8962 llvm::sys::path::append(LibDir, "arm");
8963 break;
8964 default:
8965 break;
8966 }
8967 CmdArgs.push_back(
8968 Args.MakeArgString(std::string("-libpath:") + LibDir.c_str()));
Reid Kleckner7531f7d2015-09-11 00:09:39 +00008969
8970 if (MSVC.useUniversalCRT(VisualStudioDir)) {
8971 std::string UniversalCRTLibPath;
8972 if (MSVC.getUniversalCRTLibraryPath(UniversalCRTLibPath))
8973 CmdArgs.push_back(Args.MakeArgString(std::string("-libpath:") +
8974 UniversalCRTLibPath.c_str()));
8975 }
Zachary Turner10d75b22014-10-22 20:40:43 +00008976 }
8977
8978 std::string WindowsSdkLibPath;
8979 if (MSVC.getWindowsSDKLibraryPath(WindowsSdkLibPath))
8980 CmdArgs.push_back(Args.MakeArgString(std::string("-libpath:") +
8981 WindowsSdkLibPath.c_str()));
8982 }
8983
Michael J. Spencerb186bc32010-08-21 21:55:07 +00008984 CmdArgs.push_back("-nologo");
8985
Reid Kleckner124955a2015-08-05 18:51:13 +00008986 if (Args.hasArg(options::OPT_g_Group, options::OPT__SLASH_Z7))
Hans Wennborgbbb5f072014-04-25 16:24:19 +00008987 CmdArgs.push_back("-debug");
Hans Wennborgbbb5f072014-04-25 16:24:19 +00008988
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008989 bool DLL = Args.hasArg(options::OPT__SLASH_LD, options::OPT__SLASH_LDd,
Hans Wennborge4c47f22015-03-04 23:16:21 +00008990 options::OPT_shared);
Hans Wennborgf1a74252013-09-10 20:18:04 +00008991 if (DLL) {
8992 CmdArgs.push_back(Args.MakeArgString("-dll"));
8993
8994 SmallString<128> ImplibName(Output.getFilename());
8995 llvm::sys::path::replace_extension(ImplibName, "lib");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008996 CmdArgs.push_back(Args.MakeArgString(std::string("-implib:") + ImplibName));
Hans Wennborgf1a74252013-09-10 20:18:04 +00008997 }
8998
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00008999 if (TC.getSanitizerArgs().needsAsanRt()) {
Hans Wennborg0517e752013-08-28 17:36:07 +00009000 CmdArgs.push_back(Args.MakeArgString("-debug"));
Hans Wennborgd024c1c2013-08-30 10:50:52 +00009001 CmdArgs.push_back(Args.MakeArgString("-incremental:no"));
Timur Iskhodzhanov6903e102014-08-26 10:08:24 +00009002 if (Args.hasArg(options::OPT__SLASH_MD, options::OPT__SLASH_MDd)) {
Saleem Abdulrasool1d59f492015-01-02 20:00:55 +00009003 static const char *CompilerRTComponents[] = {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009004 "asan_dynamic", "asan_dynamic_runtime_thunk",
Saleem Abdulrasool1d59f492015-01-02 20:00:55 +00009005 };
9006 for (const auto &Component : CompilerRTComponents)
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00009007 CmdArgs.push_back(getCompilerRTArgString(TC, Args, Component));
Timur Iskhodzhanov651725e2014-09-12 14:01:30 +00009008 // Make sure the dynamic runtime thunk is not optimized out at link time
9009 // to ensure proper SEH handling.
9010 CmdArgs.push_back(Args.MakeArgString("-include:___asan_seh_interceptor"));
Timur Iskhodzhanov6903e102014-08-26 10:08:24 +00009011 } else if (DLL) {
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00009012 CmdArgs.push_back(getCompilerRTArgString(TC, Args, "asan_dll_thunk"));
Alexey Samsonov6424e022014-05-12 20:20:20 +00009013 } else {
Saleem Abdulrasool1d59f492015-01-02 20:00:55 +00009014 static const char *CompilerRTComponents[] = {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009015 "asan", "asan_cxx",
Saleem Abdulrasool1d59f492015-01-02 20:00:55 +00009016 };
9017 for (const auto &Component : CompilerRTComponents)
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00009018 CmdArgs.push_back(getCompilerRTArgString(TC, Args, Component));
Alexey Samsonov6424e022014-05-12 20:20:20 +00009019 }
Hans Wennborg65f17522013-08-27 18:10:21 +00009020 }
9021
Hans Wennborg2e274592013-08-13 23:38:57 +00009022 Args.AddAllArgValues(CmdArgs, options::OPT__SLASH_link);
Michael J. Spencere2f49362012-06-18 16:56:04 +00009023
Alexey Bataevc7e84352015-08-19 04:49:01 +00009024 if (Args.hasFlag(options::OPT_fopenmp, options::OPT_fopenmp_EQ,
9025 options::OPT_fno_openmp, false)) {
9026 CmdArgs.push_back("-nodefaultlib:vcomp.lib");
9027 CmdArgs.push_back("-nodefaultlib:vcompd.lib");
9028 CmdArgs.push_back(Args.MakeArgString(std::string("-libpath:") +
9029 TC.getDriver().Dir + "/../lib"));
9030 switch (getOpenMPRuntime(getToolChain(), Args)) {
9031 case OMPRT_OMP:
9032 CmdArgs.push_back("-defaultlib:libomp.lib");
9033 break;
9034 case OMPRT_IOMP5:
9035 CmdArgs.push_back("-defaultlib:libiomp5md.lib");
9036 break;
9037 case OMPRT_GOMP:
9038 break;
9039 case OMPRT_Unknown:
9040 // Already diagnosed.
9041 break;
9042 }
9043 }
9044
Reid Kleckner337188f2014-09-16 19:22:00 +00009045 // Add filenames, libraries, and other linker inputs.
9046 for (const auto &Input : Inputs) {
9047 if (Input.isFilename()) {
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009048 CmdArgs.push_back(Input.getFilename());
Reid Kleckner337188f2014-09-16 19:22:00 +00009049 continue;
9050 }
9051
9052 const Arg &A = Input.getInputArg();
9053
9054 // Render -l options differently for the MSVC linker.
9055 if (A.getOption().matches(options::OPT_l)) {
9056 StringRef Lib = A.getValue();
9057 const char *LinkLibArg;
9058 if (Lib.endswith(".lib"))
9059 LinkLibArg = Args.MakeArgString(Lib);
9060 else
9061 LinkLibArg = Args.MakeArgString(Lib + ".lib");
9062 CmdArgs.push_back(LinkLibArg);
9063 continue;
9064 }
9065
9066 // Otherwise, this is some other kind of linker input option like -Wl, -z,
9067 // or -L. Render it, even if MSVC doesn't understand it.
9068 A.renderAsInput(Args, CmdArgs);
9069 }
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009070
Zachary Turner719f58c2014-12-01 23:06:47 +00009071 // We need to special case some linker paths. In the case of lld, we need to
9072 // translate 'lld' into 'lld-link', and in the case of the regular msvc
9073 // linker, we need to use a special search algorithm.
9074 llvm::SmallString<128> linkPath;
9075 StringRef Linker = Args.getLastArgValue(options::OPT_fuse_ld_EQ, "link");
9076 if (Linker.equals_lower("lld"))
9077 Linker = "lld-link";
9078
9079 if (Linker.equals_lower("link")) {
9080 // If we're using the MSVC linker, it's not sufficient to just use link
9081 // from the program PATH, because other environments like GnuWin32 install
9082 // their own link.exe which may come first.
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009083 linkPath = FindVisualStudioExecutable(TC, "link.exe",
Zachary Turner719f58c2014-12-01 23:06:47 +00009084 C.getDriver().getClangProgramPath());
9085 } else {
9086 linkPath = Linker;
9087 llvm::sys::path::replace_extension(linkPath, "exe");
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009088 linkPath = TC.GetProgramPath(linkPath.c_str());
Zachary Turner719f58c2014-12-01 23:06:47 +00009089 }
9090
Zachary Turner0eaf8fc2014-10-22 20:40:28 +00009091 const char *Exec = Args.MakeArgString(linkPath);
Justin Bognerd3371d82015-07-17 03:35:54 +00009092 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009093}
Hans Wennborg87cfa712013-09-19 20:32:16 +00009094
Douglas Katzman95354292015-06-23 20:42:09 +00009095void visualstudio::Compiler::ConstructJob(Compilation &C, const JobAction &JA,
9096 const InputInfo &Output,
9097 const InputInfoList &Inputs,
9098 const ArgList &Args,
9099 const char *LinkingOutput) const {
Hans Wennborg87cfa712013-09-19 20:32:16 +00009100 C.addCommand(GetCommand(C, JA, Output, Inputs, Args, LinkingOutput));
9101}
9102
Douglas Katzman95354292015-06-23 20:42:09 +00009103std::unique_ptr<Command> visualstudio::Compiler::GetCommand(
David Blaikiec11bf802014-09-04 16:04:28 +00009104 Compilation &C, const JobAction &JA, const InputInfo &Output,
9105 const InputInfoList &Inputs, const ArgList &Args,
9106 const char *LinkingOutput) const {
Hans Wennborg87cfa712013-09-19 20:32:16 +00009107 ArgStringList CmdArgs;
Hans Wennborg263c2132013-09-24 17:36:21 +00009108 CmdArgs.push_back("/nologo");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009109 CmdArgs.push_back("/c"); // Compile only.
Hans Wennborg87cfa712013-09-19 20:32:16 +00009110 CmdArgs.push_back("/W0"); // No warnings.
9111
9112 // The goal is to be able to invoke this tool correctly based on
9113 // any flag accepted by clang-cl.
9114
9115 // These are spelled the same way in clang and cl.exe,.
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00009116 Args.AddAllArgs(CmdArgs, {options::OPT_D, options::OPT_U, options::OPT_I});
Hans Wennborgb6331dc2013-09-24 18:17:21 +00009117
9118 // Optimization level.
David Majnemer015ce0f2015-07-27 07:32:11 +00009119 if (Arg *A = Args.getLastArg(options::OPT_fbuiltin, options::OPT_fno_builtin))
9120 CmdArgs.push_back(A->getOption().getID() == options::OPT_fbuiltin ? "/Oi"
9121 : "/Oi-");
Hans Wennborgb6331dc2013-09-24 18:17:21 +00009122 if (Arg *A = Args.getLastArg(options::OPT_O, options::OPT_O0)) {
9123 if (A->getOption().getID() == options::OPT_O0) {
9124 CmdArgs.push_back("/Od");
9125 } else {
David Majnemer015ce0f2015-07-27 07:32:11 +00009126 CmdArgs.push_back("/Og");
9127
Hans Wennborgb6331dc2013-09-24 18:17:21 +00009128 StringRef OptLevel = A->getValue();
David Majnemer015ce0f2015-07-27 07:32:11 +00009129 if (OptLevel == "s" || OptLevel == "z")
9130 CmdArgs.push_back("/Os");
9131 else
9132 CmdArgs.push_back("/Ot");
9133
9134 CmdArgs.push_back("/Ob2");
Hans Wennborgb6331dc2013-09-24 18:17:21 +00009135 }
9136 }
David Majnemer015ce0f2015-07-27 07:32:11 +00009137 if (Arg *A = Args.getLastArg(options::OPT_fomit_frame_pointer,
9138 options::OPT_fno_omit_frame_pointer))
9139 CmdArgs.push_back(A->getOption().getID() == options::OPT_fomit_frame_pointer
9140 ? "/Oy"
9141 : "/Oy-");
9142 if (!Args.hasArg(options::OPT_fwritable_strings))
9143 CmdArgs.push_back("/GF");
Hans Wennborg87cfa712013-09-19 20:32:16 +00009144
Nico Weber3f8dafb2015-03-12 19:37:10 +00009145 // Flags for which clang-cl has an alias.
Hans Wennborg87cfa712013-09-19 20:32:16 +00009146 // FIXME: How can we ensure this stays in sync with relevant clang-cl options?
9147
David Majnemerf6072342014-07-01 22:24:56 +00009148 if (Args.hasFlag(options::OPT__SLASH_GR_, options::OPT__SLASH_GR,
9149 /*default=*/false))
9150 CmdArgs.push_back("/GR-");
Hans Wennborg5149a3b2014-03-25 14:48:54 +00009151 if (Arg *A = Args.getLastArg(options::OPT_ffunction_sections,
9152 options::OPT_fno_function_sections))
9153 CmdArgs.push_back(A->getOption().getID() == options::OPT_ffunction_sections
9154 ? "/Gy"
9155 : "/Gy-");
David Majnemerdc7a47c2014-04-07 16:14:38 +00009156 if (Arg *A = Args.getLastArg(options::OPT_fdata_sections,
9157 options::OPT_fno_data_sections))
David Majnemer6c684a72014-04-07 16:19:27 +00009158 CmdArgs.push_back(
9159 A->getOption().getID() == options::OPT_fdata_sections ? "/Gw" : "/Gw-");
Hans Wennborg87cfa712013-09-19 20:32:16 +00009160 if (Args.hasArg(options::OPT_fsyntax_only))
9161 CmdArgs.push_back("/Zs");
Reid Kleckner124955a2015-08-05 18:51:13 +00009162 if (Args.hasArg(options::OPT_g_Flag, options::OPT_gline_tables_only,
9163 options::OPT__SLASH_Z7))
Reid Klecknerc688daf2014-02-19 22:05:59 +00009164 CmdArgs.push_back("/Z7");
Hans Wennborg87cfa712013-09-19 20:32:16 +00009165
Nico Weber3f8dafb2015-03-12 19:37:10 +00009166 std::vector<std::string> Includes =
9167 Args.getAllArgValues(options::OPT_include);
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009168 for (const auto &Include : Includes)
9169 CmdArgs.push_back(Args.MakeArgString(std::string("/FI") + Include));
Hans Wennborg260ff402013-09-27 17:54:18 +00009170
Hans Wennborg87cfa712013-09-19 20:32:16 +00009171 // Flags that can simply be passed through.
9172 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_LD);
9173 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_LDd);
Reid Klecknerc542d372014-06-27 17:02:02 +00009174 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_EH);
David Majnemerbac941c2015-07-25 06:07:59 +00009175 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_Zl);
Hans Wennborg87cfa712013-09-19 20:32:16 +00009176
9177 // The order of these flags is relevant, so pick the last one.
9178 if (Arg *A = Args.getLastArg(options::OPT__SLASH_MD, options::OPT__SLASH_MDd,
9179 options::OPT__SLASH_MT, options::OPT__SLASH_MTd))
9180 A->render(Args, CmdArgs);
9181
Hans Wennborg87cfa712013-09-19 20:32:16 +00009182 // Input filename.
9183 assert(Inputs.size() == 1);
9184 const InputInfo &II = Inputs[0];
9185 assert(II.getType() == types::TY_C || II.getType() == types::TY_CXX);
9186 CmdArgs.push_back(II.getType() == types::TY_C ? "/Tc" : "/Tp");
9187 if (II.isFilename())
9188 CmdArgs.push_back(II.getFilename());
9189 else
9190 II.getInputArg().renderAsInput(Args, CmdArgs);
9191
9192 // Output filename.
9193 assert(Output.getType() == types::TY_Object);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009194 const char *Fo =
9195 Args.MakeArgString(std::string("/Fo") + Output.getFilename());
Hans Wennborg87cfa712013-09-19 20:32:16 +00009196 CmdArgs.push_back(Fo);
9197
Hans Wennborg188382e2013-09-20 18:16:35 +00009198 const Driver &D = getToolChain().getDriver();
Zachary Turner0eaf8fc2014-10-22 20:40:28 +00009199 std::string Exec = FindVisualStudioExecutable(getToolChain(), "cl.exe",
9200 D.getClangProgramPath());
David Blaikiec11bf802014-09-04 16:04:28 +00009201 return llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Exec),
Justin Bognerd3371d82015-07-17 03:35:54 +00009202 CmdArgs, Inputs);
Hans Wennborg87cfa712013-09-19 20:32:16 +00009203}
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009204
Yaron Keren1c0070c2015-07-02 04:45:27 +00009205/// MinGW Tools
9206void MinGW::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
9207 const InputInfo &Output,
9208 const InputInfoList &Inputs,
9209 const ArgList &Args,
9210 const char *LinkingOutput) const {
9211 claimNoWarnArgs(Args);
9212 ArgStringList CmdArgs;
9213
9214 if (getToolChain().getArch() == llvm::Triple::x86) {
9215 CmdArgs.push_back("--32");
9216 } else if (getToolChain().getArch() == llvm::Triple::x86_64) {
9217 CmdArgs.push_back("--64");
9218 }
9219
9220 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
9221
9222 CmdArgs.push_back("-o");
9223 CmdArgs.push_back(Output.getFilename());
9224
9225 for (const auto &II : Inputs)
9226 CmdArgs.push_back(II.getFilename());
9227
9228 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009229 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Yaron Keren1c0070c2015-07-02 04:45:27 +00009230
9231 if (Args.hasArg(options::OPT_gsplit_dwarf))
9232 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output,
9233 SplitDebugName(Args, Inputs[0]));
9234}
9235
9236void MinGW::Linker::AddLibGCC(const ArgList &Args,
9237 ArgStringList &CmdArgs) const {
9238 if (Args.hasArg(options::OPT_mthreads))
9239 CmdArgs.push_back("-lmingwthrd");
9240 CmdArgs.push_back("-lmingw32");
Reid Kleckner0213a472015-07-22 16:01:38 +00009241
Yaron Kerenaa281332015-08-09 00:24:07 +00009242 // Make use of compiler-rt if --rtlib option is used
9243 ToolChain::RuntimeLibType RLT = getToolChain().GetRuntimeLibType(Args);
9244 if (RLT == ToolChain::RLT_Libgcc) {
9245 bool Static = Args.hasArg(options::OPT_static_libgcc) ||
9246 Args.hasArg(options::OPT_static);
9247 bool Shared = Args.hasArg(options::OPT_shared);
9248 bool CXX = getToolChain().getDriver().CCCIsCXX();
9249
9250 if (Static || (!CXX && !Shared)) {
9251 CmdArgs.push_back("-lgcc");
9252 CmdArgs.push_back("-lgcc_eh");
9253 } else {
9254 CmdArgs.push_back("-lgcc_s");
9255 CmdArgs.push_back("-lgcc");
9256 }
9257 } else {
9258 AddRunTimeLibs(getToolChain(), getToolChain().getDriver(), CmdArgs, Args);
9259 }
Reid Kleckner0213a472015-07-22 16:01:38 +00009260
Yaron Keren1c0070c2015-07-02 04:45:27 +00009261 CmdArgs.push_back("-lmoldname");
9262 CmdArgs.push_back("-lmingwex");
9263 CmdArgs.push_back("-lmsvcrt");
9264}
9265
9266void MinGW::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9267 const InputInfo &Output,
9268 const InputInfoList &Inputs,
9269 const ArgList &Args,
9270 const char *LinkingOutput) const {
9271 const ToolChain &TC = getToolChain();
9272 const Driver &D = TC.getDriver();
9273 // const SanitizerArgs &Sanitize = TC.getSanitizerArgs();
9274
9275 ArgStringList CmdArgs;
9276
9277 // Silence warning for "clang -g foo.o -o foo"
9278 Args.ClaimAllArgs(options::OPT_g_Group);
9279 // and "clang -emit-llvm foo.o -o foo"
9280 Args.ClaimAllArgs(options::OPT_emit_llvm);
9281 // and for "clang -w foo.o -o foo". Other warning options are already
9282 // handled somewhere else.
9283 Args.ClaimAllArgs(options::OPT_w);
9284
Yaron Keren2ffb36e2015-07-14 05:23:34 +00009285 StringRef LinkerName = Args.getLastArgValue(options::OPT_fuse_ld_EQ, "ld");
9286 if (LinkerName.equals_lower("lld")) {
9287 CmdArgs.push_back("-flavor");
9288 CmdArgs.push_back("gnu");
9289 }
9290
Yaron Keren1c0070c2015-07-02 04:45:27 +00009291 if (!D.SysRoot.empty())
9292 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
9293
9294 if (Args.hasArg(options::OPT_s))
9295 CmdArgs.push_back("-s");
9296
9297 CmdArgs.push_back("-m");
9298 if (TC.getArch() == llvm::Triple::x86)
9299 CmdArgs.push_back("i386pe");
9300 if (TC.getArch() == llvm::Triple::x86_64)
9301 CmdArgs.push_back("i386pep");
Yaron Keren2ffb36e2015-07-14 05:23:34 +00009302 if (TC.getArch() == llvm::Triple::arm)
9303 CmdArgs.push_back("thumb2pe");
Yaron Keren1c0070c2015-07-02 04:45:27 +00009304
9305 if (Args.hasArg(options::OPT_mwindows)) {
9306 CmdArgs.push_back("--subsystem");
9307 CmdArgs.push_back("windows");
9308 } else if (Args.hasArg(options::OPT_mconsole)) {
9309 CmdArgs.push_back("--subsystem");
9310 CmdArgs.push_back("console");
9311 }
9312
9313 if (Args.hasArg(options::OPT_static))
9314 CmdArgs.push_back("-Bstatic");
9315 else {
9316 if (Args.hasArg(options::OPT_mdll))
9317 CmdArgs.push_back("--dll");
9318 else if (Args.hasArg(options::OPT_shared))
9319 CmdArgs.push_back("--shared");
9320 CmdArgs.push_back("-Bdynamic");
9321 if (Args.hasArg(options::OPT_mdll) || Args.hasArg(options::OPT_shared)) {
9322 CmdArgs.push_back("-e");
9323 if (TC.getArch() == llvm::Triple::x86)
9324 CmdArgs.push_back("_DllMainCRTStartup@12");
9325 else
9326 CmdArgs.push_back("DllMainCRTStartup");
9327 CmdArgs.push_back("--enable-auto-image-base");
9328 }
9329 }
9330
9331 CmdArgs.push_back("-o");
9332 CmdArgs.push_back(Output.getFilename());
9333
9334 Args.AddAllArgs(CmdArgs, options::OPT_e);
9335 // FIXME: add -N, -n flags
9336 Args.AddLastArg(CmdArgs, options::OPT_r);
9337 Args.AddLastArg(CmdArgs, options::OPT_s);
9338 Args.AddLastArg(CmdArgs, options::OPT_t);
9339 Args.AddAllArgs(CmdArgs, options::OPT_u_Group);
9340 Args.AddLastArg(CmdArgs, options::OPT_Z_Flag);
9341
9342 if (!Args.hasArg(options::OPT_nostdlib) &&
9343 !Args.hasArg(options::OPT_nostartfiles)) {
9344 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_mdll)) {
9345 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("dllcrt2.o")));
9346 } else {
9347 if (Args.hasArg(options::OPT_municode))
9348 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crt2u.o")));
9349 else
9350 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crt2.o")));
9351 }
9352 if (Args.hasArg(options::OPT_pg))
9353 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("gcrt2.o")));
9354 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crtbegin.o")));
9355 }
9356
9357 Args.AddAllArgs(CmdArgs, options::OPT_L);
9358 const ToolChain::path_list Paths = TC.getFilePaths();
9359 for (const auto &Path : Paths)
9360 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
9361
9362 AddLinkerInputs(TC, Inputs, Args, CmdArgs);
9363
9364 // TODO: Add ASan stuff here
9365
9366 // TODO: Add profile stuff here
9367
9368 if (D.CCCIsCXX() && !Args.hasArg(options::OPT_nostdlib) &&
9369 !Args.hasArg(options::OPT_nodefaultlibs)) {
9370 bool OnlyLibstdcxxStatic = Args.hasArg(options::OPT_static_libstdcxx) &&
9371 !Args.hasArg(options::OPT_static);
9372 if (OnlyLibstdcxxStatic)
9373 CmdArgs.push_back("-Bstatic");
9374 TC.AddCXXStdlibLibArgs(Args, CmdArgs);
9375 if (OnlyLibstdcxxStatic)
9376 CmdArgs.push_back("-Bdynamic");
9377 }
9378
9379 if (!Args.hasArg(options::OPT_nostdlib)) {
9380 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
9381 if (Args.hasArg(options::OPT_static))
9382 CmdArgs.push_back("--start-group");
9383
9384 if (Args.hasArg(options::OPT_fstack_protector) ||
9385 Args.hasArg(options::OPT_fstack_protector_strong) ||
9386 Args.hasArg(options::OPT_fstack_protector_all)) {
9387 CmdArgs.push_back("-lssp_nonshared");
9388 CmdArgs.push_back("-lssp");
9389 }
9390 if (Args.hasArg(options::OPT_fopenmp))
9391 CmdArgs.push_back("-lgomp");
9392
9393 AddLibGCC(Args, CmdArgs);
9394
9395 if (Args.hasArg(options::OPT_pg))
9396 CmdArgs.push_back("-lgmon");
9397
Yaron Kerenadce68e2015-07-06 18:52:19 +00009398 if (Args.hasArg(options::OPT_pthread))
9399 CmdArgs.push_back("-lpthread");
Yaron Keren1c0070c2015-07-02 04:45:27 +00009400
9401 // add system libraries
9402 if (Args.hasArg(options::OPT_mwindows)) {
9403 CmdArgs.push_back("-lgdi32");
9404 CmdArgs.push_back("-lcomdlg32");
9405 }
9406 CmdArgs.push_back("-ladvapi32");
9407 CmdArgs.push_back("-lshell32");
9408 CmdArgs.push_back("-luser32");
9409 CmdArgs.push_back("-lkernel32");
9410
9411 if (Args.hasArg(options::OPT_static))
9412 CmdArgs.push_back("--end-group");
Yaron Keren2ffb36e2015-07-14 05:23:34 +00009413 else if (!LinkerName.equals_lower("lld"))
Yaron Keren1c0070c2015-07-02 04:45:27 +00009414 AddLibGCC(Args, CmdArgs);
9415 }
9416
9417 if (!Args.hasArg(options::OPT_nostartfiles)) {
9418 // Add crtfastmath.o if available and fast math is enabled.
9419 TC.AddFastMathRuntimeIfAvailable(Args, CmdArgs);
9420
9421 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crtend.o")));
9422 }
9423 }
Yaron Keren2ffb36e2015-07-14 05:23:34 +00009424 const char *Exec = Args.MakeArgString(TC.GetProgramPath(LinkerName.data()));
Justin Bognerd3371d82015-07-17 03:35:54 +00009425 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Yaron Keren1c0070c2015-07-02 04:45:27 +00009426}
9427
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009428/// XCore Tools
9429// We pass assemble and link construction to the xcc tool.
9430
Douglas Katzman95354292015-06-23 20:42:09 +00009431void XCore::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
9432 const InputInfo &Output,
9433 const InputInfoList &Inputs,
9434 const ArgList &Args,
9435 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00009436 claimNoWarnArgs(Args);
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009437 ArgStringList CmdArgs;
9438
9439 CmdArgs.push_back("-o");
9440 CmdArgs.push_back(Output.getFilename());
9441
9442 CmdArgs.push_back("-c");
9443
Robert Lytton9e8c1a42014-02-13 10:40:12 +00009444 if (Args.hasArg(options::OPT_v))
9445 CmdArgs.push_back("-v");
9446
Robert Lytton894d25c2014-05-02 09:33:25 +00009447 if (Arg *A = Args.getLastArg(options::OPT_g_Group))
9448 if (!A->getOption().matches(options::OPT_g0))
9449 CmdArgs.push_back("-g");
Robert Lytton9e8c1a42014-02-13 10:40:12 +00009450
Robert Lytton8e95d4e2014-02-11 10:34:45 +00009451 if (Args.hasFlag(options::OPT_fverbose_asm, options::OPT_fno_verbose_asm,
9452 false))
9453 CmdArgs.push_back("-fverbose-asm");
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009454
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009455 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009456
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009457 for (const auto &II : Inputs)
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009458 CmdArgs.push_back(II.getFilename());
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009459
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009460 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("xcc"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009461 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009462}
9463
Douglas Katzman95354292015-06-23 20:42:09 +00009464void XCore::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9465 const InputInfo &Output,
9466 const InputInfoList &Inputs,
9467 const ArgList &Args,
9468 const char *LinkingOutput) const {
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009469 ArgStringList CmdArgs;
9470
9471 if (Output.isFilename()) {
9472 CmdArgs.push_back("-o");
9473 CmdArgs.push_back(Output.getFilename());
9474 } else {
9475 assert(Output.isNothing() && "Invalid output.");
9476 }
9477
Robert Lytton9e8c1a42014-02-13 10:40:12 +00009478 if (Args.hasArg(options::OPT_v))
9479 CmdArgs.push_back("-v");
9480
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00009481 // Pass -fexceptions through to the linker if it was present.
9482 if (Args.hasFlag(options::OPT_fexceptions, options::OPT_fno_exceptions,
9483 false))
Robert Lyttonf7e03c12014-02-13 10:34:44 +00009484 CmdArgs.push_back("-fexceptions");
9485
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009486 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
9487
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009488 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("xcc"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009489 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009490}
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009491
Douglas Katzman95354292015-06-23 20:42:09 +00009492void CrossWindows::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
9493 const InputInfo &Output,
9494 const InputInfoList &Inputs,
9495 const ArgList &Args,
9496 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00009497 claimNoWarnArgs(Args);
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009498 const auto &TC =
9499 static_cast<const toolchains::CrossWindowsToolChain &>(getToolChain());
9500 ArgStringList CmdArgs;
9501 const char *Exec;
9502
9503 switch (TC.getArch()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009504 default:
9505 llvm_unreachable("unsupported architecture");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009506 case llvm::Triple::arm:
9507 case llvm::Triple::thumb:
9508 break;
9509 case llvm::Triple::x86:
9510 CmdArgs.push_back("--32");
9511 break;
9512 case llvm::Triple::x86_64:
9513 CmdArgs.push_back("--64");
9514 break;
9515 }
9516
9517 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
9518
9519 CmdArgs.push_back("-o");
9520 CmdArgs.push_back(Output.getFilename());
9521
9522 for (const auto &Input : Inputs)
9523 CmdArgs.push_back(Input.getFilename());
9524
9525 const std::string Assembler = TC.GetProgramPath("as");
9526 Exec = Args.MakeArgString(Assembler);
9527
Justin Bognerd3371d82015-07-17 03:35:54 +00009528 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009529}
9530
Douglas Katzman95354292015-06-23 20:42:09 +00009531void CrossWindows::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9532 const InputInfo &Output,
9533 const InputInfoList &Inputs,
9534 const ArgList &Args,
9535 const char *LinkingOutput) const {
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009536 const auto &TC =
9537 static_cast<const toolchains::CrossWindowsToolChain &>(getToolChain());
9538 const llvm::Triple &T = TC.getTriple();
9539 const Driver &D = TC.getDriver();
9540 SmallString<128> EntryPoint;
9541 ArgStringList CmdArgs;
9542 const char *Exec;
9543
9544 // Silence warning for "clang -g foo.o -o foo"
9545 Args.ClaimAllArgs(options::OPT_g_Group);
9546 // and "clang -emit-llvm foo.o -o foo"
9547 Args.ClaimAllArgs(options::OPT_emit_llvm);
9548 // and for "clang -w foo.o -o foo"
9549 Args.ClaimAllArgs(options::OPT_w);
9550 // Other warning options are already handled somewhere else.
9551
9552 if (!D.SysRoot.empty())
9553 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
9554
9555 if (Args.hasArg(options::OPT_pie))
9556 CmdArgs.push_back("-pie");
9557 if (Args.hasArg(options::OPT_rdynamic))
9558 CmdArgs.push_back("-export-dynamic");
9559 if (Args.hasArg(options::OPT_s))
9560 CmdArgs.push_back("--strip-all");
9561
9562 CmdArgs.push_back("-m");
9563 switch (TC.getArch()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009564 default:
9565 llvm_unreachable("unsupported architecture");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009566 case llvm::Triple::arm:
9567 case llvm::Triple::thumb:
9568 // FIXME: this is incorrect for WinCE
9569 CmdArgs.push_back("thumb2pe");
9570 break;
9571 case llvm::Triple::x86:
9572 CmdArgs.push_back("i386pe");
9573 EntryPoint.append("_");
9574 break;
9575 case llvm::Triple::x86_64:
9576 CmdArgs.push_back("i386pep");
9577 break;
9578 }
9579
9580 if (Args.hasArg(options::OPT_shared)) {
9581 switch (T.getArch()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009582 default:
9583 llvm_unreachable("unsupported architecture");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009584 case llvm::Triple::arm:
9585 case llvm::Triple::thumb:
9586 case llvm::Triple::x86_64:
9587 EntryPoint.append("_DllMainCRTStartup");
9588 break;
9589 case llvm::Triple::x86:
9590 EntryPoint.append("_DllMainCRTStartup@12");
9591 break;
9592 }
9593
9594 CmdArgs.push_back("-shared");
9595 CmdArgs.push_back("-Bdynamic");
9596
9597 CmdArgs.push_back("--enable-auto-image-base");
9598
9599 CmdArgs.push_back("--entry");
9600 CmdArgs.push_back(Args.MakeArgString(EntryPoint));
9601 } else {
9602 EntryPoint.append("mainCRTStartup");
9603
9604 CmdArgs.push_back(Args.hasArg(options::OPT_static) ? "-Bstatic"
9605 : "-Bdynamic");
9606
9607 if (!Args.hasArg(options::OPT_nostdlib) &&
9608 !Args.hasArg(options::OPT_nostartfiles)) {
9609 CmdArgs.push_back("--entry");
9610 CmdArgs.push_back(Args.MakeArgString(EntryPoint));
9611 }
9612
9613 // FIXME: handle subsystem
9614 }
9615
9616 // NOTE: deal with multiple definitions on Windows (e.g. COMDAT)
Saleem Abdulrasool56dd1ac2014-10-28 03:15:02 +00009617 CmdArgs.push_back("--allow-multiple-definition");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009618
9619 CmdArgs.push_back("-o");
9620 CmdArgs.push_back(Output.getFilename());
9621
9622 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_rdynamic)) {
9623 SmallString<261> ImpLib(Output.getFilename());
9624 llvm::sys::path::replace_extension(ImpLib, ".lib");
9625
9626 CmdArgs.push_back("--out-implib");
9627 CmdArgs.push_back(Args.MakeArgString(ImpLib));
9628 }
9629
9630 if (!Args.hasArg(options::OPT_nostdlib) &&
9631 !Args.hasArg(options::OPT_nostartfiles)) {
9632 const std::string CRTPath(D.SysRoot + "/usr/lib/");
9633 const char *CRTBegin;
9634
9635 CRTBegin =
9636 Args.hasArg(options::OPT_shared) ? "crtbeginS.obj" : "crtbegin.obj";
9637 CmdArgs.push_back(Args.MakeArgString(CRTPath + CRTBegin));
9638 }
9639
9640 Args.AddAllArgs(CmdArgs, options::OPT_L);
9641
9642 const auto &Paths = TC.getFilePaths();
9643 for (const auto &Path : Paths)
9644 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
9645
9646 AddLinkerInputs(TC, Inputs, Args, CmdArgs);
9647
9648 if (D.CCCIsCXX() && !Args.hasArg(options::OPT_nostdlib) &&
9649 !Args.hasArg(options::OPT_nodefaultlibs)) {
9650 bool StaticCXX = Args.hasArg(options::OPT_static_libstdcxx) &&
9651 !Args.hasArg(options::OPT_static);
9652 if (StaticCXX)
9653 CmdArgs.push_back("-Bstatic");
9654 TC.AddCXXStdlibLibArgs(Args, CmdArgs);
9655 if (StaticCXX)
9656 CmdArgs.push_back("-Bdynamic");
9657 }
9658
9659 if (!Args.hasArg(options::OPT_nostdlib)) {
9660 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
9661 // TODO handle /MT[d] /MD[d]
9662 CmdArgs.push_back("-lmsvcrt");
9663 AddRunTimeLibs(TC, D, CmdArgs, Args);
9664 }
9665 }
9666
9667 const std::string Linker = TC.GetProgramPath("ld");
9668 Exec = Args.MakeArgString(Linker);
9669
Justin Bognerd3371d82015-07-17 03:35:54 +00009670 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009671}
Douglas Katzman84a75642015-06-19 14:55:19 +00009672
Douglas Katzman95354292015-06-23 20:42:09 +00009673void tools::SHAVE::Compiler::ConstructJob(Compilation &C, const JobAction &JA,
9674 const InputInfo &Output,
9675 const InputInfoList &Inputs,
9676 const ArgList &Args,
9677 const char *LinkingOutput) const {
Douglas Katzman84a75642015-06-19 14:55:19 +00009678
9679 ArgStringList CmdArgs;
9680
9681 assert(Inputs.size() == 1);
9682 const InputInfo &II = Inputs[0];
9683 assert(II.getType() == types::TY_C || II.getType() == types::TY_CXX);
9684 assert(Output.getType() == types::TY_PP_Asm); // Require preprocessed asm.
9685
Douglas Katzman84a75642015-06-19 14:55:19 +00009686 CmdArgs.push_back("-DMYRIAD2");
9687 CmdArgs.push_back("-mcpu=myriad2");
9688 CmdArgs.push_back("-S");
9689
Douglas Katzmanf6071112015-08-03 14:34:22 +00009690 // Append all -I, -iquote, -isystem paths, defines/undefines,
9691 // 'f' flags, optimize flags, and warning options.
9692 // These are spelled the same way in clang and moviCompile.
Douglas Katzman38dca882015-09-08 19:29:55 +00009693 Args.AddAllArgs(CmdArgs, {options::OPT_I_Group, options::OPT_clang_i_Group,
9694 options::OPT_D, options::OPT_U,
9695 options::OPT_f_Group, options::OPT_f_clang_Group,
9696 options::OPT_g_Group, options::OPT_M_Group,
9697 options::OPT_O_Group, options::OPT_W_Group});
9698
9699 // If we're producing a dependency file, and assembly is the final action,
9700 // then the name of the target in the dependency file should be the '.o'
9701 // file, not the '.s' file produced by this step. For example, instead of
9702 // /tmp/mumble.s: mumble.c .../someheader.h
9703 // the filename on the lefthand side should be "mumble.o"
9704 if (Args.getLastArg(options::OPT_MF) && !Args.getLastArg(options::OPT_MT) &&
9705 C.getActions().size() == 1 &&
9706 C.getActions()[0]->getKind() == Action::AssembleJobClass) {
9707 Arg *A = Args.getLastArg(options::OPT_o);
9708 if (A) {
9709 CmdArgs.push_back("-MT");
9710 CmdArgs.push_back(Args.MakeArgString(A->getValue()));
9711 }
9712 }
9713
Douglas Katzman84a75642015-06-19 14:55:19 +00009714 CmdArgs.push_back("-fno-exceptions"); // Always do this even if unspecified.
9715
9716 CmdArgs.push_back(II.getFilename());
9717 CmdArgs.push_back("-o");
9718 CmdArgs.push_back(Output.getFilename());
9719
9720 std::string Exec =
9721 Args.MakeArgString(getToolChain().GetProgramPath("moviCompile"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009722 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Exec),
9723 CmdArgs, Inputs));
Douglas Katzman84a75642015-06-19 14:55:19 +00009724}
9725
Douglas Katzman95354292015-06-23 20:42:09 +00009726void tools::SHAVE::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
9727 const InputInfo &Output,
9728 const InputInfoList &Inputs,
9729 const ArgList &Args,
9730 const char *LinkingOutput) const {
Douglas Katzman84a75642015-06-19 14:55:19 +00009731 ArgStringList CmdArgs;
9732
9733 assert(Inputs.size() == 1);
9734 const InputInfo &II = Inputs[0];
9735 assert(II.getType() == types::TY_PP_Asm); // Require preprocessed asm input.
9736 assert(Output.getType() == types::TY_Object);
9737
9738 CmdArgs.push_back("-no6thSlotCompression");
Douglas Katzmanae2f3582015-09-11 21:13:46 +00009739 CmdArgs.push_back("-cv:myriad2"); // Chip Version
Douglas Katzman84a75642015-06-19 14:55:19 +00009740 CmdArgs.push_back("-noSPrefixing");
9741 CmdArgs.push_back("-a"); // Mystery option.
Douglas Katzmanae2f3582015-09-11 21:13:46 +00009742 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
9743 for (const Arg *A : Args.filtered(options::OPT_I, options::OPT_isystem)) {
9744 A->claim();
Douglas Katzman84a75642015-06-19 14:55:19 +00009745 CmdArgs.push_back(
Douglas Katzmanae2f3582015-09-11 21:13:46 +00009746 Args.MakeArgString(std::string("-i:") + A->getValue(0)));
Douglas Katzman84a75642015-06-19 14:55:19 +00009747 }
9748 CmdArgs.push_back("-elf"); // Output format.
9749 CmdArgs.push_back(II.getFilename());
9750 CmdArgs.push_back(
9751 Args.MakeArgString(std::string("-o:") + Output.getFilename()));
9752
9753 std::string Exec =
9754 Args.MakeArgString(getToolChain().GetProgramPath("moviAsm"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009755 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Exec),
9756 CmdArgs, Inputs));
Douglas Katzman84a75642015-06-19 14:55:19 +00009757}
Douglas Katzmand6e597c2015-09-17 19:56:40 +00009758
9759void tools::Myriad::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9760 const InputInfo &Output,
9761 const InputInfoList &Inputs,
9762 const ArgList &Args,
9763 const char *LinkingOutput) const {
9764 const auto &TC =
9765 static_cast<const toolchains::MyriadToolChain &>(getToolChain());
9766 const llvm::Triple &T = TC.getTriple();
9767 ArgStringList CmdArgs;
9768 bool UseStartfiles = !Args.hasArg(options::OPT_nostartfiles);
9769
9770 std::string StartFilesDir, BuiltinLibDir;
9771 TC.getCompilerSupportDir(StartFilesDir);
9772 TC.getBuiltinLibDir(BuiltinLibDir);
9773
9774 if (T.getArch() == llvm::Triple::sparc)
9775 CmdArgs.push_back("-EB");
9776 else // SHAVE assumes little-endian, and sparcel is expressly so.
9777 CmdArgs.push_back("-EL");
9778
9779 // The remaining logic is mostly like gnutools::Linker::ConstructJob,
9780 // but we never pass through a --sysroot option and various other bits.
9781 // For example, there are no sanitizers (yet) nor gold linker.
9782
9783 // Eat some arguments that may be present but have no effect.
9784 Args.ClaimAllArgs(options::OPT_g_Group);
9785 Args.ClaimAllArgs(options::OPT_w);
9786 Args.ClaimAllArgs(options::OPT_static_libgcc);
9787
9788 if (Args.hasArg(options::OPT_s)) // Pass the 'strip' option.
9789 CmdArgs.push_back("-s");
9790
9791 CmdArgs.push_back("-o");
9792 CmdArgs.push_back(Output.getFilename());
9793
9794 if (UseStartfiles) {
9795 // If you want startfiles, it means you want the builtin crti and crtbegin,
9796 // but not crt0. Myriad link commands provide their own crt0.o as needed.
9797 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crti.o"));
9798 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crtbegin.o"));
9799 }
9800
9801 Args.AddAllArgs(CmdArgs, {options::OPT_L, options::OPT_T_Group,
9802 options::OPT_e, options::OPT_s, options::OPT_t,
9803 options::OPT_Z_Flag, options::OPT_r});
9804
9805 // The linker doesn't use these builtin paths unless directed to,
9806 // because it was not compiled for support with sysroots, nor does
9807 // it have a default of little-endian with FPU.
9808 CmdArgs.push_back(Args.MakeArgString("-L" + BuiltinLibDir));
9809 CmdArgs.push_back(Args.MakeArgString("-L" + StartFilesDir));
9810
9811 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
9812
9813 if (T.getOS() == llvm::Triple::RTEMS) {
9814 CmdArgs.push_back("--start-group");
9815 CmdArgs.push_back("-lc");
9816 // You must provide your own "-L" option to enable finding these.
9817 CmdArgs.push_back("-lrtemscpu");
9818 CmdArgs.push_back("-lrtemsbsp");
9819 CmdArgs.push_back("--end-group");
9820 } else {
9821 CmdArgs.push_back("-lc");
9822 }
9823 if (C.getDriver().CCCIsCXX())
9824 CmdArgs.push_back("-lstdc++");
9825 CmdArgs.push_back("-lgcc");
9826 if (UseStartfiles) {
9827 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crtend.o"));
9828 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crtn.o"));
9829 }
9830
9831 std::string Exec =
9832 Args.MakeArgString(TC.GetProgramPath("sparc-myriad-elf-ld"));
9833 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Exec),
9834 CmdArgs, Inputs));
9835}