blob: a54a60f7d7ed3691953d10035f9fb5a7fc684a3b [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
Douglas Katzman9dc81a42015-10-02 14:41:38 +0000405 // Add -Wp, and -Xpreprocessor if using the preprocessor.
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000406
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()) {
Alexandros Lamprineaseda554a2015-10-05 12:45:10 +0000837 if (VersionNum < 6 ||
838 Triple.getSubArch() == llvm::Triple::SubArchType::ARMSubArch_v6m)
Akira Hatanaka7651dd82015-07-28 22:26:45 +0000839 Features.push_back("+strict-align");
840 } else if (Triple.isOSLinux() || Triple.isOSNaCl()) {
841 if (VersionNum < 7)
842 Features.push_back("+strict-align");
843 } else
844 Features.push_back("+strict-align");
845 }
846
Akira Hatanaka0a23fac2015-07-21 01:41:08 +0000847 // llvm does not support reserving registers in general. There is support
848 // for reserving r9 on ARM though (defined as a platform-specific register
849 // in ARM EABI).
850 if (Args.hasArg(options::OPT_ffixed_r9))
851 Features.push_back("+reserve-r9");
852
Akira Hatanaka580efb22015-07-16 00:43:00 +0000853 // The kext linker doesn't know how to deal with movw/movt.
854 if (KernelOrKext)
855 Features.push_back("+no-movt");
Rafael Espindola28e1f4b2013-08-21 16:39:20 +0000856}
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000857
Saleem Abdulrasoolce63ce92015-09-19 18:19:44 +0000858void Clang::AddARMTargetArgs(const llvm::Triple &Triple, const ArgList &Args,
859 ArgStringList &CmdArgs, bool KernelOrKext) const {
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000860 // Select the ABI to use.
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000861 // FIXME: Support -meabi.
Eric Christopher52276532014-12-10 22:58:34 +0000862 // FIXME: Parts of this are duplicated in the backend, unify this somehow.
Craig Topper92fc2df2014-05-17 16:56:41 +0000863 const char *ABIName = nullptr;
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000864 if (Arg *A = Args.getLastArg(options::OPT_mabi_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +0000865 ABIName = A->getValue();
Tim Northovere5c6f4c2014-05-22 12:54:30 +0000866 } else if (Triple.isOSBinFormatMachO()) {
Akira Hatanaka9d99bb52015-08-26 19:00:11 +0000867 if (useAAPCSForMachO(Triple)) {
Daniel Dunbar5f18f6e2012-10-22 18:30:51 +0000868 ABIName = "aapcs";
869 } else {
870 ABIName = "apcs-gnu";
871 }
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +0000872 } else if (Triple.isOSWindows()) {
873 // FIXME: this is invalid for WindowsCE
874 ABIName = "aapcs";
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000875 } else {
876 // Select the default based on the platform.
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000877 switch (Triple.getEnvironment()) {
Logan Chienc6fd8202012-09-02 09:30:11 +0000878 case llvm::Triple::Android:
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000879 case llvm::Triple::GNUEABI:
Jiangning Liu61b06cb2012-07-31 08:06:29 +0000880 case llvm::Triple::GNUEABIHF:
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000881 ABIName = "aapcs-linux";
882 break;
Joerg Sonnenbergerd75a1f82013-12-16 19:16:04 +0000883 case llvm::Triple::EABIHF:
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000884 case llvm::Triple::EABI:
885 ABIName = "aapcs";
886 break;
Oliver Stannardec8b6b32014-09-04 10:38:53 +0000887 default:
Eric Christopher7a8b31d2014-12-18 02:08:51 +0000888 if (Triple.getOS() == llvm::Triple::NetBSD)
889 ABIName = "apcs-gnu";
890 else
891 ABIName = "aapcs";
Oliver Stannardec8b6b32014-09-04 10:38:53 +0000892 break;
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000893 }
894 }
895 CmdArgs.push_back("-target-abi");
896 CmdArgs.push_back(ABIName);
897
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000898 // Determine floating point ABI from the options & target defaults.
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +0000899 arm::FloatABI ABI = arm::getARMFloatABI(getToolChain(), Args);
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000900 if (ABI == arm::FloatABI::Soft) {
Daniel Dunbar78485922009-09-10 23:00:09 +0000901 // Floating point operations and argument passing are soft.
Daniel Dunbar78485922009-09-10 23:00:09 +0000902 // FIXME: This changes CPP defines, we need -target-soft-float.
Daniel Dunbara74f8ff2009-11-30 08:42:00 +0000903 CmdArgs.push_back("-msoft-float");
Daniel Dunbar6cc525b2009-12-08 19:49:51 +0000904 CmdArgs.push_back("-mfloat-abi");
905 CmdArgs.push_back("soft");
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000906 } else if (ABI == arm::FloatABI::SoftFP) {
Daniel Dunbar78485922009-09-10 23:00:09 +0000907 // Floating point operations are hard, but argument passing is soft.
Daniel Dunbar6cc525b2009-12-08 19:49:51 +0000908 CmdArgs.push_back("-mfloat-abi");
909 CmdArgs.push_back("soft");
Daniel Dunbar78485922009-09-10 23:00:09 +0000910 } else {
911 // Floating point operations and argument passing are hard.
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000912 assert(ABI == arm::FloatABI::Hard && "Invalid float abi!");
Daniel Dunbar6cc525b2009-12-08 19:49:51 +0000913 CmdArgs.push_back("-mfloat-abi");
914 CmdArgs.push_back("hard");
Daniel Dunbar78485922009-09-10 23:00:09 +0000915 }
Daniel Dunbar893d4752009-12-19 04:15:38 +0000916
Ahmed Bougacha256a8692015-04-11 00:10:44 +0000917 // Forward the -mglobal-merge option for explicit control over the pass.
Chad Rosierba3df1d2011-08-26 00:26:29 +0000918 if (Arg *A = Args.getLastArg(options::OPT_mglobal_merge,
919 options::OPT_mno_global_merge)) {
Ahmed Bougacha256a8692015-04-11 00:10:44 +0000920 CmdArgs.push_back("-backend-option");
Chad Rosierba3df1d2011-08-26 00:26:29 +0000921 if (A->getOption().matches(options::OPT_mno_global_merge))
Ahmed Bougacha256a8692015-04-11 00:10:44 +0000922 CmdArgs.push_back("-arm-global-merge=false");
923 else
924 CmdArgs.push_back("-arm-global-merge=true");
Chad Rosierba3df1d2011-08-26 00:26:29 +0000925 }
Chad Rosierf1985d22012-05-16 20:40:09 +0000926
Bob Wilson9c8af452013-04-11 18:53:25 +0000927 if (!Args.hasFlag(options::OPT_mimplicit_float,
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000928 options::OPT_mno_implicit_float, true))
Chad Rosierf1985d22012-05-16 20:40:09 +0000929 CmdArgs.push_back("-no-implicit-float");
Daniel Dunbar0f5c5422009-09-10 04:57:17 +0000930}
Renato Goline17c5802015-07-27 23:44:42 +0000931// ARM tools end.
Daniel Dunbar0f5c5422009-09-10 04:57:17 +0000932
Tim Northover573cbee2014-05-24 12:52:07 +0000933/// getAArch64TargetCPU - Get the (LLVM) name of the AArch64 cpu we are
934/// targeting.
935static std::string getAArch64TargetCPU(const ArgList &Args) {
Kevin Qin110db6f2014-07-18 07:03:22 +0000936 Arg *A;
937 std::string CPU;
938 // If we have -mtune or -mcpu, use that.
939 if ((A = Args.getLastArg(options::OPT_mtune_EQ))) {
Gabor Ballabasa24a1a42015-07-20 11:28:20 +0000940 CPU = StringRef(A->getValue()).lower();
Kevin Qin110db6f2014-07-18 07:03:22 +0000941 } else if ((A = Args.getLastArg(options::OPT_mcpu_EQ))) {
Renato Golin4045f662015-05-08 15:44:36 +0000942 StringRef Mcpu = A->getValue();
Gabor Ballabas726ce7f2015-06-12 17:33:37 +0000943 CPU = Mcpu.split("+").first.lower();
Tim Northovera2ee4332014-03-29 15:09:45 +0000944 }
945
Kevin Qin110db6f2014-07-18 07:03:22 +0000946 // Handle CPU name is 'native'.
947 if (CPU == "native")
948 return llvm::sys::getHostCPUName();
949 else if (CPU.size())
950 return CPU;
Tim Northovera2ee4332014-03-29 15:09:45 +0000951
James Molloy9b1586b2014-04-17 12:51:17 +0000952 // Make sure we pick "cyclone" if -arch is used.
953 // FIXME: Should this be picked by checking the target triple instead?
954 if (Args.getLastArg(options::OPT_arch))
955 return "cyclone";
956
957 return "generic";
Tim Northovera2ee4332014-03-29 15:09:45 +0000958}
959
Tim Northover573cbee2014-05-24 12:52:07 +0000960void Clang::AddAArch64TargetArgs(const ArgList &Args,
961 ArgStringList &CmdArgs) const {
Tim Northovera2ee4332014-03-29 15:09:45 +0000962 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
963 llvm::Triple Triple(TripleStr);
964
965 if (!Args.hasFlag(options::OPT_mred_zone, options::OPT_mno_red_zone, true) ||
966 Args.hasArg(options::OPT_mkernel) ||
967 Args.hasArg(options::OPT_fapple_kext))
968 CmdArgs.push_back("-disable-red-zone");
969
970 if (!Args.hasFlag(options::OPT_mimplicit_float,
971 options::OPT_mno_implicit_float, true))
972 CmdArgs.push_back("-no-implicit-float");
973
Craig Topper92fc2df2014-05-17 16:56:41 +0000974 const char *ABIName = nullptr;
Tim Northovera2ee4332014-03-29 15:09:45 +0000975 if (Arg *A = Args.getLastArg(options::OPT_mabi_EQ))
976 ABIName = A->getValue();
977 else if (Triple.isOSDarwin())
978 ABIName = "darwinpcs";
979 else
980 ABIName = "aapcs";
981
982 CmdArgs.push_back("-target-abi");
983 CmdArgs.push_back(ABIName);
984
Bradley Smith9ff64332014-10-13 10:16:06 +0000985 if (Arg *A = Args.getLastArg(options::OPT_mfix_cortex_a53_835769,
986 options::OPT_mno_fix_cortex_a53_835769)) {
987 CmdArgs.push_back("-backend-option");
988 if (A->getOption().matches(options::OPT_mfix_cortex_a53_835769))
989 CmdArgs.push_back("-aarch64-fix-cortex-a53-835769=1");
990 else
991 CmdArgs.push_back("-aarch64-fix-cortex-a53-835769=0");
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +0000992 } else if (Triple.isAndroid()) {
Bradley Smith04ee8aa2014-10-16 16:35:14 +0000993 // Enabled A53 errata (835769) workaround by default on android
994 CmdArgs.push_back("-backend-option");
995 CmdArgs.push_back("-aarch64-fix-cortex-a53-835769=1");
Bradley Smith9ff64332014-10-13 10:16:06 +0000996 }
997
Ahmed Bougacha256a8692015-04-11 00:10:44 +0000998 // Forward the -mglobal-merge option for explicit control over the pass.
Bob Wilsonbdd2b3c2014-05-29 19:43:02 +0000999 if (Arg *A = Args.getLastArg(options::OPT_mglobal_merge,
1000 options::OPT_mno_global_merge)) {
Ahmed Bougacha256a8692015-04-11 00:10:44 +00001001 CmdArgs.push_back("-backend-option");
Bob Wilsonbdd2b3c2014-05-29 19:43:02 +00001002 if (A->getOption().matches(options::OPT_mno_global_merge))
Ahmed Bougacha256a8692015-04-11 00:10:44 +00001003 CmdArgs.push_back("-aarch64-global-merge=false");
1004 else
1005 CmdArgs.push_back("-aarch64-global-merge=true");
Bob Wilsonbdd2b3c2014-05-29 19:43:02 +00001006 }
Tim Northovera2ee4332014-03-29 15:09:45 +00001007}
1008
Simon Atanasyan3b7589a2012-04-07 22:09:23 +00001009// Get CPU and ABI names. They are not independent
1010// so we have to calculate them together.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001011void mips::getMipsCPUAndABI(const ArgList &Args, const llvm::Triple &Triple,
1012 StringRef &CPUName, StringRef &ABIName) {
Simon Atanasyan1a3665b62014-01-27 13:59:04 +00001013 const char *DefMips32CPU = "mips32r2";
1014 const char *DefMips64CPU = "mips64r2";
Akira Hatanaka37fd9e92011-09-26 21:07:52 +00001015
Daniel Sanders2bf13662014-07-10 14:40:57 +00001016 // MIPS32r6 is the default for mips(el)?-img-linux-gnu and MIPS64r6 is the
1017 // default for mips64(el)?-img-linux-gnu.
1018 if (Triple.getVendor() == llvm::Triple::ImaginationTechnologies &&
1019 Triple.getEnvironment() == llvm::Triple::GNU) {
1020 DefMips32CPU = "mips32r6";
1021 DefMips64CPU = "mips64r6";
1022 }
Renato Golin7c542b42015-07-27 23:44:45 +00001023
Petar Jovanovic9fe32cd2015-07-17 12:57:30 +00001024 // MIPS64r6 is the default for Android MIPS64 (mips64el-linux-android).
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00001025 if (Triple.isAndroid())
Petar Jovanovic9fe32cd2015-07-17 12:57:30 +00001026 DefMips64CPU = "mips64r6";
Daniel Sanders2bf13662014-07-10 14:40:57 +00001027
Brad Smithba26f582015-01-06 02:53:17 +00001028 // MIPS3 is the default for mips64*-unknown-openbsd.
1029 if (Triple.getOS() == llvm::Triple::OpenBSD)
1030 DefMips64CPU = "mips3";
1031
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001032 if (Arg *A = Args.getLastArg(options::OPT_march_EQ, options::OPT_mcpu_EQ))
Simon Atanasyane0cc7c72013-10-09 12:12:24 +00001033 CPUName = A->getValue();
Simon Atanasyan464a7f72012-09-10 08:32:41 +00001034
Simon Atanasyan4938ddb2013-04-21 13:30:10 +00001035 if (Arg *A = Args.getLastArg(options::OPT_mabi_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00001036 ABIName = A->getValue();
Simon Atanasyan4938ddb2013-04-21 13:30:10 +00001037 // Convert a GNU style Mips ABI name to the name
1038 // accepted by LLVM Mips backend.
1039 ABIName = llvm::StringSwitch<llvm::StringRef>(ABIName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001040 .Case("32", "o32")
1041 .Case("64", "n64")
1042 .Default(ABIName);
Simon Atanasyan4938ddb2013-04-21 13:30:10 +00001043 }
Simon Atanasyan464a7f72012-09-10 08:32:41 +00001044
1045 // Setup default CPU and ABI names.
1046 if (CPUName.empty() && ABIName.empty()) {
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001047 switch (Triple.getArch()) {
Simon Atanasyan464a7f72012-09-10 08:32:41 +00001048 default:
1049 llvm_unreachable("Unexpected triple arch name");
1050 case llvm::Triple::mips:
1051 case llvm::Triple::mipsel:
1052 CPUName = DefMips32CPU;
1053 break;
1054 case llvm::Triple::mips64:
1055 case llvm::Triple::mips64el:
1056 CPUName = DefMips64CPU;
1057 break;
1058 }
1059 }
1060
Simon Atanasyana42a84e2014-07-02 13:20:36 +00001061 if (ABIName.empty()) {
1062 // Deduce ABI name from the target triple.
1063 if (Triple.getArch() == llvm::Triple::mips ||
1064 Triple.getArch() == llvm::Triple::mipsel)
1065 ABIName = "o32";
1066 else
1067 ABIName = "n64";
1068 }
1069
1070 if (CPUName.empty()) {
Simon Atanasyan464a7f72012-09-10 08:32:41 +00001071 // Deduce CPU name from ABI name.
1072 CPUName = llvm::StringSwitch<const char *>(ABIName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001073 .Cases("o32", "eabi", DefMips32CPU)
1074 .Cases("n32", "n64", DefMips64CPU)
1075 .Default("");
Simon Atanasyan464a7f72012-09-10 08:32:41 +00001076 }
Simon Atanasyanc92717f2014-07-23 09:27:10 +00001077
1078 // FIXME: Warn on inconsistent use of -march and -mabi.
Simon Atanasyan3b7589a2012-04-07 22:09:23 +00001079}
1080
Simon Atanasyan0da400c2013-02-27 14:55:49 +00001081// Convert ABI name to the GNU tools acceptable variant.
1082static StringRef getGnuCompatibleMipsABIName(StringRef ABI) {
1083 return llvm::StringSwitch<llvm::StringRef>(ABI)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001084 .Case("o32", "32")
1085 .Case("n64", "64")
1086 .Default(ABI);
Simon Atanasyan0da400c2013-02-27 14:55:49 +00001087}
1088
Simon Atanasyan590ad8f2012-06-02 15:06:29 +00001089// Select the MIPS float ABI as determined by -msoft-float, -mhard-float,
1090// and -mfloat-abi=.
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001091static mips::FloatABI getMipsFloatABI(const Driver &D, const ArgList &Args) {
1092 mips::FloatABI ABI = mips::FloatABI::Invalid;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001093 if (Arg *A =
1094 Args.getLastArg(options::OPT_msoft_float, options::OPT_mhard_float,
1095 options::OPT_mfloat_abi_EQ)) {
Eric Christopher0b26a612010-03-02 02:41:08 +00001096 if (A->getOption().matches(options::OPT_msoft_float))
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001097 ABI = mips::FloatABI::Soft;
Eric Christopher0b26a612010-03-02 02:41:08 +00001098 else if (A->getOption().matches(options::OPT_mhard_float))
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001099 ABI = mips::FloatABI::Hard;
Akira Hatanaka6976ec82012-03-23 23:07:09 +00001100 else {
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001101 ABI = llvm::StringSwitch<mips::FloatABI>(A->getValue())
1102 .Case("soft", mips::FloatABI::Soft)
1103 .Case("hard", mips::FloatABI::Hard)
1104 .Default(mips::FloatABI::Invalid);
1105 if (ABI == mips::FloatABI::Invalid && !StringRef(A->getValue()).empty()) {
Simon Atanasyan590ad8f2012-06-02 15:06:29 +00001106 D.Diag(diag::err_drv_invalid_mfloat_abi) << A->getAsString(Args);
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001107 ABI = mips::FloatABI::Hard;
Akira Hatanaka6976ec82012-03-23 23:07:09 +00001108 }
1109 }
Eric Christopher0b26a612010-03-02 02:41:08 +00001110 }
1111
1112 // If unspecified, choose the default based on the platform.
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001113 if (ABI == mips::FloatABI::Invalid) {
Akira Hatanaka6976ec82012-03-23 23:07:09 +00001114 // Assume "hard", because it's a default value used by gcc.
1115 // When we start to recognize specific target MIPS processors,
1116 // we will be able to select the default more correctly.
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001117 ABI = mips::FloatABI::Hard;
Eric Christopher0b26a612010-03-02 02:41:08 +00001118 }
1119
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001120 assert(ABI != mips::FloatABI::Invalid && "must select an ABI");
1121 return ABI;
Simon Atanasyan590ad8f2012-06-02 15:06:29 +00001122}
1123
Simon Atanasyan9b1932d2012-07-05 18:51:43 +00001124static void AddTargetFeature(const ArgList &Args,
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001125 std::vector<const char *> &Features,
1126 OptSpecifier OnOpt, OptSpecifier OffOpt,
Simon Atanasyan9b1932d2012-07-05 18:51:43 +00001127 StringRef FeatureName) {
1128 if (Arg *A = Args.getLastArg(OnOpt, OffOpt)) {
Simon Atanasyan9b1932d2012-07-05 18:51:43 +00001129 if (A->getOption().matches(OnOpt))
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001130 Features.push_back(Args.MakeArgString("+" + FeatureName));
Simon Atanasyan9b1932d2012-07-05 18:51:43 +00001131 else
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001132 Features.push_back(Args.MakeArgString("-" + FeatureName));
Simon Atanasyan9b1932d2012-07-05 18:51:43 +00001133 }
1134}
1135
Daniel Sanders379d44b2014-07-16 11:52:23 +00001136static void getMIPSTargetFeatures(const Driver &D, const llvm::Triple &Triple,
1137 const ArgList &Args,
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001138 std::vector<const char *> &Features) {
Daniel Sanders379d44b2014-07-16 11:52:23 +00001139 StringRef CPUName;
1140 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00001141 mips::getMipsCPUAndABI(Args, Triple, CPUName, ABIName);
Daniel Sanders379d44b2014-07-16 11:52:23 +00001142 ABIName = getGnuCompatibleMipsABIName(ABIName);
1143
Daniel Sandersfeb61302014-08-08 15:47:17 +00001144 AddTargetFeature(Args, Features, options::OPT_mno_abicalls,
1145 options::OPT_mabicalls, "noabicalls");
Daniel Sanderse805f442014-08-08 13:44:50 +00001146
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001147 mips::FloatABI FloatABI = getMipsFloatABI(D, Args);
1148 if (FloatABI == mips::FloatABI::Soft) {
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001149 // FIXME: Note, this is a hack. We need to pass the selected float
1150 // mode to the MipsTargetInfoBase to define appropriate macros there.
1151 // Now it is the only method.
1152 Features.push_back("+soft-float");
1153 }
1154
Simon Atanasyan22127ce2013-09-24 09:09:16 +00001155 if (Arg *A = Args.getLastArg(options::OPT_mnan_EQ)) {
Matheus Almeida602bff32014-05-07 16:16:07 +00001156 StringRef Val = StringRef(A->getValue());
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00001157 if (Val == "2008") {
1158 if (mips::getSupportedNanEncoding(CPUName) & mips::Nan2008)
1159 Features.push_back("+nan2008");
1160 else {
1161 Features.push_back("-nan2008");
1162 D.Diag(diag::warn_target_unsupported_nan2008) << CPUName;
1163 }
1164 } else if (Val == "legacy") {
1165 if (mips::getSupportedNanEncoding(CPUName) & mips::NanLegacy)
1166 Features.push_back("-nan2008");
1167 else {
1168 Features.push_back("+nan2008");
1169 D.Diag(diag::warn_target_unsupported_nanlegacy) << CPUName;
1170 }
1171 } else
Matheus Almeida602bff32014-05-07 16:16:07 +00001172 D.Diag(diag::err_drv_unsupported_option_argument)
1173 << A->getOption().getName() << Val;
Simon Atanasyan22127ce2013-09-24 09:09:16 +00001174 }
1175
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001176 AddTargetFeature(Args, Features, options::OPT_msingle_float,
1177 options::OPT_mdouble_float, "single-float");
1178 AddTargetFeature(Args, Features, options::OPT_mips16, options::OPT_mno_mips16,
1179 "mips16");
1180 AddTargetFeature(Args, Features, options::OPT_mmicromips,
1181 options::OPT_mno_micromips, "micromips");
1182 AddTargetFeature(Args, Features, options::OPT_mdsp, options::OPT_mno_dsp,
1183 "dsp");
1184 AddTargetFeature(Args, Features, options::OPT_mdspr2, options::OPT_mno_dspr2,
1185 "dspr2");
1186 AddTargetFeature(Args, Features, options::OPT_mmsa, options::OPT_mno_msa,
1187 "msa");
Daniel Sanders379d44b2014-07-16 11:52:23 +00001188
1189 // Add the last -mfp32/-mfpxx/-mfp64 or if none are given and the ABI is O32
1190 // pass -mfpxx
1191 if (Arg *A = Args.getLastArg(options::OPT_mfp32, options::OPT_mfpxx,
1192 options::OPT_mfp64)) {
1193 if (A->getOption().matches(options::OPT_mfp32))
1194 Features.push_back(Args.MakeArgString("-fp64"));
1195 else if (A->getOption().matches(options::OPT_mfpxx)) {
1196 Features.push_back(Args.MakeArgString("+fpxx"));
1197 Features.push_back(Args.MakeArgString("+nooddspreg"));
1198 } else
1199 Features.push_back(Args.MakeArgString("+fp64"));
Toma Tabacu94ea6862015-06-16 13:54:13 +00001200 } else if (mips::shouldUseFPXX(Args, Triple, CPUName, ABIName, FloatABI)) {
Daniel Sanders2e9427a2014-07-16 09:57:54 +00001201 Features.push_back(Args.MakeArgString("+fpxx"));
1202 Features.push_back(Args.MakeArgString("+nooddspreg"));
1203 }
Daniel Sanders379d44b2014-07-16 11:52:23 +00001204
Daniel Sanders28e5d392014-07-10 10:39:51 +00001205 AddTargetFeature(Args, Features, options::OPT_mno_odd_spreg,
1206 options::OPT_modd_spreg, "nooddspreg");
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001207}
1208
Simon Atanasyan590ad8f2012-06-02 15:06:29 +00001209void Clang::AddMIPSTargetArgs(const ArgList &Args,
Simon Atanasyanf0087242013-04-14 14:07:41 +00001210 ArgStringList &CmdArgs) const {
Simon Atanasyan590ad8f2012-06-02 15:06:29 +00001211 const Driver &D = getToolChain().getDriver();
1212 StringRef CPUName;
1213 StringRef ABIName;
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001214 const llvm::Triple &Triple = getToolChain().getTriple();
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00001215 mips::getMipsCPUAndABI(Args, Triple, CPUName, ABIName);
Simon Atanasyan590ad8f2012-06-02 15:06:29 +00001216
1217 CmdArgs.push_back("-target-abi");
1218 CmdArgs.push_back(ABIName.data());
1219
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001220 mips::FloatABI ABI = getMipsFloatABI(D, Args);
1221 if (ABI == mips::FloatABI::Soft) {
Eric Christopher0b26a612010-03-02 02:41:08 +00001222 // Floating point operations and argument passing are soft.
Eric Christopher0b26a612010-03-02 02:41:08 +00001223 CmdArgs.push_back("-msoft-float");
Akira Hatanaka6976ec82012-03-23 23:07:09 +00001224 CmdArgs.push_back("-mfloat-abi");
1225 CmdArgs.push_back("soft");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001226 } else {
Akira Hatanaka6976ec82012-03-23 23:07:09 +00001227 // Floating point operations and argument passing are hard.
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001228 assert(ABI == mips::FloatABI::Hard && "Invalid float abi!");
Akira Hatanaka6976ec82012-03-23 23:07:09 +00001229 CmdArgs.push_back("-mfloat-abi");
1230 CmdArgs.push_back("hard");
Eric Christopher0b26a612010-03-02 02:41:08 +00001231 }
Simon Atanasyan6f23fa02012-07-05 14:19:39 +00001232
Simon Atanasyan2eaec512012-12-01 18:27:21 +00001233 if (Arg *A = Args.getLastArg(options::OPT_mxgot, options::OPT_mno_xgot)) {
1234 if (A->getOption().matches(options::OPT_mxgot)) {
1235 CmdArgs.push_back("-mllvm");
1236 CmdArgs.push_back("-mxgot");
1237 }
1238 }
1239
Simon Atanasyanc580b322013-05-11 06:33:44 +00001240 if (Arg *A = Args.getLastArg(options::OPT_mldc1_sdc1,
1241 options::OPT_mno_ldc1_sdc1)) {
1242 if (A->getOption().matches(options::OPT_mno_ldc1_sdc1)) {
1243 CmdArgs.push_back("-mllvm");
1244 CmdArgs.push_back("-mno-ldc1-sdc1");
1245 }
1246 }
1247
Akira Hatanaka0aa60ef2013-07-19 18:58:48 +00001248 if (Arg *A = Args.getLastArg(options::OPT_mcheck_zero_division,
1249 options::OPT_mno_check_zero_division)) {
1250 if (A->getOption().matches(options::OPT_mno_check_zero_division)) {
1251 CmdArgs.push_back("-mllvm");
1252 CmdArgs.push_back("-mno-check-zero-division");
1253 }
1254 }
1255
Simon Atanasyanec4b1c12012-08-27 20:55:56 +00001256 if (Arg *A = Args.getLastArg(options::OPT_G)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00001257 StringRef v = A->getValue();
Simon Atanasyanec4b1c12012-08-27 20:55:56 +00001258 CmdArgs.push_back("-mllvm");
1259 CmdArgs.push_back(Args.MakeArgString("-mips-ssection-threshold=" + v));
1260 A->claim();
1261 }
Eric Christopher0b26a612010-03-02 02:41:08 +00001262}
1263
Hal Finkel8eb59282012-06-11 22:35:19 +00001264/// getPPCTargetCPU - Get the (LLVM) name of the PowerPC cpu we are targeting.
1265static std::string getPPCTargetCPU(const ArgList &Args) {
1266 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00001267 StringRef CPUName = A->getValue();
Hal Finkel8eb59282012-06-11 22:35:19 +00001268
1269 if (CPUName == "native") {
1270 std::string CPU = llvm::sys::getHostCPUName();
1271 if (!CPU.empty() && CPU != "generic")
1272 return CPU;
1273 else
1274 return "";
1275 }
1276
1277 return llvm::StringSwitch<const char *>(CPUName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001278 .Case("common", "generic")
1279 .Case("440", "440")
1280 .Case("440fp", "440")
1281 .Case("450", "450")
1282 .Case("601", "601")
1283 .Case("602", "602")
1284 .Case("603", "603")
1285 .Case("603e", "603e")
1286 .Case("603ev", "603ev")
1287 .Case("604", "604")
1288 .Case("604e", "604e")
1289 .Case("620", "620")
1290 .Case("630", "pwr3")
1291 .Case("G3", "g3")
1292 .Case("7400", "7400")
1293 .Case("G4", "g4")
1294 .Case("7450", "7450")
1295 .Case("G4+", "g4+")
1296 .Case("750", "750")
1297 .Case("970", "970")
1298 .Case("G5", "g5")
1299 .Case("a2", "a2")
1300 .Case("a2q", "a2q")
1301 .Case("e500mc", "e500mc")
1302 .Case("e5500", "e5500")
1303 .Case("power3", "pwr3")
1304 .Case("power4", "pwr4")
1305 .Case("power5", "pwr5")
1306 .Case("power5x", "pwr5x")
1307 .Case("power6", "pwr6")
1308 .Case("power6x", "pwr6x")
1309 .Case("power7", "pwr7")
1310 .Case("power8", "pwr8")
1311 .Case("pwr3", "pwr3")
1312 .Case("pwr4", "pwr4")
1313 .Case("pwr5", "pwr5")
1314 .Case("pwr5x", "pwr5x")
1315 .Case("pwr6", "pwr6")
1316 .Case("pwr6x", "pwr6x")
1317 .Case("pwr7", "pwr7")
1318 .Case("pwr8", "pwr8")
1319 .Case("powerpc", "ppc")
1320 .Case("powerpc64", "ppc64")
1321 .Case("powerpc64le", "ppc64le")
1322 .Default("");
Hal Finkel8eb59282012-06-11 22:35:19 +00001323 }
1324
1325 return "";
1326}
1327
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001328static void getPPCTargetFeatures(const ArgList &Args,
1329 std::vector<const char *> &Features) {
Sean Silva14facf32015-06-09 01:57:17 +00001330 for (const Arg *A : Args.filtered(options::OPT_m_ppc_Features_Group)) {
1331 StringRef Name = A->getOption().getName();
1332 A->claim();
Eric Christopher643bb6a2013-10-16 20:40:08 +00001333
1334 // Skip over "-m".
1335 assert(Name.startswith("m") && "Invalid feature name.");
1336 Name = Name.substr(1);
1337
1338 bool IsNegative = Name.startswith("no-");
1339 if (IsNegative)
1340 Name = Name.substr(3);
1341
1342 // Note that gcc calls this mfcrf and LLVM calls this mfocrf so we
1343 // pass the correct option to the backend while calling the frontend
1344 // option the same.
1345 // TODO: Change the LLVM backend option maybe?
1346 if (Name == "mfcrf")
1347 Name = "mfocrf";
1348
1349 Features.push_back(Args.MakeArgString((IsNegative ? "-" : "+") + Name));
1350 }
1351
1352 // Altivec is a bit weird, allow overriding of the Altivec feature here.
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001353 AddTargetFeature(Args, Features, options::OPT_faltivec,
1354 options::OPT_fno_altivec, "altivec");
Hal Finkel8eb59282012-06-11 22:35:19 +00001355}
1356
Ulrich Weigand8afad612014-07-28 13:17:52 +00001357void Clang::AddPPCTargetArgs(const ArgList &Args,
1358 ArgStringList &CmdArgs) const {
1359 // Select the ABI to use.
1360 const char *ABIName = nullptr;
Eric Christopher71e5e3d2015-07-10 18:25:54 +00001361 if (getToolChain().getTriple().isOSLinux())
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001362 switch (getToolChain().getArch()) {
Hal Finkel0d0a1a52015-03-11 19:14:15 +00001363 case llvm::Triple::ppc64: {
1364 // When targeting a processor that supports QPX, or if QPX is
1365 // specifically enabled, default to using the ABI that supports QPX (so
1366 // long as it is not specifically disabled).
1367 bool HasQPX = false;
1368 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ))
1369 HasQPX = A->getValue() == StringRef("a2q");
1370 HasQPX = Args.hasFlag(options::OPT_mqpx, options::OPT_mno_qpx, HasQPX);
1371 if (HasQPX) {
1372 ABIName = "elfv1-qpx";
1373 break;
1374 }
1375
Ulrich Weigand8afad612014-07-28 13:17:52 +00001376 ABIName = "elfv1";
1377 break;
Hal Finkel0d0a1a52015-03-11 19:14:15 +00001378 }
Ulrich Weigand8afad612014-07-28 13:17:52 +00001379 case llvm::Triple::ppc64le:
1380 ABIName = "elfv2";
1381 break;
1382 default:
1383 break;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001384 }
Ulrich Weigand8afad612014-07-28 13:17:52 +00001385
Eric Christopher71e5e3d2015-07-10 18:25:54 +00001386 if (Arg *A = Args.getLastArg(options::OPT_mabi_EQ))
1387 // The ppc64 linux abis are all "altivec" abis by default. Accept and ignore
1388 // the option if given as we don't have backend support for any targets
1389 // that don't use the altivec abi.
1390 if (StringRef(A->getValue()) != "altivec")
1391 ABIName = A->getValue();
1392
Ulrich Weigand8afad612014-07-28 13:17:52 +00001393 if (ABIName) {
1394 CmdArgs.push_back("-target-abi");
1395 CmdArgs.push_back(ABIName);
1396 }
1397}
1398
1399bool ppc::hasPPCAbiArg(const ArgList &Args, const char *Value) {
1400 Arg *A = Args.getLastArg(options::OPT_mabi_EQ);
1401 return A && (A->getValue() == StringRef(Value));
1402}
1403
Tom Stellard6674c702013-04-01 20:56:53 +00001404/// Get the (LLVM) name of the R600 gpu we are targeting.
1405static std::string getR600TargetGPU(const ArgList &Args) {
1406 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ)) {
Benjamin Kramerb2ccade2013-10-21 12:33:55 +00001407 const char *GPUName = A->getValue();
Tom Stellard6674c702013-04-01 20:56:53 +00001408 return llvm::StringSwitch<const char *>(GPUName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001409 .Cases("rv630", "rv635", "r600")
1410 .Cases("rv610", "rv620", "rs780", "rs880")
1411 .Case("rv740", "rv770")
1412 .Case("palm", "cedar")
1413 .Cases("sumo", "sumo2", "sumo")
1414 .Case("hemlock", "cypress")
1415 .Case("aruba", "cayman")
1416 .Default(GPUName);
Tom Stellard6674c702013-04-01 20:56:53 +00001417 }
1418 return "";
1419}
1420
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001421void Clang::AddSparcTargetArgs(const ArgList &Args,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001422 ArgStringList &CmdArgs) const {
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001423 const Driver &D = getToolChain().getDriver();
James Y Knightb2406522015-06-15 20:51:24 +00001424 std::string Triple = getToolChain().ComputeEffectiveClangTriple(Args);
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001425
James Y Knightb2406522015-06-15 20:51:24 +00001426 bool SoftFloatABI = false;
1427 if (Arg *A =
1428 Args.getLastArg(options::OPT_msoft_float, options::OPT_mhard_float)) {
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001429 if (A->getOption().matches(options::OPT_msoft_float))
James Y Knightb2406522015-06-15 20:51:24 +00001430 SoftFloatABI = true;
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001431 }
1432
James Y Knightb2406522015-06-15 20:51:24 +00001433 // Only the hard-float ABI on Sparc is standardized, and it is the
1434 // default. GCC also supports a nonstandard soft-float ABI mode, and
1435 // perhaps LLVM should implement that, too. However, since llvm
1436 // currently does not support Sparc soft-float, at all, display an
1437 // error if it's requested.
1438 if (SoftFloatABI) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001439 D.Diag(diag::err_drv_unsupported_opt_for_target) << "-msoft-float"
1440 << Triple;
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001441 }
1442}
1443
Richard Sandiford4652d892013-07-19 16:51:51 +00001444static const char *getSystemZTargetCPU(const ArgList &Args) {
1445 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ))
1446 return A->getValue();
1447 return "z10";
1448}
1449
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00001450static void getSystemZTargetFeatures(const ArgList &Args,
1451 std::vector<const char *> &Features) {
1452 // -m(no-)htm overrides use of the transactional-execution facility.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001453 if (Arg *A = Args.getLastArg(options::OPT_mhtm, options::OPT_mno_htm)) {
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00001454 if (A->getOption().matches(options::OPT_mhtm))
1455 Features.push_back("+transactional-execution");
1456 else
1457 Features.push_back("-transactional-execution");
1458 }
Ulrich Weigand66ff51b2015-05-05 19:35:52 +00001459 // -m(no-)vx overrides use of the vector facility.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001460 if (Arg *A = Args.getLastArg(options::OPT_mvx, options::OPT_mno_vx)) {
Ulrich Weigand66ff51b2015-05-05 19:35:52 +00001461 if (A->getOption().matches(options::OPT_mvx))
1462 Features.push_back("+vector");
1463 else
1464 Features.push_back("-vector");
1465 }
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00001466}
1467
Chandler Carruth953fb082013-01-13 11:46:33 +00001468static const char *getX86TargetCPU(const ArgList &Args,
1469 const llvm::Triple &Triple) {
1470 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ)) {
Jim Grosbach82eee262013-11-16 00:53:35 +00001471 if (StringRef(A->getValue()) != "native") {
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00001472 if (Triple.isOSDarwin() && Triple.getArchName() == "x86_64h")
Jim Grosbach82eee262013-11-16 00:53:35 +00001473 return "core-avx2";
1474
Chandler Carruth953fb082013-01-13 11:46:33 +00001475 return A->getValue();
Jim Grosbach82eee262013-11-16 00:53:35 +00001476 }
Chandler Carruth953fb082013-01-13 11:46:33 +00001477
1478 // FIXME: Reject attempts to use -march=native unless the target matches
1479 // the host.
1480 //
1481 // FIXME: We should also incorporate the detected target features for use
1482 // with -native.
1483 std::string CPU = llvm::sys::getHostCPUName();
1484 if (!CPU.empty() && CPU != "generic")
1485 return Args.MakeArgString(CPU);
1486 }
1487
Reid Kleckner3123eff2015-06-30 16:32:04 +00001488 if (const Arg *A = Args.getLastArg(options::OPT__SLASH_arch)) {
1489 // Mapping built by referring to X86TargetInfo::getDefaultFeatures().
1490 StringRef Arch = A->getValue();
1491 const char *CPU;
1492 if (Triple.getArch() == llvm::Triple::x86) {
1493 CPU = llvm::StringSwitch<const char *>(Arch)
1494 .Case("IA32", "i386")
1495 .Case("SSE", "pentium3")
1496 .Case("SSE2", "pentium4")
1497 .Case("AVX", "sandybridge")
1498 .Case("AVX2", "haswell")
1499 .Default(nullptr);
1500 } else {
1501 CPU = llvm::StringSwitch<const char *>(Arch)
1502 .Case("AVX", "sandybridge")
1503 .Case("AVX2", "haswell")
1504 .Default(nullptr);
1505 }
1506 if (CPU)
1507 return CPU;
1508 }
1509
Chandler Carruth953fb082013-01-13 11:46:33 +00001510 // Select the default CPU if none was given (or detection failed).
1511
1512 if (Triple.getArch() != llvm::Triple::x86_64 &&
1513 Triple.getArch() != llvm::Triple::x86)
Craig Topper92fc2df2014-05-17 16:56:41 +00001514 return nullptr; // This routine is only handling x86 targets.
Chandler Carruth953fb082013-01-13 11:46:33 +00001515
1516 bool Is64Bit = Triple.getArch() == llvm::Triple::x86_64;
1517
1518 // FIXME: Need target hooks.
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00001519 if (Triple.isOSDarwin()) {
Jim Grosbach82eee262013-11-16 00:53:35 +00001520 if (Triple.getArchName() == "x86_64h")
1521 return "core-avx2";
Chandler Carruth953fb082013-01-13 11:46:33 +00001522 return Is64Bit ? "core2" : "yonah";
Jim Grosbach82eee262013-11-16 00:53:35 +00001523 }
Chandler Carruth953fb082013-01-13 11:46:33 +00001524
Filipe Cabecinhas4b442572015-01-27 17:27:37 +00001525 // Set up default CPU name for PS4 compilers.
1526 if (Triple.isPS4CPU())
1527 return "btver2";
1528
Alexey Bataev286d1b92014-01-31 04:07:13 +00001529 // On Android use targets compatible with gcc
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00001530 if (Triple.isAndroid())
Alexey Bataev286d1b92014-01-31 04:07:13 +00001531 return Is64Bit ? "x86-64" : "i686";
Chandler Carruth953fb082013-01-13 11:46:33 +00001532
Benjamin Kramerb2ccade2013-10-21 12:33:55 +00001533 // Everything else goes to x86-64 in 64-bit mode.
1534 if (Is64Bit)
1535 return "x86-64";
1536
1537 switch (Triple.getOS()) {
1538 case llvm::Triple::FreeBSD:
1539 case llvm::Triple::NetBSD:
1540 case llvm::Triple::OpenBSD:
1541 return "i486";
1542 case llvm::Triple::Haiku:
1543 return "i586";
1544 case llvm::Triple::Bitrig:
1545 return "i686";
1546 default:
1547 // Fallback to p4.
1548 return "pentium4";
1549 }
Chandler Carruth953fb082013-01-13 11:46:33 +00001550}
1551
Dan Gohmanc2853072015-09-03 22:51:53 +00001552/// Get the (LLVM) name of the WebAssembly cpu we are targeting.
1553static StringRef getWebAssemblyTargetCPU(const ArgList &Args) {
1554 // If we have -mcpu=, use that.
1555 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ)) {
1556 StringRef CPU = A->getValue();
1557
1558#ifdef __wasm__
1559 // Handle "native" by examining the host. "native" isn't meaningful when
1560 // cross compiling, so only support this when the host is also WebAssembly.
1561 if (CPU == "native")
1562 return llvm::sys::getHostCPUName();
1563#endif
1564
1565 return CPU;
1566 }
1567
1568 return "generic";
1569}
1570
Renato Golin7c542b42015-07-27 23:44:45 +00001571static std::string getCPUName(const ArgList &Args, const llvm::Triple &T,
1572 bool FromAs = false) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001573 switch (T.getArch()) {
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001574 default:
1575 return "";
1576
Amara Emerson703da2e2013-10-31 09:32:33 +00001577 case llvm::Triple::aarch64:
Christian Pirker9b019ae2014-02-25 13:51:00 +00001578 case llvm::Triple::aarch64_be:
Tim Northover573cbee2014-05-24 12:52:07 +00001579 return getAArch64TargetCPU(Args);
Quentin Colombetd9f26202014-04-15 00:27:35 +00001580
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001581 case llvm::Triple::arm:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00001582 case llvm::Triple::armeb:
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001583 case llvm::Triple::thumb:
Renato Goline17c5802015-07-27 23:44:42 +00001584 case llvm::Triple::thumbeb: {
1585 StringRef MArch, MCPU;
Renato Golin7c542b42015-07-27 23:44:45 +00001586 getARMArchCPUFromArgs(Args, MArch, MCPU, FromAs);
Renato Goline17c5802015-07-27 23:44:42 +00001587 return arm::getARMTargetCPU(MCPU, MArch, T);
1588 }
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001589 case llvm::Triple::mips:
1590 case llvm::Triple::mipsel:
1591 case llvm::Triple::mips64:
1592 case llvm::Triple::mips64el: {
1593 StringRef CPUName;
1594 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00001595 mips::getMipsCPUAndABI(Args, T, CPUName, ABIName);
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001596 return CPUName;
1597 }
1598
Artem Belevich0ff05cd2015-07-13 23:27:56 +00001599 case llvm::Triple::nvptx:
1600 case llvm::Triple::nvptx64:
1601 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ))
1602 return A->getValue();
1603 return "";
1604
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001605 case llvm::Triple::ppc:
1606 case llvm::Triple::ppc64:
1607 case llvm::Triple::ppc64le: {
1608 std::string TargetCPUName = getPPCTargetCPU(Args);
1609 // LLVM may default to generating code for the native CPU,
1610 // but, like gcc, we default to a more generic option for
1611 // each architecture. (except on Darwin)
1612 if (TargetCPUName.empty() && !T.isOSDarwin()) {
1613 if (T.getArch() == llvm::Triple::ppc64)
1614 TargetCPUName = "ppc64";
1615 else if (T.getArch() == llvm::Triple::ppc64le)
1616 TargetCPUName = "ppc64le";
1617 else
1618 TargetCPUName = "ppc";
1619 }
1620 return TargetCPUName;
1621 }
1622
1623 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00001624 case llvm::Triple::sparcel:
Roman Divackyb1ae3d42014-02-25 18:35:30 +00001625 case llvm::Triple::sparcv9:
1626 if (const Arg *A = Args.getLastArg(options::OPT_mcpu_EQ))
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001627 return A->getValue();
1628 return "";
1629
1630 case llvm::Triple::x86:
1631 case llvm::Triple::x86_64:
1632 return getX86TargetCPU(Args, T);
1633
1634 case llvm::Triple::hexagon:
Douglas Katzman54366072015-07-27 16:53:08 +00001635 return "hexagon" + toolchains::HexagonToolChain::GetTargetCPU(Args).str();
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001636
1637 case llvm::Triple::systemz:
1638 return getSystemZTargetCPU(Args);
1639
1640 case llvm::Triple::r600:
Tom Stellardd8e38a32015-01-06 20:34:47 +00001641 case llvm::Triple::amdgcn:
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001642 return getR600TargetGPU(Args);
Dan Gohmanc2853072015-09-03 22:51:53 +00001643
1644 case llvm::Triple::wasm32:
1645 case llvm::Triple::wasm64:
1646 return getWebAssemblyTargetCPU(Args);
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001647 }
1648}
1649
Alp Tokerce365ca2013-12-02 12:43:03 +00001650static void AddGoldPlugin(const ToolChain &ToolChain, const ArgList &Args,
1651 ArgStringList &CmdArgs) {
1652 // Tell the linker to load the plugin. This has to come before AddLinkerInputs
1653 // as gold requires -plugin to come before any -plugin-opt that -Wl might
1654 // forward.
1655 CmdArgs.push_back("-plugin");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001656 std::string Plugin =
1657 ToolChain.getDriver().Dir + "/../lib" CLANG_LIBDIR_SUFFIX "/LLVMgold.so";
Alp Tokerce365ca2013-12-02 12:43:03 +00001658 CmdArgs.push_back(Args.MakeArgString(Plugin));
1659
1660 // Try to pass driver level flags relevant to LTO code generation down to
1661 // the plugin.
1662
1663 // Handle flags for selecting CPU variants.
1664 std::string CPU = getCPUName(Args, ToolChain.getTriple());
1665 if (!CPU.empty())
1666 CmdArgs.push_back(Args.MakeArgString(Twine("-plugin-opt=mcpu=") + CPU));
1667}
1668
Sanjay Patel2987c292015-06-11 14:53:41 +00001669/// This is a helper function for validating the optional refinement step
1670/// parameter in reciprocal argument strings. Return false if there is an error
1671/// parsing the refinement step. Otherwise, return true and set the Position
1672/// of the refinement step in the input string.
Craig Topper3db9ba42015-09-21 00:20:04 +00001673static bool getRefinementStep(StringRef In, const Driver &D,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001674 const Arg &A, size_t &Position) {
Sanjay Patel2987c292015-06-11 14:53:41 +00001675 const char RefinementStepToken = ':';
1676 Position = In.find(RefinementStepToken);
1677 if (Position != StringRef::npos) {
1678 StringRef Option = A.getOption().getName();
1679 StringRef RefStep = In.substr(Position + 1);
1680 // Allow exactly one numeric character for the additional refinement
1681 // step parameter. This is reasonable for all currently-supported
1682 // operations and architectures because we would expect that a larger value
1683 // of refinement steps would cause the estimate "optimization" to
1684 // under-perform the native operation. Also, if the estimate does not
1685 // converge quickly, it probably will not ever converge, so further
1686 // refinement steps will not produce a better answer.
1687 if (RefStep.size() != 1) {
1688 D.Diag(diag::err_drv_invalid_value) << Option << RefStep;
1689 return false;
1690 }
1691 char RefStepChar = RefStep[0];
1692 if (RefStepChar < '0' || RefStepChar > '9') {
1693 D.Diag(diag::err_drv_invalid_value) << Option << RefStep;
1694 return false;
1695 }
1696 }
1697 return true;
1698}
1699
1700/// The -mrecip flag requires processing of many optional parameters.
1701static void ParseMRecip(const Driver &D, const ArgList &Args,
1702 ArgStringList &OutStrings) {
1703 StringRef DisabledPrefixIn = "!";
1704 StringRef DisabledPrefixOut = "!";
1705 StringRef EnabledPrefixOut = "";
1706 StringRef Out = "-mrecip=";
1707
1708 Arg *A = Args.getLastArg(options::OPT_mrecip, options::OPT_mrecip_EQ);
1709 if (!A)
1710 return;
1711
1712 unsigned NumOptions = A->getNumValues();
1713 if (NumOptions == 0) {
1714 // No option is the same as "all".
1715 OutStrings.push_back(Args.MakeArgString(Out + "all"));
1716 return;
1717 }
1718
1719 // Pass through "all", "none", or "default" with an optional refinement step.
1720 if (NumOptions == 1) {
1721 StringRef Val = A->getValue(0);
1722 size_t RefStepLoc;
1723 if (!getRefinementStep(Val, D, *A, RefStepLoc))
1724 return;
1725 StringRef ValBase = Val.slice(0, RefStepLoc);
1726 if (ValBase == "all" || ValBase == "none" || ValBase == "default") {
1727 OutStrings.push_back(Args.MakeArgString(Out + Val));
1728 return;
1729 }
1730 }
1731
1732 // Each reciprocal type may be enabled or disabled individually.
1733 // Check each input value for validity, concatenate them all back together,
1734 // and pass through.
1735
1736 llvm::StringMap<bool> OptionStrings;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001737 OptionStrings.insert(std::make_pair("divd", false));
1738 OptionStrings.insert(std::make_pair("divf", false));
1739 OptionStrings.insert(std::make_pair("vec-divd", false));
1740 OptionStrings.insert(std::make_pair("vec-divf", false));
1741 OptionStrings.insert(std::make_pair("sqrtd", false));
1742 OptionStrings.insert(std::make_pair("sqrtf", false));
1743 OptionStrings.insert(std::make_pair("vec-sqrtd", false));
1744 OptionStrings.insert(std::make_pair("vec-sqrtf", false));
Sanjay Patel2987c292015-06-11 14:53:41 +00001745
1746 for (unsigned i = 0; i != NumOptions; ++i) {
1747 StringRef Val = A->getValue(i);
1748
1749 bool IsDisabled = Val.startswith(DisabledPrefixIn);
1750 // Ignore the disablement token for string matching.
1751 if (IsDisabled)
1752 Val = Val.substr(1);
1753
1754 size_t RefStep;
1755 if (!getRefinementStep(Val, D, *A, RefStep))
1756 return;
1757
1758 StringRef ValBase = Val.slice(0, RefStep);
1759 llvm::StringMap<bool>::iterator OptionIter = OptionStrings.find(ValBase);
1760 if (OptionIter == OptionStrings.end()) {
1761 // Try again specifying float suffix.
1762 OptionIter = OptionStrings.find(ValBase.str() + 'f');
1763 if (OptionIter == OptionStrings.end()) {
1764 // The input name did not match any known option string.
1765 D.Diag(diag::err_drv_unknown_argument) << Val;
1766 return;
1767 }
1768 // The option was specified without a float or double suffix.
1769 // Make sure that the double entry was not already specified.
1770 // The float entry will be checked below.
1771 if (OptionStrings[ValBase.str() + 'd']) {
1772 D.Diag(diag::err_drv_invalid_value) << A->getOption().getName() << Val;
1773 return;
1774 }
1775 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001776
Sanjay Patel2987c292015-06-11 14:53:41 +00001777 if (OptionIter->second == true) {
1778 // Duplicate option specified.
1779 D.Diag(diag::err_drv_invalid_value) << A->getOption().getName() << Val;
1780 return;
1781 }
1782
1783 // Mark the matched option as found. Do not allow duplicate specifiers.
1784 OptionIter->second = true;
1785
1786 // If the precision was not specified, also mark the double entry as found.
1787 if (ValBase.back() != 'f' && ValBase.back() != 'd')
1788 OptionStrings[ValBase.str() + 'd'] = true;
1789
1790 // Build the output string.
1791 StringRef Prefix = IsDisabled ? DisabledPrefixOut : EnabledPrefixOut;
1792 Out = Args.MakeArgString(Out + Prefix + Val);
1793 if (i != NumOptions - 1)
1794 Out = Args.MakeArgString(Out + ",");
1795 }
1796
1797 OutStrings.push_back(Args.MakeArgString(Out));
1798}
1799
Eric Christopherc54920a2015-03-23 19:26:05 +00001800static void getX86TargetFeatures(const Driver &D, const llvm::Triple &Triple,
Jim Grosbach82eee262013-11-16 00:53:35 +00001801 const ArgList &Args,
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001802 std::vector<const char *> &Features) {
Craig Toppera8bd6002015-03-31 05:45:00 +00001803 // If -march=native, autodetect the feature list.
1804 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ)) {
1805 if (StringRef(A->getValue()) == "native") {
1806 llvm::StringMap<bool> HostFeatures;
1807 if (llvm::sys::getHostCPUFeatures(HostFeatures))
1808 for (auto &F : HostFeatures)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001809 Features.push_back(
1810 Args.MakeArgString((F.second ? "+" : "-") + F.first()));
Craig Toppera8bd6002015-03-31 05:45:00 +00001811 }
1812 }
1813
Jim Grosbach82eee262013-11-16 00:53:35 +00001814 if (Triple.getArchName() == "x86_64h") {
1815 // x86_64h implies quite a few of the more modern subtarget features
1816 // for Haswell class CPUs, but not all of them. Opt-out of a few.
1817 Features.push_back("-rdrnd");
1818 Features.push_back("-aes");
1819 Features.push_back("-pclmul");
1820 Features.push_back("-rtm");
1821 Features.push_back("-hle");
1822 Features.push_back("-fsgsbase");
1823 }
1824
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00001825 const llvm::Triple::ArchType ArchType = Triple.getArch();
Eric Christopherc54920a2015-03-23 19:26:05 +00001826 // Add features to be compatible with gcc for Android.
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00001827 if (Triple.isAndroid()) {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00001828 if (ArchType == llvm::Triple::x86_64) {
Alexey Volkov54ff0802014-06-25 12:15:36 +00001829 Features.push_back("+sse4.2");
1830 Features.push_back("+popcnt");
1831 } else
1832 Features.push_back("+ssse3");
Alexey Bataev286d1b92014-01-31 04:07:13 +00001833 }
1834
Eric Christopherc54920a2015-03-23 19:26:05 +00001835 // Set features according to the -arch flag on MSVC.
Ehsan Akhgarieeb7e652014-07-15 18:27:51 +00001836 if (Arg *A = Args.getLastArg(options::OPT__SLASH_arch)) {
1837 StringRef Arch = A->getValue();
1838 bool ArchUsed = false;
1839 // First, look for flags that are shared in x86 and x86-64.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00001840 if (ArchType == llvm::Triple::x86_64 || ArchType == llvm::Triple::x86) {
Ehsan Akhgarieeb7e652014-07-15 18:27:51 +00001841 if (Arch == "AVX" || Arch == "AVX2") {
1842 ArchUsed = true;
1843 Features.push_back(Args.MakeArgString("+" + Arch.lower()));
1844 }
1845 }
1846 // Then, look for x86-specific flags.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00001847 if (ArchType == llvm::Triple::x86) {
Ehsan Akhgarieeb7e652014-07-15 18:27:51 +00001848 if (Arch == "IA32") {
1849 ArchUsed = true;
1850 } else if (Arch == "SSE" || Arch == "SSE2") {
1851 ArchUsed = true;
1852 Features.push_back(Args.MakeArgString("+" + Arch.lower()));
1853 }
1854 }
1855 if (!ArchUsed)
1856 D.Diag(clang::diag::warn_drv_unused_argument) << A->getAsString(Args);
1857 }
1858
Jim Grosbach82eee262013-11-16 00:53:35 +00001859 // Now add any that the user explicitly requested on the command line,
1860 // which may override the defaults.
Sean Silva14facf32015-06-09 01:57:17 +00001861 for (const Arg *A : Args.filtered(options::OPT_m_x86_Features_Group)) {
1862 StringRef Name = A->getOption().getName();
1863 A->claim();
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001864
1865 // Skip over "-m".
1866 assert(Name.startswith("m") && "Invalid feature name.");
1867 Name = Name.substr(1);
1868
1869 bool IsNegative = Name.startswith("no-");
1870 if (IsNegative)
1871 Name = Name.substr(3);
1872
1873 Features.push_back(Args.MakeArgString((IsNegative ? "-" : "+") + Name));
1874 }
1875}
1876
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00001877void Clang::AddX86TargetArgs(const ArgList &Args,
1878 ArgStringList &CmdArgs) const {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001879 if (!Args.hasFlag(options::OPT_mred_zone, options::OPT_mno_red_zone, true) ||
Daniel Dunbare2cf8f72009-09-10 22:59:57 +00001880 Args.hasArg(options::OPT_mkernel) ||
1881 Args.hasArg(options::OPT_fapple_kext))
Daniel Dunbar8bed86c2009-11-20 22:21:36 +00001882 CmdArgs.push_back("-disable-red-zone");
Daniel Dunbare2cf8f72009-09-10 22:59:57 +00001883
Bob Wilson2616e2e2013-02-10 16:01:41 +00001884 // Default to avoid implicit floating-point for kernel/kext code, but allow
1885 // that to be overridden with -mno-soft-float.
1886 bool NoImplicitFloat = (Args.hasArg(options::OPT_mkernel) ||
1887 Args.hasArg(options::OPT_fapple_kext));
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001888 if (Arg *A = Args.getLastArg(
1889 options::OPT_msoft_float, options::OPT_mno_soft_float,
1890 options::OPT_mimplicit_float, options::OPT_mno_implicit_float)) {
Bob Wilson2616e2e2013-02-10 16:01:41 +00001891 const Option &O = A->getOption();
1892 NoImplicitFloat = (O.matches(options::OPT_mno_implicit_float) ||
1893 O.matches(options::OPT_msoft_float));
1894 }
1895 if (NoImplicitFloat)
Daniel Dunbar8bed86c2009-11-20 22:21:36 +00001896 CmdArgs.push_back("-no-implicit-float");
Nico Weberad8e36c2014-05-13 11:11:24 +00001897
1898 if (Arg *A = Args.getLastArg(options::OPT_masm_EQ)) {
1899 StringRef Value = A->getValue();
1900 if (Value == "intel" || Value == "att") {
1901 CmdArgs.push_back("-mllvm");
1902 CmdArgs.push_back(Args.MakeArgString("-x86-asm-syntax=" + Value));
1903 } else {
1904 getToolChain().getDriver().Diag(diag::err_drv_unsupported_option_argument)
1905 << A->getOption().getName() << Value;
1906 }
1907 }
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00001908}
1909
Tony Linthicum76329bf2011-12-12 21:14:55 +00001910void Clang::AddHexagonTargetArgs(const ArgList &Args,
1911 ArgStringList &CmdArgs) const {
Matthew Curtis6b222782012-12-07 13:52:44 +00001912 CmdArgs.push_back("-mqdsp6-compat");
1913 CmdArgs.push_back("-Wreturn-type");
Tony Linthicum76329bf2011-12-12 21:14:55 +00001914
Douglas Katzman54366072015-07-27 16:53:08 +00001915 if (const char *v =
1916 toolchains::HexagonToolChain::GetSmallDataThreshold(Args)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001917 std::string SmallDataThreshold = "-hexagon-small-data-threshold=";
Ikhlas Ajbar522e6192015-05-14 13:52:08 +00001918 SmallDataThreshold += v;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001919 CmdArgs.push_back("-mllvm");
Ikhlas Ajbar522e6192015-05-14 13:52:08 +00001920 CmdArgs.push_back(Args.MakeArgString(SmallDataThreshold));
Tony Linthicum76329bf2011-12-12 21:14:55 +00001921 }
1922
Sirish Pande11ebc4e2012-05-10 20:19:54 +00001923 if (!Args.hasArg(options::OPT_fno_short_enums))
1924 CmdArgs.push_back("-fshort-enums");
1925 if (Args.getLastArg(options::OPT_mieee_rnd_near)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001926 CmdArgs.push_back("-mllvm");
1927 CmdArgs.push_back("-enable-hexagon-ieee-rnd-near");
Sirish Pande11ebc4e2012-05-10 20:19:54 +00001928 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001929 CmdArgs.push_back("-mllvm");
1930 CmdArgs.push_back("-machine-sink-split=0");
Tony Linthicum76329bf2011-12-12 21:14:55 +00001931}
1932
Kevin Qin110db6f2014-07-18 07:03:22 +00001933// Decode AArch64 features from string like +[no]featureA+[no]featureB+...
Craig Topperbf3e3272014-08-30 16:55:52 +00001934static bool DecodeAArch64Features(const Driver &D, StringRef text,
Kevin Qin110db6f2014-07-18 07:03:22 +00001935 std::vector<const char *> &Features) {
1936 SmallVector<StringRef, 8> Split;
1937 text.split(Split, StringRef("+"), -1, false);
1938
Benjamin Kramer72e64312015-09-24 14:48:49 +00001939 for (StringRef Feature : Split) {
Douglas Katzman2675d012015-06-29 19:12:56 +00001940 const char *result = llvm::StringSwitch<const char *>(Feature)
Kevin Qin110db6f2014-07-18 07:03:22 +00001941 .Case("fp", "+fp-armv8")
1942 .Case("simd", "+neon")
1943 .Case("crc", "+crc")
1944 .Case("crypto", "+crypto")
1945 .Case("nofp", "-fp-armv8")
1946 .Case("nosimd", "-neon")
1947 .Case("nocrc", "-crc")
1948 .Case("nocrypto", "-crypto")
1949 .Default(nullptr);
1950 if (result)
1951 Features.push_back(result);
Douglas Katzman2675d012015-06-29 19:12:56 +00001952 else if (Feature == "neon" || Feature == "noneon")
Kevin Qin110db6f2014-07-18 07:03:22 +00001953 D.Diag(diag::err_drv_no_neon_modifier);
1954 else
1955 return false;
1956 }
1957 return true;
1958}
1959
1960// Check if the CPU name and feature modifiers in -mcpu are legal. If yes,
1961// decode CPU and feature.
1962static bool DecodeAArch64Mcpu(const Driver &D, StringRef Mcpu, StringRef &CPU,
1963 std::vector<const char *> &Features) {
1964 std::pair<StringRef, StringRef> Split = Mcpu.split("+");
1965 CPU = Split.first;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001966 if (CPU == "cyclone" || CPU == "cortex-a53" || CPU == "cortex-a57" ||
1967 CPU == "cortex-a72") {
Kevin Qin110db6f2014-07-18 07:03:22 +00001968 Features.push_back("+neon");
1969 Features.push_back("+crc");
1970 Features.push_back("+crypto");
1971 } else if (CPU == "generic") {
1972 Features.push_back("+neon");
1973 } else {
1974 return false;
1975 }
1976
1977 if (Split.second.size() && !DecodeAArch64Features(D, Split.second, Features))
1978 return false;
1979
1980 return true;
1981}
1982
1983static bool
1984getAArch64ArchFeaturesFromMarch(const Driver &D, StringRef March,
1985 const ArgList &Args,
1986 std::vector<const char *> &Features) {
Gabor Ballabas36451492015-06-18 14:23:12 +00001987 std::string MarchLowerCase = March.lower();
1988 std::pair<StringRef, StringRef> Split = StringRef(MarchLowerCase).split("+");
Vladimir Sukhareve851e042015-04-16 15:53:09 +00001989
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001990 if (Split.first == "armv8-a" || Split.first == "armv8a") {
Vladimir Sukhareve851e042015-04-16 15:53:09 +00001991 // ok, no additional features.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001992 } else if (Split.first == "armv8.1-a" || Split.first == "armv8.1a") {
Vladimir Sukhareve851e042015-04-16 15:53:09 +00001993 Features.push_back("+v8.1a");
1994 } else {
Kevin Qin110db6f2014-07-18 07:03:22 +00001995 return false;
Vladimir Sukhareve851e042015-04-16 15:53:09 +00001996 }
Kevin Qin110db6f2014-07-18 07:03:22 +00001997
1998 if (Split.second.size() && !DecodeAArch64Features(D, Split.second, Features))
1999 return false;
2000
2001 return true;
2002}
2003
2004static bool
2005getAArch64ArchFeaturesFromMcpu(const Driver &D, StringRef Mcpu,
2006 const ArgList &Args,
2007 std::vector<const char *> &Features) {
2008 StringRef CPU;
Gabor Ballabas726ce7f2015-06-12 17:33:37 +00002009 std::string McpuLowerCase = Mcpu.lower();
2010 if (!DecodeAArch64Mcpu(D, McpuLowerCase, CPU, Features))
Kevin Qin110db6f2014-07-18 07:03:22 +00002011 return false;
2012
2013 return true;
2014}
2015
2016static bool
2017getAArch64MicroArchFeaturesFromMtune(const Driver &D, StringRef Mtune,
2018 const ArgList &Args,
2019 std::vector<const char *> &Features) {
Gabor Ballabasa24a1a42015-07-20 11:28:20 +00002020 std::string MtuneLowerCase = Mtune.lower();
Kevin Qin110db6f2014-07-18 07:03:22 +00002021 // Handle CPU name is 'native'.
Gabor Ballabasa24a1a42015-07-20 11:28:20 +00002022 if (MtuneLowerCase == "native")
2023 MtuneLowerCase = llvm::sys::getHostCPUName();
2024 if (MtuneLowerCase == "cyclone") {
Kevin Qin110db6f2014-07-18 07:03:22 +00002025 Features.push_back("+zcm");
2026 Features.push_back("+zcz");
2027 }
2028 return true;
2029}
2030
2031static bool
2032getAArch64MicroArchFeaturesFromMcpu(const Driver &D, StringRef Mcpu,
2033 const ArgList &Args,
2034 std::vector<const char *> &Features) {
2035 StringRef CPU;
2036 std::vector<const char *> DecodedFeature;
Gabor Ballabas726ce7f2015-06-12 17:33:37 +00002037 std::string McpuLowerCase = Mcpu.lower();
2038 if (!DecodeAArch64Mcpu(D, McpuLowerCase, CPU, DecodedFeature))
Kevin Qin110db6f2014-07-18 07:03:22 +00002039 return false;
2040
2041 return getAArch64MicroArchFeaturesFromMtune(D, CPU, Args, Features);
2042}
2043
Akira Hatanaka92500472015-07-27 19:29:04 +00002044static void getAArch64TargetFeatures(const Driver &D,
2045 const llvm::Triple &Triple,
2046 const ArgList &Args,
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002047 std::vector<const char *> &Features) {
Kevin Qin110db6f2014-07-18 07:03:22 +00002048 Arg *A;
2049 bool success = true;
2050 // Enable NEON by default.
2051 Features.push_back("+neon");
2052 if ((A = Args.getLastArg(options::OPT_march_EQ)))
2053 success = getAArch64ArchFeaturesFromMarch(D, A->getValue(), Args, Features);
2054 else if ((A = Args.getLastArg(options::OPT_mcpu_EQ)))
2055 success = getAArch64ArchFeaturesFromMcpu(D, A->getValue(), Args, Features);
Tim Northover642e7702014-11-10 21:17:23 +00002056 else if (Args.hasArg(options::OPT_arch))
2057 success = getAArch64ArchFeaturesFromMcpu(D, getAArch64TargetCPU(Args), Args,
2058 Features);
Kevin Qin110db6f2014-07-18 07:03:22 +00002059
2060 if (success && (A = Args.getLastArg(options::OPT_mtune_EQ)))
2061 success =
2062 getAArch64MicroArchFeaturesFromMtune(D, A->getValue(), Args, Features);
2063 else if (success && (A = Args.getLastArg(options::OPT_mcpu_EQ)))
2064 success =
2065 getAArch64MicroArchFeaturesFromMcpu(D, A->getValue(), Args, Features);
Tim Northover642e7702014-11-10 21:17:23 +00002066 else if (Args.hasArg(options::OPT_arch))
2067 success = getAArch64MicroArchFeaturesFromMcpu(D, getAArch64TargetCPU(Args),
2068 Args, Features);
Kevin Qin110db6f2014-07-18 07:03:22 +00002069
2070 if (!success)
2071 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
Amara Emerson04e2ecf2014-01-23 15:48:30 +00002072
2073 if (Args.getLastArg(options::OPT_mgeneral_regs_only)) {
2074 Features.push_back("-fp-armv8");
2075 Features.push_back("-crypto");
2076 Features.push_back("-neon");
2077 }
Bradley Smith418c5932014-05-02 15:17:51 +00002078
2079 // En/disable crc
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002080 if (Arg *A = Args.getLastArg(options::OPT_mcrc, options::OPT_mnocrc)) {
Bradley Smith418c5932014-05-02 15:17:51 +00002081 if (A->getOption().matches(options::OPT_mcrc))
2082 Features.push_back("+crc");
2083 else
2084 Features.push_back("-crc");
2085 }
Akira Hatanaka4e3c86f2015-07-25 00:18:00 +00002086
Akira Hatanaka085da7e2015-07-29 14:25:58 +00002087 if (Arg *A = Args.getLastArg(options::OPT_mno_unaligned_access,
2088 options::OPT_munaligned_access))
2089 if (A->getOption().matches(options::OPT_mno_unaligned_access))
2090 Features.push_back("+strict-align");
2091
Akira Hatanaka92500472015-07-27 19:29:04 +00002092 if (Args.hasArg(options::OPT_ffixed_x18) || Triple.isOSDarwin())
Akira Hatanaka4e3c86f2015-07-25 00:18:00 +00002093 Features.push_back("+reserve-x18");
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002094}
2095
Dan Gohmanc2853072015-09-03 22:51:53 +00002096static void getWebAssemblyTargetFeatures(const ArgList &Args,
2097 std::vector<const char *> &Features) {
2098 for (const Arg *A : Args.filtered(options::OPT_m_wasm_Features_Group)) {
2099 StringRef Name = A->getOption().getName();
2100 A->claim();
2101
2102 // Skip over "-m".
2103 assert(Name.startswith("m") && "Invalid feature name.");
2104 Name = Name.substr(1);
2105
2106 bool IsNegative = Name.startswith("no-");
2107 if (IsNegative)
2108 Name = Name.substr(3);
2109
2110 Features.push_back(Args.MakeArgString((IsNegative ? "-" : "+") + Name));
2111 }
2112}
2113
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00002114static void getTargetFeatures(const ToolChain &TC, const llvm::Triple &Triple,
Rafael Espindola9c6fb0f2013-11-23 14:36:40 +00002115 const ArgList &Args, ArgStringList &CmdArgs,
2116 bool ForAS) {
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00002117 const Driver &D = TC.getDriver();
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002118 std::vector<const char *> Features;
2119 switch (Triple.getArch()) {
2120 default:
2121 break;
2122 case llvm::Triple::mips:
2123 case llvm::Triple::mipsel:
2124 case llvm::Triple::mips64:
2125 case llvm::Triple::mips64el:
Daniel Sanders379d44b2014-07-16 11:52:23 +00002126 getMIPSTargetFeatures(D, Triple, Args, Features);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002127 break;
2128
2129 case llvm::Triple::arm:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00002130 case llvm::Triple::armeb:
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002131 case llvm::Triple::thumb:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00002132 case llvm::Triple::thumbeb:
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00002133 getARMTargetFeatures(TC, Triple, Args, Features, ForAS);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002134 break;
2135
2136 case llvm::Triple::ppc:
2137 case llvm::Triple::ppc64:
2138 case llvm::Triple::ppc64le:
2139 getPPCTargetFeatures(Args, Features);
2140 break;
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00002141 case llvm::Triple::systemz:
2142 getSystemZTargetFeatures(Args, Features);
2143 break;
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002144 case llvm::Triple::aarch64:
Christian Pirker9b019ae2014-02-25 13:51:00 +00002145 case llvm::Triple::aarch64_be:
Akira Hatanaka92500472015-07-27 19:29:04 +00002146 getAArch64TargetFeatures(D, Triple, Args, Features);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002147 break;
2148 case llvm::Triple::x86:
2149 case llvm::Triple::x86_64:
Ehsan Akhgarieeb7e652014-07-15 18:27:51 +00002150 getX86TargetFeatures(D, Triple, Args, Features);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002151 break;
Dan Gohmanc2853072015-09-03 22:51:53 +00002152 case llvm::Triple::wasm32:
2153 case llvm::Triple::wasm64:
2154 getWebAssemblyTargetFeatures(Args, Features);
2155 break;
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002156 }
Rafael Espindola43964802013-08-21 17:34:32 +00002157
2158 // Find the last of each feature.
2159 llvm::StringMap<unsigned> LastOpt;
2160 for (unsigned I = 0, N = Features.size(); I < N; ++I) {
2161 const char *Name = Features[I];
2162 assert(Name[0] == '-' || Name[0] == '+');
2163 LastOpt[Name + 1] = I;
2164 }
2165
2166 for (unsigned I = 0, N = Features.size(); I < N; ++I) {
2167 // If this feature was overridden, ignore it.
2168 const char *Name = Features[I];
2169 llvm::StringMap<unsigned>::iterator LastI = LastOpt.find(Name + 1);
2170 assert(LastI != LastOpt.end());
2171 unsigned Last = LastI->second;
2172 if (Last != I)
2173 continue;
2174
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002175 CmdArgs.push_back("-target-feature");
Rafael Espindola43964802013-08-21 17:34:32 +00002176 CmdArgs.push_back(Name);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002177 }
Tim Northover2fe823a2013-08-01 09:23:19 +00002178}
2179
David Majnemerae394812014-12-09 00:12:30 +00002180static bool
2181shouldUseExceptionTablesForObjCExceptions(const ObjCRuntime &runtime,
2182 const llvm::Triple &Triple) {
2183 // We use the zero-cost exception tables for Objective-C if the non-fragile
2184 // ABI is enabled or when compiling for x86_64 and ARM on Snow Leopard and
2185 // later.
2186 if (runtime.isNonFragile())
2187 return true;
2188
2189 if (!Triple.isMacOSX())
2190 return false;
2191
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002192 return (!Triple.isMacOSXVersionLT(10, 5) &&
David Majnemerae394812014-12-09 00:12:30 +00002193 (Triple.getArch() == llvm::Triple::x86_64 ||
2194 Triple.getArch() == llvm::Triple::arm));
2195}
2196
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002197/// Adds exception related arguments to the driver command arguments. There's a
2198/// master flag, -fexceptions and also language specific flags to enable/disable
2199/// C++ and Objective-C exceptions. This makes it possible to for example
2200/// disable C++ exceptions but enable Objective-C exceptions.
Anders Carlssone96ab552011-02-28 02:27:16 +00002201static void addExceptionArgs(const ArgList &Args, types::ID InputType,
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002202 const ToolChain &TC, bool KernelOrKext,
John McCall5fb5df92012-06-20 06:18:46 +00002203 const ObjCRuntime &objcRuntime,
Anders Carlssone96ab552011-02-28 02:27:16 +00002204 ArgStringList &CmdArgs) {
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002205 const Driver &D = TC.getDriver();
2206 const llvm::Triple &Triple = TC.getTriple();
2207
Chad Rosier4fab82c2012-03-26 22:04:46 +00002208 if (KernelOrKext) {
2209 // -mkernel and -fapple-kext imply no exceptions, so claim exception related
2210 // arguments now to avoid warnings about unused arguments.
2211 Args.ClaimAllArgs(options::OPT_fexceptions);
2212 Args.ClaimAllArgs(options::OPT_fno_exceptions);
2213 Args.ClaimAllArgs(options::OPT_fobjc_exceptions);
2214 Args.ClaimAllArgs(options::OPT_fno_objc_exceptions);
2215 Args.ClaimAllArgs(options::OPT_fcxx_exceptions);
2216 Args.ClaimAllArgs(options::OPT_fno_cxx_exceptions);
Anders Carlssone96ab552011-02-28 02:27:16 +00002217 return;
Chad Rosier4fab82c2012-03-26 22:04:46 +00002218 }
Anders Carlssone96ab552011-02-28 02:27:16 +00002219
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00002220 // See if the user explicitly enabled exceptions.
2221 bool EH = Args.hasFlag(options::OPT_fexceptions, options::OPT_fno_exceptions,
2222 false);
Daniel Dunbar30a12b82010-09-14 23:12:31 +00002223
David Majnemerae394812014-12-09 00:12:30 +00002224 // Obj-C exceptions are enabled by default, regardless of -fexceptions. This
2225 // is not necessarily sensible, but follows GCC.
2226 if (types::isObjC(InputType) &&
2227 Args.hasFlag(options::OPT_fobjc_exceptions,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002228 options::OPT_fno_objc_exceptions, true)) {
David Majnemerae394812014-12-09 00:12:30 +00002229 CmdArgs.push_back("-fobjc-exceptions");
Anders Carlssone96ab552011-02-28 02:27:16 +00002230
David Majnemerae394812014-12-09 00:12:30 +00002231 EH |= shouldUseExceptionTablesForObjCExceptions(objcRuntime, Triple);
Anders Carlssone96ab552011-02-28 02:27:16 +00002232 }
2233
2234 if (types::isCXX(InputType)) {
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00002235 // Disable C++ EH by default on XCore, PS4, and MSVC.
2236 // FIXME: Remove MSVC from this list once things work.
2237 bool CXXExceptionsEnabled = Triple.getArch() != llvm::Triple::xcore &&
2238 !Triple.isPS4CPU() &&
2239 !Triple.isWindowsMSVCEnvironment();
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002240 Arg *ExceptionArg = Args.getLastArg(
2241 options::OPT_fcxx_exceptions, options::OPT_fno_cxx_exceptions,
2242 options::OPT_fexceptions, options::OPT_fno_exceptions);
2243 if (ExceptionArg)
David Majnemer8de68642014-12-05 08:11:58 +00002244 CXXExceptionsEnabled =
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002245 ExceptionArg->getOption().matches(options::OPT_fcxx_exceptions) ||
2246 ExceptionArg->getOption().matches(options::OPT_fexceptions);
Anders Carlssone96ab552011-02-28 02:27:16 +00002247
2248 if (CXXExceptionsEnabled) {
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002249 if (Triple.isPS4CPU()) {
2250 ToolChain::RTTIMode RTTIMode = TC.getRTTIMode();
2251 assert(ExceptionArg &&
2252 "On the PS4 exceptions should only be enabled if passing "
2253 "an argument");
2254 if (RTTIMode == ToolChain::RM_DisabledExplicitly) {
2255 const Arg *RTTIArg = TC.getRTTIArg();
2256 assert(RTTIArg && "RTTI disabled explicitly but no RTTIArg!");
2257 D.Diag(diag::err_drv_argument_not_allowed_with)
2258 << RTTIArg->getAsString(Args) << ExceptionArg->getAsString(Args);
2259 } else if (RTTIMode == ToolChain::RM_EnabledImplicitly)
2260 D.Diag(diag::warn_drv_enabling_rtti_with_exceptions);
2261 } else
2262 assert(TC.getRTTIMode() != ToolChain::RM_DisabledImplicitly);
2263
Anders Carlssone96ab552011-02-28 02:27:16 +00002264 CmdArgs.push_back("-fcxx-exceptions");
2265
David Majnemer8de68642014-12-05 08:11:58 +00002266 EH = true;
Anders Carlssone96ab552011-02-28 02:27:16 +00002267 }
2268 }
2269
David Majnemer8de68642014-12-05 08:11:58 +00002270 if (EH)
Anders Carlssone96ab552011-02-28 02:27:16 +00002271 CmdArgs.push_back("-fexceptions");
Rafael Espindola00a66572009-10-01 13:33:33 +00002272}
2273
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002274static bool ShouldDisableAutolink(const ArgList &Args, const ToolChain &TC) {
Daniel Dunbare246fbe2013-04-16 18:21:19 +00002275 bool Default = true;
2276 if (TC.getTriple().isOSDarwin()) {
2277 // The native darwin assembler doesn't support the linker_option directives,
2278 // so we disable them if we think the .s file will be passed to it.
2279 Default = TC.useIntegratedAs();
2280 }
2281 return !Args.hasFlag(options::OPT_fautolink, options::OPT_fno_autolink,
2282 Default);
2283}
2284
Ted Kremenek62093662013-03-12 17:02:12 +00002285static bool ShouldDisableDwarfDirectory(const ArgList &Args,
2286 const ToolChain &TC) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002287 bool UseDwarfDirectory =
2288 Args.hasFlag(options::OPT_fdwarf_directory_asm,
2289 options::OPT_fno_dwarf_directory_asm, TC.useIntegratedAs());
Nick Lewycky1d617ac2011-10-17 23:05:52 +00002290 return !UseDwarfDirectory;
2291}
2292
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00002293/// \brief Check whether the given input tree contains any compilation actions.
2294static bool ContainsCompileAction(const Action *A) {
Bob Wilson23a55f12014-12-21 07:00:00 +00002295 if (isa<CompileJobAction>(A) || isa<BackendJobAction>(A))
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00002296 return true;
2297
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00002298 for (const auto &Act : *A)
2299 if (ContainsCompileAction(Act))
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00002300 return true;
2301
2302 return false;
2303}
2304
2305/// \brief Check if -relax-all should be passed to the internal assembler.
2306/// This is done by default when compiling non-assembler source with -O0.
2307static bool UseRelaxAll(Compilation &C, const ArgList &Args) {
2308 bool RelaxDefault = true;
2309
2310 if (Arg *A = Args.getLastArg(options::OPT_O_Group))
2311 RelaxDefault = A->getOption().matches(options::OPT_O0);
2312
2313 if (RelaxDefault) {
2314 RelaxDefault = false;
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00002315 for (const auto &Act : C.getActions()) {
2316 if (ContainsCompileAction(Act)) {
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00002317 RelaxDefault = true;
2318 break;
2319 }
2320 }
2321 }
2322
2323 return Args.hasFlag(options::OPT_mrelax_all, options::OPT_mno_relax_all,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002324 RelaxDefault);
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00002325}
2326
Douglas Katzman3459ce22015-10-08 04:24:12 +00002327// Extract the integer N from a string spelled "-dwarf-N", returning 0
2328// on mismatch. The StringRef input (rather than an Arg) allows
2329// for use by the "-Xassembler" option parser.
2330static unsigned DwarfVersionNum(StringRef ArgValue) {
2331 return llvm::StringSwitch<unsigned>(ArgValue)
2332 .Case("-gdwarf-2", 2)
2333 .Case("-gdwarf-3", 3)
2334 .Case("-gdwarf-4", 4)
2335 .Default(0);
2336}
2337
2338static void RenderDebugEnablingArgs(const ArgList &Args, ArgStringList &CmdArgs,
2339 CodeGenOptions::DebugInfoKind DebugInfoKind,
2340 unsigned DwarfVersion) {
2341 switch (DebugInfoKind) {
2342 case CodeGenOptions::DebugLineTablesOnly:
2343 CmdArgs.push_back("-debug-info-kind=line-tables-only");
2344 break;
2345 case CodeGenOptions::LimitedDebugInfo:
2346 CmdArgs.push_back("-debug-info-kind=limited");
2347 break;
2348 case CodeGenOptions::FullDebugInfo:
2349 CmdArgs.push_back("-debug-info-kind=standalone");
2350 break;
2351 default:
2352 break;
2353 }
2354 if (DwarfVersion > 0)
2355 CmdArgs.push_back(
Benjamin Kramer32bd3c82015-10-08 10:31:17 +00002356 Args.MakeArgString("-dwarf-version=" + Twine(DwarfVersion)));
Douglas Katzman3459ce22015-10-08 04:24:12 +00002357}
2358
David Blaikie9260ed62013-07-25 21:19:01 +00002359static void CollectArgsForIntegratedAssembler(Compilation &C,
2360 const ArgList &Args,
2361 ArgStringList &CmdArgs,
2362 const Driver &D) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002363 if (UseRelaxAll(C, Args))
2364 CmdArgs.push_back("-mrelax-all");
David Blaikie9260ed62013-07-25 21:19:01 +00002365
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002366 // When passing -I arguments to the assembler we sometimes need to
2367 // unconditionally take the next argument. For example, when parsing
2368 // '-Wa,-I -Wa,foo' we need to accept the -Wa,foo arg after seeing the
2369 // -Wa,-I arg and when parsing '-Wa,-I,foo' we need to accept the 'foo'
2370 // arg after parsing the '-I' arg.
2371 bool TakeNextArg = false;
David Peixottodfb66142013-11-14 22:52:58 +00002372
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002373 // When using an integrated assembler, translate -Wa, and -Xassembler
2374 // options.
2375 bool CompressDebugSections = false;
2376 for (const Arg *A :
2377 Args.filtered(options::OPT_Wa_COMMA, options::OPT_Xassembler)) {
2378 A->claim();
David Blaikie9260ed62013-07-25 21:19:01 +00002379
Benjamin Kramer72e64312015-09-24 14:48:49 +00002380 for (StringRef Value : A->getValues()) {
Renato Golin7c542b42015-07-27 23:44:45 +00002381 if (TakeNextArg) {
2382 CmdArgs.push_back(Value.data());
2383 TakeNextArg = false;
2384 continue;
2385 }
David Blaikie9260ed62013-07-25 21:19:01 +00002386
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002387 if (Value == "-force_cpusubtype_ALL") {
2388 // Do nothing, this is the default and we don't support anything else.
2389 } else if (Value == "-L") {
2390 CmdArgs.push_back("-msave-temp-labels");
2391 } else if (Value == "--fatal-warnings") {
2392 CmdArgs.push_back("-massembler-fatal-warnings");
2393 } else if (Value == "--noexecstack") {
2394 CmdArgs.push_back("-mnoexecstack");
2395 } else if (Value == "-compress-debug-sections" ||
2396 Value == "--compress-debug-sections") {
2397 CompressDebugSections = true;
2398 } else if (Value == "-nocompress-debug-sections" ||
2399 Value == "--nocompress-debug-sections") {
2400 CompressDebugSections = false;
2401 } else if (Value.startswith("-I")) {
2402 CmdArgs.push_back(Value.data());
2403 // We need to consume the next argument if the current arg is a plain
2404 // -I. The next arg will be the include directory.
2405 if (Value == "-I")
2406 TakeNextArg = true;
2407 } else if (Value.startswith("-gdwarf-")) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00002408 // "-gdwarf-N" options are not cc1as options.
2409 unsigned DwarfVersion = DwarfVersionNum(Value);
2410 if (DwarfVersion == 0) { // Send it onward, and let cc1as complain.
2411 CmdArgs.push_back(Value.data());
2412 } else {
2413 RenderDebugEnablingArgs(
2414 Args, CmdArgs, CodeGenOptions::LimitedDebugInfo, DwarfVersion);
2415 }
Renato Golin7c542b42015-07-27 23:44:45 +00002416 } else if (Value.startswith("-mcpu") || Value.startswith("-mfpu") ||
2417 Value.startswith("-mhwdiv") || Value.startswith("-march")) {
2418 // Do nothing, we'll validate it later.
Daniel Sanders4f7cd232015-09-03 12:58:39 +00002419 } else if (Value == "--trap") {
2420 CmdArgs.push_back("-target-feature");
2421 CmdArgs.push_back("+use-tcc-in-div");
2422 } else if (Value == "--break") {
2423 CmdArgs.push_back("-target-feature");
2424 CmdArgs.push_back("-use-tcc-in-div");
Daniel Sanders63f28262015-09-22 13:52:32 +00002425 } else if (Value.startswith("-msoft-float")) {
2426 CmdArgs.push_back("-target-feature");
2427 CmdArgs.push_back("+soft-float");
2428 } else if (Value.startswith("-mhard-float")) {
2429 CmdArgs.push_back("-target-feature");
2430 CmdArgs.push_back("-soft-float");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002431 } else {
2432 D.Diag(diag::err_drv_unsupported_option_argument)
David Blaikie9260ed62013-07-25 21:19:01 +00002433 << A->getOption().getName() << Value;
David Blaikie9260ed62013-07-25 21:19:01 +00002434 }
2435 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002436 }
2437 if (CompressDebugSections) {
2438 if (llvm::zlib::isAvailable())
2439 CmdArgs.push_back("-compress-debug-sections");
2440 else
2441 D.Diag(diag::warn_debug_compression_unavailable);
2442 }
David Blaikie9260ed62013-07-25 21:19:01 +00002443}
2444
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00002445static const char *getCompilerRTArgString(const ToolChain &TC,
2446 const llvm::opt::ArgList &Args,
2447 StringRef Component,
2448 bool Shared = false) {
Vasileios Kalintiris447e3572015-10-01 16:54:58 +00002449 return Args.MakeArgString(TC.getCompilerRT(Args, Component, Shared));
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00002450}
2451
Alexey Samsonov99ee10d2014-05-22 21:13:30 +00002452// This adds the static libclang_rt.builtins-arch.a directly to the command line
Renato Golinc4b49242014-02-13 10:01:16 +00002453// FIXME: Make sure we can also emit shared objects if they're requested
2454// and available, check for possible errors, etc.
Saleem Abdulrasool8d7ade72014-12-30 02:10:36 +00002455static void addClangRT(const ToolChain &TC, const ArgList &Args,
2456 ArgStringList &CmdArgs) {
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00002457 CmdArgs.push_back(getCompilerRTArgString(TC, Args, "builtins"));
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00002458}
2459
Saleem Abdulrasool2e46ebe2014-12-30 22:52:06 +00002460static void addProfileRT(const ToolChain &TC, const ArgList &Args,
2461 ArgStringList &CmdArgs) {
Justin Bogner31a4aca2014-08-07 03:14:34 +00002462 if (!(Args.hasFlag(options::OPT_fprofile_arcs, options::OPT_fno_profile_arcs,
2463 false) ||
Chandler Carruth36381702013-06-23 11:28:48 +00002464 Args.hasArg(options::OPT_fprofile_generate) ||
Diego Novillo578caf52015-07-09 17:23:53 +00002465 Args.hasArg(options::OPT_fprofile_generate_EQ) ||
Justin Bogner6a9d2cf2014-01-06 22:27:36 +00002466 Args.hasArg(options::OPT_fprofile_instr_generate) ||
Justin Bognera71e6812015-04-30 23:49:42 +00002467 Args.hasArg(options::OPT_fprofile_instr_generate_EQ) ||
Chandler Carruth36381702013-06-23 11:28:48 +00002468 Args.hasArg(options::OPT_fcreate_profile) ||
2469 Args.hasArg(options::OPT_coverage)))
2470 return;
2471
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00002472 CmdArgs.push_back(getCompilerRTArgString(TC, Args, "profile"));
Alexey Samsonovbdfa6c22014-04-01 13:31:10 +00002473}
2474
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002475namespace {
2476enum OpenMPRuntimeKind {
2477 /// An unknown OpenMP runtime. We can't generate effective OpenMP code
2478 /// without knowing what runtime to target.
2479 OMPRT_Unknown,
2480
2481 /// The LLVM OpenMP runtime. When completed and integrated, this will become
2482 /// the default for Clang.
2483 OMPRT_OMP,
2484
2485 /// The GNU OpenMP runtime. Clang doesn't support generating OpenMP code for
2486 /// this runtime but can swallow the pragmas, and find and link against the
2487 /// runtime library itself.
2488 OMPRT_GOMP,
2489
Chandler Carruthc6625c62015-05-28 21:10:31 +00002490 /// The legacy name for the LLVM OpenMP runtime from when it was the Intel
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002491 /// OpenMP runtime. We support this mode for users with existing dependencies
2492 /// on this runtime library name.
2493 OMPRT_IOMP5
2494};
Alexander Kornienkoab9db512015-06-22 23:07:51 +00002495}
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002496
2497/// Compute the desired OpenMP runtime from the flag provided.
Chandler Carruthc6625c62015-05-28 21:10:31 +00002498static OpenMPRuntimeKind getOpenMPRuntime(const ToolChain &TC,
2499 const ArgList &Args) {
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002500 StringRef RuntimeName(CLANG_DEFAULT_OPENMP_RUNTIME);
2501
2502 const Arg *A = Args.getLastArg(options::OPT_fopenmp_EQ);
2503 if (A)
2504 RuntimeName = A->getValue();
2505
2506 auto RT = llvm::StringSwitch<OpenMPRuntimeKind>(RuntimeName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002507 .Case("libomp", OMPRT_OMP)
2508 .Case("libgomp", OMPRT_GOMP)
2509 .Case("libiomp5", OMPRT_IOMP5)
2510 .Default(OMPRT_Unknown);
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002511
2512 if (RT == OMPRT_Unknown) {
2513 if (A)
2514 TC.getDriver().Diag(diag::err_drv_unsupported_option_argument)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002515 << A->getOption().getName() << A->getValue();
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002516 else
2517 // FIXME: We could use a nicer diagnostic here.
2518 TC.getDriver().Diag(diag::err_drv_unsupported_opt) << "-fopenmp";
2519 }
2520
2521 return RT;
2522}
2523
Joerg Sonnenberger95a90132015-09-23 14:06:52 +00002524static void addOpenMPRuntime(ArgStringList &CmdArgs, const ToolChain &TC,
2525 const ArgList &Args) {
2526 if (!Args.hasFlag(options::OPT_fopenmp, options::OPT_fopenmp_EQ,
2527 options::OPT_fno_openmp, false))
2528 return;
2529
2530 switch (getOpenMPRuntime(TC, Args)) {
2531 case OMPRT_OMP:
2532 CmdArgs.push_back("-lomp");
2533 break;
2534 case OMPRT_GOMP:
2535 CmdArgs.push_back("-lgomp");
2536 break;
2537 case OMPRT_IOMP5:
2538 CmdArgs.push_back("-liomp5");
2539 break;
2540 case OMPRT_Unknown:
2541 // Already diagnosed.
2542 break;
2543 }
2544}
2545
Alexey Samsonov52550342014-09-15 19:58:40 +00002546static void addSanitizerRuntime(const ToolChain &TC, const ArgList &Args,
2547 ArgStringList &CmdArgs, StringRef Sanitizer,
2548 bool IsShared) {
Alexey Samsonov52550342014-09-15 19:58:40 +00002549 // Static runtimes must be forced into executable, so we wrap them in
Peter Collingbournef7ef3fd812013-10-20 21:29:13 +00002550 // whole-archive.
Alexey Samsonov52550342014-09-15 19:58:40 +00002551 if (!IsShared)
2552 CmdArgs.push_back("-whole-archive");
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00002553 CmdArgs.push_back(getCompilerRTArgString(TC, Args, Sanitizer, IsShared));
Alexey Samsonov52550342014-09-15 19:58:40 +00002554 if (!IsShared)
2555 CmdArgs.push_back("-no-whole-archive");
Alexey Samsonovbfb0cd32013-02-27 11:14:55 +00002556}
2557
Alexey Samsonov52550342014-09-15 19:58:40 +00002558// Tries to use a file with the list of dynamic symbols that need to be exported
2559// from the runtime library. Returns true if the file was found.
2560static bool addSanitizerDynamicList(const ToolChain &TC, const ArgList &Args,
2561 ArgStringList &CmdArgs,
2562 StringRef Sanitizer) {
Vasileios Kalintiris447e3572015-10-01 16:54:58 +00002563 SmallString<128> SanRT(TC.getCompilerRT(Args, Sanitizer));
Saleem Abdulrasool68150942014-12-30 22:52:08 +00002564 if (llvm::sys::fs::exists(SanRT + ".syms")) {
2565 CmdArgs.push_back(Args.MakeArgString("--dynamic-list=" + SanRT + ".syms"));
Alexey Samsonov52550342014-09-15 19:58:40 +00002566 return true;
2567 }
2568 return false;
2569}
2570
2571static void linkSanitizerRuntimeDeps(const ToolChain &TC,
2572 ArgStringList &CmdArgs) {
2573 // Force linking against the system libraries sanitizers depends on
2574 // (see PR15823 why this is necessary).
2575 CmdArgs.push_back("--no-as-needed");
2576 CmdArgs.push_back("-lpthread");
2577 CmdArgs.push_back("-lrt");
2578 CmdArgs.push_back("-lm");
2579 // There's no libdl on FreeBSD.
2580 if (TC.getTriple().getOS() != llvm::Triple::FreeBSD)
2581 CmdArgs.push_back("-ldl");
2582}
2583
2584static void
2585collectSanitizerRuntimes(const ToolChain &TC, const ArgList &Args,
2586 SmallVectorImpl<StringRef> &SharedRuntimes,
2587 SmallVectorImpl<StringRef> &StaticRuntimes,
2588 SmallVectorImpl<StringRef> &HelperStaticRuntimes) {
2589 const SanitizerArgs &SanArgs = TC.getSanitizerArgs();
2590 // Collect shared runtimes.
2591 if (SanArgs.needsAsanRt() && SanArgs.needsSharedAsanRt()) {
2592 SharedRuntimes.push_back("asan");
Evgeniy Stepanov77866712012-04-25 08:59:22 +00002593 }
Alexey Samsonovbdfa6c22014-04-01 13:31:10 +00002594
Alexey Samsonov52550342014-09-15 19:58:40 +00002595 // Collect static runtimes.
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00002596 if (Args.hasArg(options::OPT_shared) || TC.getTriple().isAndroid()) {
Alexey Samsonov52550342014-09-15 19:58:40 +00002597 // Don't link static runtimes into DSOs or if compiling for Android.
Alexey Samsonovbdfa6c22014-04-01 13:31:10 +00002598 return;
Alexey Samsonov52550342014-09-15 19:58:40 +00002599 }
2600 if (SanArgs.needsAsanRt()) {
2601 if (SanArgs.needsSharedAsanRt()) {
2602 HelperStaticRuntimes.push_back("asan-preinit");
2603 } else {
2604 StaticRuntimes.push_back("asan");
2605 if (SanArgs.linkCXXRuntimes())
2606 StaticRuntimes.push_back("asan_cxx");
2607 }
2608 }
2609 if (SanArgs.needsDfsanRt())
2610 StaticRuntimes.push_back("dfsan");
2611 if (SanArgs.needsLsanRt())
2612 StaticRuntimes.push_back("lsan");
Alexey Samsonov381845d2015-04-27 22:07:50 +00002613 if (SanArgs.needsMsanRt()) {
Alexey Samsonov52550342014-09-15 19:58:40 +00002614 StaticRuntimes.push_back("msan");
Alexey Samsonov381845d2015-04-27 22:07:50 +00002615 if (SanArgs.linkCXXRuntimes())
2616 StaticRuntimes.push_back("msan_cxx");
2617 }
2618 if (SanArgs.needsTsanRt()) {
Alexey Samsonov52550342014-09-15 19:58:40 +00002619 StaticRuntimes.push_back("tsan");
Alexey Samsonov381845d2015-04-27 22:07:50 +00002620 if (SanArgs.linkCXXRuntimes())
2621 StaticRuntimes.push_back("tsan_cxx");
2622 }
Alexey Samsonov52550342014-09-15 19:58:40 +00002623 if (SanArgs.needsUbsanRt()) {
Alexey Samsonov31095462015-04-01 22:42:25 +00002624 StaticRuntimes.push_back("ubsan_standalone");
2625 if (SanArgs.linkCXXRuntimes())
2626 StaticRuntimes.push_back("ubsan_standalone_cxx");
Alexey Samsonovb01f9362014-05-12 18:39:51 +00002627 }
Peter Collingbournec4122c12015-06-15 21:08:13 +00002628 if (SanArgs.needsSafeStackRt())
2629 StaticRuntimes.push_back("safestack");
Kostya Serebryany7bca6c22011-11-30 01:39:16 +00002630}
2631
Alexey Samsonov52550342014-09-15 19:58:40 +00002632// Should be called before we add system libraries (C++ ABI, libstdc++/libc++,
2633// C runtime, etc). Returns true if sanitizer system deps need to be linked in.
2634static bool addSanitizerRuntimes(const ToolChain &TC, const ArgList &Args,
Alexey Samsonovce8ab102014-02-25 12:43:43 +00002635 ArgStringList &CmdArgs) {
Alexey Samsonov52550342014-09-15 19:58:40 +00002636 SmallVector<StringRef, 4> SharedRuntimes, StaticRuntimes,
2637 HelperStaticRuntimes;
2638 collectSanitizerRuntimes(TC, Args, SharedRuntimes, StaticRuntimes,
2639 HelperStaticRuntimes);
2640 for (auto RT : SharedRuntimes)
2641 addSanitizerRuntime(TC, Args, CmdArgs, RT, true);
2642 for (auto RT : HelperStaticRuntimes)
2643 addSanitizerRuntime(TC, Args, CmdArgs, RT, false);
2644 bool AddExportDynamic = false;
2645 for (auto RT : StaticRuntimes) {
2646 addSanitizerRuntime(TC, Args, CmdArgs, RT, false);
2647 AddExportDynamic |= !addSanitizerDynamicList(TC, Args, CmdArgs, RT);
2648 }
2649 // If there is a static runtime with no dynamic list, force all the symbols
2650 // to be dynamic to be sure we export sanitizer interface functions.
2651 if (AddExportDynamic)
2652 CmdArgs.push_back("-export-dynamic");
2653 return !StaticRuntimes.empty();
Peter Collingbournec3772752013-08-07 22:47:34 +00002654}
2655
Reid Kleckner86ea7702015-02-04 23:45:07 +00002656static bool areOptimizationsEnabled(const ArgList &Args) {
2657 // Find the last -O arg and see if it is non-zero.
2658 if (Arg *A = Args.getLastArg(options::OPT_O_Group))
2659 return !A->getOption().matches(options::OPT_O0);
2660 // Defaults to -O0.
2661 return false;
2662}
2663
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002664static bool shouldUseFramePointerForTarget(const ArgList &Args,
2665 const llvm::Triple &Triple) {
Dan Gohmanc2853072015-09-03 22:51:53 +00002666 switch (Triple.getArch()) {
2667 case llvm::Triple::xcore:
2668 case llvm::Triple::wasm32:
2669 case llvm::Triple::wasm64:
2670 // XCore never wants frame pointers, regardless of OS.
2671 // WebAssembly never wants frame pointers.
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002672 return false;
Dan Gohmanc2853072015-09-03 22:51:53 +00002673 default:
2674 break;
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002675 }
Reid Kleckner86ea7702015-02-04 23:45:07 +00002676
2677 if (Triple.isOSLinux()) {
2678 switch (Triple.getArch()) {
2679 // Don't use a frame pointer on linux if optimizing for certain targets.
2680 case llvm::Triple::mips64:
2681 case llvm::Triple::mips64el:
2682 case llvm::Triple::mips:
2683 case llvm::Triple::mipsel:
2684 case llvm::Triple::systemz:
2685 case llvm::Triple::x86:
2686 case llvm::Triple::x86_64:
2687 return !areOptimizationsEnabled(Args);
2688 default:
2689 return true;
2690 }
2691 }
2692
2693 if (Triple.isOSWindows()) {
2694 switch (Triple.getArch()) {
2695 case llvm::Triple::x86:
2696 return !areOptimizationsEnabled(Args);
Saleem Abdulrasoola8180a22015-10-03 03:39:28 +00002697 case llvm::Triple::arm:
2698 case llvm::Triple::thumb:
2699 // Windows on ARM builds with FPO disabled to aid fast stack walking
2700 return true;
Reid Kleckner86ea7702015-02-04 23:45:07 +00002701 default:
2702 // All other supported Windows ISAs use xdata unwind information, so frame
2703 // pointers are not generally useful.
2704 return false;
2705 }
2706 }
2707
2708 return true;
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002709}
2710
Rafael Espindola224dd632011-12-14 21:02:23 +00002711static bool shouldUseFramePointer(const ArgList &Args,
2712 const llvm::Triple &Triple) {
2713 if (Arg *A = Args.getLastArg(options::OPT_fno_omit_frame_pointer,
2714 options::OPT_fomit_frame_pointer))
2715 return A->getOption().matches(options::OPT_fno_omit_frame_pointer);
2716
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002717 return shouldUseFramePointerForTarget(Args, Triple);
Rafael Espindola224dd632011-12-14 21:02:23 +00002718}
2719
Eric Christopherb7d97e92013-04-03 01:58:53 +00002720static bool shouldUseLeafFramePointer(const ArgList &Args,
2721 const llvm::Triple &Triple) {
2722 if (Arg *A = Args.getLastArg(options::OPT_mno_omit_leaf_frame_pointer,
2723 options::OPT_momit_leaf_frame_pointer))
2724 return A->getOption().matches(options::OPT_mno_omit_leaf_frame_pointer);
2725
Filipe Cabecinhasb1e6c2d2015-01-27 18:08:32 +00002726 if (Triple.isPS4CPU())
2727 return false;
2728
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002729 return shouldUseFramePointerForTarget(Args, Triple);
Eric Christopherb7d97e92013-04-03 01:58:53 +00002730}
2731
Rafael Espindolac7367ff2013-08-10 01:40:10 +00002732/// Add a CC1 option to specify the debug compilation directory.
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00002733static void addDebugCompDirArg(const ArgList &Args, ArgStringList &CmdArgs) {
Benjamin Kramer698d7c82013-04-27 08:12:29 +00002734 SmallString<128> cwd;
2735 if (!llvm::sys::fs::current_path(cwd)) {
Chad Rosiera35d5a32013-04-26 20:49:50 +00002736 CmdArgs.push_back("-fdebug-compilation-dir");
2737 CmdArgs.push_back(Args.MakeArgString(cwd));
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00002738 }
2739}
2740
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002741static const char *SplitDebugName(const ArgList &Args, const InputInfo &Input) {
Eric Christopherd3804002013-02-22 20:12:52 +00002742 Arg *FinalOutput = Args.getLastArg(options::OPT_o);
2743 if (FinalOutput && Args.hasArg(options::OPT_c)) {
2744 SmallString<128> T(FinalOutput->getValue());
2745 llvm::sys::path::replace_extension(T, "dwo");
2746 return Args.MakeArgString(T);
2747 } else {
2748 // Use the compilation dir.
Nico Webere8e53112014-05-11 01:04:02 +00002749 SmallString<128> T(
2750 Args.getLastArgValue(options::OPT_fdebug_compilation_dir));
Artem Belevichba558952015-05-06 18:20:23 +00002751 SmallString<128> F(llvm::sys::path::stem(Input.getBaseInput()));
Eric Christopherd3804002013-02-22 20:12:52 +00002752 llvm::sys::path::replace_extension(F, "dwo");
2753 T += F;
2754 return Args.MakeArgString(F);
2755 }
2756}
2757
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002758static void SplitDebugInfo(const ToolChain &TC, Compilation &C, const Tool &T,
2759 const JobAction &JA, const ArgList &Args,
2760 const InputInfo &Output, const char *OutFile) {
Eric Christopher248357f2013-02-21 22:35:01 +00002761 ArgStringList ExtractArgs;
2762 ExtractArgs.push_back("--extract-dwo");
2763
2764 ArgStringList StripArgs;
2765 StripArgs.push_back("--strip-dwo");
2766
2767 // Grabbing the output of the earlier compile step.
2768 StripArgs.push_back(Output.getFilename());
2769 ExtractArgs.push_back(Output.getFilename());
Eric Christopher248357f2013-02-21 22:35:01 +00002770 ExtractArgs.push_back(OutFile);
2771
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002772 const char *Exec = Args.MakeArgString(TC.GetProgramPath("objcopy"));
Justin Bognerd3371d82015-07-17 03:35:54 +00002773 InputInfo II(Output.getFilename(), types::TY_Object, Output.getFilename());
Eric Christopher248357f2013-02-21 22:35:01 +00002774
2775 // First extract the dwo sections.
Justin Bognerd3371d82015-07-17 03:35:54 +00002776 C.addCommand(llvm::make_unique<Command>(JA, T, Exec, ExtractArgs, II));
Eric Christopher248357f2013-02-21 22:35:01 +00002777
2778 // Then remove them from the original .o file.
Justin Bognerd3371d82015-07-17 03:35:54 +00002779 C.addCommand(llvm::make_unique<Command>(JA, T, Exec, StripArgs, II));
Eric Christopher248357f2013-02-21 22:35:01 +00002780}
2781
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002782/// \brief Vectorize at all optimization levels greater than 1 except for -Oz.
Chad Rosier3ba81bd2014-05-02 18:41:57 +00002783/// For -Oz the loop vectorizer is disable, while the slp vectorizer is enabled.
2784static bool shouldEnableVectorizerAtOLevel(const ArgList &Args, bool isSlpVec) {
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002785 if (Arg *A = Args.getLastArg(options::OPT_O_Group)) {
Rafael Espindolaad70d962013-08-27 16:58:15 +00002786 if (A->getOption().matches(options::OPT_O4) ||
2787 A->getOption().matches(options::OPT_Ofast))
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002788 return true;
2789
2790 if (A->getOption().matches(options::OPT_O0))
2791 return false;
2792
2793 assert(A->getOption().matches(options::OPT_O) && "Must have a -O flag");
2794
Rafael Espindola91780de2013-08-26 14:05:41 +00002795 // Vectorize -Os.
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002796 StringRef S(A->getValue());
Rafael Espindola91780de2013-08-26 14:05:41 +00002797 if (S == "s")
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002798 return true;
2799
Chad Rosier3ba81bd2014-05-02 18:41:57 +00002800 // Don't vectorize -Oz, unless it's the slp vectorizer.
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002801 if (S == "z")
Chad Rosier3ba81bd2014-05-02 18:41:57 +00002802 return isSlpVec;
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002803
2804 unsigned OptLevel = 0;
2805 if (S.getAsInteger(10, OptLevel))
2806 return false;
2807
2808 return OptLevel > 1;
2809 }
2810
2811 return false;
2812}
2813
Ben Langmuir2cb4a782014-02-05 22:21:15 +00002814/// Add -x lang to \p CmdArgs for \p Input.
2815static void addDashXForInput(const ArgList &Args, const InputInfo &Input,
2816 ArgStringList &CmdArgs) {
2817 // When using -verify-pch, we don't want to provide the type
2818 // 'precompiled-header' if it was inferred from the file extension
2819 if (Args.hasArg(options::OPT_verify_pch) && Input.getType() == types::TY_PCH)
2820 return;
2821
2822 CmdArgs.push_back("-x");
2823 if (Args.hasArg(options::OPT_rewrite_objc))
2824 CmdArgs.push_back(types::getTypeName(types::TY_PP_ObjCXX));
2825 else
2826 CmdArgs.push_back(types::getTypeName(Input.getType()));
2827}
2828
David Majnemerc371ff02015-03-22 08:39:22 +00002829static VersionTuple getMSCompatibilityVersion(unsigned Version) {
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00002830 if (Version < 100)
David Majnemerc371ff02015-03-22 08:39:22 +00002831 return VersionTuple(Version);
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00002832
2833 if (Version < 10000)
David Majnemerc371ff02015-03-22 08:39:22 +00002834 return VersionTuple(Version / 100, Version % 100);
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00002835
2836 unsigned Build = 0, Factor = 1;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002837 for (; Version > 10000; Version = Version / 10, Factor = Factor * 10)
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00002838 Build = Build + (Version % 10) * Factor;
David Majnemerc371ff02015-03-22 08:39:22 +00002839 return VersionTuple(Version / 100, Version % 100, Build);
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00002840}
2841
Rafael Espindola577637a2015-01-03 00:06:04 +00002842// Claim options we don't want to warn if they are unused. We do this for
Rafael Espindola7a45e872015-01-05 13:44:59 +00002843// options that build systems might add but are unused when assembling or only
2844// running the preprocessor for example.
Rafael Espindola577637a2015-01-03 00:06:04 +00002845static void claimNoWarnArgs(const ArgList &Args) {
2846 // Don't warn about unused -f(no-)?lto. This can happen when we're
Rafael Espindola7a45e872015-01-05 13:44:59 +00002847 // preprocessing, precompiling or assembling.
Rafael Espindola577637a2015-01-03 00:06:04 +00002848 Args.ClaimAllArgs(options::OPT_flto);
2849 Args.ClaimAllArgs(options::OPT_fno_lto);
2850}
2851
Ben Langmuir3b7b5402015-02-03 19:28:37 +00002852static void appendUserToPath(SmallVectorImpl<char> &Result) {
2853#ifdef LLVM_ON_UNIX
2854 const char *Username = getenv("LOGNAME");
2855#else
2856 const char *Username = getenv("USERNAME");
2857#endif
2858 if (Username) {
2859 // Validate that LoginName can be used in a path, and get its length.
2860 size_t Len = 0;
2861 for (const char *P = Username; *P; ++P, ++Len) {
Ben Langmuire056ec32015-02-04 18:34:23 +00002862 if (!isAlphanumeric(*P) && *P != '_') {
Ben Langmuir3b7b5402015-02-03 19:28:37 +00002863 Username = nullptr;
2864 break;
2865 }
2866 }
2867
2868 if (Username && Len > 0) {
2869 Result.append(Username, Username + Len);
2870 return;
2871 }
2872 }
2873
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002874// Fallback to user id.
Ben Langmuir3b7b5402015-02-03 19:28:37 +00002875#ifdef LLVM_ON_UNIX
2876 std::string UID = llvm::utostr(getuid());
2877#else
2878 // FIXME: Windows seems to have an 'SID' that might work.
2879 std::string UID = "9999";
2880#endif
2881 Result.append(UID.begin(), UID.end());
2882}
2883
David Majnemere11d3732015-06-08 00:22:46 +00002884VersionTuple visualstudio::getMSVCVersion(const Driver *D,
2885 const llvm::Triple &Triple,
2886 const llvm::opt::ArgList &Args,
2887 bool IsWindowsMSVC) {
2888 if (Args.hasFlag(options::OPT_fms_extensions, options::OPT_fno_ms_extensions,
2889 IsWindowsMSVC) ||
2890 Args.hasArg(options::OPT_fmsc_version) ||
2891 Args.hasArg(options::OPT_fms_compatibility_version)) {
2892 const Arg *MSCVersion = Args.getLastArg(options::OPT_fmsc_version);
2893 const Arg *MSCompatibilityVersion =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002894 Args.getLastArg(options::OPT_fms_compatibility_version);
David Majnemere11d3732015-06-08 00:22:46 +00002895
2896 if (MSCVersion && MSCompatibilityVersion) {
2897 if (D)
2898 D->Diag(diag::err_drv_argument_not_allowed_with)
2899 << MSCVersion->getAsString(Args)
2900 << MSCompatibilityVersion->getAsString(Args);
2901 return VersionTuple();
2902 }
2903
2904 if (MSCompatibilityVersion) {
2905 VersionTuple MSVT;
2906 if (MSVT.tryParse(MSCompatibilityVersion->getValue()) && D)
2907 D->Diag(diag::err_drv_invalid_value)
2908 << MSCompatibilityVersion->getAsString(Args)
2909 << MSCompatibilityVersion->getValue();
2910 return MSVT;
2911 }
2912
2913 if (MSCVersion) {
2914 unsigned Version = 0;
2915 if (StringRef(MSCVersion->getValue()).getAsInteger(10, Version) && D)
2916 D->Diag(diag::err_drv_invalid_value) << MSCVersion->getAsString(Args)
2917 << MSCVersion->getValue();
2918 return getMSCompatibilityVersion(Version);
2919 }
2920
2921 unsigned Major, Minor, Micro;
2922 Triple.getEnvironmentVersion(Major, Minor, Micro);
2923 if (Major || Minor || Micro)
2924 return VersionTuple(Major, Minor, Micro);
2925
2926 return VersionTuple(18);
2927 }
2928 return VersionTuple();
2929}
2930
Diego Novilloa0545962015-07-10 18:00:07 +00002931static void addPGOAndCoverageFlags(Compilation &C, const Driver &D,
2932 const InputInfo &Output, const ArgList &Args,
2933 ArgStringList &CmdArgs) {
2934 auto *ProfileGenerateArg = Args.getLastArg(
2935 options::OPT_fprofile_instr_generate,
2936 options::OPT_fprofile_instr_generate_EQ, options::OPT_fprofile_generate,
Diego Novillo758f3f52015-08-05 21:49:51 +00002937 options::OPT_fprofile_generate_EQ,
2938 options::OPT_fno_profile_instr_generate);
2939 if (ProfileGenerateArg &&
2940 ProfileGenerateArg->getOption().matches(
2941 options::OPT_fno_profile_instr_generate))
2942 ProfileGenerateArg = nullptr;
Diego Novilloa0545962015-07-10 18:00:07 +00002943
2944 auto *ProfileUseArg = Args.getLastArg(
2945 options::OPT_fprofile_instr_use, options::OPT_fprofile_instr_use_EQ,
Diego Novillo758f3f52015-08-05 21:49:51 +00002946 options::OPT_fprofile_use, options::OPT_fprofile_use_EQ,
2947 options::OPT_fno_profile_instr_use);
2948 if (ProfileUseArg &&
2949 ProfileUseArg->getOption().matches(options::OPT_fno_profile_instr_use))
2950 ProfileUseArg = nullptr;
Diego Novilloa0545962015-07-10 18:00:07 +00002951
2952 if (ProfileGenerateArg && ProfileUseArg)
2953 D.Diag(diag::err_drv_argument_not_allowed_with)
Renato Golin7c542b42015-07-27 23:44:45 +00002954 << ProfileGenerateArg->getSpelling() << ProfileUseArg->getSpelling();
Diego Novilloa0545962015-07-10 18:00:07 +00002955
Diego Novillo758f3f52015-08-05 21:49:51 +00002956 if (ProfileGenerateArg) {
2957 if (ProfileGenerateArg->getOption().matches(
2958 options::OPT_fprofile_instr_generate_EQ))
2959 ProfileGenerateArg->render(Args, CmdArgs);
2960 else if (ProfileGenerateArg->getOption().matches(
2961 options::OPT_fprofile_generate_EQ)) {
2962 SmallString<128> Path(ProfileGenerateArg->getValue());
2963 llvm::sys::path::append(Path, "default.profraw");
2964 CmdArgs.push_back(
2965 Args.MakeArgString(Twine("-fprofile-instr-generate=") + Path));
2966 } else
2967 Args.AddAllArgs(CmdArgs, options::OPT_fprofile_instr_generate);
2968 }
Diego Novilloa0545962015-07-10 18:00:07 +00002969
Diego Novillo758f3f52015-08-05 21:49:51 +00002970 if (ProfileUseArg) {
2971 if (ProfileUseArg->getOption().matches(options::OPT_fprofile_instr_use_EQ))
2972 ProfileUseArg->render(Args, CmdArgs);
2973 else if ((ProfileUseArg->getOption().matches(
2974 options::OPT_fprofile_use_EQ) ||
2975 ProfileUseArg->getOption().matches(
2976 options::OPT_fprofile_instr_use))) {
2977 SmallString<128> Path(
2978 ProfileUseArg->getNumValues() == 0 ? "" : ProfileUseArg->getValue());
2979 if (Path.empty() || llvm::sys::fs::is_directory(Path))
2980 llvm::sys::path::append(Path, "default.profdata");
2981 CmdArgs.push_back(
2982 Args.MakeArgString(Twine("-fprofile-instr-use=") + Path));
2983 }
Diego Novilloa0545962015-07-10 18:00:07 +00002984 }
2985
2986 if (Args.hasArg(options::OPT_ftest_coverage) ||
2987 Args.hasArg(options::OPT_coverage))
2988 CmdArgs.push_back("-femit-coverage-notes");
2989 if (Args.hasFlag(options::OPT_fprofile_arcs, options::OPT_fno_profile_arcs,
2990 false) ||
2991 Args.hasArg(options::OPT_coverage))
2992 CmdArgs.push_back("-femit-coverage-data");
2993
Diego Novilloc4b94da2015-08-05 23:27:40 +00002994 if (Args.hasFlag(options::OPT_fcoverage_mapping,
2995 options::OPT_fno_coverage_mapping, false) &&
2996 !ProfileGenerateArg)
Diego Novilloa0545962015-07-10 18:00:07 +00002997 D.Diag(diag::err_drv_argument_only_allowed_with)
2998 << "-fcoverage-mapping"
2999 << "-fprofile-instr-generate";
3000
Diego Novilloc4b94da2015-08-05 23:27:40 +00003001 if (Args.hasFlag(options::OPT_fcoverage_mapping,
3002 options::OPT_fno_coverage_mapping, false))
Diego Novilloa0545962015-07-10 18:00:07 +00003003 CmdArgs.push_back("-fcoverage-mapping");
3004
3005 if (C.getArgs().hasArg(options::OPT_c) ||
3006 C.getArgs().hasArg(options::OPT_S)) {
3007 if (Output.isFilename()) {
3008 CmdArgs.push_back("-coverage-file");
3009 SmallString<128> CoverageFilename;
3010 if (Arg *FinalOutput = C.getArgs().getLastArg(options::OPT_o)) {
3011 CoverageFilename = FinalOutput->getValue();
3012 } else {
3013 CoverageFilename = llvm::sys::path::filename(Output.getBaseInput());
3014 }
3015 if (llvm::sys::path::is_relative(CoverageFilename)) {
3016 SmallString<128> Pwd;
3017 if (!llvm::sys::fs::current_path(Pwd)) {
3018 llvm::sys::path::append(Pwd, CoverageFilename);
3019 CoverageFilename.swap(Pwd);
3020 }
3021 }
3022 CmdArgs.push_back(Args.MakeArgString(CoverageFilename));
3023 }
3024 }
3025}
3026
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003027/// Parses the various -fpic/-fPIC/-fpie/-fPIE arguments. Then,
3028/// smooshes them together with platform defaults, to decide whether
3029/// this compile should be using PIC mode or not. Returns a tuple of
3030/// (RelocationModel, PICLevel, IsPIE).
3031static std::tuple<llvm::Reloc::Model, unsigned, bool>
3032ParsePICArgs(const ToolChain &ToolChain, const llvm::Triple &Triple,
3033 const ArgList &Args) {
3034 // FIXME: why does this code...and so much everywhere else, use both
3035 // ToolChain.getTriple() and Triple?
3036 bool PIE = ToolChain.isPIEDefault();
3037 bool PIC = PIE || ToolChain.isPICDefault();
3038 bool IsPICLevelTwo = PIC;
3039
3040 bool KernelOrKext =
3041 Args.hasArg(options::OPT_mkernel, options::OPT_fapple_kext);
3042
3043 // Android-specific defaults for PIC/PIE
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00003044 if (ToolChain.getTriple().isAndroid()) {
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003045 switch (ToolChain.getArch()) {
3046 case llvm::Triple::arm:
3047 case llvm::Triple::armeb:
3048 case llvm::Triple::thumb:
3049 case llvm::Triple::thumbeb:
3050 case llvm::Triple::aarch64:
3051 case llvm::Triple::mips:
3052 case llvm::Triple::mipsel:
3053 case llvm::Triple::mips64:
3054 case llvm::Triple::mips64el:
3055 PIC = true; // "-fpic"
3056 break;
3057
3058 case llvm::Triple::x86:
3059 case llvm::Triple::x86_64:
3060 PIC = true; // "-fPIC"
3061 IsPICLevelTwo = true;
3062 break;
3063
3064 default:
3065 break;
3066 }
3067 }
3068
3069 // OpenBSD-specific defaults for PIE
3070 if (ToolChain.getTriple().getOS() == llvm::Triple::OpenBSD) {
3071 switch (ToolChain.getArch()) {
3072 case llvm::Triple::mips64:
3073 case llvm::Triple::mips64el:
3074 case llvm::Triple::sparcel:
3075 case llvm::Triple::x86:
3076 case llvm::Triple::x86_64:
3077 IsPICLevelTwo = false; // "-fpie"
3078 break;
3079
3080 case llvm::Triple::ppc:
3081 case llvm::Triple::sparc:
3082 case llvm::Triple::sparcv9:
3083 IsPICLevelTwo = true; // "-fPIE"
3084 break;
3085
3086 default:
3087 break;
3088 }
3089 }
3090
3091 // The last argument relating to either PIC or PIE wins, and no
3092 // other argument is used. If the last argument is any flavor of the
3093 // '-fno-...' arguments, both PIC and PIE are disabled. Any PIE
3094 // option implicitly enables PIC at the same level.
3095 Arg *LastPICArg = Args.getLastArg(options::OPT_fPIC, options::OPT_fno_PIC,
3096 options::OPT_fpic, options::OPT_fno_pic,
3097 options::OPT_fPIE, options::OPT_fno_PIE,
3098 options::OPT_fpie, options::OPT_fno_pie);
3099 // Check whether the tool chain trumps the PIC-ness decision. If the PIC-ness
3100 // is forced, then neither PIC nor PIE flags will have no effect.
3101 if (!ToolChain.isPICDefaultForced()) {
3102 if (LastPICArg) {
3103 Option O = LastPICArg->getOption();
3104 if (O.matches(options::OPT_fPIC) || O.matches(options::OPT_fpic) ||
3105 O.matches(options::OPT_fPIE) || O.matches(options::OPT_fpie)) {
3106 PIE = O.matches(options::OPT_fPIE) || O.matches(options::OPT_fpie);
3107 PIC =
3108 PIE || O.matches(options::OPT_fPIC) || O.matches(options::OPT_fpic);
3109 IsPICLevelTwo =
3110 O.matches(options::OPT_fPIE) || O.matches(options::OPT_fPIC);
3111 } else {
3112 PIE = PIC = false;
3113 }
3114 }
3115 }
3116
Greg Bedwell80b325c2015-09-25 16:11:00 +00003117 // Introduce a Darwin-specific hack. If the default is PIC, but the
3118 // PIC level would've been set to level 1, force it back to level 2
3119 // PIC instead. This matches the behavior of Darwin GCC (based on
3120 // chandlerc's informal testing in 2012).
3121 if (PIC && ToolChain.getTriple().isOSDarwin())
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003122 IsPICLevelTwo |= ToolChain.isPICDefault();
3123
James Y Knightc4015d32015-08-21 04:14:55 +00003124 // This kernel flags are a trump-card: they will disable PIC/PIE
3125 // generation, independent of the argument order.
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003126 if (KernelOrKext && (!Triple.isiOS() || Triple.isOSVersionLT(6)))
3127 PIC = PIE = false;
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003128
3129 if (Arg *A = Args.getLastArg(options::OPT_mdynamic_no_pic)) {
3130 // This is a very special mode. It trumps the other modes, almost no one
3131 // uses it, and it isn't even valid on any OS but Darwin.
3132 if (!ToolChain.getTriple().isOSDarwin())
3133 ToolChain.getDriver().Diag(diag::err_drv_unsupported_opt_for_target)
3134 << A->getSpelling() << ToolChain.getTriple().str();
3135
3136 // FIXME: Warn when this flag trumps some other PIC or PIE flag.
3137
3138 // Only a forced PIC mode can cause the actual compile to have PIC defines
3139 // etc., no flags are sufficient. This behavior was selected to closely
3140 // match that of llvm-gcc and Apple GCC before that.
3141 PIC = ToolChain.isPICDefault() && ToolChain.isPICDefaultForced();
3142
3143 return std::make_tuple(llvm::Reloc::DynamicNoPIC, PIC ? 2 : 0, false);
3144 }
3145
3146 if (PIC)
3147 return std::make_tuple(llvm::Reloc::PIC_, IsPICLevelTwo ? 2 : 1, PIE);
3148
3149 return std::make_tuple(llvm::Reloc::Static, 0, false);
3150}
3151
3152static const char *RelocationModelName(llvm::Reloc::Model Model) {
3153 switch (Model) {
3154 case llvm::Reloc::Default:
3155 return nullptr;
3156 case llvm::Reloc::Static:
3157 return "static";
3158 case llvm::Reloc::PIC_:
3159 return "pic";
3160 case llvm::Reloc::DynamicNoPIC:
3161 return "dynamic-no-pic";
3162 }
Aaron Ballman2ec49282015-08-20 13:31:16 +00003163 llvm_unreachable("Unknown Reloc::Model kind");
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003164}
3165
3166static void AddAssemblerKPIC(const ToolChain &ToolChain, const ArgList &Args,
3167 ArgStringList &CmdArgs) {
3168 llvm::Reloc::Model RelocationModel;
3169 unsigned PICLevel;
3170 bool IsPIE;
3171 std::tie(RelocationModel, PICLevel, IsPIE) =
3172 ParsePICArgs(ToolChain, ToolChain.getTriple(), Args);
3173
3174 if (RelocationModel != llvm::Reloc::Static)
3175 CmdArgs.push_back("-KPIC");
3176}
3177
Daniel Dunbar1a093d22009-03-18 06:00:36 +00003178void Clang::ConstructJob(Compilation &C, const JobAction &JA,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003179 const InputInfo &Output, const InputInfoList &Inputs,
3180 const ArgList &Args, const char *LinkingOutput) const {
James Y Knight2db38f32015-08-15 03:45:25 +00003181 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
3182 const llvm::Triple Triple(TripleStr);
3183
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003184 bool KernelOrKext =
3185 Args.hasArg(options::OPT_mkernel, options::OPT_fapple_kext);
Daniel Dunbar083edf72009-12-21 18:54:17 +00003186 const Driver &D = getToolChain().getDriver();
Daniel Dunbara3246a02009-03-18 08:07:30 +00003187 ArgStringList CmdArgs;
3188
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00003189 bool IsWindowsGNU = getToolChain().getTriple().isWindowsGNUEnvironment();
Nico Webere8e53112014-05-11 01:04:02 +00003190 bool IsWindowsCygnus =
3191 getToolChain().getTriple().isWindowsCygwinEnvironment();
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00003192 bool IsWindowsMSVC = getToolChain().getTriple().isWindowsMSVCEnvironment();
3193
Artem Belevich0ff05cd2015-07-13 23:27:56 +00003194 // Check number of inputs for sanity. We need at least one input.
3195 assert(Inputs.size() >= 1 && "Must have at least one input.");
Artem Belevichba558952015-05-06 18:20:23 +00003196 const InputInfo &Input = Inputs[0];
Artem Belevich0ff05cd2015-07-13 23:27:56 +00003197 // CUDA compilation may have multiple inputs (source file + results of
3198 // device-side compilations). All other jobs are expected to have exactly one
3199 // input.
3200 bool IsCuda = types::isCuda(Input.getType());
3201 assert((IsCuda || Inputs.size() == 1) && "Unable to handle multiple inputs.");
Daniel Dunbare521a892009-03-31 20:53:55 +00003202
Daniel Dunbar6c536aa2009-12-11 23:00:49 +00003203 // Invoke ourselves in -cc1 mode.
3204 //
3205 // FIXME: Implement custom jobs for internal actions.
3206 CmdArgs.push_back("-cc1");
3207
Daniel Dunbar624c21b2009-10-30 18:12:20 +00003208 // Add the "effective" target triple.
Daniel Dunbard640be22009-03-31 17:35:15 +00003209 CmdArgs.push_back("-triple");
Daniel Dunbar624c21b2009-10-30 18:12:20 +00003210 CmdArgs.push_back(Args.MakeArgString(TripleStr));
Daniel Dunbarfb58b0a2009-09-10 06:49:20 +00003211
James Y Knight2db38f32015-08-15 03:45:25 +00003212 if (Triple.isOSWindows() && (Triple.getArch() == llvm::Triple::arm ||
3213 Triple.getArch() == llvm::Triple::thumb)) {
3214 unsigned Offset = Triple.getArch() == llvm::Triple::arm ? 4 : 6;
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +00003215 unsigned Version;
James Y Knight2db38f32015-08-15 03:45:25 +00003216 Triple.getArchName().substr(Offset).getAsInteger(10, Version);
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +00003217 if (Version < 7)
James Y Knight2db38f32015-08-15 03:45:25 +00003218 D.Diag(diag::err_target_unsupported_arch) << Triple.getArchName()
Nico Webere8e53112014-05-11 01:04:02 +00003219 << TripleStr;
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +00003220 }
3221
Tim Northover336f1892014-03-29 13:16:12 +00003222 // Push all default warning arguments that are specific to
3223 // the given target. These come before user provided warning options
3224 // are provided.
3225 getToolChain().addClangWarningOptions(CmdArgs);
3226
Daniel Dunbar624c21b2009-10-30 18:12:20 +00003227 // Select the appropriate action.
John McCall5fb5df92012-06-20 06:18:46 +00003228 RewriteKind rewriteKind = RK_None;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003229
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003230 if (isa<AnalyzeJobAction>(JA)) {
3231 assert(JA.getType() == types::TY_Plist && "Invalid output type.");
3232 CmdArgs.push_back("-analyze");
Ted Kremenekf7639e12012-03-06 20:06:33 +00003233 } else if (isa<MigrateJobAction>(JA)) {
3234 CmdArgs.push_back("-migrate");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003235 } else if (isa<PreprocessJobAction>(JA)) {
Daniel Dunbard67a3222009-03-30 06:36:42 +00003236 if (Output.getType() == types::TY_Dependencies)
3237 CmdArgs.push_back("-Eonly");
Fariborz Jahaniane0a75d62013-03-18 19:41:18 +00003238 else {
Daniel Dunbard67a3222009-03-30 06:36:42 +00003239 CmdArgs.push_back("-E");
Fariborz Jahaniane0a75d62013-03-18 19:41:18 +00003240 if (Args.hasArg(options::OPT_rewrite_objc) &&
3241 !Args.hasArg(options::OPT_g_Group))
3242 CmdArgs.push_back("-P");
3243 }
Daniel Dunbarc4343942010-02-03 03:07:56 +00003244 } else if (isa<AssembleJobAction>(JA)) {
3245 CmdArgs.push_back("-emit-obj");
Daniel Dunbar06e2cc32010-05-27 06:18:05 +00003246
David Blaikie9260ed62013-07-25 21:19:01 +00003247 CollectArgsForIntegratedAssembler(C, Args, CmdArgs, D);
Daniel Dunbar7c874332010-11-19 16:23:35 +00003248
3249 // Also ignore explicit -force_cpusubtype_ALL option.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003250 (void)Args.hasArg(options::OPT_force__cpusubtype__ALL);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003251 } else if (isa<PrecompileJobAction>(JA)) {
Argyrios Kyrtzidis90bdfbb2010-08-11 23:27:58 +00003252 // Use PCH if the user requested it.
Daniel Dunbarcbc34b72009-10-15 20:02:44 +00003253 bool UsePCH = D.CCCUsePCH;
Daniel Dunbarcbc34b72009-10-15 20:02:44 +00003254
Aaron Ballman1f10cc52012-07-31 01:21:00 +00003255 if (JA.getType() == types::TY_Nothing)
3256 CmdArgs.push_back("-fsyntax-only");
3257 else if (UsePCH)
Douglas Gregor111af7d2009-04-18 00:34:01 +00003258 CmdArgs.push_back("-emit-pch");
3259 else
3260 CmdArgs.push_back("-emit-pth");
Ben Langmuir9b9a8d32014-02-06 18:53:25 +00003261 } else if (isa<VerifyPCHJobAction>(JA)) {
3262 CmdArgs.push_back("-verify-pch");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003263 } else {
Bob Wilson23a55f12014-12-21 07:00:00 +00003264 assert((isa<CompileJobAction>(JA) || isa<BackendJobAction>(JA)) &&
3265 "Invalid action for clang tool.");
Daniel Dunbard067f7f2009-04-08 23:54:23 +00003266
Renato Golin7c542b42015-07-27 23:44:45 +00003267 if (JA.getType() == types::TY_LTO_IR || JA.getType() == types::TY_LTO_BC) {
Teresa Johnson8749d8042015-07-06 16:23:00 +00003268 CmdArgs.push_back("-flto");
3269 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003270 if (JA.getType() == types::TY_Nothing) {
Ben Langmuir9b9a8d32014-02-06 18:53:25 +00003271 CmdArgs.push_back("-fsyntax-only");
Daniel Dunbar24e52992010-06-07 23:28:45 +00003272 } else if (JA.getType() == types::TY_LLVM_IR ||
3273 JA.getType() == types::TY_LTO_IR) {
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003274 CmdArgs.push_back("-emit-llvm");
Daniel Dunbar24e52992010-06-07 23:28:45 +00003275 } else if (JA.getType() == types::TY_LLVM_BC ||
3276 JA.getType() == types::TY_LTO_BC) {
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003277 CmdArgs.push_back("-emit-llvm-bc");
3278 } else if (JA.getType() == types::TY_PP_Asm) {
Daniel Dunbard112f102009-09-17 00:47:53 +00003279 CmdArgs.push_back("-S");
Daniel Dunbar6cdf83c2009-09-01 16:57:46 +00003280 } else if (JA.getType() == types::TY_AST) {
3281 CmdArgs.push_back("-emit-pch");
Douglas Gregorbf7fc9c2013-03-27 16:47:18 +00003282 } else if (JA.getType() == types::TY_ModuleFile) {
3283 CmdArgs.push_back("-module-file-info");
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00003284 } else if (JA.getType() == types::TY_RewrittenObjC) {
3285 CmdArgs.push_back("-rewrite-objc");
John McCall5fb5df92012-06-20 06:18:46 +00003286 rewriteKind = RK_NonFragile;
Fariborz Jahanian73223bb2012-04-02 15:59:19 +00003287 } else if (JA.getType() == types::TY_RewrittenLegacyObjC) {
3288 CmdArgs.push_back("-rewrite-objc");
John McCall5fb5df92012-06-20 06:18:46 +00003289 rewriteKind = RK_Fragile;
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00003290 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003291 assert(JA.getType() == types::TY_PP_Asm && "Unexpected output type!");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003292 }
Duncan P. N. Exon Smithd863f6f2015-04-14 18:30:13 +00003293
3294 // Preserve use-list order by default when emitting bitcode, so that
3295 // loading the bitcode up in 'opt' or 'llc' and running passes gives the
3296 // same result as running passes here. For LTO, we don't need to preserve
3297 // the use-list order, since serialization to bitcode is part of the flow.
Duncan P. N. Exon Smithbb618252015-04-15 01:16:18 +00003298 if (JA.getType() == types::TY_LLVM_BC)
3299 CmdArgs.push_back("-emit-llvm-uselists");
Daniel Dunbara3246a02009-03-18 08:07:30 +00003300 }
3301
Justin Bognera88f0122014-06-20 22:59:50 +00003302 // We normally speed up the clang process a bit by skipping destructors at
3303 // exit, but when we're generating diagnostics we can rely on some of the
3304 // cleanup.
3305 if (!C.isForDiagnostics())
3306 CmdArgs.push_back("-disable-free");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003307
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003308// Disable the verification pass in -asserts builds.
John McCallbb79b5f2010-02-13 03:50:24 +00003309#ifdef NDEBUG
3310 CmdArgs.push_back("-disable-llvm-verifier");
3311#endif
3312
Daniel Dunbar3b358a32009-04-08 05:11:16 +00003313 // Set the main file name, so that debug info works even with
3314 // -save-temps.
3315 CmdArgs.push_back("-main-file-name");
Artem Belevichba558952015-05-06 18:20:23 +00003316 CmdArgs.push_back(getBaseInputName(Args, Input));
Daniel Dunbar3b358a32009-04-08 05:11:16 +00003317
Daniel Dunbar17ddaa62009-04-08 18:03:55 +00003318 // Some flags which affect the language (via preprocessor
Bob Wilsondecc03e2012-11-23 06:14:39 +00003319 // defines).
Daniel Dunbar17ddaa62009-04-08 18:03:55 +00003320 if (Args.hasArg(options::OPT_static))
3321 CmdArgs.push_back("-static-define");
3322
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003323 if (isa<AnalyzeJobAction>(JA)) {
Ted Kremenek05e6f5b2009-09-25 05:55:59 +00003324 // Enable region store model by default.
3325 CmdArgs.push_back("-analyzer-store=region");
3326
Ted Kremenek7bea9a12009-12-07 22:26:14 +00003327 // Treat blocks as analysis entry points.
3328 CmdArgs.push_back("-analyzer-opt-analyze-nested-blocks");
3329
Ted Kremenek49c79792011-03-24 00:28:47 +00003330 CmdArgs.push_back("-analyzer-eagerly-assume");
3331
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003332 // Add default argument set.
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00003333 if (!Args.hasArg(options::OPT__analyzer_no_default_checks)) {
Argyrios Kyrtzidisa6d04d52011-02-15 07:42:33 +00003334 CmdArgs.push_back("-analyzer-checker=core");
Ted Kremenek49c79792011-03-24 00:28:47 +00003335
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00003336 if (!IsWindowsMSVC)
Argyrios Kyrtzidisa6d04d52011-02-15 07:42:33 +00003337 CmdArgs.push_back("-analyzer-checker=unix");
Ted Kremenek49c79792011-03-24 00:28:47 +00003338
Argyrios Kyrtzidisa6d04d52011-02-15 07:42:33 +00003339 if (getToolChain().getTriple().getVendor() == llvm::Triple::Apple)
Ted Kremenek49c79792011-03-24 00:28:47 +00003340 CmdArgs.push_back("-analyzer-checker=osx");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003341
Ted Kremenekb9ff6b22012-01-20 06:00:17 +00003342 CmdArgs.push_back("-analyzer-checker=deadcode");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003343
Artem Belevichba558952015-05-06 18:20:23 +00003344 if (types::isCXX(Input.getType()))
Jordan Rose10ad0812013-04-05 17:55:07 +00003345 CmdArgs.push_back("-analyzer-checker=cplusplus");
3346
Nico Webere8e53112014-05-11 01:04:02 +00003347 // Enable the following experimental checkers for testing.
3348 CmdArgs.push_back(
3349 "-analyzer-checker=security.insecureAPI.UncheckedReturn");
Ted Kremenek37e96522012-01-26 02:27:38 +00003350 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.getpw");
3351 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.gets");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003352 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.mktemp");
Ted Kremenek37e96522012-01-26 02:27:38 +00003353 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.mkstemp");
3354 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.vfork");
Gabor Horvathe3085992015-09-14 20:34:06 +00003355
3356 // Default nullability checks.
3357 CmdArgs.push_back("-analyzer-checker=nullability.NullPassedToNonnull");
3358 CmdArgs.push_back(
3359 "-analyzer-checker=nullability.NullReturnedFromNonnull");
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00003360 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00003361
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00003362 // Set the output format. The default is plist, for (lame) historical
3363 // reasons.
3364 CmdArgs.push_back("-analyzer-output");
3365 if (Arg *A = Args.getLastArg(options::OPT__analyzer_output))
Richard Smithbd55daf2012-11-01 04:30:05 +00003366 CmdArgs.push_back(A->getValue());
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00003367 else
3368 CmdArgs.push_back("plist");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003369
Ted Kremenekfe449a22010-03-22 22:32:05 +00003370 // Disable the presentation of standard compiler warnings when
3371 // using --analyze. We only want to show static analyzer diagnostics
3372 // or frontend errors.
3373 CmdArgs.push_back("-w");
3374
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003375 // Add -Xanalyzer arguments when running as analyzer.
3376 Args.AddAllArgValues(CmdArgs, options::OPT_Xanalyzer);
Mike Stump11289f42009-09-09 15:08:12 +00003377 }
3378
Daniel Dunbar4eadb602009-09-10 01:21:12 +00003379 CheckCodeGenerationOptions(D, Args);
3380
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003381 llvm::Reloc::Model RelocationModel;
3382 unsigned PICLevel;
3383 bool IsPIE;
3384 std::tie(RelocationModel, PICLevel, IsPIE) =
3385 ParsePICArgs(getToolChain(), Triple, Args);
Peter Collingbourne54d770c2013-04-09 04:35:11 +00003386
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003387 const char *RMName = RelocationModelName(RelocationModel);
3388 if (RMName) {
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003389 CmdArgs.push_back("-mrelocation-model");
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003390 CmdArgs.push_back(RMName);
3391 }
3392 if (PICLevel > 0) {
3393 CmdArgs.push_back("-pic-level");
3394 CmdArgs.push_back(PICLevel == 1 ? "1" : "2");
3395 if (IsPIE) {
3396 CmdArgs.push_back("-pie-level");
3397 CmdArgs.push_back(PICLevel == 1 ? "1" : "2");
Chandler Carruth76a943b2012-11-19 03:52:03 +00003398 }
Daniel Dunbar44e71222009-04-29 18:32:25 +00003399 }
Chandler Carruthc0c04552012-04-08 16:40:35 +00003400
Jonathan Roelofsb140a102014-10-03 21:57:44 +00003401 CmdArgs.push_back("-mthread-model");
3402 if (Arg *A = Args.getLastArg(options::OPT_mthread_model))
3403 CmdArgs.push_back(A->getValue());
3404 else
3405 CmdArgs.push_back(Args.MakeArgString(getToolChain().getThreadModel()));
3406
Michael Zolotukhinc888dd02015-03-17 20:03:11 +00003407 Args.AddLastArg(CmdArgs, options::OPT_fveclib);
3408
Tanya Lattnerf9d41df2009-11-04 01:18:09 +00003409 if (!Args.hasFlag(options::OPT_fmerge_all_constants,
3410 options::OPT_fno_merge_all_constants))
Chris Lattner9242b332011-04-08 18:06:54 +00003411 CmdArgs.push_back("-fno-merge-all-constants");
Daniel Dunbar306945d2009-09-16 06:17:29 +00003412
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003413 // LLVM Code Generator Options.
3414
Saleem Abdulrasool76a4b952015-01-09 05:10:20 +00003415 if (Args.hasArg(options::OPT_frewrite_map_file) ||
3416 Args.hasArg(options::OPT_frewrite_map_file_EQ)) {
Sean Silva14facf32015-06-09 01:57:17 +00003417 for (const Arg *A : Args.filtered(options::OPT_frewrite_map_file,
3418 options::OPT_frewrite_map_file_EQ)) {
Saleem Abdulrasool76a4b952015-01-09 05:10:20 +00003419 CmdArgs.push_back("-frewrite-map-file");
Sean Silva14facf32015-06-09 01:57:17 +00003420 CmdArgs.push_back(A->getValue());
3421 A->claim();
Saleem Abdulrasool76a4b952015-01-09 05:10:20 +00003422 }
3423 }
3424
Alp Tokerfb8d02b2014-06-05 22:10:59 +00003425 if (Arg *A = Args.getLastArg(options::OPT_Wframe_larger_than_EQ)) {
3426 StringRef v = A->getValue();
3427 CmdArgs.push_back("-mllvm");
3428 CmdArgs.push_back(Args.MakeArgString("-warn-stack-size=" + v));
3429 A->claim();
3430 }
3431
Daniel Dunbar0bb03312011-02-09 17:54:19 +00003432 if (Arg *A = Args.getLastArg(options::OPT_mregparm_EQ)) {
3433 CmdArgs.push_back("-mregparm");
Richard Smithbd55daf2012-11-01 04:30:05 +00003434 CmdArgs.push_back(A->getValue());
Daniel Dunbar0bb03312011-02-09 17:54:19 +00003435 }
3436
Nick Lewyckyd3f3e4f2013-06-25 01:49:44 +00003437 if (Arg *A = Args.getLastArg(options::OPT_fpcc_struct_return,
3438 options::OPT_freg_struct_return)) {
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00003439 if (getToolChain().getArch() != llvm::Triple::x86) {
John McCall1fe2a8c2013-06-18 02:46:29 +00003440 D.Diag(diag::err_drv_unsupported_opt_for_target)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003441 << A->getSpelling() << getToolChain().getTriple().str();
John McCall1fe2a8c2013-06-18 02:46:29 +00003442 } else if (A->getOption().matches(options::OPT_fpcc_struct_return)) {
3443 CmdArgs.push_back("-fpcc-struct-return");
3444 } else {
3445 assert(A->getOption().matches(options::OPT_freg_struct_return));
3446 CmdArgs.push_back("-freg-struct-return");
3447 }
3448 }
3449
Roman Divacky65b88cd2011-03-01 17:40:53 +00003450 if (Args.hasFlag(options::OPT_mrtd, options::OPT_mno_rtd, false))
3451 CmdArgs.push_back("-mrtd");
3452
Rafael Espindola224dd632011-12-14 21:02:23 +00003453 if (shouldUseFramePointer(Args, getToolChain().getTriple()))
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003454 CmdArgs.push_back("-mdisable-fp-elim");
3455 if (!Args.hasFlag(options::OPT_fzero_initialized_in_bss,
3456 options::OPT_fno_zero_initialized_in_bss))
3457 CmdArgs.push_back("-mno-zero-initialized-in-bss");
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003458
3459 bool OFastEnabled = isOptimizationLevelFast(Args);
3460 // If -Ofast is the optimization level, then -fstrict-aliasing should be
3461 // enabled. This alias option is being used to simplify the hasFlag logic.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003462 OptSpecifier StrictAliasingAliasOption =
3463 OFastEnabled ? options::OPT_Ofast : options::OPT_fstrict_aliasing;
Reid Kleckner2a24e3a2014-04-09 20:07:39 +00003464 // We turn strict aliasing off by default if we're in CL mode, since MSVC
3465 // doesn't do any TBAA.
3466 bool TBAAOnByDefault = !getToolChain().getDriver().IsCLMode();
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003467 if (!Args.hasFlag(options::OPT_fstrict_aliasing, StrictAliasingAliasOption,
Reid Kleckner2a24e3a2014-04-09 20:07:39 +00003468 options::OPT_fno_strict_aliasing, TBAAOnByDefault))
Dan Gohman10169b92010-10-14 22:36:56 +00003469 CmdArgs.push_back("-relaxed-aliasing");
Manman Renf5d9d342013-10-11 20:48:38 +00003470 if (!Args.hasFlag(options::OPT_fstruct_path_tbaa,
3471 options::OPT_fno_struct_path_tbaa))
3472 CmdArgs.push_back("-no-struct-path-tbaa");
Chandler Carruth8b4140d2012-03-27 23:58:37 +00003473 if (Args.hasFlag(options::OPT_fstrict_enums, options::OPT_fno_strict_enums,
3474 false))
3475 CmdArgs.push_back("-fstrict-enums");
Piotr Padlewski338c9d02015-09-15 21:46:47 +00003476 if (Args.hasFlag(options::OPT_fstrict_vtable_pointers,
3477 options::OPT_fno_strict_vtable_pointers,
3478 false))
3479 CmdArgs.push_back("-fstrict-vtable-pointers");
Nick Lewycky1c8c4362012-01-23 08:29:12 +00003480 if (!Args.hasFlag(options::OPT_foptimize_sibling_calls,
3481 options::OPT_fno_optimize_sibling_calls))
3482 CmdArgs.push_back("-mdisable-tail-calls");
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00003483
Eric Christopher006208c2013-04-04 06:29:47 +00003484 // Handle segmented stacks.
3485 if (Args.hasArg(options::OPT_fsplit_stack))
3486 CmdArgs.push_back("-split-stacks");
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003487
3488 // If -Ofast is the optimization level, then -ffast-math should be enabled.
3489 // This alias option is being used to simplify the getLastArg logic.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003490 OptSpecifier FastMathAliasOption =
3491 OFastEnabled ? options::OPT_Ofast : options::OPT_ffast_math;
3492
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003493 // Handle various floating point optimization flags, mapping them to the
3494 // appropriate LLVM code generation flags. The pattern for all of these is to
3495 // default off the codegen optimizations, and if any flag enables them and no
3496 // flag disables them after the flag enabling them, enable the codegen
3497 // optimization. This is complicated by several "umbrella" flags.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003498 if (Arg *A = Args.getLastArg(
3499 options::OPT_ffast_math, FastMathAliasOption,
3500 options::OPT_fno_fast_math, options::OPT_ffinite_math_only,
3501 options::OPT_fno_finite_math_only, options::OPT_fhonor_infinities,
3502 options::OPT_fno_honor_infinities))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003503 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3504 A->getOption().getID() != options::OPT_fno_finite_math_only &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003505 A->getOption().getID() != options::OPT_fhonor_infinities)
3506 CmdArgs.push_back("-menable-no-infs");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003507 if (Arg *A = Args.getLastArg(
3508 options::OPT_ffast_math, FastMathAliasOption,
3509 options::OPT_fno_fast_math, options::OPT_ffinite_math_only,
3510 options::OPT_fno_finite_math_only, options::OPT_fhonor_nans,
3511 options::OPT_fno_honor_nans))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003512 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3513 A->getOption().getID() != options::OPT_fno_finite_math_only &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003514 A->getOption().getID() != options::OPT_fhonor_nans)
3515 CmdArgs.push_back("-menable-no-nans");
3516
Benjamin Kramerc242ef22012-05-02 14:55:48 +00003517 // -fmath-errno is the default on some platforms, e.g. BSD-derived OSes.
3518 bool MathErrno = getToolChain().IsMathErrnoDefault();
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003519 if (Arg *A =
3520 Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
3521 options::OPT_fno_fast_math, options::OPT_fmath_errno,
3522 options::OPT_fno_math_errno)) {
Chandler Carruth0d4b9e62013-05-18 20:47:36 +00003523 // Turning on -ffast_math (with either flag) removes the need for MathErrno.
3524 // However, turning *off* -ffast_math merely restores the toolchain default
3525 // (which may be false).
3526 if (A->getOption().getID() == options::OPT_fno_math_errno ||
3527 A->getOption().getID() == options::OPT_ffast_math ||
3528 A->getOption().getID() == options::OPT_Ofast)
3529 MathErrno = false;
3530 else if (A->getOption().getID() == options::OPT_fmath_errno)
3531 MathErrno = true;
3532 }
Chandler Carruth3634c662012-04-26 02:10:51 +00003533 if (MathErrno)
3534 CmdArgs.push_back("-fmath-errno");
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003535
3536 // There are several flags which require disabling very specific
3537 // optimizations. Any of these being disabled forces us to turn off the
3538 // entire set of LLVM optimizations, so collect them through all the flag
3539 // madness.
3540 bool AssociativeMath = false;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003541 if (Arg *A = Args.getLastArg(
3542 options::OPT_ffast_math, FastMathAliasOption,
3543 options::OPT_fno_fast_math, options::OPT_funsafe_math_optimizations,
3544 options::OPT_fno_unsafe_math_optimizations,
3545 options::OPT_fassociative_math, options::OPT_fno_associative_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003546 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3547 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003548 A->getOption().getID() != options::OPT_fno_associative_math)
3549 AssociativeMath = true;
3550 bool ReciprocalMath = false;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003551 if (Arg *A = Args.getLastArg(
3552 options::OPT_ffast_math, FastMathAliasOption,
3553 options::OPT_fno_fast_math, options::OPT_funsafe_math_optimizations,
3554 options::OPT_fno_unsafe_math_optimizations,
3555 options::OPT_freciprocal_math, options::OPT_fno_reciprocal_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003556 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3557 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003558 A->getOption().getID() != options::OPT_fno_reciprocal_math)
3559 ReciprocalMath = true;
3560 bool SignedZeros = true;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003561 if (Arg *A = Args.getLastArg(
3562 options::OPT_ffast_math, FastMathAliasOption,
3563 options::OPT_fno_fast_math, options::OPT_funsafe_math_optimizations,
3564 options::OPT_fno_unsafe_math_optimizations,
3565 options::OPT_fsigned_zeros, options::OPT_fno_signed_zeros))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003566 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3567 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003568 A->getOption().getID() != options::OPT_fsigned_zeros)
3569 SignedZeros = false;
3570 bool TrappingMath = true;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003571 if (Arg *A = Args.getLastArg(
3572 options::OPT_ffast_math, FastMathAliasOption,
3573 options::OPT_fno_fast_math, options::OPT_funsafe_math_optimizations,
3574 options::OPT_fno_unsafe_math_optimizations,
3575 options::OPT_ftrapping_math, options::OPT_fno_trapping_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003576 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3577 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003578 A->getOption().getID() != options::OPT_ftrapping_math)
3579 TrappingMath = false;
3580 if (!MathErrno && AssociativeMath && ReciprocalMath && !SignedZeros &&
3581 !TrappingMath)
3582 CmdArgs.push_back("-menable-unsafe-fp-math");
3583
Sanjay Patel76c9e092015-01-23 16:40:50 +00003584 if (!SignedZeros)
3585 CmdArgs.push_back("-fno-signed-zeros");
Lang Hamesaa53b932012-07-06 00:59:19 +00003586
Sanjay Patel359b1052015-04-09 15:03:23 +00003587 if (ReciprocalMath)
3588 CmdArgs.push_back("-freciprocal-math");
3589
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003590 // Validate and pass through -fp-contract option.
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003591 if (Arg *A = Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003592 options::OPT_fno_fast_math,
Lang Hamesaa53b932012-07-06 00:59:19 +00003593 options::OPT_ffp_contract)) {
3594 if (A->getOption().getID() == options::OPT_ffp_contract) {
Richard Smithbd55daf2012-11-01 04:30:05 +00003595 StringRef Val = A->getValue();
Lang Hamesaa53b932012-07-06 00:59:19 +00003596 if (Val == "fast" || Val == "on" || Val == "off") {
3597 CmdArgs.push_back(Args.MakeArgString("-ffp-contract=" + Val));
3598 } else {
3599 D.Diag(diag::err_drv_unsupported_option_argument)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003600 << A->getOption().getName() << Val;
Lang Hamesaa53b932012-07-06 00:59:19 +00003601 }
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003602 } else if (A->getOption().matches(options::OPT_ffast_math) ||
3603 (OFastEnabled && A->getOption().matches(options::OPT_Ofast))) {
Lang Hamesaa53b932012-07-06 00:59:19 +00003604 // If fast-math is set then set the fp-contract mode to fast.
3605 CmdArgs.push_back(Args.MakeArgString("-ffp-contract=fast"));
3606 }
3607 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003608
Sanjay Patel2987c292015-06-11 14:53:41 +00003609 ParseMRecip(getToolChain().getDriver(), Args, CmdArgs);
Lang Hamesaa53b932012-07-06 00:59:19 +00003610
Bob Wilson6a039162012-07-19 03:52:53 +00003611 // We separately look for the '-ffast-math' and '-ffinite-math-only' flags,
3612 // and if we find them, tell the frontend to provide the appropriate
3613 // preprocessor macros. This is distinct from enabling any optimizations as
3614 // these options induce language changes which must survive serialization
3615 // and deserialization, etc.
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003616 if (Arg *A = Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
3617 options::OPT_fno_fast_math))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003618 if (!A->getOption().matches(options::OPT_fno_fast_math))
3619 CmdArgs.push_back("-ffast-math");
Nico Webere8e53112014-05-11 01:04:02 +00003620 if (Arg *A = Args.getLastArg(options::OPT_ffinite_math_only,
3621 options::OPT_fno_fast_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003622 if (A->getOption().matches(options::OPT_ffinite_math_only))
3623 CmdArgs.push_back("-ffinite-math-only");
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003624
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00003625 // Decide whether to use verbose asm. Verbose assembly is the default on
3626 // toolchains which have the integrated assembler on by default.
Saleem Abdulrasool42e4b592014-02-22 23:37:58 +00003627 bool IsIntegratedAssemblerDefault =
3628 getToolChain().IsIntegratedAssemblerDefault();
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00003629 if (Args.hasFlag(options::OPT_fverbose_asm, options::OPT_fno_verbose_asm,
Saleem Abdulrasool42e4b592014-02-22 23:37:58 +00003630 IsIntegratedAssemblerDefault) ||
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00003631 Args.hasArg(options::OPT_dA))
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003632 CmdArgs.push_back("-masm-verbose");
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00003633
Rafael Espindolab8a12932015-05-22 20:44:03 +00003634 if (!Args.hasFlag(options::OPT_fintegrated_as, options::OPT_fno_integrated_as,
3635 IsIntegratedAssemblerDefault))
Saleem Abdulrasool42e4b592014-02-22 23:37:58 +00003636 CmdArgs.push_back("-no-integrated-as");
3637
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003638 if (Args.hasArg(options::OPT_fdebug_pass_structure)) {
3639 CmdArgs.push_back("-mdebug-pass");
3640 CmdArgs.push_back("Structure");
3641 }
3642 if (Args.hasArg(options::OPT_fdebug_pass_arguments)) {
3643 CmdArgs.push_back("-mdebug-pass");
3644 CmdArgs.push_back("Arguments");
3645 }
3646
John McCall8517abc2010-02-19 02:45:38 +00003647 // Enable -mconstructor-aliases except on darwin, where we have to
3648 // work around a linker bug; see <rdar://problem/7651567>.
Bob Wilson6524dd32011-10-14 05:03:44 +00003649 if (!getToolChain().getTriple().isOSDarwin())
John McCall8517abc2010-02-19 02:45:38 +00003650 CmdArgs.push_back("-mconstructor-aliases");
NAKAMURA Takumi029d74b2011-02-17 08:50:50 +00003651
John McCall7ef5cb32011-03-18 02:56:14 +00003652 // Darwin's kernel doesn't support guard variables; just die if we
3653 // try to use them.
Bob Wilson6524dd32011-10-14 05:03:44 +00003654 if (KernelOrKext && getToolChain().getTriple().isOSDarwin())
John McCall7ef5cb32011-03-18 02:56:14 +00003655 CmdArgs.push_back("-fforbid-guard-variables");
3656
Douglas Gregordbe39272011-02-01 15:15:22 +00003657 if (Args.hasArg(options::OPT_mms_bitfields)) {
3658 CmdArgs.push_back("-mms-bitfields");
3659 }
John McCall8517abc2010-02-19 02:45:38 +00003660
Daniel Dunbar306945d2009-09-16 06:17:29 +00003661 // This is a coarse approximation of what llvm-gcc actually does, both
3662 // -fasynchronous-unwind-tables and -fnon-call-exceptions interact in more
3663 // complicated ways.
3664 bool AsynchronousUnwindTables =
Evgeniy Stepanov7429c592014-02-14 08:56:25 +00003665 Args.hasFlag(options::OPT_fasynchronous_unwind_tables,
3666 options::OPT_fno_asynchronous_unwind_tables,
3667 (getToolChain().IsUnwindTablesDefault() ||
3668 getToolChain().getSanitizerArgs().needsUnwindTables()) &&
3669 !KernelOrKext);
Daniel Dunbar306945d2009-09-16 06:17:29 +00003670 if (Args.hasFlag(options::OPT_funwind_tables, options::OPT_fno_unwind_tables,
3671 AsynchronousUnwindTables))
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003672 CmdArgs.push_back("-munwind-tables");
3673
Chandler Carruth05fb5852012-11-21 23:40:23 +00003674 getToolChain().addClangTargetOptions(Args, CmdArgs);
Rafael Espindola66aa0452012-06-19 01:26:10 +00003675
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003676 if (Arg *A = Args.getLastArg(options::OPT_flimited_precision_EQ)) {
3677 CmdArgs.push_back("-mlimit-float-precision");
Richard Smithbd55daf2012-11-01 04:30:05 +00003678 CmdArgs.push_back(A->getValue());
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003679 }
Daniel Dunbar44e71222009-04-29 18:32:25 +00003680
Daniel Dunbar4dbaaa62009-05-06 03:16:41 +00003681 // FIXME: Handle -mtune=.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003682 (void)Args.hasArg(options::OPT_mtune_EQ);
Daniel Dunbar44e71222009-04-29 18:32:25 +00003683
Benjamin Kramercf4371a2009-08-05 14:30:52 +00003684 if (Arg *A = Args.getLastArg(options::OPT_mcmodel_EQ)) {
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003685 CmdArgs.push_back("-mcode-model");
Richard Smithbd55daf2012-11-01 04:30:05 +00003686 CmdArgs.push_back(A->getValue());
Benjamin Kramercf4371a2009-08-05 14:30:52 +00003687 }
3688
Rafael Espindola22ce34a2013-08-20 22:12:08 +00003689 // Add the target cpu
Renato Golin7c542b42015-07-27 23:44:45 +00003690 std::string CPU = getCPUName(Args, Triple, /*FromAs*/ false);
Rafael Espindola22ce34a2013-08-20 22:12:08 +00003691 if (!CPU.empty()) {
3692 CmdArgs.push_back("-target-cpu");
3693 CmdArgs.push_back(Args.MakeArgString(CPU));
3694 }
3695
Rafael Espindolaeb265472013-08-21 21:59:03 +00003696 if (const Arg *A = Args.getLastArg(options::OPT_mfpmath_EQ)) {
3697 CmdArgs.push_back("-mfpmath");
3698 CmdArgs.push_back(A->getValue());
3699 }
3700
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00003701 // Add the target features
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00003702 getTargetFeatures(getToolChain(), Triple, Args, CmdArgs, false);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00003703
Rafael Espindola22ce34a2013-08-20 22:12:08 +00003704 // Add target specific flags.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003705 switch (getToolChain().getArch()) {
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00003706 default:
3707 break;
Daniel Dunbar4dbaaa62009-05-06 03:16:41 +00003708
Daniel Dunbar0f5c5422009-09-10 04:57:17 +00003709 case llvm::Triple::arm:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00003710 case llvm::Triple::armeb:
Daniel Dunbar0f5c5422009-09-10 04:57:17 +00003711 case llvm::Triple::thumb:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00003712 case llvm::Triple::thumbeb:
Saleem Abdulrasoolce63ce92015-09-19 18:19:44 +00003713 // Use the effective triple, which takes into account the deployment target.
3714 AddARMTargetArgs(Triple, Args, CmdArgs, KernelOrKext);
Daniel Dunbar0f5c5422009-09-10 04:57:17 +00003715 break;
3716
Tim Northover573cbee2014-05-24 12:52:07 +00003717 case llvm::Triple::aarch64:
3718 case llvm::Triple::aarch64_be:
Tim Northover573cbee2014-05-24 12:52:07 +00003719 AddAArch64TargetArgs(Args, CmdArgs);
Tim Northovera2ee4332014-03-29 15:09:45 +00003720 break;
3721
Eric Christopher0b26a612010-03-02 02:41:08 +00003722 case llvm::Triple::mips:
3723 case llvm::Triple::mipsel:
Akira Hatanaka94ab5542011-09-21 02:13:07 +00003724 case llvm::Triple::mips64:
3725 case llvm::Triple::mips64el:
Eric Christopher0b26a612010-03-02 02:41:08 +00003726 AddMIPSTargetArgs(Args, CmdArgs);
3727 break;
3728
Ulrich Weigand8afad612014-07-28 13:17:52 +00003729 case llvm::Triple::ppc:
3730 case llvm::Triple::ppc64:
3731 case llvm::Triple::ppc64le:
3732 AddPPCTargetArgs(Args, CmdArgs);
3733 break;
3734
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00003735 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00003736 case llvm::Triple::sparcel:
Brad Smith10cd0f42014-07-11 20:12:08 +00003737 case llvm::Triple::sparcv9:
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00003738 AddSparcTargetArgs(Args, CmdArgs);
3739 break;
3740
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00003741 case llvm::Triple::x86:
3742 case llvm::Triple::x86_64:
3743 AddX86TargetArgs(Args, CmdArgs);
3744 break;
Tony Linthicum76329bf2011-12-12 21:14:55 +00003745
3746 case llvm::Triple::hexagon:
3747 AddHexagonTargetArgs(Args, CmdArgs);
3748 break;
Daniel Dunbar44e71222009-04-29 18:32:25 +00003749 }
3750
Douglas Katzman3459ce22015-10-08 04:24:12 +00003751 // The 'g' groups options involve a somewhat intricate sequence of decisions
3752 // about what to pass from the driver to the frontend, but by the time they
3753 // reach cc1 they've been factored into two well-defined orthogonal choices:
3754 // * what level of debug info to generate
3755 // * what dwarf version to write
3756 // This avoids having to monkey around further in cc1 other than to disable
3757 // codeview if not running in a Windows environment. Perhaps even that
3758 // decision should be made in the driver as well though.
3759 enum CodeGenOptions::DebugInfoKind DebugInfoKind =
3760 CodeGenOptions::NoDebugInfo;
3761 // These two are potentially updated by AddClangCLArgs.
3762 unsigned DwarfVersion = 0;
3763 bool EmitCodeView = false;
3764
Hans Wennborg75958c42013-08-08 00:17:41 +00003765 // Add clang-cl arguments.
3766 if (getToolChain().getDriver().IsCLMode())
Douglas Katzman3459ce22015-10-08 04:24:12 +00003767 AddClangCLArgs(Args, CmdArgs, &DebugInfoKind, &EmitCodeView);
Hans Wennborg75958c42013-08-08 00:17:41 +00003768
Daniel Dunbar976a2f52010-08-11 23:07:47 +00003769 // Pass the linker version in use.
3770 if (Arg *A = Args.getLastArg(options::OPT_mlinker_version_EQ)) {
3771 CmdArgs.push_back("-target-linker-version");
Richard Smithbd55daf2012-11-01 04:30:05 +00003772 CmdArgs.push_back(A->getValue());
Daniel Dunbar976a2f52010-08-11 23:07:47 +00003773 }
3774
Eric Christopherb7d97e92013-04-03 01:58:53 +00003775 if (!shouldUseLeafFramePointer(Args, getToolChain().getTriple()))
Daniel Dunbarbb7ac522010-07-01 01:31:45 +00003776 CmdArgs.push_back("-momit-leaf-frame-pointer");
3777
Daniel Dunbarfcc49a82010-05-12 18:19:58 +00003778 // Explicitly error on some things we know we don't support and can't just
3779 // ignore.
Artem Belevichba558952015-05-06 18:20:23 +00003780 types::ID InputType = Input.getType();
Daniel Dunbar4ed214a2010-09-24 19:39:37 +00003781 if (!Args.hasArg(options::OPT_fallow_unsupported)) {
3782 Arg *Unsupported;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003783 if (types::isCXX(InputType) && getToolChain().getTriple().isOSDarwin() &&
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00003784 getToolChain().getArch() == llvm::Triple::x86) {
Bob Wilson0d45f582011-08-13 23:48:55 +00003785 if ((Unsupported = Args.getLastArg(options::OPT_fapple_kext)) ||
3786 (Unsupported = Args.getLastArg(options::OPT_mkernel)))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00003787 D.Diag(diag::err_drv_clang_unsupported_opt_cxx_darwin_i386)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003788 << Unsupported->getOption().getName();
Daniel Dunbar4ed214a2010-09-24 19:39:37 +00003789 }
Daniel Dunbarfcc49a82010-05-12 18:19:58 +00003790 }
3791
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003792 Args.AddAllArgs(CmdArgs, options::OPT_v);
Daniel Dunbard4352752010-08-24 22:44:13 +00003793 Args.AddLastArg(CmdArgs, options::OPT_H);
Chad Rosierbe10f982011-08-02 17:58:04 +00003794 if (D.CCPrintHeaders && !D.CCGenDiagnostics) {
Daniel Dunbarac540b32011-02-02 21:11:35 +00003795 CmdArgs.push_back("-header-include-file");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003796 CmdArgs.push_back(D.CCPrintHeadersFilename ? D.CCPrintHeadersFilename
3797 : "-");
Daniel Dunbarac540b32011-02-02 21:11:35 +00003798 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003799 Args.AddLastArg(CmdArgs, options::OPT_P);
Mike Stump11289f42009-09-09 15:08:12 +00003800 Args.AddLastArg(CmdArgs, options::OPT_print_ivar_layout);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003801
Chad Rosierbe10f982011-08-02 17:58:04 +00003802 if (D.CCLogDiagnostics && !D.CCGenDiagnostics) {
Daniel Dunbar529c03b2011-04-07 18:01:20 +00003803 CmdArgs.push_back("-diagnostic-log-file");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003804 CmdArgs.push_back(D.CCLogDiagnosticsFilename ? D.CCLogDiagnosticsFilename
3805 : "-");
Daniel Dunbar529c03b2011-04-07 18:01:20 +00003806 }
3807
Rafael Espindola08a692a2010-03-07 04:46:18 +00003808 Args.ClaimAllArgs(options::OPT_g_Group);
David Blaikiece3e7a62015-07-30 21:42:22 +00003809 Arg *SplitDwarfArg = Args.getLastArg(options::OPT_gsplit_dwarf);
Alexey Samsonovdda3a7f2012-05-29 08:10:34 +00003810 if (Arg *A = Args.getLastArg(options::OPT_g_Group)) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00003811 // If you say "-gline-tables-only -gsplit-dwarf", split-dwarf wins,
3812 // which mandates turning on "-g". But -split-dwarf is not a g_group option,
3813 // hence it takes a nontrivial test to decide about line-tables-only.
Douglas Katzman9a2ef282015-09-30 15:55:59 +00003814 if (A->getOption().matches(options::OPT_gline_tables_only) &&
David Blaikiece3e7a62015-07-30 21:42:22 +00003815 (!SplitDwarfArg || A->getIndex() > SplitDwarfArg->getIndex())) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00003816 DebugInfoKind = CodeGenOptions::DebugLineTablesOnly;
David Blaikiece3e7a62015-07-30 21:42:22 +00003817 SplitDwarfArg = nullptr;
Douglas Katzman9a2ef282015-09-30 15:55:59 +00003818 } else if (!A->getOption().matches(options::OPT_g0)) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00003819 // Some 'g' group option other than one expressly disabling debug info
3820 // must have been the final (winning) one. They're all equivalent.
3821 DebugInfoKind = CodeGenOptions::LimitedDebugInfo;
Adrian Prantl549c5142014-02-17 17:40:52 +00003822 }
Alexey Samsonovdda3a7f2012-05-29 08:10:34 +00003823 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003824
Douglas Katzman3459ce22015-10-08 04:24:12 +00003825 // If a -gdwarf argument appeared, use it, unless DebugInfoKind is None
3826 // (because that would mean that "-g0" was the rightmost 'g' group option).
3827 // FIXME: specifying "-gdwarf-<N>" "-g1" in that order works,
3828 // but "-g1" "-gdwarf-<N>" does not. A deceptively simple (but wrong) "fix"
3829 // exists of removing the gdwarf options from the g_group.
3830 if (Arg *A = Args.getLastArg(options::OPT_gdwarf_2, options::OPT_gdwarf_3,
3831 options::OPT_gdwarf_4))
3832 DwarfVersion = DwarfVersionNum(A->getSpelling());
3833
Reid Kleckner124955a2015-08-05 18:51:13 +00003834 // Forward -gcodeview.
Douglas Katzman3459ce22015-10-08 04:24:12 +00003835 // 'EmitCodeView might have been set by CL-compatibility argument parsing.
3836 if (Args.hasArg(options::OPT_gcodeview) || EmitCodeView) {
3837 // DwarfVersion remains at 0 if no explicit choice was made.
3838 CmdArgs.push_back("-gcodeview");
3839 } else if (DwarfVersion == 0 &&
3840 DebugInfoKind != CodeGenOptions::NoDebugInfo) {
3841 DwarfVersion = getToolChain().GetDefaultDwarfVersion();
3842 }
Reid Kleckner124955a2015-08-05 18:51:13 +00003843
Alexey Samsonovf50a9ff2012-06-21 08:22:39 +00003844 // We ignore flags -gstrict-dwarf and -grecord-gcc-switches for now.
3845 Args.ClaimAllArgs(options::OPT_g_flags_Group);
Diego Novillo94b276d2014-07-10 23:29:28 +00003846 if (Args.hasFlag(options::OPT_gcolumn_info, options::OPT_gno_column_info,
Greg Bedwell80b325c2015-09-25 16:11:00 +00003847 /*Default*/ true))
Eric Christophera2f7eb72012-10-18 21:52:18 +00003848 CmdArgs.push_back("-dwarf-column-info");
Alexey Samsonovf50a9ff2012-06-21 08:22:39 +00003849
Eric Christopher138c32b2013-09-13 22:37:55 +00003850 // FIXME: Move backend command line options to the module.
Adrian Prantl6b21ab22015-08-27 19:46:20 +00003851 if (Args.hasArg(options::OPT_gmodules)) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00003852 DebugInfoKind = CodeGenOptions::LimitedDebugInfo;
Adrian Prantl6b21ab22015-08-27 19:46:20 +00003853 CmdArgs.push_back("-dwarf-ext-refs");
3854 CmdArgs.push_back("-fmodule-format=obj");
3855 }
3856
Eric Christopher2ba5fcb2013-02-05 07:29:57 +00003857 // -gsplit-dwarf should turn on -g and enable the backend dwarf
3858 // splitting and extraction.
Eric Christopherd42fb732013-02-21 22:35:05 +00003859 // FIXME: Currently only works on Linux.
David Blaikiece3e7a62015-07-30 21:42:22 +00003860 if (getToolChain().getTriple().isOSLinux() && SplitDwarfArg) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00003861 DebugInfoKind = CodeGenOptions::LimitedDebugInfo;
Eric Christopher2ba5fcb2013-02-05 07:29:57 +00003862 CmdArgs.push_back("-backend-option");
3863 CmdArgs.push_back("-split-dwarf=Enable");
3864 }
3865
Douglas Katzman3459ce22015-10-08 04:24:12 +00003866 // After we've dealt with all combinations of things that could
3867 // make DebugInfoKind be other than None or DebugLineTablesOnly,
3868 // figure out if we need to "upgrade" it to standalone debug info.
3869 // We parse these two '-f' options whether or not they will be used,
3870 // to claim them even if you wrote "-fstandalone-debug -gline-tables-only"
3871 bool NeedFullDebug = Args.hasFlag(options::OPT_fstandalone_debug,
3872 options::OPT_fno_standalone_debug,
3873 getToolChain().GetDefaultStandaloneDebug());
3874 if (DebugInfoKind == CodeGenOptions::LimitedDebugInfo && NeedFullDebug)
3875 DebugInfoKind = CodeGenOptions::FullDebugInfo;
3876 RenderDebugEnablingArgs(Args, CmdArgs, DebugInfoKind, DwarfVersion);
3877
Eric Christopher138c32b2013-09-13 22:37:55 +00003878 // -ggnu-pubnames turns on gnu style pubnames in the backend.
3879 if (Args.hasArg(options::OPT_ggnu_pubnames)) {
3880 CmdArgs.push_back("-backend-option");
3881 CmdArgs.push_back("-generate-gnu-dwarf-pub-sections");
3882 }
Eric Christophereec89c22013-06-18 00:03:50 +00003883
Eric Christopher0d403d22014-02-14 01:27:03 +00003884 // -gdwarf-aranges turns on the emission of the aranges section in the
3885 // backend.
Greg Bedwell80b325c2015-09-25 16:11:00 +00003886 if (Args.hasArg(options::OPT_gdwarf_aranges)) {
Eric Christopher0d403d22014-02-14 01:27:03 +00003887 CmdArgs.push_back("-backend-option");
3888 CmdArgs.push_back("-generate-arange-section");
3889 }
3890
David Blaikief36d9ba2014-01-27 18:52:43 +00003891 if (Args.hasFlag(options::OPT_fdebug_types_section,
3892 options::OPT_fno_debug_types_section, false)) {
David Blaikied74be702014-01-18 02:02:06 +00003893 CmdArgs.push_back("-backend-option");
3894 CmdArgs.push_back("-generate-type-units");
3895 }
Eric Christophereec89c22013-06-18 00:03:50 +00003896
Ed Schouten6e576152015-03-26 17:50:28 +00003897 // CloudABI uses -ffunction-sections and -fdata-sections by default.
3898 bool UseSeparateSections = Triple.getOS() == llvm::Triple::CloudABI;
3899
Evgeniy Stepanov9e7cb332014-02-03 11:11:37 +00003900 if (Args.hasFlag(options::OPT_ffunction_sections,
Ed Schouten6e576152015-03-26 17:50:28 +00003901 options::OPT_fno_function_sections, UseSeparateSections)) {
Evgeniy Stepanov9e7cb332014-02-03 11:11:37 +00003902 CmdArgs.push_back("-ffunction-sections");
3903 }
3904
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003905 if (Args.hasFlag(options::OPT_fdata_sections, options::OPT_fno_data_sections,
3906 UseSeparateSections)) {
Evgeniy Stepanov9e7cb332014-02-03 11:11:37 +00003907 CmdArgs.push_back("-fdata-sections");
3908 }
Rafael Espindola66bfb2752010-05-06 21:06:04 +00003909
Rafael Espindola6b07a1c2015-02-20 18:08:57 +00003910 if (!Args.hasFlag(options::OPT_funique_section_names,
Rafael Espindolab8a12932015-05-22 20:44:03 +00003911 options::OPT_fno_unique_section_names, true))
Rafael Espindola6b07a1c2015-02-20 18:08:57 +00003912 CmdArgs.push_back("-fno-unique-section-names");
3913
Chris Lattner3c77a352010-06-22 00:03:40 +00003914 Args.AddAllArgs(CmdArgs, options::OPT_finstrument_functions);
3915
Diego Novilloa0545962015-07-10 18:00:07 +00003916 addPGOAndCoverageFlags(C, D, Output, Args, CmdArgs);
Nick Lewycky480cb992011-05-04 20:46:58 +00003917
Daniel Dunbarb25bfde2011-10-11 18:20:10 +00003918 // Pass options for controlling the default header search paths.
3919 if (Args.hasArg(options::OPT_nostdinc)) {
3920 CmdArgs.push_back("-nostdsysteminc");
3921 CmdArgs.push_back("-nobuiltininc");
3922 } else {
Daniel Dunbar0f41eee2011-10-11 18:20:16 +00003923 if (Args.hasArg(options::OPT_nostdlibinc))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003924 CmdArgs.push_back("-nostdsysteminc");
Daniel Dunbarb25bfde2011-10-11 18:20:10 +00003925 Args.AddLastArg(CmdArgs, options::OPT_nostdincxx);
3926 Args.AddLastArg(CmdArgs, options::OPT_nobuiltininc);
3927 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003928
Daniel Dunbar34e0b8c2009-12-15 01:02:52 +00003929 // Pass the path to compiler resource files.
Daniel Dunbar34e0b8c2009-12-15 01:02:52 +00003930 CmdArgs.push_back("-resource-dir");
Daniel Dunbar3f3e2cd2010-01-20 02:35:16 +00003931 CmdArgs.push_back(D.ResourceDir.c_str());
Daniel Dunbar9dc82a22009-04-07 21:42:00 +00003932
Argyrios Kyrtzidis71731d62010-11-03 22:45:23 +00003933 Args.AddLastArg(CmdArgs, options::OPT_working_directory);
3934
Ted Kremenekf7639e12012-03-06 20:06:33 +00003935 bool ARCMTEnabled = false;
Argyrios Kyrtzidis85230d52013-09-17 19:14:29 +00003936 if (!Args.hasArg(options::OPT_fno_objc_arc, options::OPT_fobjc_arc)) {
Argyrios Kyrtzidisc44b93d2011-07-07 04:00:39 +00003937 if (const Arg *A = Args.getLastArg(options::OPT_ccc_arcmt_check,
Argyrios Kyrtzidis7fbd97f2011-07-09 20:00:58 +00003938 options::OPT_ccc_arcmt_modify,
3939 options::OPT_ccc_arcmt_migrate)) {
Ted Kremenekf7639e12012-03-06 20:06:33 +00003940 ARCMTEnabled = true;
John McCalld70fb982011-06-15 23:25:17 +00003941 switch (A->getOption().getID()) {
3942 default:
3943 llvm_unreachable("missed a case");
Argyrios Kyrtzidisc44b93d2011-07-07 04:00:39 +00003944 case options::OPT_ccc_arcmt_check:
John McCalld70fb982011-06-15 23:25:17 +00003945 CmdArgs.push_back("-arcmt-check");
3946 break;
Argyrios Kyrtzidisc44b93d2011-07-07 04:00:39 +00003947 case options::OPT_ccc_arcmt_modify:
John McCalld70fb982011-06-15 23:25:17 +00003948 CmdArgs.push_back("-arcmt-modify");
3949 break;
Argyrios Kyrtzidis7fbd97f2011-07-09 20:00:58 +00003950 case options::OPT_ccc_arcmt_migrate:
3951 CmdArgs.push_back("-arcmt-migrate");
Ted Kremenekf7639e12012-03-06 20:06:33 +00003952 CmdArgs.push_back("-mt-migrate-directory");
Richard Smithbd55daf2012-11-01 04:30:05 +00003953 CmdArgs.push_back(A->getValue());
Argyrios Kyrtzidisd5713632011-07-19 17:20:03 +00003954
3955 Args.AddLastArg(CmdArgs, options::OPT_arcmt_migrate_report_output);
3956 Args.AddLastArg(CmdArgs, options::OPT_arcmt_migrate_emit_arc_errors);
Argyrios Kyrtzidis7fbd97f2011-07-09 20:00:58 +00003957 break;
John McCalld70fb982011-06-15 23:25:17 +00003958 }
3959 }
Argyrios Kyrtzidisb11a1922013-06-24 19:01:18 +00003960 } else {
3961 Args.ClaimAllArgs(options::OPT_ccc_arcmt_check);
3962 Args.ClaimAllArgs(options::OPT_ccc_arcmt_modify);
3963 Args.ClaimAllArgs(options::OPT_ccc_arcmt_migrate);
John McCalld70fb982011-06-15 23:25:17 +00003964 }
Eric Christopher84fbdb42011-08-19 00:30:14 +00003965
Ted Kremenekf7639e12012-03-06 20:06:33 +00003966 if (const Arg *A = Args.getLastArg(options::OPT_ccc_objcmt_migrate)) {
3967 if (ARCMTEnabled) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003968 D.Diag(diag::err_drv_argument_not_allowed_with) << A->getAsString(Args)
3969 << "-ccc-arcmt-migrate";
Ted Kremenekf7639e12012-03-06 20:06:33 +00003970 }
3971 CmdArgs.push_back("-mt-migrate-directory");
Richard Smithbd55daf2012-11-01 04:30:05 +00003972 CmdArgs.push_back(A->getValue());
Ted Kremenekf7639e12012-03-06 20:06:33 +00003973
3974 if (!Args.hasArg(options::OPT_objcmt_migrate_literals,
Fariborz Jahaniand83ef842013-07-09 16:59:14 +00003975 options::OPT_objcmt_migrate_subscripting,
3976 options::OPT_objcmt_migrate_property)) {
Ted Kremenekf7639e12012-03-06 20:06:33 +00003977 // None specified, means enable them all.
3978 CmdArgs.push_back("-objcmt-migrate-literals");
3979 CmdArgs.push_back("-objcmt-migrate-subscripting");
Fariborz Jahaniand83ef842013-07-09 16:59:14 +00003980 CmdArgs.push_back("-objcmt-migrate-property");
Ted Kremenekf7639e12012-03-06 20:06:33 +00003981 } else {
3982 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_literals);
3983 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_subscripting);
Fariborz Jahaniand83ef842013-07-09 16:59:14 +00003984 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_property);
Ted Kremenekf7639e12012-03-06 20:06:33 +00003985 }
Argyrios Kyrtzidis55ecf992013-11-13 23:38:20 +00003986 } else {
3987 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_literals);
3988 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_subscripting);
3989 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_property);
3990 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_all);
3991 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_readonly_property);
3992 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_readwrite_property);
Fariborz Jahanian773fa2c2015-03-03 17:15:38 +00003993 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_property_dot_syntax);
Argyrios Kyrtzidis55ecf992013-11-13 23:38:20 +00003994 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_annotation);
3995 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_instancetype);
3996 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_nsmacros);
3997 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_protocol_conformance);
3998 Args.AddLastArg(CmdArgs, options::OPT_objcmt_atomic_property);
3999 Args.AddLastArg(CmdArgs, options::OPT_objcmt_returns_innerpointer_property);
4000 Args.AddLastArg(CmdArgs, options::OPT_objcmt_ns_nonatomic_iosonly);
Argyrios Kyrtzidis74aa02562013-12-11 01:29:48 +00004001 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_designated_init);
Argyrios Kyrtzidisd5ba86b2013-12-10 18:36:53 +00004002 Args.AddLastArg(CmdArgs, options::OPT_objcmt_whitelist_dir_path);
Ted Kremenekf7639e12012-03-06 20:06:33 +00004003 }
4004
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004005 // Add preprocessing options like -I, -D, etc. if we are using the
4006 // preprocessor.
4007 //
4008 // FIXME: Support -fpreprocessed
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004009 if (types::getPreprocessedType(InputType) != types::TY_INVALID)
Chad Rosier633dcdc2013-01-24 19:14:47 +00004010 AddPreprocessingOptions(C, JA, D, Args, CmdArgs, Output, Inputs);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004011
Rafael Espindolaa7431922011-07-21 23:40:37 +00004012 // Don't warn about "clang -c -DPIC -fPIC test.i" because libtool.m4 assumes
4013 // that "The compiler can only warn and ignore the option if not recognized".
4014 // When building with ccache, it will pass -D options to clang even on
4015 // preprocessed inputs and configure concludes that -fPIC is not supported.
4016 Args.ClaimAllArgs(options::OPT_D);
4017
Alp Toker7874bdc2013-11-15 20:40:58 +00004018 // Manually translate -O4 to -O3; let clang reject others.
Rafael Espindolaad70d962013-08-27 16:58:15 +00004019 if (Arg *A = Args.getLastArg(options::OPT_O_Group)) {
4020 if (A->getOption().matches(options::OPT_O4)) {
4021 CmdArgs.push_back("-O3");
4022 D.Diag(diag::warn_O4_is_O3);
4023 } else {
4024 A->render(Args, CmdArgs);
4025 }
4026 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004027
Sylvestre Ledru2fe501e2014-07-11 11:43:57 +00004028 // Warn about ignored options to clang.
Sean Silva14facf32015-06-09 01:57:17 +00004029 for (const Arg *A :
4030 Args.filtered(options::OPT_clang_ignored_gcc_optimization_f_Group)) {
4031 D.Diag(diag::warn_ignored_gcc_optimization) << A->getAsString(Args);
Douglas Katzman8b50e012015-08-05 18:03:47 +00004032 A->claim();
Sylvestre Ledru2fe501e2014-07-11 11:43:57 +00004033 }
4034
Rafael Espindola577637a2015-01-03 00:06:04 +00004035 claimNoWarnArgs(Args);
Chad Rosier86b82082012-12-12 20:06:31 +00004036
Richard Smith3be1cb22014-08-07 00:24:21 +00004037 Args.AddAllArgs(CmdArgs, options::OPT_R_Group);
Daniel Dunbar945577c2009-10-29 02:24:45 +00004038 Args.AddAllArgs(CmdArgs, options::OPT_W_Group);
Ted Kremenekb22ea2a2012-07-07 05:53:30 +00004039 if (Args.hasFlag(options::OPT_pedantic, options::OPT_no_pedantic, false))
4040 CmdArgs.push_back("-pedantic");
Daniel Dunbar945577c2009-10-29 02:24:45 +00004041 Args.AddLastArg(CmdArgs, options::OPT_pedantic_errors);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004042 Args.AddLastArg(CmdArgs, options::OPT_w);
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004043
4044 // Handle -{std, ansi, trigraphs} -- take the last of -{std, ansi}
Hans Wennborgec993822013-07-31 16:57:56 +00004045 // (-ansi is equivalent to -std=c89 or -std=c++98).
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004046 //
4047 // If a std is supplied, only add -trigraphs if it follows the
4048 // option.
David Majnemer8db91762015-05-18 04:49:30 +00004049 bool ImplyVCPPCXXVer = false;
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004050 if (Arg *Std = Args.getLastArg(options::OPT_std_EQ, options::OPT_ansi)) {
4051 if (Std->getOption().matches(options::OPT_ansi))
Nuno Lopes275225d2009-10-16 14:28:06 +00004052 if (types::isCXX(InputType))
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004053 CmdArgs.push_back("-std=c++98");
Nuno Lopes275225d2009-10-16 14:28:06 +00004054 else
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004055 CmdArgs.push_back("-std=c89");
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004056 else
4057 Std->render(Args, CmdArgs);
4058
Nico Weber00721502014-12-23 22:32:37 +00004059 // If -f(no-)trigraphs appears after the language standard flag, honor it.
Daniel Dunbar3f1a1ff2010-06-14 21:23:08 +00004060 if (Arg *A = Args.getLastArg(options::OPT_std_EQ, options::OPT_ansi,
Nico Weber00721502014-12-23 22:32:37 +00004061 options::OPT_ftrigraphs,
4062 options::OPT_fno_trigraphs))
Daniel Dunbar3f1a1ff2010-06-14 21:23:08 +00004063 if (A != Std)
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004064 A->render(Args, CmdArgs);
Daniel Dunbar72a60902009-04-26 01:10:38 +00004065 } else {
4066 // Honor -std-default.
Daniel Dunbar12998192010-01-29 21:03:02 +00004067 //
4068 // FIXME: Clang doesn't correctly handle -std= when the input language
4069 // doesn't match. For the time being just ignore this for C++ inputs;
4070 // eventually we want to do all the standard defaulting here instead of
4071 // splitting it between the driver and clang -cc1.
4072 if (!types::isCXX(InputType))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004073 Args.AddAllArgsTranslated(CmdArgs, options::OPT_std_default_EQ, "-std=",
4074 /*Joined=*/true);
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00004075 else if (IsWindowsMSVC)
David Majnemer8db91762015-05-18 04:49:30 +00004076 ImplyVCPPCXXVer = true;
Nico Weber723b4f02012-08-30 02:08:31 +00004077
Nico Weber00721502014-12-23 22:32:37 +00004078 Args.AddLastArg(CmdArgs, options::OPT_ftrigraphs,
4079 options::OPT_fno_trigraphs);
Daniel Dunbar72a60902009-04-26 01:10:38 +00004080 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004081
Richard Smith282b4492013-09-04 22:50:31 +00004082 // GCC's behavior for -Wwrite-strings is a bit strange:
4083 // * In C, this "warning flag" changes the types of string literals from
4084 // 'char[N]' to 'const char[N]', and thus triggers an unrelated warning
4085 // for the discarded qualifier.
4086 // * In C++, this is just a normal warning flag.
4087 //
4088 // Implementing this warning correctly in C is hard, so we follow GCC's
4089 // behavior for now. FIXME: Directly diagnose uses of a string literal as
4090 // a non-const char* in C, rather than using this crude hack.
4091 if (!types::isCXX(InputType)) {
Argyrios Kyrtzidis25f2afde2014-02-07 08:33:28 +00004092 // FIXME: This should behave just like a warning flag, and thus should also
4093 // respect -Weverything, -Wno-everything, -Werror=write-strings, and so on.
4094 Arg *WriteStrings =
4095 Args.getLastArg(options::OPT_Wwrite_strings,
4096 options::OPT_Wno_write_strings, options::OPT_w);
4097 if (WriteStrings &&
4098 WriteStrings->getOption().matches(options::OPT_Wwrite_strings))
Richard Smith282b4492013-09-04 22:50:31 +00004099 CmdArgs.push_back("-fconst-strings");
Chandler Carruthb009b142011-04-23 06:30:43 +00004100 }
4101
Chandler Carruth61fbf622011-04-23 09:27:53 +00004102 // GCC provides a macro definition '__DEPRECATED' when -Wdeprecated is active
Chandler Carruth30483fb2011-04-23 19:48:40 +00004103 // during C++ compilation, which it is by default. GCC keeps this define even
4104 // in the presence of '-w', match this behavior bug-for-bug.
4105 if (types::isCXX(InputType) &&
4106 Args.hasFlag(options::OPT_Wdeprecated, options::OPT_Wno_deprecated,
4107 true)) {
4108 CmdArgs.push_back("-fdeprecated-macro");
Chandler Carruth61fbf622011-04-23 09:27:53 +00004109 }
4110
Chandler Carruthe0391482010-05-22 02:21:53 +00004111 // Translate GCC's misnamer '-fasm' arguments to '-fgnu-keywords'.
4112 if (Arg *Asm = Args.getLastArg(options::OPT_fasm, options::OPT_fno_asm)) {
4113 if (Asm->getOption().matches(options::OPT_fasm))
4114 CmdArgs.push_back("-fgnu-keywords");
4115 else
4116 CmdArgs.push_back("-fno-gnu-keywords");
4117 }
4118
Nick Lewycky1d617ac2011-10-17 23:05:52 +00004119 if (ShouldDisableDwarfDirectory(Args, getToolChain()))
4120 CmdArgs.push_back("-fno-dwarf-directory-asm");
4121
Daniel Dunbare246fbe2013-04-16 18:21:19 +00004122 if (ShouldDisableAutolink(Args, getToolChain()))
4123 CmdArgs.push_back("-fno-autolink");
4124
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00004125 // Add in -fdebug-compilation-dir if necessary.
4126 addDebugCompDirArg(Args, CmdArgs);
Nick Lewyckyba743b72011-10-21 02:32:14 +00004127
Richard Smith9a568822011-11-21 19:36:32 +00004128 if (Arg *A = Args.getLastArg(options::OPT_ftemplate_depth_,
4129 options::OPT_ftemplate_depth_EQ)) {
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004130 CmdArgs.push_back("-ftemplate-depth");
Richard Smithbd55daf2012-11-01 04:30:05 +00004131 CmdArgs.push_back(A->getValue());
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004132 }
4133
Richard Smith79c927b2013-11-06 19:31:51 +00004134 if (Arg *A = Args.getLastArg(options::OPT_foperator_arrow_depth_EQ)) {
4135 CmdArgs.push_back("-foperator-arrow-depth");
4136 CmdArgs.push_back(A->getValue());
4137 }
4138
Richard Smith9a568822011-11-21 19:36:32 +00004139 if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_depth_EQ)) {
4140 CmdArgs.push_back("-fconstexpr-depth");
Richard Smithbd55daf2012-11-01 04:30:05 +00004141 CmdArgs.push_back(A->getValue());
Richard Smith9a568822011-11-21 19:36:32 +00004142 }
4143
Richard Smitha3d3bd22013-05-08 02:12:03 +00004144 if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_steps_EQ)) {
4145 CmdArgs.push_back("-fconstexpr-steps");
4146 CmdArgs.push_back(A->getValue());
4147 }
4148
Richard Smithb3a14522013-02-22 01:59:51 +00004149 if (Arg *A = Args.getLastArg(options::OPT_fbracket_depth_EQ)) {
4150 CmdArgs.push_back("-fbracket-depth");
4151 CmdArgs.push_back(A->getValue());
4152 }
4153
Argyrios Kyrtzidisef6c8da2010-11-18 00:20:36 +00004154 if (Arg *A = Args.getLastArg(options::OPT_Wlarge_by_value_copy_EQ,
4155 options::OPT_Wlarge_by_value_copy_def)) {
Jean-Daniel Dupas73d801c2012-05-04 08:08:37 +00004156 if (A->getNumValues()) {
Richard Smithbd55daf2012-11-01 04:30:05 +00004157 StringRef bytes = A->getValue();
Jean-Daniel Dupas73d801c2012-05-04 08:08:37 +00004158 CmdArgs.push_back(Args.MakeArgString("-Wlarge-by-value-copy=" + bytes));
4159 } else
4160 CmdArgs.push_back("-Wlarge-by-value-copy=64"); // default value
Argyrios Kyrtzidisaf84ec02010-11-17 23:11:54 +00004161 }
4162
Michael J. Spencer929fccd2012-10-22 22:13:48 +00004163 if (Args.hasArg(options::OPT_relocatable_pch))
Daniel Dunbar8bed86c2009-11-20 22:21:36 +00004164 CmdArgs.push_back("-relocatable-pch");
Mike Stump11289f42009-09-09 15:08:12 +00004165
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004166 if (Arg *A = Args.getLastArg(options::OPT_fconstant_string_class_EQ)) {
4167 CmdArgs.push_back("-fconstant-string-class");
Richard Smithbd55daf2012-11-01 04:30:05 +00004168 CmdArgs.push_back(A->getValue());
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004169 }
David Chisnall5778fce2009-08-31 16:41:57 +00004170
Chris Lattnere23003d2010-01-09 21:54:33 +00004171 if (Arg *A = Args.getLastArg(options::OPT_ftabstop_EQ)) {
4172 CmdArgs.push_back("-ftabstop");
Richard Smithbd55daf2012-11-01 04:30:05 +00004173 CmdArgs.push_back(A->getValue());
Chris Lattnere23003d2010-01-09 21:54:33 +00004174 }
4175
Chris Lattnerb35583d2010-04-07 20:49:23 +00004176 CmdArgs.push_back("-ferror-limit");
4177 if (Arg *A = Args.getLastArg(options::OPT_ferror_limit_EQ))
Richard Smithbd55daf2012-11-01 04:30:05 +00004178 CmdArgs.push_back(A->getValue());
Chris Lattnerb35583d2010-04-07 20:49:23 +00004179 else
4180 CmdArgs.push_back("19");
Douglas Gregorffed1cb2010-04-20 07:18:24 +00004181
Chandler Carrutha77a7272010-05-06 04:55:18 +00004182 if (Arg *A = Args.getLastArg(options::OPT_fmacro_backtrace_limit_EQ)) {
4183 CmdArgs.push_back("-fmacro-backtrace-limit");
Richard Smithbd55daf2012-11-01 04:30:05 +00004184 CmdArgs.push_back(A->getValue());
Chandler Carrutha77a7272010-05-06 04:55:18 +00004185 }
4186
4187 if (Arg *A = Args.getLastArg(options::OPT_ftemplate_backtrace_limit_EQ)) {
4188 CmdArgs.push_back("-ftemplate-backtrace-limit");
Richard Smithbd55daf2012-11-01 04:30:05 +00004189 CmdArgs.push_back(A->getValue());
Chandler Carrutha77a7272010-05-06 04:55:18 +00004190 }
4191
Richard Smithf6f003a2011-12-16 19:06:07 +00004192 if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_backtrace_limit_EQ)) {
4193 CmdArgs.push_back("-fconstexpr-backtrace-limit");
Richard Smithbd55daf2012-11-01 04:30:05 +00004194 CmdArgs.push_back(A->getValue());
Richard Smithf6f003a2011-12-16 19:06:07 +00004195 }
4196
Nick Lewycky24653262014-12-16 21:39:02 +00004197 if (Arg *A = Args.getLastArg(options::OPT_fspell_checking_limit_EQ)) {
4198 CmdArgs.push_back("-fspell-checking-limit");
4199 CmdArgs.push_back(A->getValue());
4200 }
4201
Daniel Dunbar2c978472009-11-04 06:24:47 +00004202 // Pass -fmessage-length=.
Daniel Dunbar84bb7932009-11-30 08:40:54 +00004203 CmdArgs.push_back("-fmessage-length");
Daniel Dunbar2c978472009-11-04 06:24:47 +00004204 if (Arg *A = Args.getLastArg(options::OPT_fmessage_length_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00004205 CmdArgs.push_back(A->getValue());
Daniel Dunbar2c978472009-11-04 06:24:47 +00004206 } else {
4207 // If -fmessage-length=N was not specified, determine whether this is a
4208 // terminal and, if so, implicitly define -fmessage-length appropriately.
4209 unsigned N = llvm::sys::Process::StandardErrColumns();
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004210 CmdArgs.push_back(Args.MakeArgString(Twine(N)));
Daniel Dunbar2c978472009-11-04 06:24:47 +00004211 }
4212
John McCallb4a99d32013-02-19 01:57:35 +00004213 // -fvisibility= and -fvisibility-ms-compat are of a piece.
4214 if (const Arg *A = Args.getLastArg(options::OPT_fvisibility_EQ,
4215 options::OPT_fvisibility_ms_compat)) {
4216 if (A->getOption().matches(options::OPT_fvisibility_EQ)) {
4217 CmdArgs.push_back("-fvisibility");
4218 CmdArgs.push_back(A->getValue());
4219 } else {
4220 assert(A->getOption().matches(options::OPT_fvisibility_ms_compat));
4221 CmdArgs.push_back("-fvisibility");
4222 CmdArgs.push_back("hidden");
4223 CmdArgs.push_back("-ftype-visibility");
4224 CmdArgs.push_back("default");
4225 }
Daniel Dunbare357d562009-12-03 18:42:11 +00004226 }
4227
Douglas Gregor08329632010-06-15 17:05:35 +00004228 Args.AddLastArg(CmdArgs, options::OPT_fvisibility_inlines_hidden);
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00004229
Hans Wennborgf60f6af2012-06-28 08:01:44 +00004230 Args.AddLastArg(CmdArgs, options::OPT_ftlsmodel_EQ);
4231
Daniel Dunbare46b52a2010-03-20 04:52:14 +00004232 // -fhosted is default.
Chad Rosier4fab82c2012-03-26 22:04:46 +00004233 if (Args.hasFlag(options::OPT_ffreestanding, options::OPT_fhosted, false) ||
4234 KernelOrKext)
Daniel Dunbare46b52a2010-03-20 04:52:14 +00004235 CmdArgs.push_back("-ffreestanding");
4236
Daniel Dunbare357d562009-12-03 18:42:11 +00004237 // Forward -f (flag) options which we can pass directly.
Daniel Dunbar3a148f22009-04-07 21:51:40 +00004238 Args.AddLastArg(CmdArgs, options::OPT_femit_all_decls);
Daniel Dunbar3a148f22009-04-07 21:51:40 +00004239 Args.AddLastArg(CmdArgs, options::OPT_fheinous_gnu_extensions);
Eric Christopher86050822011-10-25 07:13:06 +00004240 Args.AddLastArg(CmdArgs, options::OPT_fno_operator_names);
Chih-Hung Hsieh2c656c92015-07-28 16:27:56 +00004241 // Emulated TLS is enabled by default on Android, and can be enabled manually
4242 // with -femulated-tls.
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00004243 bool EmulatedTLSDefault = Triple.isAndroid();
Chih-Hung Hsieh2c656c92015-07-28 16:27:56 +00004244 if (Args.hasFlag(options::OPT_femulated_tls, options::OPT_fno_emulated_tls,
4245 EmulatedTLSDefault))
4246 CmdArgs.push_back("-femulated-tls");
Ulrich Weigand3c5038a2015-07-30 14:08:36 +00004247 // AltiVec-like language extensions aren't relevant for assembling.
4248 if (!isa<PreprocessJobAction>(JA) || Output.getType() != types::TY_PP_Asm) {
Bill Schmidtb3b804e2013-07-03 15:36:02 +00004249 Args.AddLastArg(CmdArgs, options::OPT_faltivec);
Ulrich Weigand3c5038a2015-07-30 14:08:36 +00004250 Args.AddLastArg(CmdArgs, options::OPT_fzvector);
4251 }
Richard Trieu91844232012-06-26 18:18:47 +00004252 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_show_template_tree);
4253 Args.AddLastArg(CmdArgs, options::OPT_fno_elide_type);
Chad Rosier864dfe12012-03-13 23:45:51 +00004254
Alexey Bataevdb390212015-05-20 04:24:19 +00004255 // Forward flags for OpenMP
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00004256 if (Args.hasFlag(options::OPT_fopenmp, options::OPT_fopenmp_EQ,
4257 options::OPT_fno_openmp, false))
4258 switch (getOpenMPRuntime(getToolChain(), Args)) {
4259 case OMPRT_OMP:
4260 case OMPRT_IOMP5:
4261 // Clang can generate useful OpenMP code for these two runtime libraries.
4262 CmdArgs.push_back("-fopenmp");
Samuel Antaof8b50122015-07-13 22:54:53 +00004263
4264 // If no option regarding the use of TLS in OpenMP codegeneration is
4265 // given, decide a default based on the target. Otherwise rely on the
4266 // options and pass the right information to the frontend.
4267 if (!Args.hasFlag(options::OPT_fopenmp_use_tls,
Alexey Bataev6a43c002015-09-10 12:06:58 +00004268 options::OPT_fnoopenmp_use_tls, /*Default=*/true))
Samuel Antaof8b50122015-07-13 22:54:53 +00004269 CmdArgs.push_back("-fnoopenmp-use-tls");
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00004270 break;
4271 default:
4272 // By default, if Clang doesn't know how to generate useful OpenMP code
4273 // for a specific runtime library, we just don't pass the '-fopenmp' flag
4274 // down to the actual compilation.
4275 // FIXME: It would be better to have a mode which *only* omits IR
4276 // generation based on the OpenMP support so that we get consistent
4277 // semantic analysis, etc.
4278 break;
4279 }
Alexey Bataevdb390212015-05-20 04:24:19 +00004280
Peter Collingbourne32701642013-11-01 18:16:25 +00004281 const SanitizerArgs &Sanitize = getToolChain().getSanitizerArgs();
Peter Collingbourne581f4382015-07-02 01:48:12 +00004282 Sanitize.addArgs(getToolChain(), Args, CmdArgs, InputType);
Richard Smith52be6192012-11-05 22:04:41 +00004283
Eric Christopher459d2712013-02-19 06:16:53 +00004284 // Report an error for -faltivec on anything other than PowerPC.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00004285 if (const Arg *A = Args.getLastArg(options::OPT_faltivec)) {
4286 const llvm::Triple::ArchType Arch = getToolChain().getArch();
4287 if (!(Arch == llvm::Triple::ppc || Arch == llvm::Triple::ppc64 ||
4288 Arch == llvm::Triple::ppc64le))
4289 D.Diag(diag::err_drv_argument_only_allowed_with) << A->getAsString(Args)
4290 << "ppc/ppc64/ppc64le";
4291 }
Chad Rosier864dfe12012-03-13 23:45:51 +00004292
Ulrich Weigand3c5038a2015-07-30 14:08:36 +00004293 // -fzvector is incompatible with -faltivec.
4294 if (Arg *A = Args.getLastArg(options::OPT_fzvector))
4295 if (Args.hasArg(options::OPT_faltivec))
4296 D.Diag(diag::err_drv_argument_not_allowed_with) << A->getAsString(Args)
4297 << "-faltivec";
4298
Daniel Dunbar733b0f82011-03-01 18:49:30 +00004299 if (getToolChain().SupportsProfiling())
4300 Args.AddLastArg(CmdArgs, options::OPT_pg);
Daniel Dunbar35621a92010-03-16 16:57:46 +00004301
4302 // -flax-vector-conversions is default.
4303 if (!Args.hasFlag(options::OPT_flax_vector_conversions,
4304 options::OPT_fno_lax_vector_conversions))
4305 CmdArgs.push_back("-fno-lax-vector-conversions");
4306
John Brawna7b4ec02015-08-10 11:11:28 +00004307 if (Args.getLastArg(options::OPT_fapple_kext) ||
4308 (Args.hasArg(options::OPT_mkernel) && types::isCXX(InputType)))
Fariborz Jahaniana4cfff82011-01-07 01:05:02 +00004309 CmdArgs.push_back("-fapple-kext");
4310
Fariborz Jahaniana4404f22009-05-22 20:17:16 +00004311 Args.AddLastArg(CmdArgs, options::OPT_fobjc_sender_dependent_dispatch);
Chris Lattner69686412009-04-21 05:34:31 +00004312 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_print_source_range_info);
Douglas Gregoreec975c2010-08-19 20:24:43 +00004313 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_parseable_fixits);
Daniel Dunbar3a148f22009-04-07 21:51:40 +00004314 Args.AddLastArg(CmdArgs, options::OPT_ftime_report);
4315 Args.AddLastArg(CmdArgs, options::OPT_ftrapv);
David Chisnalldd84ef12010-09-17 18:29:54 +00004316
4317 if (Arg *A = Args.getLastArg(options::OPT_ftrapv_handler_EQ)) {
4318 CmdArgs.push_back("-ftrapv-handler");
Richard Smithbd55daf2012-11-01 04:30:05 +00004319 CmdArgs.push_back(A->getValue());
David Chisnalldd84ef12010-09-17 18:29:54 +00004320 }
4321
Bob Wilson14adb362012-02-03 06:27:22 +00004322 Args.AddLastArg(CmdArgs, options::OPT_ftrap_function_EQ);
Evan Cheng04c94292011-04-08 21:37:45 +00004323
Chandler Carruth6e501032011-03-27 00:04:55 +00004324 // -fno-strict-overflow implies -fwrapv if it isn't disabled, but
4325 // -fstrict-overflow won't turn off an explicitly enabled -fwrapv.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004326 if (Arg *A = Args.getLastArg(options::OPT_fwrapv, options::OPT_fno_wrapv)) {
Chandler Carruth6e501032011-03-27 00:04:55 +00004327 if (A->getOption().matches(options::OPT_fwrapv))
4328 CmdArgs.push_back("-fwrapv");
4329 } else if (Arg *A = Args.getLastArg(options::OPT_fstrict_overflow,
4330 options::OPT_fno_strict_overflow)) {
4331 if (A->getOption().matches(options::OPT_fno_strict_overflow))
4332 CmdArgs.push_back("-fwrapv");
4333 }
Hal Finkelce0697f2013-11-17 16:03:29 +00004334
4335 if (Arg *A = Args.getLastArg(options::OPT_freroll_loops,
4336 options::OPT_fno_reroll_loops))
4337 if (A->getOption().matches(options::OPT_freroll_loops))
4338 CmdArgs.push_back("-freroll-loops");
4339
Daniel Dunbar3a148f22009-04-07 21:51:40 +00004340 Args.AddLastArg(CmdArgs, options::OPT_fwritable_strings);
Chandler Carruth54c29102013-08-08 08:34:35 +00004341 Args.AddLastArg(CmdArgs, options::OPT_funroll_loops,
4342 options::OPT_fno_unroll_loops);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004343
Daniel Dunbara77eaeb2009-09-03 04:54:28 +00004344 Args.AddLastArg(CmdArgs, options::OPT_pthread);
4345
Daniel Dunbar4930e332009-11-17 08:07:36 +00004346 // -stack-protector=0 is default.
4347 unsigned StackProtectorLevel = 0;
Peter Collingbournec4122c12015-06-15 21:08:13 +00004348 if (getToolChain().getSanitizerArgs().needsSafeStackRt()) {
4349 Args.ClaimAllArgs(options::OPT_fno_stack_protector);
4350 Args.ClaimAllArgs(options::OPT_fstack_protector_all);
4351 Args.ClaimAllArgs(options::OPT_fstack_protector_strong);
4352 Args.ClaimAllArgs(options::OPT_fstack_protector);
4353 } else if (Arg *A = Args.getLastArg(options::OPT_fno_stack_protector,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004354 options::OPT_fstack_protector_all,
4355 options::OPT_fstack_protector_strong,
4356 options::OPT_fstack_protector)) {
Rafael Espindolace5c6092014-05-22 22:57:39 +00004357 if (A->getOption().matches(options::OPT_fstack_protector)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004358 StackProtectorLevel = std::max<unsigned>(
4359 LangOptions::SSPOn,
4360 getToolChain().GetDefaultStackProtectorLevel(KernelOrKext));
Rafael Espindolace5c6092014-05-22 22:57:39 +00004361 } else if (A->getOption().matches(options::OPT_fstack_protector_strong))
Josh Mageee0fc1a82014-02-11 01:35:14 +00004362 StackProtectorLevel = LangOptions::SSPStrong;
Daniel Dunbar4930e332009-11-17 08:07:36 +00004363 else if (A->getOption().matches(options::OPT_fstack_protector_all))
Josh Mageee0fc1a82014-02-11 01:35:14 +00004364 StackProtectorLevel = LangOptions::SSPReq;
Nico Weberdd473632011-08-23 07:38:27 +00004365 } else {
4366 StackProtectorLevel =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004367 getToolChain().GetDefaultStackProtectorLevel(KernelOrKext);
Nico Weberdd473632011-08-23 07:38:27 +00004368 }
Daniel Dunbar4930e332009-11-17 08:07:36 +00004369 if (StackProtectorLevel) {
4370 CmdArgs.push_back("-stack-protector");
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004371 CmdArgs.push_back(Args.MakeArgString(Twine(StackProtectorLevel)));
Joerg Sonnenberger85e2bbc2012-09-12 13:51:14 +00004372 }
Chad Rosierdb3da832012-08-21 16:16:06 +00004373
Joerg Sonnenberger85e2bbc2012-09-12 13:51:14 +00004374 // --param ssp-buffer-size=
Sean Silva14facf32015-06-09 01:57:17 +00004375 for (const Arg *A : Args.filtered(options::OPT__param)) {
4376 StringRef Str(A->getValue());
Joerg Sonnenberger85e2bbc2012-09-12 13:51:14 +00004377 if (Str.startswith("ssp-buffer-size=")) {
4378 if (StackProtectorLevel) {
Chad Rosierdb3da832012-08-21 16:16:06 +00004379 CmdArgs.push_back("-stack-protector-buffer-size");
4380 // FIXME: Verify the argument is a valid integer.
4381 CmdArgs.push_back(Args.MakeArgString(Str.drop_front(16)));
Chad Rosierdb3da832012-08-21 16:16:06 +00004382 }
Sean Silva14facf32015-06-09 01:57:17 +00004383 A->claim();
Chad Rosierdb3da832012-08-21 16:16:06 +00004384 }
Bill Wendlingd63bbad2009-06-28 07:36:13 +00004385 }
4386
Nick Lewyckyf4d3f7a2011-12-06 03:33:03 +00004387 // Translate -mstackrealign
4388 if (Args.hasFlag(options::OPT_mstackrealign, options::OPT_mno_stackrealign,
Akira Hatanakaaecca042015-09-11 18:55:09 +00004389 false))
Nick Lewyckyf4d3f7a2011-12-06 03:33:03 +00004390 CmdArgs.push_back(Args.MakeArgString("-mstackrealign"));
Nick Lewyckyf4d3f7a2011-12-06 03:33:03 +00004391
Joerg Sonnenbergerdb66ed02011-12-05 23:05:23 +00004392 if (Args.hasArg(options::OPT_mstack_alignment)) {
4393 StringRef alignment = Args.getLastArgValue(options::OPT_mstack_alignment);
4394 CmdArgs.push_back(Args.MakeArgString("-mstack-alignment=" + alignment));
Eric Christopherd5c45f62011-05-02 21:18:22 +00004395 }
Eric Christopher84fbdb42011-08-19 00:30:14 +00004396
Hans Wennborg77dc2362015-01-20 19:45:50 +00004397 if (Args.hasArg(options::OPT_mstack_probe_size)) {
4398 StringRef Size = Args.getLastArgValue(options::OPT_mstack_probe_size);
4399
4400 if (!Size.empty())
4401 CmdArgs.push_back(Args.MakeArgString("-mstack-probe-size=" + Size));
4402 else
4403 CmdArgs.push_back("-mstack-probe-size=0");
4404 }
4405
Oliver Stannarddc2854c2015-09-03 12:40:58 +00004406 switch (getToolChain().getArch()) {
4407 case llvm::Triple::aarch64:
4408 case llvm::Triple::aarch64_be:
4409 case llvm::Triple::arm:
4410 case llvm::Triple::armeb:
4411 case llvm::Triple::thumb:
4412 case llvm::Triple::thumbeb:
Oliver Stannarded8ecc82014-08-27 16:31:57 +00004413 CmdArgs.push_back("-fallow-half-arguments-and-returns");
Oliver Stannarddc2854c2015-09-03 12:40:58 +00004414 break;
4415
4416 default:
4417 break;
4418 }
Oliver Stannarded8ecc82014-08-27 16:31:57 +00004419
Weiming Zhao580dcfb2013-11-13 18:31:23 +00004420 if (Arg *A = Args.getLastArg(options::OPT_mrestrict_it,
4421 options::OPT_mno_restrict_it)) {
4422 if (A->getOption().matches(options::OPT_mrestrict_it)) {
4423 CmdArgs.push_back("-backend-option");
4424 CmdArgs.push_back("-arm-restrict-it");
4425 } else {
4426 CmdArgs.push_back("-backend-option");
4427 CmdArgs.push_back("-arm-no-restrict-it");
4428 }
James Y Knight2db38f32015-08-15 03:45:25 +00004429 } else if (Triple.isOSWindows() &&
4430 (Triple.getArch() == llvm::Triple::arm ||
4431 Triple.getArch() == llvm::Triple::thumb)) {
Saleem Abdulrasool6deb8162014-05-18 06:42:02 +00004432 // Windows on ARM expects restricted IT blocks
4433 CmdArgs.push_back("-backend-option");
4434 CmdArgs.push_back("-arm-restrict-it");
Weiming Zhao580dcfb2013-11-13 18:31:23 +00004435 }
4436
Daniel Dunbard18049a2009-04-07 21:16:11 +00004437 // Forward -f options with positive and negative forms; we translate
4438 // these by hand.
Diego Novillo5c297052013-11-13 12:22:39 +00004439 if (Arg *A = Args.getLastArg(options::OPT_fprofile_sample_use_EQ)) {
4440 StringRef fname = A->getValue();
4441 if (!llvm::sys::fs::exists(fname))
4442 D.Diag(diag::err_drv_no_such_file) << fname;
4443 else
4444 A->render(Args, CmdArgs);
4445 }
Daniel Dunbard18049a2009-04-07 21:16:11 +00004446
John Brawna7b4ec02015-08-10 11:11:28 +00004447 // -fbuiltin is default unless -mkernel is used
4448 if (!Args.hasFlag(options::OPT_fbuiltin, options::OPT_fno_builtin,
4449 !Args.hasArg(options::OPT_mkernel)))
Daniel Dunbar484afa22009-11-19 04:55:23 +00004450 CmdArgs.push_back("-fno-builtin");
Daniel Dunbard18049a2009-04-07 21:16:11 +00004451
Nuno Lopes13c88c72009-12-16 16:59:22 +00004452 if (!Args.hasFlag(options::OPT_fassume_sane_operator_new,
4453 options::OPT_fno_assume_sane_operator_new))
4454 CmdArgs.push_back("-fno-assume-sane-operator-new");
4455
Daniel Dunbar4930e332009-11-17 08:07:36 +00004456 // -fblocks=0 is default.
4457 if (Args.hasFlag(options::OPT_fblocks, options::OPT_fno_blocks,
David Chisnallda209912011-02-28 17:11:43 +00004458 getToolChain().IsBlocksDefault()) ||
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004459 (Args.hasArg(options::OPT_fgnu_runtime) &&
4460 Args.hasArg(options::OPT_fobjc_nonfragile_abi) &&
4461 !Args.hasArg(options::OPT_fno_blocks))) {
Daniel Dunbar4930e332009-11-17 08:07:36 +00004462 CmdArgs.push_back("-fblocks");
John McCall7959fee2011-09-09 20:41:01 +00004463
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004464 if (!Args.hasArg(options::OPT_fgnu_runtime) &&
John McCall7959fee2011-09-09 20:41:01 +00004465 !getToolChain().hasBlocksRuntime())
4466 CmdArgs.push_back("-fblocks-runtime-optional");
David Chisnall950a9512009-11-17 19:33:30 +00004467 }
Daniel Dunbard18049a2009-04-07 21:16:11 +00004468
Richard Smith47972af2015-06-16 00:08:24 +00004469 // -fmodules enables the use of precompiled modules (off by default).
Richard Smithffb65082014-09-30 23:10:19 +00004470 // Users can pass -fno-cxx-modules to turn off modules support for
Richard Smith47972af2015-06-16 00:08:24 +00004471 // C++/Objective-C++ programs.
Douglas Gregorc60437f2013-01-16 01:23:41 +00004472 bool HaveModules = false;
Douglas Gregor226173a2012-01-18 15:19:58 +00004473 if (Args.hasFlag(options::OPT_fmodules, options::OPT_fno_modules, false)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004474 bool AllowedInCXX = Args.hasFlag(options::OPT_fcxx_modules,
4475 options::OPT_fno_cxx_modules, true);
Douglas Gregorc60437f2013-01-16 01:23:41 +00004476 if (AllowedInCXX || !types::isCXX(InputType)) {
Douglas Gregor226173a2012-01-18 15:19:58 +00004477 CmdArgs.push_back("-fmodules");
Douglas Gregorc60437f2013-01-16 01:23:41 +00004478 HaveModules = true;
4479 }
4480 }
4481
Richard Smith47972af2015-06-16 00:08:24 +00004482 // -fmodule-maps enables implicit reading of module map files. By default,
4483 // this is enabled if we are using precompiled modules.
Richard Smithcf18b792015-06-16 00:20:23 +00004484 if (Args.hasFlag(options::OPT_fimplicit_module_maps,
4485 options::OPT_fno_implicit_module_maps, HaveModules)) {
Richard Smith47972af2015-06-16 00:08:24 +00004486 CmdArgs.push_back("-fimplicit-module-maps");
Daniel Jasper07e6c402013-08-05 20:26:17 +00004487 }
4488
Daniel Jasperac42b752013-10-21 06:34:34 +00004489 // -fmodules-decluse checks that modules used are declared so (off by
4490 // default).
Daniel Jasperba7f2f72013-09-24 09:14:14 +00004491 if (Args.hasFlag(options::OPT_fmodules_decluse,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004492 options::OPT_fno_modules_decluse, false)) {
Daniel Jasper6e16d542013-09-29 12:40:54 +00004493 CmdArgs.push_back("-fmodules-decluse");
Daniel Jasperba7f2f72013-09-24 09:14:14 +00004494 }
4495
Daniel Jasper962b38e2014-04-11 11:47:45 +00004496 // -fmodules-strict-decluse is like -fmodule-decluse, but also checks that
4497 // all #included headers are part of modules.
4498 if (Args.hasFlag(options::OPT_fmodules_strict_decluse,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004499 options::OPT_fno_modules_strict_decluse, false)) {
Daniel Jasper962b38e2014-04-11 11:47:45 +00004500 CmdArgs.push_back("-fmodules-strict-decluse");
4501 }
4502
Manuel Klimekd2e8b042015-02-20 11:44:41 +00004503 // -fno-implicit-modules turns off implicitly compiling modules on demand.
4504 if (!Args.hasFlag(options::OPT_fimplicit_modules,
4505 options::OPT_fno_implicit_modules)) {
4506 CmdArgs.push_back("-fno-implicit-modules");
4507 }
4508
Daniel Jasperac42b752013-10-21 06:34:34 +00004509 // -fmodule-name specifies the module that is currently being built (or
4510 // used for header checking by -fmodule-maps).
Richard Smith9887d792014-10-17 01:42:53 +00004511 Args.AddLastArg(CmdArgs, options::OPT_fmodule_name);
Daniel Jasperac42b752013-10-21 06:34:34 +00004512
Richard Smith9887d792014-10-17 01:42:53 +00004513 // -fmodule-map-file can be used to specify files containing module
Daniel Jasperac42b752013-10-21 06:34:34 +00004514 // definitions.
Richard Smith9887d792014-10-17 01:42:53 +00004515 Args.AddAllArgs(CmdArgs, options::OPT_fmodule_map_file);
Daniel Jasperac42b752013-10-21 06:34:34 +00004516
Richard Smithe842a472014-10-22 02:05:46 +00004517 // -fmodule-file can be used to specify files containing precompiled modules.
Richard Smith7acebe42015-09-11 03:58:07 +00004518 if (HaveModules)
4519 Args.AddAllArgs(CmdArgs, options::OPT_fmodule_file);
4520 else
4521 Args.ClaimAllArgs(options::OPT_fmodule_file);
Richard Smithe842a472014-10-22 02:05:46 +00004522
4523 // -fmodule-cache-path specifies where our implicitly-built module files
4524 // should be written.
Diego Novilloa0545962015-07-10 18:00:07 +00004525 SmallString<128> Path;
Justin Bognera88f0122014-06-20 22:59:50 +00004526 if (Arg *A = Args.getLastArg(options::OPT_fmodules_cache_path))
Daniel Jasper7450f912015-07-10 08:25:54 +00004527 Path = A->getValue();
Justin Bognera88f0122014-06-20 22:59:50 +00004528 if (HaveModules) {
4529 if (C.isForDiagnostics()) {
4530 // When generating crash reports, we want to emit the modules along with
4531 // the reproduction sources, so we ignore any provided module path.
Daniel Jasper7450f912015-07-10 08:25:54 +00004532 Path = Output.getFilename();
4533 llvm::sys::path::replace_extension(Path, ".cache");
4534 llvm::sys::path::append(Path, "modules");
4535 } else if (Path.empty()) {
Justin Bognera88f0122014-06-20 22:59:50 +00004536 // No module path was provided: use the default.
Renato Golin7c542b42015-07-27 23:44:45 +00004537 llvm::sys::path::system_temp_directory(/*erasedOnReboot=*/false, Path);
Daniel Jasper7450f912015-07-10 08:25:54 +00004538 llvm::sys::path::append(Path, "org.llvm.clang.");
4539 appendUserToPath(Path);
4540 llvm::sys::path::append(Path, "ModuleCache");
Justin Bognera88f0122014-06-20 22:59:50 +00004541 }
Douglas Gregor4bedb492013-02-07 22:59:12 +00004542 const char Arg[] = "-fmodules-cache-path=";
Daniel Jasper7450f912015-07-10 08:25:54 +00004543 Path.insert(Path.begin(), Arg, Arg + strlen(Arg));
4544 CmdArgs.push_back(Args.MakeArgString(Path));
Justin Bognera88f0122014-06-20 22:59:50 +00004545 }
4546
4547 // When building modules and generating crashdumps, we need to dump a module
4548 // dependency VFS alongside the output.
4549 if (HaveModules && C.isForDiagnostics()) {
4550 SmallString<128> VFSDir(Output.getFilename());
4551 llvm::sys::path::replace_extension(VFSDir, ".cache");
Justin Bogner659ecc32014-10-20 22:47:23 +00004552 // Add the cache directory as a temp so the crash diagnostics pick it up.
4553 C.addTempFile(Args.MakeArgString(VFSDir));
4554
Justin Bognera88f0122014-06-20 22:59:50 +00004555 llvm::sys::path::append(VFSDir, "vfs");
4556 CmdArgs.push_back("-module-dependency-dir");
4557 CmdArgs.push_back(Args.MakeArgString(VFSDir));
Douglas Gregor35b04d62013-02-07 19:01:24 +00004558 }
4559
Richard Smith9887d792014-10-17 01:42:53 +00004560 if (HaveModules)
4561 Args.AddLastArg(CmdArgs, options::OPT_fmodules_user_build_path);
Argyrios Kyrtzidis1594c152014-03-03 08:12:05 +00004562
Douglas Gregor35b04d62013-02-07 19:01:24 +00004563 // Pass through all -fmodules-ignore-macro arguments.
4564 Args.AddAllArgs(CmdArgs, options::OPT_fmodules_ignore_macro);
Douglas Gregor527b1c92013-03-25 21:19:16 +00004565 Args.AddLastArg(CmdArgs, options::OPT_fmodules_prune_interval);
4566 Args.AddLastArg(CmdArgs, options::OPT_fmodules_prune_after);
Douglas Gregor35b04d62013-02-07 19:01:24 +00004567
Dmitri Gribenkof430da42014-02-12 10:33:14 +00004568 Args.AddLastArg(CmdArgs, options::OPT_fbuild_session_timestamp);
4569
Ben Langmuir19e6acb2014-08-01 22:12:21 +00004570 if (Arg *A = Args.getLastArg(options::OPT_fbuild_session_file)) {
4571 if (Args.hasArg(options::OPT_fbuild_session_timestamp))
4572 D.Diag(diag::err_drv_argument_not_allowed_with)
4573 << A->getAsString(Args) << "-fbuild-session-timestamp";
4574
4575 llvm::sys::fs::file_status Status;
4576 if (llvm::sys::fs::status(A->getValue(), Status))
4577 D.Diag(diag::err_drv_no_such_file) << A->getValue();
Benjamin Kramer320fc262015-02-14 18:19:55 +00004578 CmdArgs.push_back(Args.MakeArgString(
4579 "-fbuild-session-timestamp=" +
4580 Twine((uint64_t)Status.getLastModificationTime().toEpochTime())));
Ben Langmuir19e6acb2014-08-01 22:12:21 +00004581 }
4582
Dmitri Gribenkof430da42014-02-12 10:33:14 +00004583 if (Args.getLastArg(options::OPT_fmodules_validate_once_per_build_session)) {
Ben Langmuir19e6acb2014-08-01 22:12:21 +00004584 if (!Args.getLastArg(options::OPT_fbuild_session_timestamp,
4585 options::OPT_fbuild_session_file))
Dmitri Gribenkof430da42014-02-12 10:33:14 +00004586 D.Diag(diag::err_drv_modules_validate_once_requires_timestamp);
4587
4588 Args.AddLastArg(CmdArgs,
4589 options::OPT_fmodules_validate_once_per_build_session);
4590 }
4591
Ben Langmuirdcf73862014-03-12 00:06:17 +00004592 Args.AddLastArg(CmdArgs, options::OPT_fmodules_validate_system_headers);
4593
John McCalldfea9982010-04-09 19:12:06 +00004594 // -faccess-control is default.
John McCall3155f572010-04-09 19:03:51 +00004595 if (Args.hasFlag(options::OPT_fno_access_control,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004596 options::OPT_faccess_control, false))
John McCall3155f572010-04-09 19:03:51 +00004597 CmdArgs.push_back("-fno-access-control");
John McCall59bb1d42010-03-17 01:32:13 +00004598
Anders Carlssond470fef2010-11-21 00:09:52 +00004599 // -felide-constructors is the default.
4600 if (Args.hasFlag(options::OPT_fno_elide_constructors,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004601 options::OPT_felide_constructors, false))
Anders Carlssond470fef2010-11-21 00:09:52 +00004602 CmdArgs.push_back("-fno-elide-constructors");
4603
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00004604 ToolChain::RTTIMode RTTIMode = getToolChain().getRTTIMode();
Filipe Cabecinhas28f353c2015-01-29 23:56:43 +00004605
Filipe Cabecinhasc4732552015-03-20 23:51:15 +00004606 if (KernelOrKext || (types::isCXX(InputType) &&
4607 (RTTIMode == ToolChain::RM_DisabledExplicitly ||
4608 RTTIMode == ToolChain::RM_DisabledImplicitly)))
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00004609 CmdArgs.push_back("-fno-rtti");
Richard Smith52be6192012-11-05 22:04:41 +00004610
Tony Linthicum76329bf2011-12-12 21:14:55 +00004611 // -fshort-enums=0 is default for all architectures except Hexagon.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004612 if (Args.hasFlag(options::OPT_fshort_enums, options::OPT_fno_short_enums,
4613 getToolChain().getArch() == llvm::Triple::hexagon))
Argyrios Kyrtzidis74825bc2010-10-08 00:25:19 +00004614 CmdArgs.push_back("-fshort-enums");
4615
Daniel Dunbard609b7b2009-11-17 06:37:03 +00004616 // -fsigned-char is default.
David Majnemerc3658d22015-05-23 18:48:37 +00004617 if (Arg *A = Args.getLastArg(
4618 options::OPT_fsigned_char, options::OPT_fno_signed_char,
4619 options::OPT_funsigned_char, options::OPT_fno_unsigned_char)) {
4620 if (A->getOption().matches(options::OPT_funsigned_char) ||
4621 A->getOption().matches(options::OPT_fno_signed_char)) {
4622 CmdArgs.push_back("-fno-signed-char");
4623 }
4624 } else if (!isSignedCharDefault(getToolChain().getTriple())) {
Daniel Dunbar5fe08662009-11-29 02:39:08 +00004625 CmdArgs.push_back("-fno-signed-char");
David Majnemerc3658d22015-05-23 18:48:37 +00004626 }
Eli Friedman327f0b52009-06-05 07:21:14 +00004627
Daniel Dunbarfe06df42010-03-20 04:15:41 +00004628 // -fuse-cxa-atexit is default.
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00004629 if (!Args.hasFlag(options::OPT_fuse_cxa_atexit,
4630 options::OPT_fno_use_cxa_atexit,
4631 !IsWindowsCygnus && !IsWindowsGNU &&
4632 getToolChain().getTriple().getOS() != llvm::Triple::Solaris &&
4633 getToolChain().getArch() != llvm::Triple::hexagon &&
4634 getToolChain().getArch() != llvm::Triple::xcore) ||
Chad Rosier4fab82c2012-03-26 22:04:46 +00004635 KernelOrKext)
Daniel Dunbarfe06df42010-03-20 04:15:41 +00004636 CmdArgs.push_back("-fno-use-cxa-atexit");
4637
Daniel Dunbar0730e4f2009-11-17 07:06:20 +00004638 // -fms-extensions=0 is default.
Daniel Dunbar5bdd2992009-11-25 10:14:30 +00004639 if (Args.hasFlag(options::OPT_fms_extensions, options::OPT_fno_ms_extensions,
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00004640 IsWindowsMSVC))
Daniel Dunbar0730e4f2009-11-17 07:06:20 +00004641 CmdArgs.push_back("-fms-extensions");
4642
Reid Kleckner1df0fea2015-02-26 00:17:25 +00004643 // -fno-use-line-directives is default.
4644 if (Args.hasFlag(options::OPT_fuse_line_directives,
4645 options::OPT_fno_use_line_directives, false))
4646 CmdArgs.push_back("-fuse-line-directives");
4647
Francois Pichet1b4f1632011-09-17 04:32:15 +00004648 // -fms-compatibility=0 is default.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004649 if (Args.hasFlag(options::OPT_fms_compatibility,
Douglas Gregor2b4907e2011-10-24 15:49:38 +00004650 options::OPT_fno_ms_compatibility,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004651 (IsWindowsMSVC &&
4652 Args.hasFlag(options::OPT_fms_extensions,
4653 options::OPT_fno_ms_extensions, true))))
Francois Pichet1b4f1632011-09-17 04:32:15 +00004654 CmdArgs.push_back("-fms-compatibility");
4655
David Majnemerc371ff02015-03-22 08:39:22 +00004656 // -fms-compatibility-version=18.00 is default.
David Majnemere11d3732015-06-08 00:22:46 +00004657 VersionTuple MSVT = visualstudio::getMSVCVersion(
4658 &D, getToolChain().getTriple(), Args, IsWindowsMSVC);
4659 if (!MSVT.empty())
David Majnemerc371ff02015-03-22 08:39:22 +00004660 CmdArgs.push_back(
4661 Args.MakeArgString("-fms-compatibility-version=" + MSVT.getAsString()));
Michael J. Spencer4992ca4b2010-10-21 05:21:48 +00004662
David Majnemer8db91762015-05-18 04:49:30 +00004663 bool IsMSVC2015Compatible = MSVT.getMajor() >= 19;
4664 if (ImplyVCPPCXXVer) {
4665 if (IsMSVC2015Compatible)
4666 CmdArgs.push_back("-std=c++14");
4667 else
4668 CmdArgs.push_back("-std=c++11");
4669 }
4670
Eric Christopher5ecce122013-02-18 00:38:31 +00004671 // -fno-borland-extensions is default.
Dawn Perchik68bb1b42010-09-02 23:59:25 +00004672 if (Args.hasFlag(options::OPT_fborland_extensions,
4673 options::OPT_fno_borland_extensions, false))
4674 CmdArgs.push_back("-fborland-extensions");
4675
Saleem Abdulrasoold170c4b2015-10-04 17:51:05 +00004676 // -fno-declspec is default, except for PS4.
4677 if (Args.hasFlag(options::OPT_fdeclspec, options::OPT_fno_declspec,
4678 getToolChain().getTriple().isPS4()))
4679 CmdArgs.push_back("-fdeclspec");
4680 else if (Args.hasArg(options::OPT_fno_declspec))
4681 CmdArgs.push_back("-fno-declspec"); // Explicitly disabling __declspec.
4682
David Majnemerc371ff02015-03-22 08:39:22 +00004683 // -fthreadsafe-static is default, except for MSVC compatibility versions less
4684 // than 19.
4685 if (!Args.hasFlag(options::OPT_fthreadsafe_statics,
4686 options::OPT_fno_threadsafe_statics,
David Majnemer8db91762015-05-18 04:49:30 +00004687 !IsWindowsMSVC || IsMSVC2015Compatible))
David Majnemerc371ff02015-03-22 08:39:22 +00004688 CmdArgs.push_back("-fno-threadsafe-statics");
4689
Francois Pichet02744872011-09-01 16:38:08 +00004690 // -fno-delayed-template-parsing is default, except for Windows where MSVC STL
4691 // needs it.
Francois Pichet1c229c02011-04-22 22:18:13 +00004692 if (Args.hasFlag(options::OPT_fdelayed_template_parsing,
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00004693 options::OPT_fno_delayed_template_parsing, IsWindowsMSVC))
Francois Pichet35bc5de2011-08-26 00:22:34 +00004694 CmdArgs.push_back("-fdelayed-template-parsing");
Francois Pichet1c229c02011-04-22 22:18:13 +00004695
Chandler Carruthe03aa552010-04-17 20:17:31 +00004696 // -fgnu-keywords default varies depending on language; only pass if
4697 // specified.
4698 if (Arg *A = Args.getLastArg(options::OPT_fgnu_keywords,
Daniel Dunbardb059592010-04-24 17:56:39 +00004699 options::OPT_fno_gnu_keywords))
4700 A->render(Args, CmdArgs);
Chandler Carruthe03aa552010-04-17 20:17:31 +00004701
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004702 if (Args.hasFlag(options::OPT_fgnu89_inline, options::OPT_fno_gnu89_inline,
Rafael Espindola922a6242011-06-02 17:30:53 +00004703 false))
Rafael Espindolafb2af642011-06-02 16:13:27 +00004704 CmdArgs.push_back("-fgnu89-inline");
4705
Chad Rosier9c76d242012-03-15 22:31:42 +00004706 if (Args.hasArg(options::OPT_fno_inline))
4707 CmdArgs.push_back("-fno-inline");
4708
Chad Rosier64d6be92012-03-06 21:17:19 +00004709 if (Args.hasArg(options::OPT_fno_inline_functions))
4710 CmdArgs.push_back("-fno-inline-functions");
Chad Rosier80603182012-03-06 18:49:20 +00004711
John McCall5fb5df92012-06-20 06:18:46 +00004712 ObjCRuntime objcRuntime = AddObjCRuntimeArgs(Args, CmdArgs, rewriteKind);
John McCall24fc0de2011-07-06 00:26:06 +00004713
John McCall5fb5df92012-06-20 06:18:46 +00004714 // -fobjc-dispatch-method is only relevant with the nonfragile-abi, and
Fariborz Jahanian15f60cb2014-01-20 19:32:33 +00004715 // legacy is the default. Except for deployment taget of 10.5,
4716 // next runtime is always legacy dispatch and -fno-objc-legacy-dispatch
4717 // gets ignored silently.
4718 if (objcRuntime.isNonFragile()) {
David Chisnall3154e682011-09-30 13:32:35 +00004719 if (!Args.hasFlag(options::OPT_fobjc_legacy_dispatch,
4720 options::OPT_fno_objc_legacy_dispatch,
David Chisnallda225352012-07-04 11:52:24 +00004721 objcRuntime.isLegacyDispatchDefaultForArch(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004722 getToolChain().getArch()))) {
David Chisnall3154e682011-09-30 13:32:35 +00004723 if (getToolChain().UseObjCMixedDispatch())
4724 CmdArgs.push_back("-fobjc-dispatch-method=mixed");
4725 else
4726 CmdArgs.push_back("-fobjc-dispatch-method=non-legacy");
4727 }
4728 }
Rafael Espindolab44676c2013-11-12 04:33:56 +00004729
Fariborz Jahanianfd4ce192013-11-12 17:08:46 +00004730 // When ObjectiveC legacy runtime is in effect on MacOSX,
4731 // turn on the option to do Array/Dictionary subscripting
4732 // by default.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00004733 if (getToolChain().getArch() == llvm::Triple::x86 &&
Fariborz Jahanianff6c97c2013-11-12 20:50:26 +00004734 getToolChain().getTriple().isMacOSX() &&
4735 !getToolChain().getTriple().isMacOSXVersionLT(10, 7) &&
4736 objcRuntime.getKind() == ObjCRuntime::FragileMacOSX &&
Fariborz Jahanianfd4ce192013-11-12 17:08:46 +00004737 objcRuntime.isNeXTFamily())
4738 CmdArgs.push_back("-fobjc-subscripting-legacy-runtime");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004739
Fariborz Jahanian0e3043b2012-11-15 19:02:45 +00004740 // -fencode-extended-block-signature=1 is default.
4741 if (getToolChain().IsEncodeExtendedBlockSignatureDefault()) {
4742 CmdArgs.push_back("-fencode-extended-block-signature");
4743 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004744
John McCall24fc0de2011-07-06 00:26:06 +00004745 // Allow -fno-objc-arr to trump -fobjc-arr/-fobjc-arc.
4746 // NOTE: This logic is duplicated in ToolChains.cpp.
4747 bool ARC = isObjCAutoRefCount(Args);
4748 if (ARC) {
John McCall3deb1ad2012-08-21 02:47:43 +00004749 getToolChain().CheckObjCARC();
Argyrios Kyrtzidis3dbeb552012-02-29 03:43:52 +00004750
John McCall24fc0de2011-07-06 00:26:06 +00004751 CmdArgs.push_back("-fobjc-arc");
4752
Chandler Carruth491db322011-11-04 07:34:47 +00004753 // FIXME: It seems like this entire block, and several around it should be
4754 // wrapped in isObjC, but for now we just use it here as this is where it
4755 // was being used previously.
4756 if (types::isCXX(InputType) && types::isObjC(InputType)) {
4757 if (getToolChain().GetCXXStdlibType(Args) == ToolChain::CST_Libcxx)
4758 CmdArgs.push_back("-fobjc-arc-cxxlib=libc++");
4759 else
4760 CmdArgs.push_back("-fobjc-arc-cxxlib=libstdc++");
4761 }
4762
John McCall24fc0de2011-07-06 00:26:06 +00004763 // Allow the user to enable full exceptions code emission.
4764 // We define off for Objective-CC, on for Objective-C++.
4765 if (Args.hasFlag(options::OPT_fobjc_arc_exceptions,
4766 options::OPT_fno_objc_arc_exceptions,
4767 /*default*/ types::isCXX(InputType)))
4768 CmdArgs.push_back("-fobjc-arc-exceptions");
4769 }
4770
4771 // -fobjc-infer-related-result-type is the default, except in the Objective-C
4772 // rewriter.
John McCall5fb5df92012-06-20 06:18:46 +00004773 if (rewriteKind != RK_None)
John McCall24fc0de2011-07-06 00:26:06 +00004774 CmdArgs.push_back("-fno-objc-infer-related-result-type");
Eric Christopher84fbdb42011-08-19 00:30:14 +00004775
John McCall24fc0de2011-07-06 00:26:06 +00004776 // Handle -fobjc-gc and -fobjc-gc-only. They are exclusive, and -fobjc-gc-only
4777 // takes precedence.
4778 const Arg *GCArg = Args.getLastArg(options::OPT_fobjc_gc_only);
4779 if (!GCArg)
4780 GCArg = Args.getLastArg(options::OPT_fobjc_gc);
4781 if (GCArg) {
4782 if (ARC) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004783 D.Diag(diag::err_drv_objc_gc_arr) << GCArg->getAsString(Args);
John McCall24fc0de2011-07-06 00:26:06 +00004784 } else if (getToolChain().SupportsObjCGC()) {
4785 GCArg->render(Args, CmdArgs);
4786 } else {
4787 // FIXME: We should move this to a hard error.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004788 D.Diag(diag::warn_drv_objc_gc_unsupported) << GCArg->getAsString(Args);
John McCall24fc0de2011-07-06 00:26:06 +00004789 }
4790 }
4791
Bob Wilsonb111ec92015-03-02 19:01:14 +00004792 if (Args.hasFlag(options::OPT_fapplication_extension,
4793 options::OPT_fno_application_extension, false))
4794 CmdArgs.push_back("-fapplication-extension");
4795
Reid Klecknerc542d372014-06-27 17:02:02 +00004796 // Handle GCC-style exception args.
4797 if (!C.getDriver().IsCLMode())
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004798 addExceptionArgs(Args, InputType, getToolChain(), KernelOrKext, objcRuntime,
4799 CmdArgs);
John McCallb5f652e2011-06-22 00:53:57 +00004800
4801 if (getToolChain().UseSjLjExceptions())
4802 CmdArgs.push_back("-fsjlj-exceptions");
4803
4804 // C++ "sane" operator new.
Daniel Dunbar2e3f2c82010-02-01 21:07:25 +00004805 if (!Args.hasFlag(options::OPT_fassume_sane_operator_new,
4806 options::OPT_fno_assume_sane_operator_new))
4807 CmdArgs.push_back("-fno-assume-sane-operator-new");
4808
Reid Kleckner7ffc3fb2015-03-20 00:31:07 +00004809 // -fsized-deallocation is off by default, as it is an ABI-breaking change for
4810 // most platforms.
4811 if (Args.hasFlag(options::OPT_fsized_deallocation,
4812 options::OPT_fno_sized_deallocation, false))
4813 CmdArgs.push_back("-fsized-deallocation");
4814
Daniel Dunbar34d7a992010-04-27 15:34:57 +00004815 // -fconstant-cfstrings is default, and may be subject to argument translation
4816 // on Darwin.
4817 if (!Args.hasFlag(options::OPT_fconstant_cfstrings,
4818 options::OPT_fno_constant_cfstrings) ||
4819 !Args.hasFlag(options::OPT_mconstant_cfstrings,
4820 options::OPT_mno_constant_cfstrings))
4821 CmdArgs.push_back("-fno-constant-cfstrings");
4822
John Thompsoned4e2952009-11-05 20:14:16 +00004823 // -fshort-wchar default varies depending on platform; only
4824 // pass if specified.
Richard Bartonc9b5f352014-02-24 18:43:28 +00004825 if (Arg *A = Args.getLastArg(options::OPT_fshort_wchar,
4826 options::OPT_fno_short_wchar))
Daniel Dunbar2cb4e7a2010-04-27 15:35:03 +00004827 A->render(Args, CmdArgs);
John Thompsoned4e2952009-11-05 20:14:16 +00004828
Hans Wennborg28c96312013-07-31 23:39:13 +00004829 // -fno-pascal-strings is default, only pass non-default.
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004830 if (Args.hasFlag(options::OPT_fpascal_strings,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004831 options::OPT_fno_pascal_strings, false))
Daniel Dunbard18049a2009-04-07 21:16:11 +00004832 CmdArgs.push_back("-fpascal-strings");
NAKAMURA Takumi029d74b2011-02-17 08:50:50 +00004833
Daniel Dunbar096ed292011-10-05 21:04:55 +00004834 // Honor -fpack-struct= and -fpack-struct, if given. Note that
4835 // -fno-pack-struct doesn't apply to -fpack-struct=.
4836 if (Arg *A = Args.getLastArg(options::OPT_fpack_struct_EQ)) {
James Molloycebf75e2012-05-02 07:56:14 +00004837 std::string PackStructStr = "-fpack-struct=";
Richard Smithbd55daf2012-11-01 04:30:05 +00004838 PackStructStr += A->getValue();
James Molloycebf75e2012-05-02 07:56:14 +00004839 CmdArgs.push_back(Args.MakeArgString(PackStructStr));
Daniel Dunbar096ed292011-10-05 21:04:55 +00004840 } else if (Args.hasFlag(options::OPT_fpack_struct,
4841 options::OPT_fno_pack_struct, false)) {
James Molloycebf75e2012-05-02 07:56:14 +00004842 CmdArgs.push_back("-fpack-struct=1");
Daniel Dunbar096ed292011-10-05 21:04:55 +00004843 }
4844
Fariborz Jahanianbcd82af2014-08-05 18:37:48 +00004845 // Handle -fmax-type-align=N and -fno-type-align
4846 bool SkipMaxTypeAlign = Args.hasArg(options::OPT_fno_max_type_align);
4847 if (Arg *A = Args.getLastArg(options::OPT_fmax_type_align_EQ)) {
4848 if (!SkipMaxTypeAlign) {
4849 std::string MaxTypeAlignStr = "-fmax-type-align=";
4850 MaxTypeAlignStr += A->getValue();
4851 CmdArgs.push_back(Args.MakeArgString(MaxTypeAlignStr));
4852 }
4853 } else if (getToolChain().getTriple().isOSDarwin()) {
4854 if (!SkipMaxTypeAlign) {
4855 std::string MaxTypeAlignStr = "-fmax-type-align=16";
4856 CmdArgs.push_back(Args.MakeArgString(MaxTypeAlignStr));
4857 }
4858 }
4859
John Brawna7b4ec02015-08-10 11:11:28 +00004860 // -fcommon is the default unless compiling kernel code or the target says so
4861 bool NoCommonDefault =
4862 KernelOrKext || isNoCommonDefault(getToolChain().getTriple());
4863 if (!Args.hasFlag(options::OPT_fcommon, options::OPT_fno_common,
4864 !NoCommonDefault))
Daniel Dunbard18049a2009-04-07 21:16:11 +00004865 CmdArgs.push_back("-fno-common");
4866
Daniel Dunbar2edd9232009-04-15 02:37:43 +00004867 // -fsigned-bitfields is default, and clang doesn't yet support
Daniel Dunbar6358d682010-10-15 22:30:42 +00004868 // -funsigned-bitfields.
Mike Stump11289f42009-09-09 15:08:12 +00004869 if (!Args.hasFlag(options::OPT_fsigned_bitfields,
Daniel Dunbar2edd9232009-04-15 02:37:43 +00004870 options::OPT_funsigned_bitfields))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004871 D.Diag(diag::warn_drv_clang_unsupported)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004872 << Args.getLastArg(options::OPT_funsigned_bitfields)->getAsString(Args);
Daniel Dunbar2edd9232009-04-15 02:37:43 +00004873
Daniel Dunbar6358d682010-10-15 22:30:42 +00004874 // -fsigned-bitfields is default, and clang doesn't support -fno-for-scope.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004875 if (!Args.hasFlag(options::OPT_ffor_scope, options::OPT_fno_for_scope))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004876 D.Diag(diag::err_drv_clang_unsupported)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004877 << Args.getLastArg(options::OPT_fno_for_scope)->getAsString(Args);
Daniel Dunbar6358d682010-10-15 22:30:42 +00004878
Sylvestre Ledru91f380a2014-07-01 17:24:27 +00004879 // -finput_charset=UTF-8 is default. Reject others
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004880 if (Arg *inputCharset = Args.getLastArg(options::OPT_finput_charset_EQ)) {
4881 StringRef value = inputCharset->getValue();
4882 if (value != "UTF-8")
4883 D.Diag(diag::err_drv_invalid_value) << inputCharset->getAsString(Args)
4884 << value;
Sylvestre Ledru91f380a2014-07-01 17:24:27 +00004885 }
4886
Sylvestre Ledrub8198f0222014-08-11 18:09:03 +00004887 // -fexec_charset=UTF-8 is default. Reject others
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004888 if (Arg *execCharset = Args.getLastArg(options::OPT_fexec_charset_EQ)) {
4889 StringRef value = execCharset->getValue();
4890 if (value != "UTF-8")
4891 D.Diag(diag::err_drv_invalid_value) << execCharset->getAsString(Args)
4892 << value;
Sylvestre Ledrub8198f0222014-08-11 18:09:03 +00004893 }
4894
Jeffrey Yasskin460aa542010-06-08 04:56:20 +00004895 // -fcaret-diagnostics is default.
4896 if (!Args.hasFlag(options::OPT_fcaret_diagnostics,
4897 options::OPT_fno_caret_diagnostics, true))
4898 CmdArgs.push_back("-fno-caret-diagnostics");
4899
Daniel Dunbar8281bde2009-04-19 21:09:34 +00004900 // -fdiagnostics-fixit-info is default, only pass non-default.
Mike Stump11289f42009-09-09 15:08:12 +00004901 if (!Args.hasFlag(options::OPT_fdiagnostics_fixit_info,
Daniel Dunbar8281bde2009-04-19 21:09:34 +00004902 options::OPT_fno_diagnostics_fixit_info))
4903 CmdArgs.push_back("-fno-diagnostics-fixit-info");
Eric Christopher84fbdb42011-08-19 00:30:14 +00004904
Daniel Dunbar092f0cc2009-04-16 06:32:38 +00004905 // Enable -fdiagnostics-show-option by default.
Mike Stump11289f42009-09-09 15:08:12 +00004906 if (Args.hasFlag(options::OPT_fdiagnostics_show_option,
Daniel Dunbar092f0cc2009-04-16 06:32:38 +00004907 options::OPT_fno_diagnostics_show_option))
4908 CmdArgs.push_back("-fdiagnostics-show-option");
Daniel Dunbar5ec95022009-11-04 06:24:57 +00004909
Chris Lattnerbf6fac82010-05-04 21:55:25 +00004910 if (const Arg *A =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004911 Args.getLastArg(options::OPT_fdiagnostics_show_category_EQ)) {
Chris Lattnerbf6fac82010-05-04 21:55:25 +00004912 CmdArgs.push_back("-fdiagnostics-show-category");
Richard Smithbd55daf2012-11-01 04:30:05 +00004913 CmdArgs.push_back(A->getValue());
Chris Lattnerbf6fac82010-05-04 21:55:25 +00004914 }
Daniel Dunbarfe6c97b2010-08-24 16:47:49 +00004915
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004916 if (const Arg *A = Args.getLastArg(options::OPT_fdiagnostics_format_EQ)) {
Douglas Gregor643c9222011-05-21 17:07:29 +00004917 CmdArgs.push_back("-fdiagnostics-format");
Richard Smithbd55daf2012-11-01 04:30:05 +00004918 CmdArgs.push_back(A->getValue());
Douglas Gregor643c9222011-05-21 17:07:29 +00004919 }
4920
Chandler Carruthb6766f02011-03-27 01:50:55 +00004921 if (Arg *A = Args.getLastArg(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004922 options::OPT_fdiagnostics_show_note_include_stack,
4923 options::OPT_fno_diagnostics_show_note_include_stack)) {
Chandler Carruthb6766f02011-03-27 01:50:55 +00004924 if (A->getOption().matches(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004925 options::OPT_fdiagnostics_show_note_include_stack))
Chandler Carruthb6766f02011-03-27 01:50:55 +00004926 CmdArgs.push_back("-fdiagnostics-show-note-include-stack");
4927 else
4928 CmdArgs.push_back("-fno-diagnostics-show-note-include-stack");
4929 }
4930
Daniel Dunbar5ec95022009-11-04 06:24:57 +00004931 // Color diagnostics are the default, unless the terminal doesn't support
4932 // them.
Nico Weber7e2da792013-04-17 21:52:44 +00004933 // Support both clang's -f[no-]color-diagnostics and gcc's
4934 // -f[no-]diagnostics-colors[=never|always|auto].
4935 enum { Colors_On, Colors_Off, Colors_Auto } ShowColors = Colors_Auto;
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00004936 for (const auto &Arg : Args) {
4937 const Option &O = Arg->getOption();
Nico Weber7e2da792013-04-17 21:52:44 +00004938 if (!O.matches(options::OPT_fcolor_diagnostics) &&
4939 !O.matches(options::OPT_fdiagnostics_color) &&
4940 !O.matches(options::OPT_fno_color_diagnostics) &&
4941 !O.matches(options::OPT_fno_diagnostics_color) &&
4942 !O.matches(options::OPT_fdiagnostics_color_EQ))
4943 continue;
4944
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00004945 Arg->claim();
Nico Weber7e2da792013-04-17 21:52:44 +00004946 if (O.matches(options::OPT_fcolor_diagnostics) ||
4947 O.matches(options::OPT_fdiagnostics_color)) {
4948 ShowColors = Colors_On;
4949 } else if (O.matches(options::OPT_fno_color_diagnostics) ||
4950 O.matches(options::OPT_fno_diagnostics_color)) {
4951 ShowColors = Colors_Off;
4952 } else {
4953 assert(O.matches(options::OPT_fdiagnostics_color_EQ));
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00004954 StringRef value(Arg->getValue());
Nico Weber7e2da792013-04-17 21:52:44 +00004955 if (value == "always")
4956 ShowColors = Colors_On;
4957 else if (value == "never")
4958 ShowColors = Colors_Off;
4959 else if (value == "auto")
4960 ShowColors = Colors_Auto;
4961 else
4962 getToolChain().getDriver().Diag(diag::err_drv_clang_unsupported)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004963 << ("-fdiagnostics-color=" + value).str();
Nico Weber7e2da792013-04-17 21:52:44 +00004964 }
4965 }
4966 if (ShowColors == Colors_On ||
4967 (ShowColors == Colors_Auto && llvm::sys::Process::StandardErrHasColors()))
Daniel Dunbar5ec95022009-11-04 06:24:57 +00004968 CmdArgs.push_back("-fcolor-diagnostics");
4969
Nico Rieck7857d462013-09-11 00:38:02 +00004970 if (Args.hasArg(options::OPT_fansi_escape_codes))
4971 CmdArgs.push_back("-fansi-escape-codes");
4972
Daniel Dunbardb097022009-06-08 21:13:54 +00004973 if (!Args.hasFlag(options::OPT_fshow_source_location,
4974 options::OPT_fno_show_source_location))
4975 CmdArgs.push_back("-fno-show-source-location");
Daniel Dunbar092f0cc2009-04-16 06:32:38 +00004976
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004977 if (!Args.hasFlag(options::OPT_fshow_column, options::OPT_fno_show_column,
Douglas Gregor643c9222011-05-21 17:07:29 +00004978 true))
4979 CmdArgs.push_back("-fno-show-column");
4980
Douglas Gregor8ed0c0b2010-07-09 17:35:33 +00004981 if (!Args.hasFlag(options::OPT_fspell_checking,
4982 options::OPT_fno_spell_checking))
4983 CmdArgs.push_back("-fno-spell-checking");
Daniel Dunbarfe6c97b2010-08-24 16:47:49 +00004984
Chad Rosierc8e56e82012-12-05 21:08:21 +00004985 // -fno-asm-blocks is default.
4986 if (Args.hasFlag(options::OPT_fasm_blocks, options::OPT_fno_asm_blocks,
4987 false))
4988 CmdArgs.push_back("-fasm-blocks");
Daniel Dunbar473f8a62010-10-18 22:49:46 +00004989
Steven Wucb0d13f2015-01-16 23:05:28 +00004990 // -fgnu-inline-asm is default.
4991 if (!Args.hasFlag(options::OPT_fgnu_inline_asm,
4992 options::OPT_fno_gnu_inline_asm, true))
4993 CmdArgs.push_back("-fno-gnu-inline-asm");
4994
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00004995 // Enable vectorization per default according to the optimization level
4996 // selected. For optimization levels that want vectorization we use the alias
4997 // option to simplify the hasFlag logic.
Chad Rosier3ba81bd2014-05-02 18:41:57 +00004998 bool EnableVec = shouldEnableVectorizerAtOLevel(Args, false);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004999 OptSpecifier VectorizeAliasOption =
5000 EnableVec ? options::OPT_O_Group : options::OPT_fvectorize;
Chad Rosier679b0752013-04-24 18:29:59 +00005001 if (Args.hasFlag(options::OPT_fvectorize, VectorizeAliasOption,
Hal Finkel108c46a2013-08-28 05:21:45 +00005002 options::OPT_fno_vectorize, EnableVec))
Chad Rosier0d3ed6f2012-12-11 17:12:28 +00005003 CmdArgs.push_back("-vectorize-loops");
Chad Rosier0d3ed6f2012-12-11 17:12:28 +00005004
Chad Rosier136d67d2014-04-28 19:30:57 +00005005 // -fslp-vectorize is enabled based on the optimization level selected.
Chad Rosier3ba81bd2014-05-02 18:41:57 +00005006 bool EnableSLPVec = shouldEnableVectorizerAtOLevel(Args, true);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005007 OptSpecifier SLPVectAliasOption =
5008 EnableSLPVec ? options::OPT_O_Group : options::OPT_fslp_vectorize;
Chad Rosier136d67d2014-04-28 19:30:57 +00005009 if (Args.hasFlag(options::OPT_fslp_vectorize, SLPVectAliasOption,
Chad Rosier3ba81bd2014-05-02 18:41:57 +00005010 options::OPT_fno_slp_vectorize, EnableSLPVec))
Nadav Rotem0a2604d2013-04-15 04:57:18 +00005011 CmdArgs.push_back("-vectorize-slp");
Hal Finkel061f1652012-12-11 19:59:32 +00005012
Nadav Rotem6a0dd6b2013-04-15 05:38:41 +00005013 // -fno-slp-vectorize-aggressive is default.
5014 if (Args.hasFlag(options::OPT_fslp_vectorize_aggressive,
Nick Lewyckyd3f3e4f2013-06-25 01:49:44 +00005015 options::OPT_fno_slp_vectorize_aggressive, false))
Nadav Rotem6a0dd6b2013-04-15 05:38:41 +00005016 CmdArgs.push_back("-vectorize-slp-aggressive");
Nadav Rotem6a0dd6b2013-04-15 05:38:41 +00005017
Jeffrey Yasskin2b99c6f2010-06-11 05:57:47 +00005018 if (Arg *A = Args.getLastArg(options::OPT_fshow_overloads_EQ))
5019 A->render(Args, CmdArgs);
5020
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00005021 // -fdollars-in-identifiers default varies depending on platform and
5022 // language; only pass if specified.
Mike Stump11289f42009-09-09 15:08:12 +00005023 if (Arg *A = Args.getLastArg(options::OPT_fdollars_in_identifiers,
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00005024 options::OPT_fno_dollars_in_identifiers)) {
5025 if (A->getOption().matches(options::OPT_fdollars_in_identifiers))
Daniel Dunbar15cef0e2009-12-16 20:10:18 +00005026 CmdArgs.push_back("-fdollars-in-identifiers");
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00005027 else
Daniel Dunbar15cef0e2009-12-16 20:10:18 +00005028 CmdArgs.push_back("-fno-dollars-in-identifiers");
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00005029 }
5030
Daniel Dunbaradeeb052009-05-22 19:02:20 +00005031 // -funit-at-a-time is default, and we don't support -fno-unit-at-a-time for
5032 // practical purposes.
Mike Stump11289f42009-09-09 15:08:12 +00005033 if (Arg *A = Args.getLastArg(options::OPT_funit_at_a_time,
Daniel Dunbaradeeb052009-05-22 19:02:20 +00005034 options::OPT_fno_unit_at_a_time)) {
5035 if (A->getOption().matches(options::OPT_fno_unit_at_a_time))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00005036 D.Diag(diag::warn_drv_clang_unsupported) << A->getAsString(Args);
Daniel Dunbaradeeb052009-05-22 19:02:20 +00005037 }
Eli Friedmanbb0d9a52009-07-14 21:58:17 +00005038
Eli Friedman055c9702011-11-02 01:53:16 +00005039 if (Args.hasFlag(options::OPT_fapple_pragma_pack,
5040 options::OPT_fno_apple_pragma_pack, false))
5041 CmdArgs.push_back("-fapple-pragma-pack");
5042
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005043 // le32-specific flags:
Eli Benderskyc95cfe82013-07-24 18:20:14 +00005044 // -fno-math-builtin: clang should not convert math builtins to intrinsics
5045 // by default.
5046 if (getToolChain().getArch() == llvm::Triple::le32) {
5047 CmdArgs.push_back("-fno-math-builtin");
5048 }
5049
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005050// Default to -fno-builtin-str{cat,cpy} on Darwin for ARM.
5051//
5052// FIXME: This is disabled until clang -cc1 supports -fno-builtin-foo. PR4941.
Daniel Dunbar4fa08112009-09-10 04:57:27 +00005053#if 0
Bob Wilson6524dd32011-10-14 05:03:44 +00005054 if (getToolChain().getTriple().isOSDarwin() &&
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00005055 (getToolChain().getArch() == llvm::Triple::arm ||
5056 getToolChain().getArch() == llvm::Triple::thumb)) {
Daniel Dunbar2ffe0292009-09-10 03:37:02 +00005057 if (!Args.hasArg(options::OPT_fbuiltin_strcat))
5058 CmdArgs.push_back("-fno-builtin-strcat");
5059 if (!Args.hasArg(options::OPT_fbuiltin_strcpy))
5060 CmdArgs.push_back("-fno-builtin-strcpy");
5061 }
Daniel Dunbar4fa08112009-09-10 04:57:27 +00005062#endif
Daniel Dunbar2ffe0292009-09-10 03:37:02 +00005063
Justin Bognera88f0122014-06-20 22:59:50 +00005064 // Enable rewrite includes if the user's asked for it or if we're generating
5065 // diagnostics.
5066 // TODO: Once -module-dependency-dir works with -frewrite-includes it'd be
5067 // nice to enable this when doing a crashdump for modules as well.
Justin Bogner332a5e52014-06-20 22:16:00 +00005068 if (Args.hasFlag(options::OPT_frewrite_includes,
5069 options::OPT_fno_rewrite_includes, false) ||
Justin Bognera88f0122014-06-20 22:59:50 +00005070 (C.isForDiagnostics() && !HaveModules))
Justin Bogner332a5e52014-06-20 22:16:00 +00005071 CmdArgs.push_back("-frewrite-includes");
5072
Daniel Dunbar8c3d7352011-03-18 21:23:40 +00005073 // Only allow -traditional or -traditional-cpp outside in preprocessing modes.
Mike Stump11289f42009-09-09 15:08:12 +00005074 if (Arg *A = Args.getLastArg(options::OPT_traditional,
Daniel Dunbar8c3d7352011-03-18 21:23:40 +00005075 options::OPT_traditional_cpp)) {
5076 if (isa<PreprocessJobAction>(JA))
5077 CmdArgs.push_back("-traditional-cpp");
Eric Christopher84fbdb42011-08-19 00:30:14 +00005078 else
Chris Lattner0e62c1c2011-07-23 10:55:15 +00005079 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
Daniel Dunbar8c3d7352011-03-18 21:23:40 +00005080 }
Eli Friedmanbb0d9a52009-07-14 21:58:17 +00005081
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005082 Args.AddLastArg(CmdArgs, options::OPT_dM);
Chris Lattnercac63f32009-04-12 01:56:53 +00005083 Args.AddLastArg(CmdArgs, options::OPT_dD);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005084
Ted Kremeneke73d9ed2011-11-11 00:07:43 +00005085 // Handle serialized diagnostics.
5086 if (Arg *A = Args.getLastArg(options::OPT__serialize_diags)) {
5087 CmdArgs.push_back("-serialize-diagnostic-file");
Richard Smithbd55daf2012-11-01 04:30:05 +00005088 CmdArgs.push_back(Args.MakeArgString(A->getValue()));
Ted Kremeneke73d9ed2011-11-11 00:07:43 +00005089 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005090
Ted Kremenekb47e6bc2012-09-13 06:41:18 +00005091 if (Args.hasArg(options::OPT_fretain_comments_from_system_headers))
5092 CmdArgs.push_back("-fretain-comments-from-system-headers");
5093
Dmitri Gribenkoacf2e782013-02-22 14:21:27 +00005094 // Forward -fcomment-block-commands to -cc1.
5095 Args.AddAllArgs(CmdArgs, options::OPT_fcomment_block_commands);
Dmitri Gribenkoa7d16ce2013-04-10 15:35:17 +00005096 // Forward -fparse-all-comments to -cc1.
5097 Args.AddAllArgs(CmdArgs, options::OPT_fparse_all_comments);
Dmitri Gribenkoacf2e782013-02-22 14:21:27 +00005098
John Brawnad31ace2015-09-23 13:55:40 +00005099 // Turn -fplugin=name.so into -load name.so
5100 for (const Arg *A : Args.filtered(options::OPT_fplugin_EQ)) {
5101 CmdArgs.push_back("-load");
5102 CmdArgs.push_back(A->getValue());
5103 A->claim();
5104 }
5105
Daniel Dunbar76fa8402010-04-15 06:09:03 +00005106 // Forward -Xclang arguments to -cc1, and -mllvm arguments to the LLVM option
5107 // parser.
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005108 Args.AddAllArgValues(CmdArgs, options::OPT_Xclang);
Sean Silva14facf32015-06-09 01:57:17 +00005109 for (const Arg *A : Args.filtered(options::OPT_mllvm)) {
5110 A->claim();
Daniel Dunbar88534f42010-04-17 06:10:00 +00005111
Daniel Dunbar76fa8402010-04-15 06:09:03 +00005112 // We translate this by hand to the -cc1 argument, since nightly test uses
5113 // it and developers have been trained to spell it with -mllvm.
Sean Silva14facf32015-06-09 01:57:17 +00005114 if (StringRef(A->getValue(0)) == "-disable-llvm-optzns") {
Daniel Dunbar76fa8402010-04-15 06:09:03 +00005115 CmdArgs.push_back("-disable-llvm-optzns");
Bob Wilson23a55f12014-12-21 07:00:00 +00005116 } else
Sean Silva14facf32015-06-09 01:57:17 +00005117 A->render(Args, CmdArgs);
Daniel Dunbar76fa8402010-04-15 06:09:03 +00005118 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005119
Bob Wilson23a55f12014-12-21 07:00:00 +00005120 // With -save-temps, we want to save the unoptimized bitcode output from the
Steven Wu546a1962015-07-17 20:09:56 +00005121 // CompileJobAction, use -disable-llvm-passes to get pristine IR generated
5122 // by the frontend.
5123 if (C.getDriver().isSaveTempsEnabled() && isa<CompileJobAction>(JA))
5124 CmdArgs.push_back("-disable-llvm-passes");
Bob Wilson23a55f12014-12-21 07:00:00 +00005125
Daniel Dunbard67a3222009-03-30 06:36:42 +00005126 if (Output.getType() == types::TY_Dependencies) {
5127 // Handled with other dependency code.
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005128 } else if (Output.isFilename()) {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005129 CmdArgs.push_back("-o");
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005130 CmdArgs.push_back(Output.getFilename());
5131 } else {
5132 assert(Output.isNothing() && "Invalid output.");
Daniel Dunbara3246a02009-03-18 08:07:30 +00005133 }
5134
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005135 addDashXForInput(Args, Input, CmdArgs);
Ben Langmuir2cb4a782014-02-05 22:21:15 +00005136
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005137 if (Input.isFilename())
5138 CmdArgs.push_back(Input.getFilename());
5139 else
5140 Input.getInputArg().renderAsInput(Args, CmdArgs);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00005141
Chris Lattnere9d7d782009-11-03 19:50:27 +00005142 Args.AddAllArgs(CmdArgs, options::OPT_undef);
5143
Daniel Dunbarb31b76f2010-07-18 21:16:15 +00005144 const char *Exec = getToolChain().getDriver().getClangProgramPath();
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005145
5146 // Optionally embed the -cc1 level arguments into the debug info, for build
5147 // analysis.
5148 if (getToolChain().UseDwarfDebugFlags()) {
Daniel Dunbar7f3d9502010-06-04 18:47:06 +00005149 ArgStringList OriginalArgs;
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005150 for (const auto &Arg : Args)
5151 Arg->render(Args, OriginalArgs);
Daniel Dunbarfe6c97b2010-08-24 16:47:49 +00005152
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +00005153 SmallString<256> Flags;
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005154 Flags += Exec;
Douglas Katzman6bbffc42015-06-25 18:51:37 +00005155 for (const char *OriginalArg : OriginalArgs) {
Bob Wilsond5aad2a2014-11-04 22:28:48 +00005156 SmallString<128> EscapedArg;
Douglas Katzman6bbffc42015-06-25 18:51:37 +00005157 EscapeSpacesAndBackslashes(OriginalArg, EscapedArg);
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005158 Flags += " ";
Bob Wilsond5aad2a2014-11-04 22:28:48 +00005159 Flags += EscapedArg;
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005160 }
5161 CmdArgs.push_back("-dwarf-debug-flags");
Yaron Keren92e1b622015-03-18 10:17:07 +00005162 CmdArgs.push_back(Args.MakeArgString(Flags));
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005163 }
5164
Eric Christopherd3804002013-02-22 20:12:52 +00005165 // Add the split debug info name to the command lines here so we
5166 // can propagate it to the backend.
David Blaikiece3e7a62015-07-30 21:42:22 +00005167 bool SplitDwarf = SplitDwarfArg && getToolChain().getTriple().isOSLinux() &&
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005168 (isa<AssembleJobAction>(JA) || isa<CompileJobAction>(JA) ||
5169 isa<BackendJobAction>(JA));
Eric Christopherd3804002013-02-22 20:12:52 +00005170 const char *SplitDwarfOut;
5171 if (SplitDwarf) {
5172 CmdArgs.push_back("-split-dwarf-file");
Artem Belevichba558952015-05-06 18:20:23 +00005173 SplitDwarfOut = SplitDebugName(Args, Input);
Eric Christopherd3804002013-02-22 20:12:52 +00005174 CmdArgs.push_back(SplitDwarfOut);
5175 }
5176
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005177 // Host-side cuda compilation receives device-side outputs as Inputs[1...].
5178 // Include them with -fcuda-include-gpubinary.
5179 if (IsCuda && Inputs.size() > 1)
Artem Belevich5bde4e02015-07-20 20:02:54 +00005180 for (auto I = std::next(Inputs.begin()), E = Inputs.end(); I != E; ++I) {
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005181 CmdArgs.push_back("-fcuda-include-gpubinary");
Artem Belevich5bde4e02015-07-20 20:02:54 +00005182 CmdArgs.push_back(I->getFilename());
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005183 }
5184
Eric Christopherd3804002013-02-22 20:12:52 +00005185 // Finally add the compile command to the compilation.
Hans Wennborg859422a2014-01-13 22:24:42 +00005186 if (Args.hasArg(options::OPT__SLASH_fallback) &&
Hans Wennborg26a44302014-04-25 16:44:17 +00005187 Output.getType() == types::TY_Object &&
5188 (InputType == types::TY_C || InputType == types::TY_CXX)) {
David Blaikiec11bf802014-09-04 16:04:28 +00005189 auto CLCommand =
5190 getCLFallback()->GetCommand(C, JA, Output, Inputs, Args, LinkingOutput);
Justin Bognerd3371d82015-07-17 03:35:54 +00005191 C.addCommand(llvm::make_unique<FallbackCommand>(
5192 JA, *this, Exec, CmdArgs, Inputs, std::move(CLCommand)));
Hans Wennborg87cfa712013-09-19 20:32:16 +00005193 } else {
Justin Bognerd3371d82015-07-17 03:35:54 +00005194 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Hans Wennborg87cfa712013-09-19 20:32:16 +00005195 }
5196
Eric Christopherf1545832013-02-22 23:50:16 +00005197 // Handle the debug info splitting at object creation time if we're
5198 // creating an object.
Eric Christopher248357f2013-02-21 22:35:01 +00005199 // TODO: Currently only works on linux with newer objcopy.
Bob Wilson23a55f12014-12-21 07:00:00 +00005200 if (SplitDwarf && !isa<CompileJobAction>(JA) && !isa<BackendJobAction>(JA))
Eric Christopherd3804002013-02-22 20:12:52 +00005201 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output, SplitDwarfOut);
Eric Christopher248357f2013-02-21 22:35:01 +00005202
Roman Divacky178e01602011-02-10 16:52:03 +00005203 if (Arg *A = Args.getLastArg(options::OPT_pg))
5204 if (Args.hasArg(options::OPT_fomit_frame_pointer))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005205 D.Diag(diag::err_drv_argument_not_allowed_with) << "-fomit-frame-pointer"
5206 << A->getAsString(Args);
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00005207
Daniel Dunbarc2a71892009-04-03 20:51:31 +00005208 // Claim some arguments which clang supports automatically.
5209
Daniel Dunbar3e0cac62010-04-15 06:18:42 +00005210 // -fpch-preprocess is used with gcc to add a special marker in the output to
5211 // include the PCH file. Clang's PTH solution is completely transparent, so we
5212 // do not need to deal with it at all.
Daniel Dunbarc2a71892009-04-03 20:51:31 +00005213 Args.ClaimAllArgs(options::OPT_fpch_preprocess);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00005214
Daniel Dunbar17731772009-03-23 19:03:36 +00005215 // Claim some arguments which clang doesn't support, but we don't
5216 // care to warn the user about.
Daniel Dunbar44b36ee2009-11-25 11:53:23 +00005217 Args.ClaimAllArgs(options::OPT_clang_ignored_f_Group);
5218 Args.ClaimAllArgs(options::OPT_clang_ignored_m_Group);
Rafael Espindola22f603032011-02-28 23:29:45 +00005219
Rafael Espindolab0092d72013-09-04 19:37:35 +00005220 // Disable warnings for clang -E -emit-llvm foo.c
Rafael Espindolad95a8122011-03-01 05:25:27 +00005221 Args.ClaimAllArgs(options::OPT_emit_llvm);
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005222}
5223
John McCall5fb5df92012-06-20 06:18:46 +00005224/// Add options related to the Objective-C runtime/ABI.
5225///
5226/// Returns true if the runtime is non-fragile.
5227ObjCRuntime Clang::AddObjCRuntimeArgs(const ArgList &args,
5228 ArgStringList &cmdArgs,
5229 RewriteKind rewriteKind) const {
5230 // Look for the controlling runtime option.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005231 Arg *runtimeArg =
5232 args.getLastArg(options::OPT_fnext_runtime, options::OPT_fgnu_runtime,
5233 options::OPT_fobjc_runtime_EQ);
John McCall5fb5df92012-06-20 06:18:46 +00005234
5235 // Just forward -fobjc-runtime= to the frontend. This supercedes
5236 // options about fragility.
5237 if (runtimeArg &&
5238 runtimeArg->getOption().matches(options::OPT_fobjc_runtime_EQ)) {
5239 ObjCRuntime runtime;
Richard Smithbd55daf2012-11-01 04:30:05 +00005240 StringRef value = runtimeArg->getValue();
John McCall5fb5df92012-06-20 06:18:46 +00005241 if (runtime.tryParse(value)) {
5242 getToolChain().getDriver().Diag(diag::err_drv_unknown_objc_runtime)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005243 << value;
John McCall5fb5df92012-06-20 06:18:46 +00005244 }
5245
5246 runtimeArg->render(args, cmdArgs);
5247 return runtime;
5248 }
5249
5250 // Otherwise, we'll need the ABI "version". Version numbers are
5251 // slightly confusing for historical reasons:
5252 // 1 - Traditional "fragile" ABI
5253 // 2 - Non-fragile ABI, version 1
5254 // 3 - Non-fragile ABI, version 2
5255 unsigned objcABIVersion = 1;
5256 // If -fobjc-abi-version= is present, use that to set the version.
5257 if (Arg *abiArg = args.getLastArg(options::OPT_fobjc_abi_version_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00005258 StringRef value = abiArg->getValue();
John McCall5fb5df92012-06-20 06:18:46 +00005259 if (value == "1")
5260 objcABIVersion = 1;
5261 else if (value == "2")
5262 objcABIVersion = 2;
5263 else if (value == "3")
5264 objcABIVersion = 3;
5265 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005266 getToolChain().getDriver().Diag(diag::err_drv_clang_unsupported) << value;
John McCall5fb5df92012-06-20 06:18:46 +00005267 } else {
5268 // Otherwise, determine if we are using the non-fragile ABI.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005269 bool nonFragileABIIsDefault =
5270 (rewriteKind == RK_NonFragile ||
5271 (rewriteKind == RK_None &&
5272 getToolChain().IsObjCNonFragileABIDefault()));
John McCall5fb5df92012-06-20 06:18:46 +00005273 if (args.hasFlag(options::OPT_fobjc_nonfragile_abi,
5274 options::OPT_fno_objc_nonfragile_abi,
5275 nonFragileABIIsDefault)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005276// Determine the non-fragile ABI version to use.
John McCall5fb5df92012-06-20 06:18:46 +00005277#ifdef DISABLE_DEFAULT_NONFRAGILEABI_TWO
5278 unsigned nonFragileABIVersion = 1;
5279#else
5280 unsigned nonFragileABIVersion = 2;
5281#endif
5282
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005283 if (Arg *abiArg =
5284 args.getLastArg(options::OPT_fobjc_nonfragile_abi_version_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00005285 StringRef value = abiArg->getValue();
John McCall5fb5df92012-06-20 06:18:46 +00005286 if (value == "1")
5287 nonFragileABIVersion = 1;
5288 else if (value == "2")
5289 nonFragileABIVersion = 2;
5290 else
5291 getToolChain().getDriver().Diag(diag::err_drv_clang_unsupported)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005292 << value;
John McCall5fb5df92012-06-20 06:18:46 +00005293 }
5294
5295 objcABIVersion = 1 + nonFragileABIVersion;
5296 } else {
5297 objcABIVersion = 1;
5298 }
5299 }
5300
5301 // We don't actually care about the ABI version other than whether
5302 // it's non-fragile.
5303 bool isNonFragile = objcABIVersion != 1;
5304
5305 // If we have no runtime argument, ask the toolchain for its default runtime.
5306 // However, the rewriter only really supports the Mac runtime, so assume that.
5307 ObjCRuntime runtime;
5308 if (!runtimeArg) {
5309 switch (rewriteKind) {
5310 case RK_None:
5311 runtime = getToolChain().getDefaultObjCRuntime(isNonFragile);
5312 break;
5313 case RK_Fragile:
5314 runtime = ObjCRuntime(ObjCRuntime::FragileMacOSX, VersionTuple());
5315 break;
5316 case RK_NonFragile:
5317 runtime = ObjCRuntime(ObjCRuntime::MacOSX, VersionTuple());
5318 break;
5319 }
5320
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005321 // -fnext-runtime
John McCall5fb5df92012-06-20 06:18:46 +00005322 } else if (runtimeArg->getOption().matches(options::OPT_fnext_runtime)) {
5323 // On Darwin, make this use the default behavior for the toolchain.
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00005324 if (getToolChain().getTriple().isOSDarwin()) {
John McCall5fb5df92012-06-20 06:18:46 +00005325 runtime = getToolChain().getDefaultObjCRuntime(isNonFragile);
5326
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005327 // Otherwise, build for a generic macosx port.
John McCall5fb5df92012-06-20 06:18:46 +00005328 } else {
5329 runtime = ObjCRuntime(ObjCRuntime::MacOSX, VersionTuple());
5330 }
5331
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005332 // -fgnu-runtime
John McCall5fb5df92012-06-20 06:18:46 +00005333 } else {
5334 assert(runtimeArg->getOption().matches(options::OPT_fgnu_runtime));
David Chisnall314896c2012-07-04 10:37:03 +00005335 // Legacy behaviour is to target the gnustep runtime if we are i
5336 // non-fragile mode or the GCC runtime in fragile mode.
5337 if (isNonFragile)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005338 runtime = ObjCRuntime(ObjCRuntime::GNUstep, VersionTuple(1, 6));
David Chisnall314896c2012-07-04 10:37:03 +00005339 else
5340 runtime = ObjCRuntime(ObjCRuntime::GCC, VersionTuple());
John McCall5fb5df92012-06-20 06:18:46 +00005341 }
5342
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005343 cmdArgs.push_back(
5344 args.MakeArgString("-fobjc-runtime=" + runtime.getAsString()));
John McCall5fb5df92012-06-20 06:18:46 +00005345 return runtime;
5346}
5347
Reid Klecknerc542d372014-06-27 17:02:02 +00005348static bool maybeConsumeDash(const std::string &EH, size_t &I) {
5349 bool HaveDash = (I + 1 < EH.size() && EH[I + 1] == '-');
5350 I += HaveDash;
5351 return !HaveDash;
Chandler Carruth095b6962014-06-29 22:42:51 +00005352}
Reid Klecknerc542d372014-06-27 17:02:02 +00005353
5354struct EHFlags {
5355 EHFlags() : Synch(false), Asynch(false), NoExceptC(false) {}
5356 bool Synch;
5357 bool Asynch;
5358 bool NoExceptC;
5359};
5360
5361/// /EH controls whether to run destructor cleanups when exceptions are
5362/// thrown. There are three modifiers:
5363/// - s: Cleanup after "synchronous" exceptions, aka C++ exceptions.
5364/// - a: Cleanup after "asynchronous" exceptions, aka structured exceptions.
5365/// The 'a' modifier is unimplemented and fundamentally hard in LLVM IR.
5366/// - c: Assume that extern "C" functions are implicitly noexcept. This
5367/// modifier is an optimization, so we ignore it for now.
5368/// The default is /EHs-c-, meaning cleanups are disabled.
5369static EHFlags parseClangCLEHFlags(const Driver &D, const ArgList &Args) {
5370 EHFlags EH;
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00005371
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005372 std::vector<std::string> EHArgs =
5373 Args.getAllArgValues(options::OPT__SLASH_EH);
Reid Klecknerc542d372014-06-27 17:02:02 +00005374 for (auto EHVal : EHArgs) {
5375 for (size_t I = 0, E = EHVal.size(); I != E; ++I) {
5376 switch (EHVal[I]) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005377 case 'a':
5378 EH.Asynch = maybeConsumeDash(EHVal, I);
5379 continue;
5380 case 'c':
5381 EH.NoExceptC = maybeConsumeDash(EHVal, I);
5382 continue;
5383 case 's':
5384 EH.Synch = maybeConsumeDash(EHVal, I);
5385 continue;
5386 default:
5387 break;
Reid Klecknerc542d372014-06-27 17:02:02 +00005388 }
5389 D.Diag(clang::diag::err_drv_invalid_value) << "/EH" << EHVal;
5390 break;
5391 }
5392 }
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00005393
Reid Klecknerc542d372014-06-27 17:02:02 +00005394 return EH;
5395}
5396
Douglas Katzman3459ce22015-10-08 04:24:12 +00005397void Clang::AddClangCLArgs(const ArgList &Args, ArgStringList &CmdArgs,
5398 enum CodeGenOptions::DebugInfoKind *DebugInfoKind,
5399 bool *EmitCodeView) const {
Hans Wennborg75958c42013-08-08 00:17:41 +00005400 unsigned RTOptionID = options::OPT__SLASH_MT;
5401
Hans Wennborgf1a74252013-09-10 20:18:04 +00005402 if (Args.hasArg(options::OPT__SLASH_LDd))
5403 // The /LDd option implies /MTd. The dependent lib part can be overridden,
5404 // but defining _DEBUG is sticky.
5405 RTOptionID = options::OPT__SLASH_MTd;
5406
Hans Wennborg9cb7d9ba2013-09-18 22:26:39 +00005407 if (Arg *A = Args.getLastArg(options::OPT__SLASH_M_Group))
Hans Wennborg75958c42013-08-08 00:17:41 +00005408 RTOptionID = A->getOption().getID();
Hans Wennborgd9ad0682013-09-11 16:38:41 +00005409
David Majnemere2afb472015-07-24 06:49:13 +00005410 StringRef FlagForCRT;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005411 switch (RTOptionID) {
5412 case options::OPT__SLASH_MD:
5413 if (Args.hasArg(options::OPT__SLASH_LDd))
Hans Wennborg75958c42013-08-08 00:17:41 +00005414 CmdArgs.push_back("-D_DEBUG");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005415 CmdArgs.push_back("-D_MT");
5416 CmdArgs.push_back("-D_DLL");
David Majnemere2afb472015-07-24 06:49:13 +00005417 FlagForCRT = "--dependent-lib=msvcrt";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005418 break;
5419 case options::OPT__SLASH_MDd:
5420 CmdArgs.push_back("-D_DEBUG");
5421 CmdArgs.push_back("-D_MT");
5422 CmdArgs.push_back("-D_DLL");
David Majnemere2afb472015-07-24 06:49:13 +00005423 FlagForCRT = "--dependent-lib=msvcrtd";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005424 break;
5425 case options::OPT__SLASH_MT:
5426 if (Args.hasArg(options::OPT__SLASH_LDd))
Hans Wennborg75958c42013-08-08 00:17:41 +00005427 CmdArgs.push_back("-D_DEBUG");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005428 CmdArgs.push_back("-D_MT");
David Majnemere2afb472015-07-24 06:49:13 +00005429 FlagForCRT = "--dependent-lib=libcmt";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005430 break;
5431 case options::OPT__SLASH_MTd:
5432 CmdArgs.push_back("-D_DEBUG");
5433 CmdArgs.push_back("-D_MT");
David Majnemere2afb472015-07-24 06:49:13 +00005434 FlagForCRT = "--dependent-lib=libcmtd";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005435 break;
5436 default:
5437 llvm_unreachable("Unexpected option ID.");
Hans Wennborg75958c42013-08-08 00:17:41 +00005438 }
5439
David Majnemere2afb472015-07-24 06:49:13 +00005440 if (Args.hasArg(options::OPT__SLASH_Zl)) {
5441 CmdArgs.push_back("-D_VC_NODEFAULTLIB");
5442 } else {
5443 CmdArgs.push_back(FlagForCRT.data());
5444
5445 // This provides POSIX compatibility (maps 'open' to '_open'), which most
5446 // users want. The /Za flag to cl.exe turns this off, but it's not
5447 // implemented in clang.
5448 CmdArgs.push_back("--dependent-lib=oldnames");
5449 }
Hans Wennborg614f7072013-08-08 19:54:30 +00005450
Hans Wennborg8858a032014-07-21 23:42:07 +00005451 // Both /showIncludes and /E (and /EP) write to stdout. Allowing both
5452 // would produce interleaved output, so ignore /showIncludes in such cases.
5453 if (!Args.hasArg(options::OPT_E) && !Args.hasArg(options::OPT__SLASH_EP))
5454 if (Arg *A = Args.getLastArg(options::OPT_show_includes))
5455 A->render(Args, CmdArgs);
Hans Wennborg81f74482013-09-10 01:07:07 +00005456
David Majnemerf6072342014-07-01 22:24:56 +00005457 // This controls whether or not we emit RTTI data for polymorphic types.
5458 if (Args.hasFlag(options::OPT__SLASH_GR_, options::OPT__SLASH_GR,
5459 /*default=*/false))
5460 CmdArgs.push_back("-fno-rtti-data");
Hans Wennborg7b0dcef2014-02-25 18:36:22 +00005461
Reid Kleckner124955a2015-08-05 18:51:13 +00005462 // Emit CodeView if -Z7 is present.
Douglas Katzman3459ce22015-10-08 04:24:12 +00005463 *EmitCodeView = Args.hasArg(options::OPT__SLASH_Z7);
Reid Kleckner124955a2015-08-05 18:51:13 +00005464 bool EmitDwarf = Args.hasArg(options::OPT_gdwarf);
5465 // If we are emitting CV but not DWARF, don't build information that LLVM
5466 // can't yet process.
Douglas Katzman3459ce22015-10-08 04:24:12 +00005467 if (*EmitCodeView && !EmitDwarf)
5468 *DebugInfoKind = CodeGenOptions::DebugLineTablesOnly;
5469 if (*EmitCodeView)
Reid Kleckner124955a2015-08-05 18:51:13 +00005470 CmdArgs.push_back("-gcodeview");
5471
Reid Klecknerc542d372014-06-27 17:02:02 +00005472 const Driver &D = getToolChain().getDriver();
5473 EHFlags EH = parseClangCLEHFlags(D, Args);
5474 // FIXME: Do something with NoExceptC.
Reid Klecknerdeeddec2015-02-05 18:56:03 +00005475 if (EH.Synch || EH.Asynch) {
Reid Klecknerc542d372014-06-27 17:02:02 +00005476 CmdArgs.push_back("-fcxx-exceptions");
Reid Klecknerdeeddec2015-02-05 18:56:03 +00005477 CmdArgs.push_back("-fexceptions");
5478 }
Reid Klecknerc542d372014-06-27 17:02:02 +00005479
Hans Wennborge50cec32014-06-13 20:59:54 +00005480 // /EP should expand to -E -P.
5481 if (Args.hasArg(options::OPT__SLASH_EP)) {
5482 CmdArgs.push_back("-E");
5483 CmdArgs.push_back("-P");
5484 }
5485
David Majnemera5b195a2015-02-14 01:35:12 +00005486 unsigned VolatileOptionID;
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00005487 if (getToolChain().getArch() == llvm::Triple::x86_64 ||
5488 getToolChain().getArch() == llvm::Triple::x86)
David Majnemera5b195a2015-02-14 01:35:12 +00005489 VolatileOptionID = options::OPT__SLASH_volatile_ms;
5490 else
5491 VolatileOptionID = options::OPT__SLASH_volatile_iso;
5492
5493 if (Arg *A = Args.getLastArg(options::OPT__SLASH_volatile_Group))
5494 VolatileOptionID = A->getOption().getID();
5495
5496 if (VolatileOptionID == options::OPT__SLASH_volatile_ms)
5497 CmdArgs.push_back("-fms-volatile");
5498
David Majnemer86c318f2014-02-11 21:05:00 +00005499 Arg *MostGeneralArg = Args.getLastArg(options::OPT__SLASH_vmg);
5500 Arg *BestCaseArg = Args.getLastArg(options::OPT__SLASH_vmb);
5501 if (MostGeneralArg && BestCaseArg)
5502 D.Diag(clang::diag::err_drv_argument_not_allowed_with)
5503 << MostGeneralArg->getAsString(Args) << BestCaseArg->getAsString(Args);
5504
5505 if (MostGeneralArg) {
5506 Arg *SingleArg = Args.getLastArg(options::OPT__SLASH_vms);
5507 Arg *MultipleArg = Args.getLastArg(options::OPT__SLASH_vmm);
5508 Arg *VirtualArg = Args.getLastArg(options::OPT__SLASH_vmv);
5509
5510 Arg *FirstConflict = SingleArg ? SingleArg : MultipleArg;
5511 Arg *SecondConflict = VirtualArg ? VirtualArg : MultipleArg;
5512 if (FirstConflict && SecondConflict && FirstConflict != SecondConflict)
5513 D.Diag(clang::diag::err_drv_argument_not_allowed_with)
5514 << FirstConflict->getAsString(Args)
5515 << SecondConflict->getAsString(Args);
5516
5517 if (SingleArg)
5518 CmdArgs.push_back("-fms-memptr-rep=single");
5519 else if (MultipleArg)
5520 CmdArgs.push_back("-fms-memptr-rep=multiple");
5521 else
5522 CmdArgs.push_back("-fms-memptr-rep=virtual");
5523 }
5524
Reid Klecknerc0dca6d2014-02-12 23:50:26 +00005525 if (Arg *A = Args.getLastArg(options::OPT_vtordisp_mode_EQ))
5526 A->render(Args, CmdArgs);
5527
Hans Wennborg81f74482013-09-10 01:07:07 +00005528 if (!Args.hasArg(options::OPT_fdiagnostics_format_EQ)) {
5529 CmdArgs.push_back("-fdiagnostics-format");
Hans Wennborgf4aee182013-09-24 00:08:55 +00005530 if (Args.hasArg(options::OPT__SLASH_fallback))
5531 CmdArgs.push_back("msvc-fallback");
5532 else
5533 CmdArgs.push_back("msvc");
Hans Wennborg81f74482013-09-10 01:07:07 +00005534 }
Hans Wennborg75958c42013-08-08 00:17:41 +00005535}
5536
Douglas Katzman95354292015-06-23 20:42:09 +00005537visualstudio::Compiler *Clang::getCLFallback() const {
Hans Wennborg1da044a2014-06-26 19:59:02 +00005538 if (!CLFallback)
Douglas Katzman95354292015-06-23 20:42:09 +00005539 CLFallback.reset(new visualstudio::Compiler(getToolChain()));
Hans Wennborg1da044a2014-06-26 19:59:02 +00005540 return CLFallback.get();
5541}
5542
Daniel Sanders7f933f42015-01-30 17:35:23 +00005543void ClangAs::AddMIPSTargetArgs(const ArgList &Args,
5544 ArgStringList &CmdArgs) const {
5545 StringRef CPUName;
5546 StringRef ABIName;
5547 const llvm::Triple &Triple = getToolChain().getTriple();
5548 mips::getMipsCPUAndABI(Args, Triple, CPUName, ABIName);
5549
5550 CmdArgs.push_back("-target-abi");
5551 CmdArgs.push_back(ABIName.data());
5552}
5553
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005554void ClangAs::ConstructJob(Compilation &C, const JobAction &JA,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005555 const InputInfo &Output, const InputInfoList &Inputs,
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005556 const ArgList &Args,
5557 const char *LinkingOutput) const {
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005558 ArgStringList CmdArgs;
5559
5560 assert(Inputs.size() == 1 && "Unexpected number of inputs.");
5561 const InputInfo &Input = Inputs[0];
5562
James Y Knight2db38f32015-08-15 03:45:25 +00005563 std::string TripleStr =
5564 getToolChain().ComputeEffectiveClangTriple(Args, Input.getType());
5565 const llvm::Triple Triple(TripleStr);
5566
Rafael Espindolacfaadda2010-11-17 22:13:25 +00005567 // Don't warn about "clang -w -c foo.s"
5568 Args.ClaimAllArgs(options::OPT_w);
Rafael Espindolad95a8122011-03-01 05:25:27 +00005569 // and "clang -emit-llvm -c foo.s"
5570 Args.ClaimAllArgs(options::OPT_emit_llvm);
Rafael Espindolacfaadda2010-11-17 22:13:25 +00005571
Rafael Espindola577637a2015-01-03 00:06:04 +00005572 claimNoWarnArgs(Args);
Rafael Espindola16042fc2015-01-02 23:23:52 +00005573
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005574 // Invoke ourselves in -cc1as mode.
5575 //
5576 // FIXME: Implement custom jobs for internal actions.
5577 CmdArgs.push_back("-cc1as");
5578
5579 // Add the "effective" target triple.
5580 CmdArgs.push_back("-triple");
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005581 CmdArgs.push_back(Args.MakeArgString(TripleStr));
5582
5583 // Set the output mode, we currently only expect to be used as a real
5584 // assembler.
5585 CmdArgs.push_back("-filetype");
5586 CmdArgs.push_back("obj");
5587
Eric Christopher45f2e712012-12-18 00:31:10 +00005588 // Set the main file name, so that debug info works even with
5589 // -save-temps or preprocessed assembly.
5590 CmdArgs.push_back("-main-file-name");
Artem Belevichba558952015-05-06 18:20:23 +00005591 CmdArgs.push_back(Clang::getBaseInputName(Args, Input));
Eric Christopher45f2e712012-12-18 00:31:10 +00005592
Rafael Espindola22ce34a2013-08-20 22:12:08 +00005593 // Add the target cpu
Renato Golin7c542b42015-07-27 23:44:45 +00005594 std::string CPU = getCPUName(Args, Triple, /*FromAs*/ true);
Rafael Espindola22ce34a2013-08-20 22:12:08 +00005595 if (!CPU.empty()) {
5596 CmdArgs.push_back("-target-cpu");
5597 CmdArgs.push_back(Args.MakeArgString(CPU));
5598 }
5599
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00005600 // Add the target features
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00005601 getTargetFeatures(getToolChain(), Triple, Args, CmdArgs, true);
Jim Grosbach576452b2012-02-10 20:37:10 +00005602
Daniel Dunbar1d733e22011-03-17 17:37:29 +00005603 // Ignore explicit -force_cpusubtype_ALL option.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005604 (void)Args.hasArg(options::OPT_force__cpusubtype__ALL);
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005605
Jim Grosbachc78c2bc2015-06-23 18:20:13 +00005606 // Pass along any -I options so we get proper .include search paths.
5607 Args.AddAllArgs(CmdArgs, options::OPT_I_Group);
5608
Eric Christopherfc3ee562012-01-10 00:38:01 +00005609 // Determine the original source input.
5610 const Action *SourceAction = &JA;
5611 while (SourceAction->getKind() != Action::InputClass) {
5612 assert(!SourceAction->getInputs().empty() && "unexpected root action!");
5613 SourceAction = SourceAction->getInputs()[0];
5614 }
5615
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00005616 // Forward -g and handle debug info related flags, assuming we are dealing
5617 // with an actual assembly file.
Eric Christopherfc3ee562012-01-10 00:38:01 +00005618 if (SourceAction->getType() == types::TY_Asm ||
5619 SourceAction->getType() == types::TY_PP_Asm) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00005620 bool WantDebug = false;
5621 unsigned DwarfVersion = 0;
Eric Christopherfc3ee562012-01-10 00:38:01 +00005622 Args.ClaimAllArgs(options::OPT_g_Group);
Douglas Katzman3459ce22015-10-08 04:24:12 +00005623 if (Arg *A = Args.getLastArg(options::OPT_g_Group)) {
5624 WantDebug = !A->getOption().matches(options::OPT_g0);
5625 if (WantDebug) {
5626 if ((DwarfVersion = DwarfVersionNum(A->getSpelling())) == 0)
5627 DwarfVersion = getToolChain().GetDefaultDwarfVersion();
5628 }
5629 }
5630 RenderDebugEnablingArgs(Args, CmdArgs,
5631 (WantDebug ? CodeGenOptions::LimitedDebugInfo
5632 : CodeGenOptions::NoDebugInfo),
5633 DwarfVersion);
Oliver Stannard9b2a7d42014-05-19 13:39:13 +00005634
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00005635 // Add the -fdebug-compilation-dir flag if needed.
5636 addDebugCompDirArg(Args, CmdArgs);
Kevin Enderbyae2ec472013-01-17 21:38:06 +00005637
5638 // Set the AT_producer to the clang version when using the integrated
5639 // assembler on assembly source files.
5640 CmdArgs.push_back("-dwarf-debug-producer");
5641 CmdArgs.push_back(Args.MakeArgString(getClangFullVersion()));
Renato Golina74bbc72015-07-22 15:32:36 +00005642
5643 // And pass along -I options
5644 Args.AddAllArgs(CmdArgs, options::OPT_I);
Eric Christopherfc3ee562012-01-10 00:38:01 +00005645 }
Kevin Enderby292dc082011-12-22 19:31:58 +00005646
James Y Knight5bdf7ab2015-08-19 15:12:02 +00005647 // Handle -fPIC et al -- the relocation-model affects the assembler
5648 // for some targets.
5649 llvm::Reloc::Model RelocationModel;
5650 unsigned PICLevel;
5651 bool IsPIE;
5652 std::tie(RelocationModel, PICLevel, IsPIE) =
5653 ParsePICArgs(getToolChain(), Triple, Args);
5654
5655 const char *RMName = RelocationModelName(RelocationModel);
5656 if (RMName) {
5657 CmdArgs.push_back("-mrelocation-model");
5658 CmdArgs.push_back(RMName);
5659 }
5660
Kevin Enderby292dc082011-12-22 19:31:58 +00005661 // Optionally embed the -cc1as level arguments into the debug info, for build
5662 // analysis.
5663 if (getToolChain().UseDwarfDebugFlags()) {
5664 ArgStringList OriginalArgs;
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005665 for (const auto &Arg : Args)
5666 Arg->render(Args, OriginalArgs);
Kevin Enderby292dc082011-12-22 19:31:58 +00005667
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +00005668 SmallString<256> Flags;
Kevin Enderby292dc082011-12-22 19:31:58 +00005669 const char *Exec = getToolChain().getDriver().getClangProgramPath();
5670 Flags += Exec;
Douglas Katzman6bbffc42015-06-25 18:51:37 +00005671 for (const char *OriginalArg : OriginalArgs) {
Bob Wilsond5aad2a2014-11-04 22:28:48 +00005672 SmallString<128> EscapedArg;
Douglas Katzman6bbffc42015-06-25 18:51:37 +00005673 EscapeSpacesAndBackslashes(OriginalArg, EscapedArg);
Kevin Enderby292dc082011-12-22 19:31:58 +00005674 Flags += " ";
Bob Wilsond5aad2a2014-11-04 22:28:48 +00005675 Flags += EscapedArg;
Kevin Enderby292dc082011-12-22 19:31:58 +00005676 }
5677 CmdArgs.push_back("-dwarf-debug-flags");
Yaron Keren92e1b622015-03-18 10:17:07 +00005678 CmdArgs.push_back(Args.MakeArgString(Flags));
Kevin Enderby292dc082011-12-22 19:31:58 +00005679 }
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005680
5681 // FIXME: Add -static support, once we have it.
5682
Daniel Sanders7f933f42015-01-30 17:35:23 +00005683 // Add target specific flags.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005684 switch (getToolChain().getArch()) {
Daniel Sanders7f933f42015-01-30 17:35:23 +00005685 default:
5686 break;
5687
5688 case llvm::Triple::mips:
5689 case llvm::Triple::mipsel:
5690 case llvm::Triple::mips64:
5691 case llvm::Triple::mips64el:
5692 AddMIPSTargetArgs(Args, CmdArgs);
5693 break;
5694 }
5695
David Blaikie372d9502014-01-17 03:17:40 +00005696 // Consume all the warning flags. Usually this would be handled more
5697 // gracefully by -cc1 (warning about unknown warning flags, etc) but -cc1as
5698 // doesn't handle that so rather than warning about unused flags that are
5699 // actually used, we'll lie by omission instead.
5700 // FIXME: Stop lying and consume only the appropriate driver flags
Sean Silva14facf32015-06-09 01:57:17 +00005701 for (const Arg *A : Args.filtered(options::OPT_W_Group))
5702 A->claim();
David Blaikie372d9502014-01-17 03:17:40 +00005703
David Blaikie9260ed62013-07-25 21:19:01 +00005704 CollectArgsForIntegratedAssembler(C, Args, CmdArgs,
5705 getToolChain().getDriver());
5706
Daniel Dunbar252e8f92011-04-29 17:53:18 +00005707 Args.AddAllArgs(CmdArgs, options::OPT_mllvm);
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005708
5709 assert(Output.isFilename() && "Unexpected lipo output.");
5710 CmdArgs.push_back("-o");
5711 CmdArgs.push_back(Output.getFilename());
5712
Daniel Dunbarb440f562010-08-02 02:38:21 +00005713 assert(Input.isFilename() && "Invalid input.");
5714 CmdArgs.push_back(Input.getFilename());
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005715
Daniel Dunbarb31b76f2010-07-18 21:16:15 +00005716 const char *Exec = getToolChain().getDriver().getClangProgramPath();
Justin Bognerd3371d82015-07-17 03:35:54 +00005717 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eric Christophera75018a2013-04-10 21:30:40 +00005718
5719 // Handle the debug info splitting at object creation time if we're
5720 // creating an object.
5721 // TODO: Currently only works on linux with newer objcopy.
5722 if (Args.hasArg(options::OPT_gsplit_dwarf) &&
Cameron Esfahani556d91e2013-09-14 01:09:11 +00005723 getToolChain().getTriple().isOSLinux())
Eric Christophera75018a2013-04-10 21:30:40 +00005724 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output,
Artem Belevichba558952015-05-06 18:20:23 +00005725 SplitDebugName(Args, Input));
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005726}
5727
Reid Kleckner0290c9c2014-09-15 17:45:39 +00005728void GnuTool::anchor() {}
5729
Daniel Dunbara3246a02009-03-18 08:07:30 +00005730void gcc::Common::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbara3246a02009-03-18 08:07:30 +00005731 const InputInfo &Output,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005732 const InputInfoList &Inputs, const ArgList &Args,
Daniel Dunbara3246a02009-03-18 08:07:30 +00005733 const char *LinkingOutput) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00005734 const Driver &D = getToolChain().getDriver();
Daniel Dunbara3246a02009-03-18 08:07:30 +00005735 ArgStringList CmdArgs;
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005736
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005737 for (const auto &A : Args) {
Michael J. Spencer66e2b202012-10-19 22:37:06 +00005738 if (forwardToGCC(A->getOption())) {
Daniel Dunbar939c1212010-08-03 16:14:14 +00005739 // Don't forward any -g arguments to assembly steps.
5740 if (isa<AssembleJobAction>(JA) &&
5741 A->getOption().matches(options::OPT_g_Group))
5742 continue;
5743
NAKAMURA Takumi053704f2013-08-19 11:51:51 +00005744 // Don't forward any -W arguments to assembly and link steps.
5745 if ((isa<AssembleJobAction>(JA) || isa<LinkJobAction>(JA)) &&
5746 A->getOption().matches(options::OPT_W_Group))
5747 continue;
5748
Daniel Dunbar2da02722009-03-19 07:55:12 +00005749 // It is unfortunate that we have to claim here, as this means
5750 // we will basically never report anything interesting for
Daniel Dunbar5716d872009-05-02 21:41:52 +00005751 // platforms using a generic gcc, even if we are just using gcc
5752 // to get to the assembler.
Daniel Dunbar2da02722009-03-19 07:55:12 +00005753 A->claim();
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005754 A->render(Args, CmdArgs);
Daniel Dunbar2da02722009-03-19 07:55:12 +00005755 }
Daniel Dunbara3246a02009-03-18 08:07:30 +00005756 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00005757
Daniel Dunbar4e295052010-01-25 22:35:08 +00005758 RenderExtraToolArgs(JA, CmdArgs);
Daniel Dunbara3246a02009-03-18 08:07:30 +00005759
5760 // If using a driver driver, force the arch.
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00005761 if (getToolChain().getTriple().isOSDarwin()) {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005762 CmdArgs.push_back("-arch");
Rafael Espindolaed1233e2014-08-28 21:23:05 +00005763 CmdArgs.push_back(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005764 Args.MakeArgString(getToolChain().getDefaultUniversalArchName()));
Daniel Dunbara3246a02009-03-18 08:07:30 +00005765 }
5766
Daniel Dunbar5716d872009-05-02 21:41:52 +00005767 // Try to force gcc to match the tool chain we want, if we recognize
5768 // the arch.
Daniel Dunbar5bbebfe2009-05-22 02:21:04 +00005769 //
5770 // FIXME: The triple class should directly provide the information we want
5771 // here.
Douglas Katzman38857552015-08-20 18:32:26 +00005772 switch (getToolChain().getArch()) {
5773 default:
5774 break;
5775 case llvm::Triple::x86:
5776 case llvm::Triple::ppc:
Daniel Dunbar5716d872009-05-02 21:41:52 +00005777 CmdArgs.push_back("-m32");
Douglas Katzman38857552015-08-20 18:32:26 +00005778 break;
5779 case llvm::Triple::x86_64:
5780 case llvm::Triple::ppc64:
5781 case llvm::Triple::ppc64le:
Daniel Dunbar5716d872009-05-02 21:41:52 +00005782 CmdArgs.push_back("-m64");
Douglas Katzman38857552015-08-20 18:32:26 +00005783 break;
5784 case llvm::Triple::sparcel:
5785 CmdArgs.push_back("-EL");
5786 break;
5787 }
Daniel Dunbar5716d872009-05-02 21:41:52 +00005788
Daniel Dunbarb440f562010-08-02 02:38:21 +00005789 if (Output.isFilename()) {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005790 CmdArgs.push_back("-o");
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005791 CmdArgs.push_back(Output.getFilename());
5792 } else {
5793 assert(Output.isNothing() && "Unexpected output");
Daniel Dunbara3246a02009-03-18 08:07:30 +00005794 CmdArgs.push_back("-fsyntax-only");
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005795 }
Daniel Dunbara3246a02009-03-18 08:07:30 +00005796
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005797 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbara3246a02009-03-18 08:07:30 +00005798
5799 // Only pass -x if gcc will understand it; otherwise hope gcc
5800 // understands the suffix correctly. The main use case this would go
5801 // wrong in is for linker inputs if they happened to have an odd
5802 // suffix; really the only way to get this to happen is a command
5803 // like '-x foobar a.c' which will treat a.c like a linker input.
5804 //
5805 // FIXME: For the linker case specifically, can we safely convert
5806 // inputs into '-Wl,' options?
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005807 for (const auto &II : Inputs) {
Daniel Dunbar6cdf83c2009-09-01 16:57:46 +00005808 // Don't try to pass LLVM or AST inputs to a generic gcc.
Daniel Dunbar24e52992010-06-07 23:28:45 +00005809 if (II.getType() == types::TY_LLVM_IR || II.getType() == types::TY_LTO_IR ||
5810 II.getType() == types::TY_LLVM_BC || II.getType() == types::TY_LTO_BC)
Chris Lattner0e62c1c2011-07-23 10:55:15 +00005811 D.Diag(diag::err_drv_no_linker_llvm_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005812 << getToolChain().getTripleString();
Daniel Dunbar6cdf83c2009-09-01 16:57:46 +00005813 else if (II.getType() == types::TY_AST)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005814 D.Diag(diag::err_drv_no_ast_support) << getToolChain().getTripleString();
Douglas Gregorbf7fc9c2013-03-27 16:47:18 +00005815 else if (II.getType() == types::TY_ModuleFile)
5816 D.Diag(diag::err_drv_no_module_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005817 << getToolChain().getTripleString();
Daniel Dunbare3e263f2009-05-02 20:14:53 +00005818
Daniel Dunbara3246a02009-03-18 08:07:30 +00005819 if (types::canTypeBeUserSpecified(II.getType())) {
5820 CmdArgs.push_back("-x");
5821 CmdArgs.push_back(types::getTypeName(II.getType()));
5822 }
5823
Daniel Dunbarb440f562010-08-02 02:38:21 +00005824 if (II.isFilename())
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005825 CmdArgs.push_back(II.getFilename());
Daniel Dunbarf2476752010-09-25 18:10:05 +00005826 else {
5827 const Arg &A = II.getInputArg();
5828
5829 // Reverse translate some rewritten options.
5830 if (A.getOption().matches(options::OPT_Z_reserved_lib_stdcxx)) {
5831 CmdArgs.push_back("-lstdc++");
5832 continue;
5833 }
5834
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005835 // Don't render as input, we need gcc to do the translations.
Daniel Dunbarf2476752010-09-25 18:10:05 +00005836 A.render(Args, CmdArgs);
5837 }
Daniel Dunbara3246a02009-03-18 08:07:30 +00005838 }
5839
Dylan Noblesmith70e73a32011-04-09 13:31:59 +00005840 const std::string customGCCName = D.getCCCGenericGCCName();
5841 const char *GCCName;
5842 if (!customGCCName.empty())
5843 GCCName = customGCCName.c_str();
Hans Wennborg70850d82013-07-18 20:29:38 +00005844 else if (D.CCCIsCXX()) {
Dylan Noblesmith70e73a32011-04-09 13:31:59 +00005845 GCCName = "g++";
Dylan Noblesmith70e73a32011-04-09 13:31:59 +00005846 } else
5847 GCCName = "gcc";
5848
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005849 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath(GCCName));
Justin Bognerd3371d82015-07-17 03:35:54 +00005850 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005851}
5852
Douglas Katzman95354292015-06-23 20:42:09 +00005853void gcc::Preprocessor::RenderExtraToolArgs(const JobAction &JA,
5854 ArgStringList &CmdArgs) const {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005855 CmdArgs.push_back("-E");
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005856}
5857
Douglas Katzman95354292015-06-23 20:42:09 +00005858void gcc::Compiler::RenderExtraToolArgs(const JobAction &JA,
5859 ArgStringList &CmdArgs) const {
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00005860 const Driver &D = getToolChain().getDriver();
5861
Eric Christophercc7ff502015-01-29 00:56:17 +00005862 switch (JA.getType()) {
Daniel Dunbar4e295052010-01-25 22:35:08 +00005863 // If -flto, etc. are present then make sure not to force assembly output.
Eric Christophercc7ff502015-01-29 00:56:17 +00005864 case types::TY_LLVM_IR:
5865 case types::TY_LTO_IR:
5866 case types::TY_LLVM_BC:
5867 case types::TY_LTO_BC:
Daniel Dunbar4e295052010-01-25 22:35:08 +00005868 CmdArgs.push_back("-c");
Eric Christophercc7ff502015-01-29 00:56:17 +00005869 break;
5870 case types::TY_PP_Asm:
Daniel Dunbar4e295052010-01-25 22:35:08 +00005871 CmdArgs.push_back("-S");
Eric Christopher58c21992015-01-30 18:22:23 +00005872 break;
Eric Christophercc7ff502015-01-29 00:56:17 +00005873 case types::TY_Nothing:
5874 CmdArgs.push_back("-fsyntax-only");
5875 break;
5876 default:
5877 D.Diag(diag::err_drv_invalid_gcc_output_type) << getTypeName(JA.getType());
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00005878 }
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005879}
5880
Douglas Katzman95354292015-06-23 20:42:09 +00005881void gcc::Linker::RenderExtraToolArgs(const JobAction &JA,
5882 ArgStringList &CmdArgs) const {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005883 // The types are (hopefully) good enough.
5884}
5885
Tony Linthicum76329bf2011-12-12 21:14:55 +00005886// Hexagon tools start.
Douglas Katzman95354292015-06-23 20:42:09 +00005887void hexagon::Assembler::RenderExtraToolArgs(const JobAction &JA,
5888 ArgStringList &CmdArgs) const {}
5889void hexagon::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
5890 const InputInfo &Output,
5891 const InputInfoList &Inputs,
5892 const ArgList &Args,
5893 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00005894 claimNoWarnArgs(Args);
Tony Linthicum76329bf2011-12-12 21:14:55 +00005895
5896 const Driver &D = getToolChain().getDriver();
5897 ArgStringList CmdArgs;
5898
5899 std::string MarchString = "-march=";
Douglas Katzman54366072015-07-27 16:53:08 +00005900 MarchString += toolchains::HexagonToolChain::GetTargetCPU(Args);
Tony Linthicum76329bf2011-12-12 21:14:55 +00005901 CmdArgs.push_back(Args.MakeArgString(MarchString));
5902
5903 RenderExtraToolArgs(JA, CmdArgs);
5904
5905 if (Output.isFilename()) {
5906 CmdArgs.push_back("-o");
5907 CmdArgs.push_back(Output.getFilename());
5908 } else {
5909 assert(Output.isNothing() && "Unexpected output");
5910 CmdArgs.push_back("-fsyntax-only");
5911 }
5912
Douglas Katzman54366072015-07-27 16:53:08 +00005913 if (const char *v = toolchains::HexagonToolChain::GetSmallDataThreshold(Args))
Ikhlas Ajbar522e6192015-05-14 13:52:08 +00005914 CmdArgs.push_back(Args.MakeArgString(std::string("-G") + v));
Tony Linthicum76329bf2011-12-12 21:14:55 +00005915
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005916 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Matthew Curtise5df3812012-12-07 17:23:04 +00005917
Tony Linthicum76329bf2011-12-12 21:14:55 +00005918 // Only pass -x if gcc will understand it; otherwise hope gcc
5919 // understands the suffix correctly. The main use case this would go
5920 // wrong in is for linker inputs if they happened to have an odd
5921 // suffix; really the only way to get this to happen is a command
5922 // like '-x foobar a.c' which will treat a.c like a linker input.
5923 //
5924 // FIXME: For the linker case specifically, can we safely convert
5925 // inputs into '-Wl,' options?
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005926 for (const auto &II : Inputs) {
Tony Linthicum76329bf2011-12-12 21:14:55 +00005927 // Don't try to pass LLVM or AST inputs to a generic gcc.
5928 if (II.getType() == types::TY_LLVM_IR || II.getType() == types::TY_LTO_IR ||
5929 II.getType() == types::TY_LLVM_BC || II.getType() == types::TY_LTO_BC)
5930 D.Diag(clang::diag::err_drv_no_linker_llvm_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005931 << getToolChain().getTripleString();
Tony Linthicum76329bf2011-12-12 21:14:55 +00005932 else if (II.getType() == types::TY_AST)
5933 D.Diag(clang::diag::err_drv_no_ast_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005934 << getToolChain().getTripleString();
Douglas Gregorbf7fc9c2013-03-27 16:47:18 +00005935 else if (II.getType() == types::TY_ModuleFile)
5936 D.Diag(diag::err_drv_no_module_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005937 << getToolChain().getTripleString();
Tony Linthicum76329bf2011-12-12 21:14:55 +00005938
5939 if (II.isFilename())
5940 CmdArgs.push_back(II.getFilename());
5941 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005942 // Don't render as input, we need gcc to do the translations.
5943 // FIXME: Pranav: What is this ?
Tony Linthicum76329bf2011-12-12 21:14:55 +00005944 II.getInputArg().render(Args, CmdArgs);
5945 }
5946
5947 const char *GCCName = "hexagon-as";
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005948 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath(GCCName));
Justin Bognerd3371d82015-07-17 03:35:54 +00005949 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Tony Linthicum76329bf2011-12-12 21:14:55 +00005950}
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005951
Douglas Katzman95354292015-06-23 20:42:09 +00005952void hexagon::Linker::RenderExtraToolArgs(const JobAction &JA,
5953 ArgStringList &CmdArgs) const {
Tony Linthicum76329bf2011-12-12 21:14:55 +00005954 // The types are (hopefully) good enough.
5955}
5956
Douglas Katzman54366072015-07-27 16:53:08 +00005957static void
5958constructHexagonLinkArgs(Compilation &C, const JobAction &JA,
5959 const toolchains::HexagonToolChain &ToolChain,
5960 const InputInfo &Output, const InputInfoList &Inputs,
5961 const ArgList &Args, ArgStringList &CmdArgs,
5962 const char *LinkingOutput) {
Tony Linthicum76329bf2011-12-12 21:14:55 +00005963
Matthew Curtise689b052012-12-06 15:46:07 +00005964 const Driver &D = ToolChain.getDriver();
5965
Matthew Curtise689b052012-12-06 15:46:07 +00005966 //----------------------------------------------------------------------------
5967 //
5968 //----------------------------------------------------------------------------
5969 bool hasStaticArg = Args.hasArg(options::OPT_static);
5970 bool buildingLib = Args.hasArg(options::OPT_shared);
Matthew Curtise8f80a12012-12-06 17:49:03 +00005971 bool buildPIE = Args.hasArg(options::OPT_pie);
Matthew Curtise689b052012-12-06 15:46:07 +00005972 bool incStdLib = !Args.hasArg(options::OPT_nostdlib);
5973 bool incStartFiles = !Args.hasArg(options::OPT_nostartfiles);
5974 bool incDefLibs = !Args.hasArg(options::OPT_nodefaultlibs);
Ikhlas Ajbar522e6192015-05-14 13:52:08 +00005975 bool useG0 = false;
Matthew Curtise689b052012-12-06 15:46:07 +00005976 bool useShared = buildingLib && !hasStaticArg;
Tony Linthicum76329bf2011-12-12 21:14:55 +00005977
Matthew Curtise689b052012-12-06 15:46:07 +00005978 //----------------------------------------------------------------------------
5979 // Silence warnings for various options
5980 //----------------------------------------------------------------------------
Tony Linthicum76329bf2011-12-12 21:14:55 +00005981
Matthew Curtise689b052012-12-06 15:46:07 +00005982 Args.ClaimAllArgs(options::OPT_g_Group);
5983 Args.ClaimAllArgs(options::OPT_emit_llvm);
5984 Args.ClaimAllArgs(options::OPT_w); // Other warning options are already
5985 // handled somewhere else.
5986 Args.ClaimAllArgs(options::OPT_static_libgcc);
5987
5988 //----------------------------------------------------------------------------
5989 //
5990 //----------------------------------------------------------------------------
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005991 for (const auto &Opt : ToolChain.ExtraOpts)
5992 CmdArgs.push_back(Opt.c_str());
Tony Linthicum76329bf2011-12-12 21:14:55 +00005993
Douglas Katzman54366072015-07-27 16:53:08 +00005994 std::string MarchString = toolchains::HexagonToolChain::GetTargetCPU(Args);
Matthew Curtisf10a5952012-12-06 14:16:43 +00005995 CmdArgs.push_back(Args.MakeArgString("-m" + MarchString));
Sebastian Pop86500282012-01-13 20:37:10 +00005996
Matthew Curtise689b052012-12-06 15:46:07 +00005997 if (buildingLib) {
5998 CmdArgs.push_back("-shared");
5999 CmdArgs.push_back("-call_shared"); // should be the default, but doing as
6000 // hexagon-gcc does
Tony Linthicum76329bf2011-12-12 21:14:55 +00006001 }
6002
Matthew Curtise689b052012-12-06 15:46:07 +00006003 if (hasStaticArg)
6004 CmdArgs.push_back("-static");
Tony Linthicum76329bf2011-12-12 21:14:55 +00006005
Matthew Curtise8f80a12012-12-06 17:49:03 +00006006 if (buildPIE && !buildingLib)
6007 CmdArgs.push_back("-pie");
6008
Douglas Katzman54366072015-07-27 16:53:08 +00006009 if (const char *v =
6010 toolchains::HexagonToolChain::GetSmallDataThreshold(Args)) {
Ikhlas Ajbar522e6192015-05-14 13:52:08 +00006011 CmdArgs.push_back(Args.MakeArgString(std::string("-G") + v));
Douglas Katzman54366072015-07-27 16:53:08 +00006012 useG0 = toolchains::HexagonToolChain::UsesG0(v);
Matthew Curtise8f80a12012-12-06 17:49:03 +00006013 }
6014
Matthew Curtise689b052012-12-06 15:46:07 +00006015 //----------------------------------------------------------------------------
6016 //
6017 //----------------------------------------------------------------------------
6018 CmdArgs.push_back("-o");
6019 CmdArgs.push_back(Output.getFilename());
Tony Linthicum76329bf2011-12-12 21:14:55 +00006020
Matthew Curtise689b052012-12-06 15:46:07 +00006021 const std::string MarchSuffix = "/" + MarchString;
6022 const std::string G0Suffix = "/G0";
6023 const std::string MarchG0Suffix = MarchSuffix + G0Suffix;
Benjamin Kramerd45b2052015-10-07 15:48:01 +00006024 const std::string RootDir = ToolChain.GetGnuDir(D.InstalledDir, Args) + "/";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006025 const std::string StartFilesDir =
6026 RootDir + "hexagon/lib" + (useG0 ? MarchG0Suffix : MarchSuffix);
Matthew Curtise689b052012-12-06 15:46:07 +00006027
6028 //----------------------------------------------------------------------------
6029 // moslib
6030 //----------------------------------------------------------------------------
6031 std::vector<std::string> oslibs;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006032 bool hasStandalone = false;
Matthew Curtise689b052012-12-06 15:46:07 +00006033
Sean Silva14facf32015-06-09 01:57:17 +00006034 for (const Arg *A : Args.filtered(options::OPT_moslib_EQ)) {
6035 A->claim();
6036 oslibs.emplace_back(A->getValue());
Matthew Curtise689b052012-12-06 15:46:07 +00006037 hasStandalone = hasStandalone || (oslibs.back() == "standalone");
Tony Linthicum76329bf2011-12-12 21:14:55 +00006038 }
Matthew Curtise689b052012-12-06 15:46:07 +00006039 if (oslibs.empty()) {
6040 oslibs.push_back("standalone");
6041 hasStandalone = true;
6042 }
Tony Linthicum76329bf2011-12-12 21:14:55 +00006043
Matthew Curtise689b052012-12-06 15:46:07 +00006044 //----------------------------------------------------------------------------
6045 // Start Files
6046 //----------------------------------------------------------------------------
6047 if (incStdLib && incStartFiles) {
6048
6049 if (!buildingLib) {
6050 if (hasStandalone) {
6051 CmdArgs.push_back(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006052 Args.MakeArgString(StartFilesDir + "/crt0_standalone.o"));
Matthew Curtise689b052012-12-06 15:46:07 +00006053 }
6054 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crt0.o"));
6055 }
6056 std::string initObj = useShared ? "/initS.o" : "/init.o";
6057 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + initObj));
6058 }
6059
6060 //----------------------------------------------------------------------------
6061 // Library Search Paths
6062 //----------------------------------------------------------------------------
6063 const ToolChain::path_list &LibPaths = ToolChain.getFilePaths();
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006064 for (const auto &LibPath : LibPaths)
6065 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + LibPath));
Matthew Curtise689b052012-12-06 15:46:07 +00006066
6067 //----------------------------------------------------------------------------
6068 //
6069 //----------------------------------------------------------------------------
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00006070 Args.AddAllArgs(CmdArgs,
6071 {options::OPT_T_Group, options::OPT_e, options::OPT_s,
6072 options::OPT_t, options::OPT_u_Group});
Matthew Curtise689b052012-12-06 15:46:07 +00006073
6074 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
6075
6076 //----------------------------------------------------------------------------
6077 // Libraries
6078 //----------------------------------------------------------------------------
6079 if (incStdLib && incDefLibs) {
Hans Wennborg70850d82013-07-18 20:29:38 +00006080 if (D.CCCIsCXX()) {
Matthew Curtise689b052012-12-06 15:46:07 +00006081 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
6082 CmdArgs.push_back("-lm");
6083 }
6084
6085 CmdArgs.push_back("--start-group");
6086
6087 if (!buildingLib) {
Douglas Katzman2675d012015-06-29 19:12:56 +00006088 for (const std::string &Lib : oslibs)
6089 CmdArgs.push_back(Args.MakeArgString("-l" + Lib));
Matthew Curtise689b052012-12-06 15:46:07 +00006090 CmdArgs.push_back("-lc");
6091 }
6092 CmdArgs.push_back("-lgcc");
6093
6094 CmdArgs.push_back("--end-group");
6095 }
6096
6097 //----------------------------------------------------------------------------
6098 // End files
6099 //----------------------------------------------------------------------------
6100 if (incStdLib && incStartFiles) {
6101 std::string finiObj = useShared ? "/finiS.o" : "/fini.o";
6102 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + finiObj));
6103 }
Ikhlas Ajbar71d19f32015-05-09 02:13:25 +00006104}
6105
Douglas Katzman95354292015-06-23 20:42:09 +00006106void hexagon::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6107 const InputInfo &Output,
6108 const InputInfoList &Inputs,
6109 const ArgList &Args,
6110 const char *LinkingOutput) const {
Ikhlas Ajbar71d19f32015-05-09 02:13:25 +00006111
Douglas Katzman54366072015-07-27 16:53:08 +00006112 const toolchains::HexagonToolChain &ToolChain =
6113 static_cast<const toolchains::HexagonToolChain &>(getToolChain());
Ikhlas Ajbar71d19f32015-05-09 02:13:25 +00006114
6115 ArgStringList CmdArgs;
6116 constructHexagonLinkArgs(C, JA, ToolChain, Output, Inputs, Args, CmdArgs,
6117 LinkingOutput);
Matthew Curtise689b052012-12-06 15:46:07 +00006118
6119 std::string Linker = ToolChain.GetProgramPath("hexagon-ld");
David Blaikiec11bf802014-09-04 16:04:28 +00006120 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Linker),
Justin Bognerd3371d82015-07-17 03:35:54 +00006121 CmdArgs, Inputs));
Tony Linthicum76329bf2011-12-12 21:14:55 +00006122}
6123// Hexagon tools end.
6124
Tom Stellard8fa33092015-07-18 01:49:05 +00006125void amdgpu::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6126 const InputInfo &Output,
6127 const InputInfoList &Inputs,
6128 const ArgList &Args,
6129 const char *LinkingOutput) const {
6130
6131 std::string Linker = getToolChain().GetProgramPath(getShortName());
6132 ArgStringList CmdArgs;
6133 CmdArgs.push_back("-flavor");
6134 CmdArgs.push_back("gnu");
6135 CmdArgs.push_back("-target");
Tom Stellard1de69e82015-07-18 02:11:07 +00006136 CmdArgs.push_back(Args.MakeArgString(getToolChain().getTripleString()));
Tom Stellard8fa33092015-07-18 01:49:05 +00006137 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
6138 CmdArgs.push_back("-o");
6139 CmdArgs.push_back(Output.getFilename());
6140 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Linker),
6141 CmdArgs, Inputs));
6142}
6143// AMDGPU tools end.
6144
Renato Golin7c542b42015-07-27 23:44:45 +00006145const std::string arm::getARMArch(StringRef Arch, const llvm::Triple &Triple) {
Gabor Ballabascebcb3b2015-06-11 12:29:56 +00006146 std::string MArch;
Renato Goline17c5802015-07-27 23:44:42 +00006147 if (!Arch.empty())
6148 MArch = Arch;
6149 else
Bernard Ogden31561762013-12-12 13:27:11 +00006150 MArch = Triple.getArchName();
Gabor Ballabascebcb3b2015-06-11 12:29:56 +00006151 MArch = StringRef(MArch).lower();
John Brawn94fd9632015-05-21 12:19:49 +00006152
6153 // Handle -march=native.
6154 if (MArch == "native") {
6155 std::string CPU = llvm::sys::getHostCPUName();
6156 if (CPU != "generic") {
6157 // Translate the native cpu into the architecture suffix for that CPU.
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006158 StringRef Suffix = arm::getLLVMArchSuffixForARM(CPU, MArch, Triple);
John Brawn94fd9632015-05-21 12:19:49 +00006159 // If there is no valid architecture suffix for this CPU we don't know how
6160 // to handle it, so return no architecture.
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006161 if (Suffix.empty())
John Brawn94fd9632015-05-21 12:19:49 +00006162 MArch = "";
6163 else
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006164 MArch = std::string("arm") + Suffix.str();
John Brawn94fd9632015-05-21 12:19:49 +00006165 }
6166 }
6167
Vladimir Sukharevc6dab752015-05-14 08:25:18 +00006168 return MArch;
6169}
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006170
Vladimir Sukharevc6dab752015-05-14 08:25:18 +00006171/// Get the (LLVM) name of the minimum ARM CPU for the arch we are targeting.
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006172StringRef arm::getARMCPUForMArch(StringRef Arch, const llvm::Triple &Triple) {
Renato Goline17c5802015-07-27 23:44:42 +00006173 std::string MArch = getARMArch(Arch, Triple);
John Brawn94fd9632015-05-21 12:19:49 +00006174 // getARMCPUForArch defaults to the triple if MArch is empty, but empty MArch
6175 // here means an -march=native that we can't handle, so instead return no CPU.
6176 if (MArch.empty())
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006177 return StringRef();
Bernard Ogden31561762013-12-12 13:27:11 +00006178
John Brawna95c1a82015-05-08 12:52:18 +00006179 // We need to return an empty string here on invalid MArch values as the
6180 // various places that call this function can't cope with a null result.
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006181 return Triple.getARMCPUForArch(MArch);
Bernard Ogden31561762013-12-12 13:27:11 +00006182}
6183
6184/// getARMTargetCPU - Get the (LLVM) name of the ARM cpu we are targeting.
Renato Golin7c542b42015-07-27 23:44:45 +00006185std::string arm::getARMTargetCPU(StringRef CPU, StringRef Arch,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006186 const llvm::Triple &Triple) {
Bernard Ogden31561762013-12-12 13:27:11 +00006187 // FIXME: Warn on inconsistent use of -mcpu and -march.
6188 // If we have -mcpu=, use that.
Renato Goline17c5802015-07-27 23:44:42 +00006189 if (!CPU.empty()) {
6190 std::string MCPU = StringRef(CPU).lower();
Bernard Ogden31561762013-12-12 13:27:11 +00006191 // Handle -mcpu=native.
6192 if (MCPU == "native")
Rafael Espindola9c5ef122013-12-12 15:39:05 +00006193 return llvm::sys::getHostCPUName();
Bernard Ogden31561762013-12-12 13:27:11 +00006194 else
Rafael Espindola80d333b2013-12-12 15:48:19 +00006195 return MCPU;
Bernard Ogden31561762013-12-12 13:27:11 +00006196 }
6197
Renato Goline17c5802015-07-27 23:44:42 +00006198 return getARMCPUForMArch(Arch, Triple);
Bernard Ogden31561762013-12-12 13:27:11 +00006199}
6200
6201/// getLLVMArchSuffixForARM - Get the LLVM arch name to use for a particular
Vladimir Sukharevc6dab752015-05-14 08:25:18 +00006202/// CPU (or Arch, if CPU is generic).
Bernard Ogden31561762013-12-12 13:27:11 +00006203// FIXME: This is redundant with -mcpu, why does LLVM use this.
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006204StringRef arm::getLLVMArchSuffixForARM(StringRef CPU, StringRef Arch,
6205 const llvm::Triple &Triple) {
6206 unsigned ArchKind;
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006207 if (CPU == "generic") {
Vladimir Sukhareva317dfb2015-09-24 10:06:44 +00006208 std::string ARMArch = tools::arm::getARMArch(Arch, Triple);
Vladimir Sukharev2eef4b52015-09-24 09:55:08 +00006209 ArchKind = llvm::ARM::parseArch(ARMArch);
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006210 if (ArchKind == llvm::ARM::AK_INVALID)
6211 // In case of generic Arch, i.e. "arm",
6212 // extract arch from default cpu of the Triple
Vladimir Sukharev2eef4b52015-09-24 09:55:08 +00006213 ArchKind = llvm::ARM::parseCPUArch(Triple.getARMCPUForArch(ARMArch));
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006214 } else {
6215 ArchKind = llvm::ARM::parseCPUArch(CPU);
6216 }
Renato Golin3c007252015-05-28 15:05:53 +00006217 if (ArchKind == llvm::ARM::AK_INVALID)
6218 return "";
Chandler Carruthaa0caeb2015-08-30 02:16:36 +00006219 return llvm::ARM::getSubArch(ArchKind);
Bernard Ogden31561762013-12-12 13:27:11 +00006220}
6221
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006222void arm::appendEBLinkFlags(const ArgList &Args, ArgStringList &CmdArgs,
Vladimir Sukharevc6dab752015-05-14 08:25:18 +00006223 const llvm::Triple &Triple) {
Joerg Sonnenberger1689d3f2015-01-28 23:30:39 +00006224 if (Args.hasArg(options::OPT_r))
6225 return;
6226
John Brawn94fd9632015-05-21 12:19:49 +00006227 // ARMv7 (and later) and ARMv6-M do not support BE-32, so instruct the linker
6228 // to generate BE-8 executables.
6229 if (getARMSubArchVersionNumber(Triple) >= 7 || isARMMProfile(Triple))
6230 CmdArgs.push_back("--be8");
Joerg Sonnenberger1689d3f2015-01-28 23:30:39 +00006231}
6232
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00006233mips::NanEncoding mips::getSupportedNanEncoding(StringRef &CPU) {
Daniel Sanderse0395a72015-09-24 10:22:17 +00006234 // Strictly speaking, mips32r2 and mips64r2 are NanLegacy-only since Nan2008
6235 // was first introduced in Release 3. However, other compilers have
6236 // traditionally allowed it for Release 2 so we should do the same.
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00006237 return (NanEncoding)llvm::StringSwitch<int>(CPU)
6238 .Case("mips1", NanLegacy)
6239 .Case("mips2", NanLegacy)
6240 .Case("mips3", NanLegacy)
6241 .Case("mips4", NanLegacy)
6242 .Case("mips5", NanLegacy)
6243 .Case("mips32", NanLegacy)
Daniel Sanderse0395a72015-09-24 10:22:17 +00006244 .Case("mips32r2", NanLegacy | Nan2008)
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00006245 .Case("mips32r3", NanLegacy | Nan2008)
6246 .Case("mips32r5", NanLegacy | Nan2008)
6247 .Case("mips32r6", Nan2008)
6248 .Case("mips64", NanLegacy)
Daniel Sanderse0395a72015-09-24 10:22:17 +00006249 .Case("mips64r2", NanLegacy | Nan2008)
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00006250 .Case("mips64r3", NanLegacy | Nan2008)
6251 .Case("mips64r5", NanLegacy | Nan2008)
6252 .Case("mips64r6", Nan2008)
6253 .Default(NanLegacy);
6254}
6255
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00006256bool mips::hasMipsAbiArg(const ArgList &Args, const char *Value) {
6257 Arg *A = Args.getLastArg(options::OPT_mabi_EQ);
6258 return A && (A->getValue() == StringRef(Value));
6259}
6260
Simon Atanasyand95c67d2014-08-13 14:34:14 +00006261bool mips::isUCLibc(const ArgList &Args) {
6262 Arg *A = Args.getLastArg(options::OPT_m_libc_Group);
Rafael Espindolad3d657c2014-08-13 17:15:42 +00006263 return A && A->getOption().matches(options::OPT_muclibc);
Simon Atanasyand95c67d2014-08-13 14:34:14 +00006264}
6265
Daniel Sanders2bf13662014-07-10 14:40:57 +00006266bool mips::isNaN2008(const ArgList &Args, const llvm::Triple &Triple) {
Daniel Sanders3b92c5b2014-06-24 15:04:16 +00006267 if (Arg *NaNArg = Args.getLastArg(options::OPT_mnan_EQ))
6268 return llvm::StringSwitch<bool>(NaNArg->getValue())
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006269 .Case("2008", true)
6270 .Case("legacy", false)
6271 .Default(false);
Daniel Sanders3b92c5b2014-06-24 15:04:16 +00006272
6273 // NaN2008 is the default for MIPS32r6/MIPS64r6.
Daniel Sanders2bf13662014-07-10 14:40:57 +00006274 return llvm::StringSwitch<bool>(getCPUName(Args, Triple))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006275 .Cases("mips32r6", "mips64r6", true)
6276 .Default(false);
Daniel Sanders3b92c5b2014-06-24 15:04:16 +00006277
6278 return false;
6279}
6280
Daniel Sanders379d44b2014-07-16 11:52:23 +00006281bool mips::isFPXXDefault(const llvm::Triple &Triple, StringRef CPUName,
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00006282 StringRef ABIName, mips::FloatABI FloatABI) {
Daniel Sanders379d44b2014-07-16 11:52:23 +00006283 if (Triple.getVendor() != llvm::Triple::ImaginationTechnologies &&
Daniel Sanders492beb12014-07-18 15:05:38 +00006284 Triple.getVendor() != llvm::Triple::MipsTechnologies)
Daniel Sanders379d44b2014-07-16 11:52:23 +00006285 return false;
6286
6287 if (ABIName != "32")
6288 return false;
6289
Toma Tabacu94ea6862015-06-16 13:54:13 +00006290 // FPXX shouldn't be used if either -msoft-float or -mfloat-abi=soft is
6291 // present.
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00006292 if (FloatABI == mips::FloatABI::Soft)
Toma Tabacu94ea6862015-06-16 13:54:13 +00006293 return false;
6294
Daniel Sanders379d44b2014-07-16 11:52:23 +00006295 return llvm::StringSwitch<bool>(CPUName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006296 .Cases("mips2", "mips3", "mips4", "mips5", true)
6297 .Cases("mips32", "mips32r2", "mips32r3", "mips32r5", true)
6298 .Cases("mips64", "mips64r2", "mips64r3", "mips64r5", true)
6299 .Default(false);
Daniel Sanders379d44b2014-07-16 11:52:23 +00006300}
6301
Toma Tabacu94ea6862015-06-16 13:54:13 +00006302bool mips::shouldUseFPXX(const ArgList &Args, const llvm::Triple &Triple,
6303 StringRef CPUName, StringRef ABIName,
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00006304 mips::FloatABI FloatABI) {
Toma Tabacu94ea6862015-06-16 13:54:13 +00006305 bool UseFPXX = isFPXXDefault(Triple, CPUName, ABIName, FloatABI);
6306
6307 // FPXX shouldn't be used if -msingle-float is present.
6308 if (Arg *A = Args.getLastArg(options::OPT_msingle_float,
6309 options::OPT_mdouble_float))
6310 if (A->getOption().matches(options::OPT_msingle_float))
6311 UseFPXX = false;
6312
6313 return UseFPXX;
6314}
6315
Tim Northover157d9112014-01-16 08:48:16 +00006316llvm::Triple::ArchType darwin::getArchTypeForMachOArchName(StringRef Str) {
Rafael Espindoladcbf6982012-10-31 18:51:07 +00006317 // See arch(3) and llvm-gcc's driver-driver.c. We don't implement support for
6318 // archs which Darwin doesn't use.
6319
6320 // The matching this routine does is fairly pointless, since it is neither the
6321 // complete architecture list, nor a reasonable subset. The problem is that
6322 // historically the driver driver accepts this and also ties its -march=
6323 // handling to the architecture name, so we need to be careful before removing
6324 // support for it.
6325
6326 // This code must be kept in sync with Clang's Darwin specific argument
6327 // translation.
6328
6329 return llvm::StringSwitch<llvm::Triple::ArchType>(Str)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006330 .Cases("ppc", "ppc601", "ppc603", "ppc604", "ppc604e", llvm::Triple::ppc)
6331 .Cases("ppc750", "ppc7400", "ppc7450", "ppc970", llvm::Triple::ppc)
6332 .Case("ppc64", llvm::Triple::ppc64)
6333 .Cases("i386", "i486", "i486SX", "i586", "i686", llvm::Triple::x86)
6334 .Cases("pentium", "pentpro", "pentIIm3", "pentIIm5", "pentium4",
6335 llvm::Triple::x86)
6336 .Cases("x86_64", "x86_64h", llvm::Triple::x86_64)
6337 // This is derived from the driver driver.
6338 .Cases("arm", "armv4t", "armv5", "armv6", "armv6m", llvm::Triple::arm)
6339 .Cases("armv7", "armv7em", "armv7k", "armv7m", llvm::Triple::arm)
6340 .Cases("armv7s", "xscale", llvm::Triple::arm)
6341 .Case("arm64", llvm::Triple::aarch64)
6342 .Case("r600", llvm::Triple::r600)
6343 .Case("amdgcn", llvm::Triple::amdgcn)
6344 .Case("nvptx", llvm::Triple::nvptx)
6345 .Case("nvptx64", llvm::Triple::nvptx64)
6346 .Case("amdil", llvm::Triple::amdil)
6347 .Case("spir", llvm::Triple::spir)
6348 .Default(llvm::Triple::UnknownArch);
Rafael Espindoladcbf6982012-10-31 18:51:07 +00006349}
Tony Linthicum76329bf2011-12-12 21:14:55 +00006350
Tim Northover157d9112014-01-16 08:48:16 +00006351void darwin::setTripleTypeForMachOArchName(llvm::Triple &T, StringRef Str) {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00006352 const llvm::Triple::ArchType Arch = getArchTypeForMachOArchName(Str);
Tim Northover157d9112014-01-16 08:48:16 +00006353 T.setArch(Arch);
6354
6355 if (Str == "x86_64h")
6356 T.setArchName(Str);
6357 else if (Str == "armv6m" || Str == "armv7m" || Str == "armv7em") {
6358 T.setOS(llvm::Triple::UnknownOS);
Saleem Abdulrasool29b82b62014-03-06 20:47:19 +00006359 T.setObjectFormat(llvm::Triple::MachO);
Tim Northover157d9112014-01-16 08:48:16 +00006360 }
6361}
6362
Bob Wilsondecc03e2012-11-23 06:14:39 +00006363const char *Clang::getBaseInputName(const ArgList &Args,
Artem Belevichba558952015-05-06 18:20:23 +00006364 const InputInfo &Input) {
6365 return Args.MakeArgString(llvm::sys::path::filename(Input.getBaseInput()));
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006366}
6367
Bob Wilsondecc03e2012-11-23 06:14:39 +00006368const char *Clang::getBaseInputStem(const ArgList &Args,
6369 const InputInfoList &Inputs) {
Artem Belevichba558952015-05-06 18:20:23 +00006370 const char *Str = getBaseInputName(Args, Inputs[0]);
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006371
Chris Lattner906bb902011-01-16 08:14:11 +00006372 if (const char *End = strrchr(Str, '.'))
Daniel Dunbar1c28f1e2009-09-09 22:32:48 +00006373 return Args.MakeArgString(std::string(Str, End));
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006374
6375 return Str;
6376}
6377
Bob Wilsondecc03e2012-11-23 06:14:39 +00006378const char *Clang::getDependencyFileName(const ArgList &Args,
6379 const InputInfoList &Inputs) {
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006380 // FIXME: Think about this more.
6381 std::string Res;
6382
6383 if (Arg *OutputOpt = Args.getLastArg(options::OPT_o)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00006384 std::string Str(OutputOpt->getValue());
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006385 Res = Str.substr(0, Str.rfind('.'));
Chad Rosier6fdf38b2011-08-17 23:08:45 +00006386 } else {
Bob Wilsondecc03e2012-11-23 06:14:39 +00006387 Res = getBaseInputStem(Args, Inputs);
Chad Rosier6fdf38b2011-08-17 23:08:45 +00006388 }
Daniel Dunbar1c28f1e2009-09-09 22:32:48 +00006389 return Args.MakeArgString(Res + ".d");
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006390}
6391
Douglas Katzman95354292015-06-23 20:42:09 +00006392void cloudabi::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6393 const InputInfo &Output,
6394 const InputInfoList &Inputs,
6395 const ArgList &Args,
6396 const char *LinkingOutput) const {
Ed Schouten3c3e58c2015-03-26 11:13:44 +00006397 const ToolChain &ToolChain = getToolChain();
6398 const Driver &D = ToolChain.getDriver();
6399 ArgStringList CmdArgs;
6400
6401 // Silence warning for "clang -g foo.o -o foo"
6402 Args.ClaimAllArgs(options::OPT_g_Group);
6403 // and "clang -emit-llvm foo.o -o foo"
6404 Args.ClaimAllArgs(options::OPT_emit_llvm);
6405 // and for "clang -w foo.o -o foo". Other warning options are already
6406 // handled somewhere else.
6407 Args.ClaimAllArgs(options::OPT_w);
6408
6409 if (!D.SysRoot.empty())
6410 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
6411
6412 // CloudABI only supports static linkage.
6413 CmdArgs.push_back("-Bstatic");
6414 CmdArgs.push_back("--eh-frame-hdr");
6415 CmdArgs.push_back("--gc-sections");
6416
6417 if (Output.isFilename()) {
6418 CmdArgs.push_back("-o");
6419 CmdArgs.push_back(Output.getFilename());
6420 } else {
6421 assert(Output.isNothing() && "Invalid output.");
6422 }
6423
6424 if (!Args.hasArg(options::OPT_nostdlib) &&
6425 !Args.hasArg(options::OPT_nostartfiles)) {
6426 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crt0.o")));
6427 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtbegin.o")));
6428 }
6429
6430 Args.AddAllArgs(CmdArgs, options::OPT_L);
6431 const ToolChain::path_list &Paths = ToolChain.getFilePaths();
6432 for (const auto &Path : Paths)
6433 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00006434 Args.AddAllArgs(CmdArgs,
6435 {options::OPT_T_Group, options::OPT_e, options::OPT_s,
6436 options::OPT_t, options::OPT_Z_Flag, options::OPT_r});
Ed Schouten3c3e58c2015-03-26 11:13:44 +00006437
Alexey Samsonov907880e2015-06-19 19:57:46 +00006438 if (D.IsUsingLTO(Args))
Ed Schouten3c3e58c2015-03-26 11:13:44 +00006439 AddGoldPlugin(ToolChain, Args, CmdArgs);
6440
6441 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
6442
6443 if (!Args.hasArg(options::OPT_nostdlib) &&
6444 !Args.hasArg(options::OPT_nodefaultlibs)) {
6445 if (D.CCCIsCXX())
6446 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
6447 CmdArgs.push_back("-lc");
6448 CmdArgs.push_back("-lcompiler_rt");
6449 }
6450
6451 if (!Args.hasArg(options::OPT_nostdlib) &&
6452 !Args.hasArg(options::OPT_nostartfiles))
6453 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtend.o")));
6454
6455 const char *Exec = Args.MakeArgString(ToolChain.GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00006456 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Ed Schouten3c3e58c2015-03-26 11:13:44 +00006457}
6458
Douglas Katzman95354292015-06-23 20:42:09 +00006459void darwin::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
6460 const InputInfo &Output,
6461 const InputInfoList &Inputs,
6462 const ArgList &Args,
6463 const char *LinkingOutput) const {
Daniel Dunbarbe220842009-03-20 16:06:39 +00006464 ArgStringList CmdArgs;
6465
6466 assert(Inputs.size() == 1 && "Unexpected number of inputs.");
6467 const InputInfo &Input = Inputs[0];
6468
Daniel Dunbardc8355e2011-04-12 23:59:20 +00006469 // Determine the original source input.
6470 const Action *SourceAction = &JA;
6471 while (SourceAction->getKind() != Action::InputClass) {
6472 assert(!SourceAction->getInputs().empty() && "unexpected root action!");
6473 SourceAction = SourceAction->getInputs()[0];
6474 }
6475
Saleem Abdulrasoolcfeb90d2014-02-23 00:40:30 +00006476 // If -fno_integrated_as is used add -Q to the darwin assember driver to make
Kevin Enderby319baa42013-11-18 23:30:29 +00006477 // sure it runs its system assembler not clang's integrated assembler.
David Fang073a7c92013-12-10 22:51:25 +00006478 // Applicable to darwin11+ and Xcode 4+. darwin<10 lacked integrated-as.
6479 // FIXME: at run-time detect assembler capabilities or rely on version
6480 // information forwarded by -target-assembler-version (future)
Saleem Abdulrasoolcfeb90d2014-02-23 00:40:30 +00006481 if (Args.hasArg(options::OPT_fno_integrated_as)) {
David Fangadcdde02013-12-10 23:13:11 +00006482 const llvm::Triple &T(getToolChain().getTriple());
6483 if (!(T.isMacOSX() && T.isMacOSXVersionLT(10, 7)))
David Fang073a7c92013-12-10 22:51:25 +00006484 CmdArgs.push_back("-Q");
6485 }
Kevin Enderby319baa42013-11-18 23:30:29 +00006486
Daniel Dunbardc8355e2011-04-12 23:59:20 +00006487 // Forward -g, assuming we are dealing with an actual assembly file.
Eric Christopher84fbdb42011-08-19 00:30:14 +00006488 if (SourceAction->getType() == types::TY_Asm ||
Daniel Dunbardc8355e2011-04-12 23:59:20 +00006489 SourceAction->getType() == types::TY_PP_Asm) {
Daniel Dunbar5c9c1182009-04-01 00:27:44 +00006490 if (Args.hasArg(options::OPT_gstabs))
6491 CmdArgs.push_back("--gstabs");
6492 else if (Args.hasArg(options::OPT_g_Group))
Bob Wilson126c4912011-11-02 05:10:45 +00006493 CmdArgs.push_back("-g");
Daniel Dunbar5c9c1182009-04-01 00:27:44 +00006494 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006495
Daniel Dunbarbe220842009-03-20 16:06:39 +00006496 // Derived from asm spec.
Tim Northover157d9112014-01-16 08:48:16 +00006497 AddMachOArch(Args, CmdArgs);
Daniel Dunbarbe220842009-03-20 16:06:39 +00006498
Daniel Dunbar6d484762010-07-22 01:47:22 +00006499 // Use -force_cpusubtype_ALL on x86 by default.
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00006500 if (getToolChain().getArch() == llvm::Triple::x86 ||
6501 getToolChain().getArch() == llvm::Triple::x86_64 ||
Daniel Dunbar3571dd92009-09-09 18:36:27 +00006502 Args.hasArg(options::OPT_force__cpusubtype__ALL))
6503 CmdArgs.push_back("-force_cpusubtype_ALL");
6504
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00006505 if (getToolChain().getArch() != llvm::Triple::x86_64 &&
Daniel Dunbarbd847cc2012-10-15 22:23:53 +00006506 (((Args.hasArg(options::OPT_mkernel) ||
Eric Christopher248357f2013-02-21 22:35:01 +00006507 Args.hasArg(options::OPT_fapple_kext)) &&
Tim Northover157d9112014-01-16 08:48:16 +00006508 getMachOToolChain().isKernelStatic()) ||
Daniel Dunbarbd847cc2012-10-15 22:23:53 +00006509 Args.hasArg(options::OPT_static)))
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006510 CmdArgs.push_back("-static");
6511
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006512 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbarbe220842009-03-20 16:06:39 +00006513
6514 assert(Output.isFilename() && "Unexpected lipo output.");
6515 CmdArgs.push_back("-o");
6516 CmdArgs.push_back(Output.getFilename());
6517
Daniel Dunbarb440f562010-08-02 02:38:21 +00006518 assert(Input.isFilename() && "Invalid input.");
6519 CmdArgs.push_back(Input.getFilename());
Daniel Dunbarbe220842009-03-20 16:06:39 +00006520
6521 // asm_final spec is empty.
6522
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006523 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00006524 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbarbe220842009-03-20 16:06:39 +00006525}
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006526
Tim Northover157d9112014-01-16 08:48:16 +00006527void darwin::MachOTool::anchor() {}
David Blaikie68e081d2011-12-20 02:48:34 +00006528
Tim Northover157d9112014-01-16 08:48:16 +00006529void darwin::MachOTool::AddMachOArch(const ArgList &Args,
6530 ArgStringList &CmdArgs) const {
6531 StringRef ArchName = getMachOToolChain().getMachOArchName(Args);
Daniel Dunbardcc3b652010-01-22 02:04:58 +00006532
Daniel Dunbarc1964212009-03-26 16:23:12 +00006533 // Derived from darwin_arch spec.
6534 CmdArgs.push_back("-arch");
Daniel Dunbardcc3b652010-01-22 02:04:58 +00006535 CmdArgs.push_back(Args.MakeArgString(ArchName));
Daniel Dunbar91dbfd62009-09-04 18:35:31 +00006536
Daniel Dunbardcc3b652010-01-22 02:04:58 +00006537 // FIXME: Is this needed anymore?
6538 if (ArchName == "arm")
Daniel Dunbar91dbfd62009-09-04 18:35:31 +00006539 CmdArgs.push_back("-force_cpusubtype_ALL");
Daniel Dunbarc1964212009-03-26 16:23:12 +00006540}
6541
Douglas Katzman95354292015-06-23 20:42:09 +00006542bool darwin::Linker::NeedsTempPath(const InputInfoList &Inputs) const {
Bill Wendling3b2000f2012-10-02 18:02:50 +00006543 // We only need to generate a temp path for LTO if we aren't compiling object
6544 // files. When compiling source files, we run 'dsymutil' after linking. We
6545 // don't run 'dsymutil' when compiling object files.
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006546 for (const auto &Input : Inputs)
6547 if (Input.getType() != types::TY_Object)
Bill Wendling3b2000f2012-10-02 18:02:50 +00006548 return true;
6549
6550 return false;
6551}
6552
Douglas Katzman95354292015-06-23 20:42:09 +00006553void darwin::Linker::AddLinkArgs(Compilation &C, const ArgList &Args,
6554 ArgStringList &CmdArgs,
6555 const InputInfoList &Inputs) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00006556 const Driver &D = getToolChain().getDriver();
Tim Northover157d9112014-01-16 08:48:16 +00006557 const toolchains::MachO &MachOTC = getMachOToolChain();
Daniel Dunbarc1964212009-03-26 16:23:12 +00006558
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006559 unsigned Version[3] = {0, 0, 0};
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00006560 if (Arg *A = Args.getLastArg(options::OPT_mlinker_version_EQ)) {
6561 bool HadExtra;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006562 if (!Driver::GetReleaseVersion(A->getValue(), Version[0], Version[1],
6563 Version[2], HadExtra) ||
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00006564 HadExtra)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006565 D.Diag(diag::err_drv_invalid_version_number) << A->getAsString(Args);
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00006566 }
6567
Bob Wilson5a4f3ea2014-01-14 01:56:31 +00006568 // Newer linkers support -demangle. Pass it if supported and not disabled by
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00006569 // the user.
Bob Wilson5a4f3ea2014-01-14 01:56:31 +00006570 if (Version[0] >= 100 && !Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
6571 CmdArgs.push_back("-demangle");
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00006572
Bob Wilson3d27dad2013-08-02 22:25:34 +00006573 if (Args.hasArg(options::OPT_rdynamic) && Version[0] >= 137)
6574 CmdArgs.push_back("-export_dynamic");
6575
Bob Wilsonb111ec92015-03-02 19:01:14 +00006576 // If we are using App Extension restrictions, pass a flag to the linker
6577 // telling it that the compiled code has been audited.
6578 if (Args.hasFlag(options::OPT_fapplication_extension,
6579 options::OPT_fno_application_extension, false))
6580 CmdArgs.push_back("-application_extension");
6581
Bruno Cardoso Lopesa5efe3a2015-10-02 15:10:33 +00006582 if (D.IsUsingLTO(Args)) {
6583 // If we are using LTO, then automatically create a temporary file path for
6584 // the linker to use, so that it's lifetime will extend past a possible
6585 // dsymutil step.
6586 if (Version[0] >= 116 && NeedsTempPath(Inputs)) {
6587 const char *TmpPath = C.getArgs().MakeArgString(
6588 D.GetTemporaryPath("cc", types::getTypeTempSuffix(types::TY_Object)));
6589 C.addTempFile(TmpPath);
6590 CmdArgs.push_back("-object_path_lto");
6591 CmdArgs.push_back(TmpPath);
6592 }
6593
6594 // Use -lto_library option to specify the libLTO.dylib path. Try to find
6595 // it in clang installed libraries. If not found, the option is not used
6596 // and 'ld' will use its default mechanism to search for libLTO.dylib.
6597 if (Version[0] >= 133) {
6598 // Search for libLTO in <InstalledDir>/../lib/libLTO.dylib
6599 StringRef P = llvm::sys::path::parent_path(D.getInstalledDir());
6600 SmallString<128> LibLTOPath(P);
6601 llvm::sys::path::append(LibLTOPath, "lib");
6602 llvm::sys::path::append(LibLTOPath, "libLTO.dylib");
6603 if (llvm::sys::fs::exists(LibLTOPath)) {
6604 CmdArgs.push_back("-lto_library");
6605 CmdArgs.push_back(C.getArgs().MakeArgString(LibLTOPath));
6606 } else {
6607 D.Diag(diag::warn_drv_lto_libpath);
6608 }
6609 }
Daniel Dunbaref889c72011-06-21 20:55:11 +00006610 }
6611
Daniel Dunbarc1964212009-03-26 16:23:12 +00006612 // Derived from the "link" spec.
6613 Args.AddAllArgs(CmdArgs, options::OPT_static);
6614 if (!Args.hasArg(options::OPT_static))
6615 CmdArgs.push_back("-dynamic");
6616 if (Args.hasArg(options::OPT_fgnu_runtime)) {
6617 // FIXME: gcc replaces -lobjc in forward args with -lobjc-gnu
6618 // here. How do we wish to handle such things?
6619 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006620
Daniel Dunbarc1964212009-03-26 16:23:12 +00006621 if (!Args.hasArg(options::OPT_dynamiclib)) {
Tim Northover157d9112014-01-16 08:48:16 +00006622 AddMachOArch(Args, CmdArgs);
Daniel Dunbara48823f2010-01-22 02:04:52 +00006623 // FIXME: Why do this only on this path?
Daniel Dunbar93d7acf2010-01-22 03:37:33 +00006624 Args.AddLastArg(CmdArgs, options::OPT_force__cpusubtype__ALL);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006625
6626 Args.AddLastArg(CmdArgs, options::OPT_bundle);
6627 Args.AddAllArgs(CmdArgs, options::OPT_bundle__loader);
6628 Args.AddAllArgs(CmdArgs, options::OPT_client__name);
6629
6630 Arg *A;
6631 if ((A = Args.getLastArg(options::OPT_compatibility__version)) ||
6632 (A = Args.getLastArg(options::OPT_current__version)) ||
6633 (A = Args.getLastArg(options::OPT_install__name)))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006634 D.Diag(diag::err_drv_argument_only_allowed_with) << A->getAsString(Args)
6635 << "-dynamiclib";
Daniel Dunbarc1964212009-03-26 16:23:12 +00006636
6637 Args.AddLastArg(CmdArgs, options::OPT_force__flat__namespace);
6638 Args.AddLastArg(CmdArgs, options::OPT_keep__private__externs);
6639 Args.AddLastArg(CmdArgs, options::OPT_private__bundle);
6640 } else {
6641 CmdArgs.push_back("-dylib");
6642
6643 Arg *A;
6644 if ((A = Args.getLastArg(options::OPT_bundle)) ||
6645 (A = Args.getLastArg(options::OPT_bundle__loader)) ||
6646 (A = Args.getLastArg(options::OPT_client__name)) ||
6647 (A = Args.getLastArg(options::OPT_force__flat__namespace)) ||
6648 (A = Args.getLastArg(options::OPT_keep__private__externs)) ||
6649 (A = Args.getLastArg(options::OPT_private__bundle)))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006650 D.Diag(diag::err_drv_argument_not_allowed_with) << A->getAsString(Args)
6651 << "-dynamiclib";
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006652
Daniel Dunbarc1964212009-03-26 16:23:12 +00006653 Args.AddAllArgsTranslated(CmdArgs, options::OPT_compatibility__version,
6654 "-dylib_compatibility_version");
6655 Args.AddAllArgsTranslated(CmdArgs, options::OPT_current__version,
6656 "-dylib_current_version");
6657
Tim Northover157d9112014-01-16 08:48:16 +00006658 AddMachOArch(Args, CmdArgs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006659
6660 Args.AddAllArgsTranslated(CmdArgs, options::OPT_install__name,
6661 "-dylib_install_name");
6662 }
6663
6664 Args.AddLastArg(CmdArgs, options::OPT_all__load);
6665 Args.AddAllArgs(CmdArgs, options::OPT_allowable__client);
6666 Args.AddLastArg(CmdArgs, options::OPT_bind__at__load);
Tim Northover157d9112014-01-16 08:48:16 +00006667 if (MachOTC.isTargetIOSBased())
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00006668 Args.AddLastArg(CmdArgs, options::OPT_arch__errors__fatal);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006669 Args.AddLastArg(CmdArgs, options::OPT_dead__strip);
6670 Args.AddLastArg(CmdArgs, options::OPT_no__dead__strip__inits__and__terms);
6671 Args.AddAllArgs(CmdArgs, options::OPT_dylib__file);
6672 Args.AddLastArg(CmdArgs, options::OPT_dynamic);
6673 Args.AddAllArgs(CmdArgs, options::OPT_exported__symbols__list);
6674 Args.AddLastArg(CmdArgs, options::OPT_flat__namespace);
Daniel Dunbar044a3902011-06-28 20:16:02 +00006675 Args.AddAllArgs(CmdArgs, options::OPT_force__load);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006676 Args.AddAllArgs(CmdArgs, options::OPT_headerpad__max__install__names);
6677 Args.AddAllArgs(CmdArgs, options::OPT_image__base);
6678 Args.AddAllArgs(CmdArgs, options::OPT_init);
6679
Daniel Dunbarc44d3132011-04-28 21:23:41 +00006680 // Add the deployment target.
Tim Northover157d9112014-01-16 08:48:16 +00006681 MachOTC.addMinVersionArgs(Args, CmdArgs);
Daniel Dunbarc44d3132011-04-28 21:23:41 +00006682
Daniel Dunbarc1964212009-03-26 16:23:12 +00006683 Args.AddLastArg(CmdArgs, options::OPT_nomultidefs);
6684 Args.AddLastArg(CmdArgs, options::OPT_multi__module);
6685 Args.AddLastArg(CmdArgs, options::OPT_single__module);
6686 Args.AddAllArgs(CmdArgs, options::OPT_multiply__defined);
6687 Args.AddAllArgs(CmdArgs, options::OPT_multiply__defined__unused);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006688
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006689 if (const Arg *A =
6690 Args.getLastArg(options::OPT_fpie, options::OPT_fPIE,
6691 options::OPT_fno_pie, options::OPT_fno_PIE)) {
Daniel Dunbaraf68a882010-07-13 23:31:40 +00006692 if (A->getOption().matches(options::OPT_fpie) ||
6693 A->getOption().matches(options::OPT_fPIE))
6694 CmdArgs.push_back("-pie");
6695 else
6696 CmdArgs.push_back("-no_pie");
6697 }
Daniel Dunbarc1964212009-03-26 16:23:12 +00006698
6699 Args.AddLastArg(CmdArgs, options::OPT_prebind);
6700 Args.AddLastArg(CmdArgs, options::OPT_noprebind);
6701 Args.AddLastArg(CmdArgs, options::OPT_nofixprebinding);
6702 Args.AddLastArg(CmdArgs, options::OPT_prebind__all__twolevel__modules);
6703 Args.AddLastArg(CmdArgs, options::OPT_read__only__relocs);
6704 Args.AddAllArgs(CmdArgs, options::OPT_sectcreate);
6705 Args.AddAllArgs(CmdArgs, options::OPT_sectorder);
6706 Args.AddAllArgs(CmdArgs, options::OPT_seg1addr);
6707 Args.AddAllArgs(CmdArgs, options::OPT_segprot);
6708 Args.AddAllArgs(CmdArgs, options::OPT_segaddr);
6709 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__only__addr);
6710 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__write__addr);
6711 Args.AddAllArgs(CmdArgs, options::OPT_seg__addr__table);
6712 Args.AddAllArgs(CmdArgs, options::OPT_seg__addr__table__filename);
6713 Args.AddAllArgs(CmdArgs, options::OPT_sub__library);
6714 Args.AddAllArgs(CmdArgs, options::OPT_sub__umbrella);
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00006715
Daniel Dunbar84384642011-05-02 21:03:47 +00006716 // Give --sysroot= preference, over the Apple specific behavior to also use
6717 // --isysroot as the syslibroot.
Sebastian Pop980920a2012-04-16 04:16:43 +00006718 StringRef sysroot = C.getSysRoot();
6719 if (sysroot != "") {
Daniel Dunbar84384642011-05-02 21:03:47 +00006720 CmdArgs.push_back("-syslibroot");
Sebastian Pop980920a2012-04-16 04:16:43 +00006721 CmdArgs.push_back(C.getArgs().MakeArgString(sysroot));
Daniel Dunbar84384642011-05-02 21:03:47 +00006722 } else if (const Arg *A = Args.getLastArg(options::OPT_isysroot)) {
6723 CmdArgs.push_back("-syslibroot");
Richard Smithbd55daf2012-11-01 04:30:05 +00006724 CmdArgs.push_back(A->getValue());
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00006725 }
6726
Daniel Dunbarc1964212009-03-26 16:23:12 +00006727 Args.AddLastArg(CmdArgs, options::OPT_twolevel__namespace);
6728 Args.AddLastArg(CmdArgs, options::OPT_twolevel__namespace__hints);
6729 Args.AddAllArgs(CmdArgs, options::OPT_umbrella);
6730 Args.AddAllArgs(CmdArgs, options::OPT_undefined);
6731 Args.AddAllArgs(CmdArgs, options::OPT_unexported__symbols__list);
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00006732 Args.AddAllArgs(CmdArgs, options::OPT_weak__reference__mismatches);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006733 Args.AddLastArg(CmdArgs, options::OPT_X_Flag);
6734 Args.AddAllArgs(CmdArgs, options::OPT_y);
6735 Args.AddLastArg(CmdArgs, options::OPT_w);
6736 Args.AddAllArgs(CmdArgs, options::OPT_pagezero__size);
6737 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__);
6738 Args.AddLastArg(CmdArgs, options::OPT_seglinkedit);
6739 Args.AddLastArg(CmdArgs, options::OPT_noseglinkedit);
6740 Args.AddAllArgs(CmdArgs, options::OPT_sectalign);
6741 Args.AddAllArgs(CmdArgs, options::OPT_sectobjectsymbols);
6742 Args.AddAllArgs(CmdArgs, options::OPT_segcreate);
6743 Args.AddLastArg(CmdArgs, options::OPT_whyload);
6744 Args.AddLastArg(CmdArgs, options::OPT_whatsloaded);
6745 Args.AddAllArgs(CmdArgs, options::OPT_dylinker__install__name);
6746 Args.AddLastArg(CmdArgs, options::OPT_dylinker);
6747 Args.AddLastArg(CmdArgs, options::OPT_Mach);
6748}
6749
Douglas Katzman95354292015-06-23 20:42:09 +00006750void darwin::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6751 const InputInfo &Output,
6752 const InputInfoList &Inputs,
6753 const ArgList &Args,
6754 const char *LinkingOutput) const {
Daniel Dunbarc1964212009-03-26 16:23:12 +00006755 assert(Output.getType() == types::TY_Image && "Invalid linker output type.");
Daniel Dunbarc09988d2009-09-08 16:39:16 +00006756
Reid Kleckner0290c9c2014-09-15 17:45:39 +00006757 // If the number of arguments surpasses the system limits, we will encode the
6758 // input files in a separate file, shortening the command line. To this end,
6759 // build a list of input file names that can be passed via a file with the
6760 // -filelist linker option.
6761 llvm::opt::ArgStringList InputFileList;
6762
Daniel Dunbarc1964212009-03-26 16:23:12 +00006763 // The logic here is derived from gcc's behavior; most of which
6764 // comes from specs (starting with link_command). Consult gcc for
6765 // more information.
Daniel Dunbarc1964212009-03-26 16:23:12 +00006766 ArgStringList CmdArgs;
6767
Argyrios Kyrtzidis741fab12011-10-07 22:58:08 +00006768 /// Hack(tm) to ignore linking errors when we are doing ARC migration.
6769 if (Args.hasArg(options::OPT_ccc_arcmt_check,
6770 options::OPT_ccc_arcmt_migrate)) {
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006771 for (const auto &Arg : Args)
6772 Arg->claim();
Argyrios Kyrtzidis741fab12011-10-07 22:58:08 +00006773 const char *Exec =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006774 Args.MakeArgString(getToolChain().GetProgramPath("touch"));
Argyrios Kyrtzidis741fab12011-10-07 22:58:08 +00006775 CmdArgs.push_back(Output.getFilename());
Justin Bognerd3371d82015-07-17 03:35:54 +00006776 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, None));
Argyrios Kyrtzidis741fab12011-10-07 22:58:08 +00006777 return;
6778 }
6779
Daniel Dunbarc1964212009-03-26 16:23:12 +00006780 // I'm not sure why this particular decomposition exists in gcc, but
6781 // we follow suite for ease of comparison.
Bill Wendling3b2000f2012-10-02 18:02:50 +00006782 AddLinkArgs(C, Args, CmdArgs, Inputs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006783
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00006784 // It seems that the 'e' option is completely ignored for dynamic executables
6785 // (the default), and with static executables, the last one wins, as expected.
6786 Args.AddAllArgs(CmdArgs, {options::OPT_d_Flag, options::OPT_s, options::OPT_t,
6787 options::OPT_Z_Flag, options::OPT_u_Group,
6788 options::OPT_e, options::OPT_r});
Daniel Dunbarc1964212009-03-26 16:23:12 +00006789
Daniel Dunbar767bbab2010-10-18 22:08:36 +00006790 // Forward -ObjC when either -ObjC or -ObjC++ is used, to force loading
6791 // members of static archive libraries which implement Objective-C classes or
6792 // categories.
6793 if (Args.hasArg(options::OPT_ObjC) || Args.hasArg(options::OPT_ObjCXX))
6794 CmdArgs.push_back("-ObjC");
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00006795
Daniel Dunbarc1964212009-03-26 16:23:12 +00006796 CmdArgs.push_back("-o");
6797 CmdArgs.push_back(Output.getFilename());
6798
Chad Rosier06fd3c62012-05-16 23:45:12 +00006799 if (!Args.hasArg(options::OPT_nostdlib) &&
Tim Northover157d9112014-01-16 08:48:16 +00006800 !Args.hasArg(options::OPT_nostartfiles))
6801 getMachOToolChain().addStartObjectFileArgs(Args, CmdArgs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006802
Peter Collingbournec4122c12015-06-15 21:08:13 +00006803 // SafeStack requires its own runtime libraries
6804 // These libraries should be linked first, to make sure the
6805 // __safestack_init constructor executes before everything else
6806 if (getToolChain().getSanitizerArgs().needsSafeStackRt()) {
6807 getMachOToolChain().AddLinkRuntimeLib(Args, CmdArgs,
6808 "libclang_rt.safestack_osx.a",
6809 /*AlwaysLink=*/true);
6810 }
6811
Daniel Dunbarc1964212009-03-26 16:23:12 +00006812 Args.AddAllArgs(CmdArgs, options::OPT_L);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006813
Douglas Gregor9295df02012-05-15 21:00:27 +00006814 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Reid Kleckner0290c9c2014-09-15 17:45:39 +00006815 // Build the input file for -filelist (list of linker input files) in case we
6816 // need it later
6817 for (const auto &II : Inputs) {
6818 if (!II.isFilename()) {
6819 // This is a linker input argument.
6820 // We cannot mix input arguments and file names in a -filelist input, thus
6821 // we prematurely stop our list (remaining files shall be passed as
6822 // arguments).
6823 if (InputFileList.size() > 0)
6824 break;
6825
6826 continue;
6827 }
6828
6829 InputFileList.push_back(II.getFilename());
6830 }
6831
Joerg Sonnenberger5c3f9d52015-09-23 20:07:56 +00006832 if (!Args.hasArg(options::OPT_nostdlib) &&
6833 !Args.hasArg(options::OPT_nodefaultlibs))
6834 addOpenMPRuntime(CmdArgs, getToolChain(), Args);
6835
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006836 if (isObjCRuntimeLinked(Args) && !Args.hasArg(options::OPT_nostdlib) &&
Bob Wilson16d93952012-05-15 18:57:39 +00006837 !Args.hasArg(options::OPT_nodefaultlibs)) {
Tim Northover157d9112014-01-16 08:48:16 +00006838 // We use arclite library for both ARC and subscripting support.
6839 getMachOToolChain().AddLinkARCArgs(Args, CmdArgs);
6840
Bob Wilson7dda0cd2012-04-21 00:21:42 +00006841 CmdArgs.push_back("-framework");
6842 CmdArgs.push_back("Foundation");
Ted Kremeneke65b0862012-03-06 20:05:56 +00006843 // Link libobj.
6844 CmdArgs.push_back("-lobjc");
John McCall24fc0de2011-07-06 00:26:06 +00006845 }
John McCall31168b02011-06-15 23:02:42 +00006846
Daniel Dunbarc1964212009-03-26 16:23:12 +00006847 if (LinkingOutput) {
6848 CmdArgs.push_back("-arch_multiple");
6849 CmdArgs.push_back("-final_output");
6850 CmdArgs.push_back(LinkingOutput);
6851 }
6852
Daniel Dunbarc1964212009-03-26 16:23:12 +00006853 if (Args.hasArg(options::OPT_fnested_functions))
6854 CmdArgs.push_back("-allow_stack_execute");
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006855
Justin Bognerc7701242015-05-12 05:44:36 +00006856 // TODO: It would be nice to use addProfileRT() here, but darwin's compiler-rt
6857 // paths are different enough from other toolchains that this needs a fair
6858 // amount of refactoring done first.
6859 getMachOToolChain().addProfileRTLibs(Args, CmdArgs);
6860
Daniel Dunbarc1964212009-03-26 16:23:12 +00006861 if (!Args.hasArg(options::OPT_nostdlib) &&
6862 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00006863 if (getToolChain().getDriver().CCCIsCXX())
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00006864 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Daniel Dunbarad0f62b2009-04-08 06:06:21 +00006865
Daniel Dunbarc1964212009-03-26 16:23:12 +00006866 // link_ssp spec is empty.
6867
Daniel Dunbar26d482a2009-09-18 08:15:03 +00006868 // Let the tool chain choose which runtime library to link.
Tim Northover157d9112014-01-16 08:48:16 +00006869 getMachOToolChain().AddLinkRuntimeLibArgs(Args, CmdArgs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006870 }
6871
Chad Rosier06fd3c62012-05-16 23:45:12 +00006872 if (!Args.hasArg(options::OPT_nostdlib) &&
Daniel Dunbarc1964212009-03-26 16:23:12 +00006873 !Args.hasArg(options::OPT_nostartfiles)) {
6874 // endfile_spec is empty.
6875 }
6876
6877 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
6878 Args.AddAllArgs(CmdArgs, options::OPT_F);
6879
Steven Wu3ffb61b2015-02-06 18:08:29 +00006880 // -iframework should be forwarded as -F.
Sean Silva14facf32015-06-09 01:57:17 +00006881 for (const Arg *A : Args.filtered(options::OPT_iframework))
6882 CmdArgs.push_back(Args.MakeArgString(std::string("-F") + A->getValue()));
Steven Wu3ffb61b2015-02-06 18:08:29 +00006883
Michael Zolotukhind0cf6c82015-03-17 22:13:05 +00006884 if (!Args.hasArg(options::OPT_nostdlib) &&
6885 !Args.hasArg(options::OPT_nodefaultlibs)) {
6886 if (Arg *A = Args.getLastArg(options::OPT_fveclib)) {
6887 if (A->getValue() == StringRef("Accelerate")) {
6888 CmdArgs.push_back("-framework");
6889 CmdArgs.push_back("Accelerate");
6890 }
6891 }
6892 }
6893
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006894 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Reid Kleckner0290c9c2014-09-15 17:45:39 +00006895 std::unique_ptr<Command> Cmd =
Justin Bognerd3371d82015-07-17 03:35:54 +00006896 llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs);
Reid Kleckner0290c9c2014-09-15 17:45:39 +00006897 Cmd->setInputFileList(std::move(InputFileList));
6898 C.addCommand(std::move(Cmd));
Daniel Dunbarc1964212009-03-26 16:23:12 +00006899}
6900
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006901void darwin::Lipo::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00006902 const InputInfo &Output,
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006903 const InputInfoList &Inputs,
6904 const ArgList &Args,
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006905 const char *LinkingOutput) const {
6906 ArgStringList CmdArgs;
6907
6908 CmdArgs.push_back("-create");
6909 assert(Output.isFilename() && "Unexpected lipo output.");
Daniel Dunbar06686ab2009-03-24 00:24:37 +00006910
6911 CmdArgs.push_back("-output");
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006912 CmdArgs.push_back(Output.getFilename());
Daniel Dunbar06686ab2009-03-24 00:24:37 +00006913
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006914 for (const auto &II : Inputs) {
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006915 assert(II.isFilename() && "Unexpected lipo input.");
6916 CmdArgs.push_back(II.getFilename());
6917 }
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006918
6919 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("lipo"));
Justin Bognerd3371d82015-07-17 03:35:54 +00006920 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006921}
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00006922
Daniel Dunbar88299622010-06-04 18:28:36 +00006923void darwin::Dsymutil::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00006924 const InputInfo &Output,
Daniel Dunbar88299622010-06-04 18:28:36 +00006925 const InputInfoList &Inputs,
6926 const ArgList &Args,
6927 const char *LinkingOutput) const {
6928 ArgStringList CmdArgs;
6929
Daniel Dunbareb86b042011-05-09 17:23:16 +00006930 CmdArgs.push_back("-o");
6931 CmdArgs.push_back(Output.getFilename());
6932
Daniel Dunbar88299622010-06-04 18:28:36 +00006933 assert(Inputs.size() == 1 && "Unable to handle multiple inputs.");
6934 const InputInfo &Input = Inputs[0];
6935 assert(Input.isFilename() && "Unexpected dsymutil input.");
6936 CmdArgs.push_back(Input.getFilename());
6937
Daniel Dunbar88299622010-06-04 18:28:36 +00006938 const char *Exec =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006939 Args.MakeArgString(getToolChain().GetProgramPath("dsymutil"));
Justin Bognerd3371d82015-07-17 03:35:54 +00006940 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar88299622010-06-04 18:28:36 +00006941}
6942
Eric Christopher551ef452011-08-23 17:56:55 +00006943void darwin::VerifyDebug::ConstructJob(Compilation &C, const JobAction &JA,
Eric Christopher45f2e712012-12-18 00:31:10 +00006944 const InputInfo &Output,
6945 const InputInfoList &Inputs,
6946 const ArgList &Args,
6947 const char *LinkingOutput) const {
Eric Christopher551ef452011-08-23 17:56:55 +00006948 ArgStringList CmdArgs;
6949 CmdArgs.push_back("--verify");
Eric Christopher36222212012-02-06 19:13:09 +00006950 CmdArgs.push_back("--debug-info");
6951 CmdArgs.push_back("--eh-frame");
Eric Christopher65c05fa2012-02-06 19:43:51 +00006952 CmdArgs.push_back("--quiet");
Eric Christopher551ef452011-08-23 17:56:55 +00006953
6954 assert(Inputs.size() == 1 && "Unable to handle multiple inputs.");
6955 const InputInfo &Input = Inputs[0];
6956 assert(Input.isFilename() && "Unexpected verify input");
6957
6958 // Grabbing the output of the earlier dsymutil run.
6959 CmdArgs.push_back(Input.getFilename());
6960
6961 const char *Exec =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006962 Args.MakeArgString(getToolChain().GetProgramPath("dwarfdump"));
Justin Bognerd3371d82015-07-17 03:35:54 +00006963 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eric Christopher551ef452011-08-23 17:56:55 +00006964}
6965
Douglas Katzman95354292015-06-23 20:42:09 +00006966void solaris::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
David Chisnallf571cde2012-02-15 13:39:01 +00006967 const InputInfo &Output,
6968 const InputInfoList &Inputs,
6969 const ArgList &Args,
6970 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00006971 claimNoWarnArgs(Args);
David Chisnallf571cde2012-02-15 13:39:01 +00006972 ArgStringList CmdArgs;
6973
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006974 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
David Chisnallf571cde2012-02-15 13:39:01 +00006975
6976 CmdArgs.push_back("-o");
6977 CmdArgs.push_back(Output.getFilename());
6978
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006979 for (const auto &II : Inputs)
David Chisnallf571cde2012-02-15 13:39:01 +00006980 CmdArgs.push_back(II.getFilename());
David Chisnallf571cde2012-02-15 13:39:01 +00006981
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006982 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00006983 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
David Chisnallf571cde2012-02-15 13:39:01 +00006984}
6985
Douglas Katzman95354292015-06-23 20:42:09 +00006986void solaris::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6987 const InputInfo &Output,
6988 const InputInfoList &Inputs,
6989 const ArgList &Args,
6990 const char *LinkingOutput) const {
David Chisnallf571cde2012-02-15 13:39:01 +00006991 ArgStringList CmdArgs;
6992
David Chisnall272a0712012-02-29 15:06:12 +00006993 // Demangle C++ names in errors
6994 CmdArgs.push_back("-C");
6995
David Chisnallf571cde2012-02-15 13:39:01 +00006996 if ((!Args.hasArg(options::OPT_nostdlib)) &&
6997 (!Args.hasArg(options::OPT_shared))) {
6998 CmdArgs.push_back("-e");
6999 CmdArgs.push_back("_start");
7000 }
7001
7002 if (Args.hasArg(options::OPT_static)) {
7003 CmdArgs.push_back("-Bstatic");
7004 CmdArgs.push_back("-dn");
7005 } else {
7006 CmdArgs.push_back("-Bdynamic");
7007 if (Args.hasArg(options::OPT_shared)) {
7008 CmdArgs.push_back("-shared");
7009 } else {
7010 CmdArgs.push_back("--dynamic-linker");
Rafael Espindolac53c5b12015-08-31 19:17:51 +00007011 CmdArgs.push_back(
7012 Args.MakeArgString(getToolChain().GetFilePath("ld.so.1")));
David Chisnallf571cde2012-02-15 13:39:01 +00007013 }
7014 }
7015
7016 if (Output.isFilename()) {
7017 CmdArgs.push_back("-o");
7018 CmdArgs.push_back(Output.getFilename());
7019 } else {
7020 assert(Output.isNothing() && "Invalid output.");
7021 }
7022
7023 if (!Args.hasArg(options::OPT_nostdlib) &&
7024 !Args.hasArg(options::OPT_nostartfiles)) {
Rafael Espindolac53c5b12015-08-31 19:17:51 +00007025 if (!Args.hasArg(options::OPT_shared))
7026 CmdArgs.push_back(
7027 Args.MakeArgString(getToolChain().GetFilePath("crt1.o")));
7028
7029 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
7030 CmdArgs.push_back(
7031 Args.MakeArgString(getToolChain().GetFilePath("values-Xa.o")));
7032 CmdArgs.push_back(
7033 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
David Chisnallf571cde2012-02-15 13:39:01 +00007034 }
7035
Rafael Espindolac53c5b12015-08-31 19:17:51 +00007036 const ToolChain::path_list &Paths = getToolChain().getFilePaths();
7037 for (const auto &Path : Paths)
7038 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
David Chisnallf571cde2012-02-15 13:39:01 +00007039
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00007040 Args.AddAllArgs(CmdArgs, {options::OPT_L, options::OPT_T_Group,
7041 options::OPT_e, options::OPT_r});
David Chisnallf571cde2012-02-15 13:39:01 +00007042
7043 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
7044
7045 if (!Args.hasArg(options::OPT_nostdlib) &&
7046 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00007047 if (getToolChain().getDriver().CCCIsCXX())
David Chisnall3d127c72012-04-10 11:49:50 +00007048 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
David Chisnall1026fb02012-02-15 18:24:31 +00007049 CmdArgs.push_back("-lgcc_s");
Rafael Espindola8d4d9d2f2015-09-14 19:30:53 +00007050 CmdArgs.push_back("-lc");
David Chisnall0c52c0f2012-02-28 17:10:04 +00007051 if (!Args.hasArg(options::OPT_shared)) {
7052 CmdArgs.push_back("-lgcc");
David Chisnallc73fb892012-02-28 20:06:45 +00007053 CmdArgs.push_back("-lm");
David Chisnall0c52c0f2012-02-28 17:10:04 +00007054 }
David Chisnallf571cde2012-02-15 13:39:01 +00007055 }
7056
7057 if (!Args.hasArg(options::OPT_nostdlib) &&
7058 !Args.hasArg(options::OPT_nostartfiles)) {
Rafael Espindolac53c5b12015-08-31 19:17:51 +00007059 CmdArgs.push_back(
7060 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
David Chisnallf571cde2012-02-15 13:39:01 +00007061 }
Rafael Espindolac53c5b12015-08-31 19:17:51 +00007062 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
David Chisnallf571cde2012-02-15 13:39:01 +00007063
Alexey Samsonov7811d192014-02-20 13:57:37 +00007064 addProfileRT(getToolChain(), Args, CmdArgs);
David Chisnallf571cde2012-02-15 13:39:01 +00007065
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007066 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007067 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
David Chisnallf571cde2012-02-15 13:39:01 +00007068}
7069
Douglas Katzman95354292015-06-23 20:42:09 +00007070void openbsd::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
7071 const InputInfo &Output,
7072 const InputInfoList &Inputs,
7073 const ArgList &Args,
7074 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007075 claimNoWarnArgs(Args);
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007076 ArgStringList CmdArgs;
Rafael Espindolacc126272014-02-28 01:55:21 +00007077 bool NeedsKPIC = false;
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007078
Rafael Espindolacc126272014-02-28 01:55:21 +00007079 switch (getToolChain().getArch()) {
7080 case llvm::Triple::x86:
7081 // When building 32-bit code on OpenBSD/amd64, we have to explicitly
7082 // instruct as in the base system to assemble 32-bit code.
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007083 CmdArgs.push_back("--32");
Rafael Espindolacc126272014-02-28 01:55:21 +00007084 break;
7085
7086 case llvm::Triple::ppc:
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007087 CmdArgs.push_back("-mppc");
7088 CmdArgs.push_back("-many");
Rafael Espindolacc126272014-02-28 01:55:21 +00007089 break;
7090
7091 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00007092 case llvm::Triple::sparcel:
Rafael Espindolacc126272014-02-28 01:55:21 +00007093 CmdArgs.push_back("-32");
7094 NeedsKPIC = true;
7095 break;
7096
7097 case llvm::Triple::sparcv9:
7098 CmdArgs.push_back("-64");
7099 CmdArgs.push_back("-Av9a");
7100 NeedsKPIC = true;
7101 break;
7102
7103 case llvm::Triple::mips64:
7104 case llvm::Triple::mips64el: {
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007105 StringRef CPUName;
7106 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00007107 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007108
7109 CmdArgs.push_back("-mabi");
7110 CmdArgs.push_back(getGnuCompatibleMipsABIName(ABIName).data());
7111
7112 if (getToolChain().getArch() == llvm::Triple::mips64)
7113 CmdArgs.push_back("-EB");
7114 else
7115 CmdArgs.push_back("-EL");
7116
Rafael Espindolacc126272014-02-28 01:55:21 +00007117 NeedsKPIC = true;
7118 break;
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007119 }
7120
Rafael Espindolacc126272014-02-28 01:55:21 +00007121 default:
7122 break;
7123 }
7124
7125 if (NeedsKPIC)
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007126 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Rafael Espindolacc126272014-02-28 01:55:21 +00007127
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007128 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007129
7130 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00007131 CmdArgs.push_back(Output.getFilename());
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007132
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007133 for (const auto &II : Inputs)
Daniel Dunbarb440f562010-08-02 02:38:21 +00007134 CmdArgs.push_back(II.getFilename());
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007135
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007136 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00007137 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007138}
7139
Douglas Katzman95354292015-06-23 20:42:09 +00007140void openbsd::Linker::ConstructJob(Compilation &C, const JobAction &JA,
7141 const InputInfo &Output,
7142 const InputInfoList &Inputs,
7143 const ArgList &Args,
7144 const char *LinkingOutput) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00007145 const Driver &D = getToolChain().getDriver();
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007146 ArgStringList CmdArgs;
7147
Rafael Espindolaaadd30e2012-12-31 22:41:36 +00007148 // Silence warning for "clang -g foo.o -o foo"
7149 Args.ClaimAllArgs(options::OPT_g_Group);
7150 // and "clang -emit-llvm foo.o -o foo"
7151 Args.ClaimAllArgs(options::OPT_emit_llvm);
7152 // and for "clang -w foo.o -o foo". Other warning options are already
7153 // handled somewhere else.
7154 Args.ClaimAllArgs(options::OPT_w);
7155
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007156 if (getToolChain().getArch() == llvm::Triple::mips64)
7157 CmdArgs.push_back("-EB");
7158 else if (getToolChain().getArch() == llvm::Triple::mips64el)
7159 CmdArgs.push_back("-EL");
7160
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007161 if ((!Args.hasArg(options::OPT_nostdlib)) &&
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00007162 (!Args.hasArg(options::OPT_shared))) {
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007163 CmdArgs.push_back("-e");
7164 CmdArgs.push_back("__start");
7165 }
7166
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007167 if (Args.hasArg(options::OPT_static)) {
7168 CmdArgs.push_back("-Bstatic");
7169 } else {
Rafael Espindola7ba97af2010-11-11 02:17:51 +00007170 if (Args.hasArg(options::OPT_rdynamic))
7171 CmdArgs.push_back("-export-dynamic");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007172 CmdArgs.push_back("--eh-frame-hdr");
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007173 CmdArgs.push_back("-Bdynamic");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007174 if (Args.hasArg(options::OPT_shared)) {
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007175 CmdArgs.push_back("-shared");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007176 } else {
7177 CmdArgs.push_back("-dynamic-linker");
7178 CmdArgs.push_back("/usr/libexec/ld.so");
7179 }
7180 }
7181
Rafael Espindola044f7832013-06-05 04:28:55 +00007182 if (Args.hasArg(options::OPT_nopie))
7183 CmdArgs.push_back("-nopie");
7184
Daniel Dunbarb440f562010-08-02 02:38:21 +00007185 if (Output.isFilename()) {
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007186 CmdArgs.push_back("-o");
7187 CmdArgs.push_back(Output.getFilename());
7188 } else {
7189 assert(Output.isNothing() && "Invalid output.");
7190 }
7191
7192 if (!Args.hasArg(options::OPT_nostdlib) &&
7193 !Args.hasArg(options::OPT_nostartfiles)) {
7194 if (!Args.hasArg(options::OPT_shared)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007195 if (Args.hasArg(options::OPT_pg))
7196 CmdArgs.push_back(
7197 Args.MakeArgString(getToolChain().GetFilePath("gcrt0.o")));
Eli Friedman3715d1f2011-12-15 02:15:56 +00007198 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007199 CmdArgs.push_back(
7200 Args.MakeArgString(getToolChain().GetFilePath("crt0.o")));
7201 CmdArgs.push_back(
7202 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007203 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007204 CmdArgs.push_back(
7205 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007206 }
7207 }
7208
Edward O'Callaghan5c521462009-10-28 15:13:08 +00007209 std::string Triple = getToolChain().getTripleString();
7210 if (Triple.substr(0, 6) == "x86_64")
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00007211 Triple.replace(0, 6, "amd64");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007212 CmdArgs.push_back(
7213 Args.MakeArgString("-L/usr/lib/gcc-lib/" + Triple + "/4.2.1"));
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007214
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00007215 Args.AddAllArgs(CmdArgs, {options::OPT_L, options::OPT_T_Group,
7216 options::OPT_e, options::OPT_s, options::OPT_t,
7217 options::OPT_Z_Flag, options::OPT_r});
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007218
Daniel Dunbar54423b22010-09-17 00:24:54 +00007219 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007220
7221 if (!Args.hasArg(options::OPT_nostdlib) &&
7222 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00007223 if (D.CCCIsCXX()) {
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00007224 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007225 if (Args.hasArg(options::OPT_pg))
Eli Friedman3715d1f2011-12-15 02:15:56 +00007226 CmdArgs.push_back("-lm_p");
7227 else
7228 CmdArgs.push_back("-lm");
Daniel Dunbarea3813f2010-08-01 23:13:54 +00007229 }
7230
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007231 // FIXME: For some reason GCC passes -lgcc before adding
7232 // the default system libraries. Just mimic this for now.
7233 CmdArgs.push_back("-lgcc");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007234
Eric Christopher17674ec2012-09-13 06:32:34 +00007235 if (Args.hasArg(options::OPT_pthread)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007236 if (!Args.hasArg(options::OPT_shared) && Args.hasArg(options::OPT_pg))
7237 CmdArgs.push_back("-lpthread_p");
Eric Christopher17674ec2012-09-13 06:32:34 +00007238 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007239 CmdArgs.push_back("-lpthread");
Eric Christopher17674ec2012-09-13 06:32:34 +00007240 }
7241
Chandler Carruth45661652011-12-17 22:32:42 +00007242 if (!Args.hasArg(options::OPT_shared)) {
Eric Christopher17674ec2012-09-13 06:32:34 +00007243 if (Args.hasArg(options::OPT_pg))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007244 CmdArgs.push_back("-lc_p");
Eli Friedman3715d1f2011-12-15 02:15:56 +00007245 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007246 CmdArgs.push_back("-lc");
Chandler Carruth45661652011-12-17 22:32:42 +00007247 }
Eric Christopher17674ec2012-09-13 06:32:34 +00007248
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007249 CmdArgs.push_back("-lgcc");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007250 }
7251
7252 if (!Args.hasArg(options::OPT_nostdlib) &&
7253 !Args.hasArg(options::OPT_nostartfiles)) {
7254 if (!Args.hasArg(options::OPT_shared))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007255 CmdArgs.push_back(
7256 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007257 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007258 CmdArgs.push_back(
7259 Args.MakeArgString(getToolChain().GetFilePath("crtendS.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007260 }
7261
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007262 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007263 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007264}
Ed Schoutene33194b2009-04-02 19:13:12 +00007265
Douglas Katzman95354292015-06-23 20:42:09 +00007266void bitrig::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
7267 const InputInfo &Output,
7268 const InputInfoList &Inputs,
7269 const ArgList &Args,
7270 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007271 claimNoWarnArgs(Args);
Eli Friedman9fa28852012-08-08 23:57:20 +00007272 ArgStringList CmdArgs;
7273
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007274 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Eli Friedman9fa28852012-08-08 23:57:20 +00007275
7276 CmdArgs.push_back("-o");
7277 CmdArgs.push_back(Output.getFilename());
7278
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007279 for (const auto &II : Inputs)
Eli Friedman9fa28852012-08-08 23:57:20 +00007280 CmdArgs.push_back(II.getFilename());
Eli Friedman9fa28852012-08-08 23:57:20 +00007281
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007282 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00007283 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eli Friedman9fa28852012-08-08 23:57:20 +00007284}
7285
Douglas Katzman95354292015-06-23 20:42:09 +00007286void bitrig::Linker::ConstructJob(Compilation &C, const JobAction &JA,
7287 const InputInfo &Output,
7288 const InputInfoList &Inputs,
7289 const ArgList &Args,
7290 const char *LinkingOutput) const {
Eli Friedman9fa28852012-08-08 23:57:20 +00007291 const Driver &D = getToolChain().getDriver();
7292 ArgStringList CmdArgs;
7293
7294 if ((!Args.hasArg(options::OPT_nostdlib)) &&
7295 (!Args.hasArg(options::OPT_shared))) {
7296 CmdArgs.push_back("-e");
7297 CmdArgs.push_back("__start");
7298 }
7299
7300 if (Args.hasArg(options::OPT_static)) {
7301 CmdArgs.push_back("-Bstatic");
7302 } else {
7303 if (Args.hasArg(options::OPT_rdynamic))
7304 CmdArgs.push_back("-export-dynamic");
7305 CmdArgs.push_back("--eh-frame-hdr");
7306 CmdArgs.push_back("-Bdynamic");
7307 if (Args.hasArg(options::OPT_shared)) {
7308 CmdArgs.push_back("-shared");
7309 } else {
7310 CmdArgs.push_back("-dynamic-linker");
7311 CmdArgs.push_back("/usr/libexec/ld.so");
7312 }
7313 }
7314
7315 if (Output.isFilename()) {
7316 CmdArgs.push_back("-o");
7317 CmdArgs.push_back(Output.getFilename());
7318 } else {
7319 assert(Output.isNothing() && "Invalid output.");
7320 }
7321
7322 if (!Args.hasArg(options::OPT_nostdlib) &&
7323 !Args.hasArg(options::OPT_nostartfiles)) {
7324 if (!Args.hasArg(options::OPT_shared)) {
7325 if (Args.hasArg(options::OPT_pg))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007326 CmdArgs.push_back(
7327 Args.MakeArgString(getToolChain().GetFilePath("gcrt0.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00007328 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007329 CmdArgs.push_back(
7330 Args.MakeArgString(getToolChain().GetFilePath("crt0.o")));
7331 CmdArgs.push_back(
7332 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00007333 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007334 CmdArgs.push_back(
7335 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00007336 }
7337 }
7338
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00007339 Args.AddAllArgs(CmdArgs,
7340 {options::OPT_L, options::OPT_T_Group, options::OPT_e});
Eli Friedman9fa28852012-08-08 23:57:20 +00007341
7342 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
7343
7344 if (!Args.hasArg(options::OPT_nostdlib) &&
7345 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00007346 if (D.CCCIsCXX()) {
Eli Friedman9fa28852012-08-08 23:57:20 +00007347 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
7348 if (Args.hasArg(options::OPT_pg))
7349 CmdArgs.push_back("-lm_p");
7350 else
7351 CmdArgs.push_back("-lm");
7352 }
7353
Rafael Espindola1ad26f02012-10-23 17:07:31 +00007354 if (Args.hasArg(options::OPT_pthread)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007355 if (!Args.hasArg(options::OPT_shared) && Args.hasArg(options::OPT_pg))
Rafael Espindola1ad26f02012-10-23 17:07:31 +00007356 CmdArgs.push_back("-lpthread_p");
7357 else
7358 CmdArgs.push_back("-lpthread");
7359 }
7360
Eli Friedman9fa28852012-08-08 23:57:20 +00007361 if (!Args.hasArg(options::OPT_shared)) {
7362 if (Args.hasArg(options::OPT_pg))
7363 CmdArgs.push_back("-lc_p");
7364 else
7365 CmdArgs.push_back("-lc");
7366 }
7367
Benjamin Kramerb2ccade2013-10-21 12:33:55 +00007368 StringRef MyArch;
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007369 switch (getToolChain().getArch()) {
Benjamin Kramerb2ccade2013-10-21 12:33:55 +00007370 case llvm::Triple::arm:
7371 MyArch = "arm";
7372 break;
7373 case llvm::Triple::x86:
7374 MyArch = "i386";
7375 break;
7376 case llvm::Triple::x86_64:
7377 MyArch = "amd64";
7378 break;
7379 default:
7380 llvm_unreachable("Unsupported architecture");
7381 }
7382 CmdArgs.push_back(Args.MakeArgString("-lclang_rt." + MyArch));
Eli Friedman9fa28852012-08-08 23:57:20 +00007383 }
7384
7385 if (!Args.hasArg(options::OPT_nostdlib) &&
7386 !Args.hasArg(options::OPT_nostartfiles)) {
7387 if (!Args.hasArg(options::OPT_shared))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007388 CmdArgs.push_back(
7389 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00007390 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007391 CmdArgs.push_back(
7392 Args.MakeArgString(getToolChain().GetFilePath("crtendS.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00007393 }
Eli Friedman5bb2ba02012-08-09 22:42:04 +00007394
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007395 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007396 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eli Friedman9fa28852012-08-08 23:57:20 +00007397}
7398
Douglas Katzman95354292015-06-23 20:42:09 +00007399void freebsd::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
7400 const InputInfo &Output,
7401 const InputInfoList &Inputs,
7402 const ArgList &Args,
7403 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007404 claimNoWarnArgs(Args);
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007405 ArgStringList CmdArgs;
7406
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007407 // When building 32-bit code on FreeBSD/amd64, we have to explicitly
7408 // instruct as in the base system to assemble 32-bit code.
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007409 if (getToolChain().getArch() == llvm::Triple::x86)
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007410 CmdArgs.push_back("--32");
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007411 else if (getToolChain().getArch() == llvm::Triple::ppc)
Roman Divacky00859c22011-06-04 07:37:31 +00007412 CmdArgs.push_back("-a32");
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007413 else if (getToolChain().getArch() == llvm::Triple::mips ||
7414 getToolChain().getArch() == llvm::Triple::mipsel ||
7415 getToolChain().getArch() == llvm::Triple::mips64 ||
7416 getToolChain().getArch() == llvm::Triple::mips64el) {
7417 StringRef CPUName;
7418 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00007419 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00007420
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007421 CmdArgs.push_back("-march");
7422 CmdArgs.push_back(CPUName.data());
7423
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007424 CmdArgs.push_back("-mabi");
Simon Atanasyan0da400c2013-02-27 14:55:49 +00007425 CmdArgs.push_back(getGnuCompatibleMipsABIName(ABIName).data());
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007426
7427 if (getToolChain().getArch() == llvm::Triple::mips ||
7428 getToolChain().getArch() == llvm::Triple::mips64)
7429 CmdArgs.push_back("-EB");
7430 else
7431 CmdArgs.push_back("-EL");
7432
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007433 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Rafael Espindola0f207ed2012-12-13 04:17:14 +00007434 } else if (getToolChain().getArch() == llvm::Triple::arm ||
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00007435 getToolChain().getArch() == llvm::Triple::armeb ||
7436 getToolChain().getArch() == llvm::Triple::thumb ||
7437 getToolChain().getArch() == llvm::Triple::thumbeb) {
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00007438 arm::FloatABI ABI = arm::getARMFloatABI(getToolChain(), Args);
Renato Golinf4421f72014-02-19 10:44:07 +00007439
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +00007440 if (ABI == arm::FloatABI::Hard)
Renato Golinf4421f72014-02-19 10:44:07 +00007441 CmdArgs.push_back("-mfpu=vfp");
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +00007442 else
Renato Golinf4421f72014-02-19 10:44:07 +00007443 CmdArgs.push_back("-mfpu=softvfp");
Renato Golinf4421f72014-02-19 10:44:07 +00007444
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007445 switch (getToolChain().getTriple().getEnvironment()) {
Renato Golinf4421f72014-02-19 10:44:07 +00007446 case llvm::Triple::GNUEABIHF:
Rafael Espindola0f207ed2012-12-13 04:17:14 +00007447 case llvm::Triple::GNUEABI:
7448 case llvm::Triple::EABI:
Anton Korobeynikov2bed8472013-03-18 07:59:20 +00007449 CmdArgs.push_back("-meabi=5");
Rafael Espindola0f207ed2012-12-13 04:17:14 +00007450 break;
7451
7452 default:
7453 CmdArgs.push_back("-matpcs");
7454 }
Roman Divacky47f4ff82014-01-02 15:13:18 +00007455 } else if (getToolChain().getArch() == llvm::Triple::sparc ||
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00007456 getToolChain().getArch() == llvm::Triple::sparcel ||
Roman Divackyfeb5e632014-01-02 15:34:59 +00007457 getToolChain().getArch() == llvm::Triple::sparcv9) {
Roman Divacky9f779402014-02-25 18:45:49 +00007458 if (getToolChain().getArch() == llvm::Triple::sparc)
7459 CmdArgs.push_back("-Av8plusa");
7460 else
7461 CmdArgs.push_back("-Av9a");
7462
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007463 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007464 }
Eric Christopher0b26a612010-03-02 02:41:08 +00007465
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007466 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007467
7468 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00007469 CmdArgs.push_back(Output.getFilename());
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007470
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007471 for (const auto &II : Inputs)
Daniel Dunbarb440f562010-08-02 02:38:21 +00007472 CmdArgs.push_back(II.getFilename());
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007473
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007474 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00007475 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007476}
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007477
Douglas Katzman95354292015-06-23 20:42:09 +00007478void freebsd::Linker::ConstructJob(Compilation &C, const JobAction &JA,
7479 const InputInfo &Output,
7480 const InputInfoList &Inputs,
7481 const ArgList &Args,
7482 const char *LinkingOutput) const {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007483 const toolchains::FreeBSD &ToolChain =
7484 static_cast<const toolchains::FreeBSD &>(getToolChain());
Roman Divackyafe2f232012-08-28 15:09:03 +00007485 const Driver &D = ToolChain.getDriver();
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007486 const llvm::Triple::ArchType Arch = ToolChain.getArch();
Alexey Samsonove65ceb92014-02-25 13:26:03 +00007487 const bool IsPIE =
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007488 !Args.hasArg(options::OPT_shared) &&
7489 (Args.hasArg(options::OPT_pie) || ToolChain.isPIEDefault());
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007490 ArgStringList CmdArgs;
David Chisnall5f99f482012-07-29 15:24:44 +00007491
7492 // Silence warning for "clang -g foo.o -o foo"
7493 Args.ClaimAllArgs(options::OPT_g_Group);
7494 // and "clang -emit-llvm foo.o -o foo"
7495 Args.ClaimAllArgs(options::OPT_emit_llvm);
7496 // and for "clang -w foo.o -o foo". Other warning options are already
7497 // handled somewhere else.
7498 Args.ClaimAllArgs(options::OPT_w);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007499
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00007500 if (!D.SysRoot.empty())
7501 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
7502
Alexey Samsonove65ceb92014-02-25 13:26:03 +00007503 if (IsPIE)
Roman Divackyafe2f232012-08-28 15:09:03 +00007504 CmdArgs.push_back("-pie");
7505
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007506 if (Args.hasArg(options::OPT_static)) {
7507 CmdArgs.push_back("-Bstatic");
7508 } else {
Rafael Espindola7ba97af2010-11-11 02:17:51 +00007509 if (Args.hasArg(options::OPT_rdynamic))
7510 CmdArgs.push_back("-export-dynamic");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007511 CmdArgs.push_back("--eh-frame-hdr");
7512 if (Args.hasArg(options::OPT_shared)) {
7513 CmdArgs.push_back("-Bshareable");
7514 } else {
7515 CmdArgs.push_back("-dynamic-linker");
7516 CmdArgs.push_back("/libexec/ld-elf.so.1");
7517 }
Roman Divackyafe2f232012-08-28 15:09:03 +00007518 if (ToolChain.getTriple().getOSMajorVersion() >= 9) {
David Chisnall5f99f482012-07-29 15:24:44 +00007519 if (Arch == llvm::Triple::arm || Arch == llvm::Triple::sparc ||
7520 Arch == llvm::Triple::x86 || Arch == llvm::Triple::x86_64) {
7521 CmdArgs.push_back("--hash-style=both");
7522 }
7523 }
7524 CmdArgs.push_back("--enable-new-dtags");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007525 }
7526
7527 // When building 32-bit code on FreeBSD/amd64, we have to explicitly
7528 // instruct ld in the base system to link 32-bit code.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007529 if (Arch == llvm::Triple::x86) {
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007530 CmdArgs.push_back("-m");
7531 CmdArgs.push_back("elf_i386_fbsd");
7532 }
7533
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007534 if (Arch == llvm::Triple::ppc) {
Roman Divacky5e300b82011-06-04 07:40:24 +00007535 CmdArgs.push_back("-m");
Roman Divackyd150ad32011-11-21 16:50:32 +00007536 CmdArgs.push_back("elf32ppc_fbsd");
Roman Divacky5e300b82011-06-04 07:40:24 +00007537 }
7538
Daniel Dunbarb440f562010-08-02 02:38:21 +00007539 if (Output.isFilename()) {
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007540 CmdArgs.push_back("-o");
7541 CmdArgs.push_back(Output.getFilename());
7542 } else {
7543 assert(Output.isNothing() && "Invalid output.");
7544 }
7545
7546 if (!Args.hasArg(options::OPT_nostdlib) &&
7547 !Args.hasArg(options::OPT_nostartfiles)) {
Craig Topper92fc2df2014-05-17 16:56:41 +00007548 const char *crt1 = nullptr;
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007549 if (!Args.hasArg(options::OPT_shared)) {
Roman Divacky66f22762011-02-10 16:59:40 +00007550 if (Args.hasArg(options::OPT_pg))
Roman Divackyafe2f232012-08-28 15:09:03 +00007551 crt1 = "gcrt1.o";
Alexey Samsonove65ceb92014-02-25 13:26:03 +00007552 else if (IsPIE)
Roman Divackyafe2f232012-08-28 15:09:03 +00007553 crt1 = "Scrt1.o";
7554 else
7555 crt1 = "crt1.o";
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007556 }
Roman Divackyafe2f232012-08-28 15:09:03 +00007557 if (crt1)
7558 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crt1)));
7559
7560 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
7561
Craig Topper92fc2df2014-05-17 16:56:41 +00007562 const char *crtbegin = nullptr;
Roman Divackyafe2f232012-08-28 15:09:03 +00007563 if (Args.hasArg(options::OPT_static))
7564 crtbegin = "crtbeginT.o";
Alexey Samsonove65ceb92014-02-25 13:26:03 +00007565 else if (Args.hasArg(options::OPT_shared) || IsPIE)
Roman Divackyafe2f232012-08-28 15:09:03 +00007566 crtbegin = "crtbeginS.o";
7567 else
7568 crtbegin = "crtbegin.o";
7569
7570 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtbegin)));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007571 }
7572
7573 Args.AddAllArgs(CmdArgs, options::OPT_L);
Benjamin Kramer22c68ef2014-09-11 14:13:49 +00007574 const ToolChain::path_list &Paths = ToolChain.getFilePaths();
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007575 for (const auto &Path : Paths)
7576 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007577 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
7578 Args.AddAllArgs(CmdArgs, options::OPT_e);
David Chisnall589a4942010-08-15 22:58:12 +00007579 Args.AddAllArgs(CmdArgs, options::OPT_s);
7580 Args.AddAllArgs(CmdArgs, options::OPT_t);
7581 Args.AddAllArgs(CmdArgs, options::OPT_Z_Flag);
7582 Args.AddAllArgs(CmdArgs, options::OPT_r);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007583
Alexey Samsonov907880e2015-06-19 19:57:46 +00007584 if (D.IsUsingLTO(Args))
Alp Tokerce365ca2013-12-02 12:43:03 +00007585 AddGoldPlugin(ToolChain, Args, CmdArgs);
Roman Divackyf0d7f942013-11-10 09:31:43 +00007586
Alexey Samsonov52550342014-09-15 19:58:40 +00007587 bool NeedsSanitizerDeps = addSanitizerRuntimes(ToolChain, Args, CmdArgs);
Roman Divackyafe2f232012-08-28 15:09:03 +00007588 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007589
7590 if (!Args.hasArg(options::OPT_nostdlib) &&
7591 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00007592 if (D.CCCIsCXX()) {
Roman Divackyafe2f232012-08-28 15:09:03 +00007593 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
Roman Divacky66f22762011-02-10 16:59:40 +00007594 if (Args.hasArg(options::OPT_pg))
7595 CmdArgs.push_back("-lm_p");
7596 else
7597 CmdArgs.push_back("-lm");
Daniel Dunbar4b8ef282010-02-17 08:07:51 +00007598 }
Alexey Samsonov52550342014-09-15 19:58:40 +00007599 if (NeedsSanitizerDeps)
7600 linkSanitizerRuntimeDeps(ToolChain, CmdArgs);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007601 // FIXME: For some reason GCC passes -lgcc and -lgcc_s before adding
7602 // the default system libraries. Just mimic this for now.
Roman Divacky66f22762011-02-10 16:59:40 +00007603 if (Args.hasArg(options::OPT_pg))
7604 CmdArgs.push_back("-lgcc_p");
7605 else
7606 CmdArgs.push_back("-lgcc");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007607 if (Args.hasArg(options::OPT_static)) {
7608 CmdArgs.push_back("-lgcc_eh");
Roman Divacky66f22762011-02-10 16:59:40 +00007609 } else if (Args.hasArg(options::OPT_pg)) {
7610 CmdArgs.push_back("-lgcc_eh_p");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007611 } else {
7612 CmdArgs.push_back("--as-needed");
7613 CmdArgs.push_back("-lgcc_s");
7614 CmdArgs.push_back("--no-as-needed");
7615 }
7616
Matt Beaumont-Gay1fe49152011-02-10 20:35:01 +00007617 if (Args.hasArg(options::OPT_pthread)) {
Roman Divacky66f22762011-02-10 16:59:40 +00007618 if (Args.hasArg(options::OPT_pg))
7619 CmdArgs.push_back("-lpthread_p");
7620 else
7621 CmdArgs.push_back("-lpthread");
Matt Beaumont-Gay1fe49152011-02-10 20:35:01 +00007622 }
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007623
Roman Divacky66f22762011-02-10 16:59:40 +00007624 if (Args.hasArg(options::OPT_pg)) {
7625 if (Args.hasArg(options::OPT_shared))
7626 CmdArgs.push_back("-lc");
7627 else
7628 CmdArgs.push_back("-lc_p");
7629 CmdArgs.push_back("-lgcc_p");
7630 } else {
7631 CmdArgs.push_back("-lc");
7632 CmdArgs.push_back("-lgcc");
7633 }
7634
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007635 if (Args.hasArg(options::OPT_static)) {
7636 CmdArgs.push_back("-lgcc_eh");
Roman Divacky66f22762011-02-10 16:59:40 +00007637 } else if (Args.hasArg(options::OPT_pg)) {
7638 CmdArgs.push_back("-lgcc_eh_p");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007639 } else {
7640 CmdArgs.push_back("--as-needed");
7641 CmdArgs.push_back("-lgcc_s");
7642 CmdArgs.push_back("--no-as-needed");
7643 }
7644 }
7645
7646 if (!Args.hasArg(options::OPT_nostdlib) &&
7647 !Args.hasArg(options::OPT_nostartfiles)) {
Alexey Samsonove65ceb92014-02-25 13:26:03 +00007648 if (Args.hasArg(options::OPT_shared) || IsPIE)
Roman Divackyafe2f232012-08-28 15:09:03 +00007649 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtendS.o")));
Roman Divackya3c50242012-09-07 13:36:21 +00007650 else
7651 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtend.o")));
Roman Divackyafe2f232012-08-28 15:09:03 +00007652 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007653 }
7654
Alexey Samsonov7811d192014-02-20 13:57:37 +00007655 addProfileRT(ToolChain, Args, CmdArgs);
Nick Lewycky82fe5f42011-05-24 21:54:59 +00007656
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007657 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007658 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007659}
Daniel Dunbarcc912342009-05-02 18:28:39 +00007660
Douglas Katzman95354292015-06-23 20:42:09 +00007661void netbsd::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007662 const InputInfo &Output,
7663 const InputInfoList &Inputs,
7664 const ArgList &Args,
7665 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007666 claimNoWarnArgs(Args);
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007667 ArgStringList CmdArgs;
7668
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007669 // GNU as needs different flags for creating the correct output format
7670 // on architectures with different ABIs or optional feature sets.
7671 switch (getToolChain().getArch()) {
7672 case llvm::Triple::x86:
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007673 CmdArgs.push_back("--32");
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007674 break;
7675 case llvm::Triple::arm:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00007676 case llvm::Triple::armeb:
7677 case llvm::Triple::thumb:
7678 case llvm::Triple::thumbeb: {
Renato Goline17c5802015-07-27 23:44:42 +00007679 StringRef MArch, MCPU;
Renato Golin7c542b42015-07-27 23:44:45 +00007680 getARMArchCPUFromArgs(Args, MArch, MCPU, /*FromAs*/ true);
7681 std::string Arch =
7682 arm::getARMTargetCPU(MCPU, MArch, getToolChain().getTriple());
Renato Goline17c5802015-07-27 23:44:42 +00007683 CmdArgs.push_back(Args.MakeArgString("-mcpu=" + Arch));
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007684 break;
Joerg Sonnenberger1f94da52013-12-05 21:07:29 +00007685 }
7686
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007687 case llvm::Triple::mips:
7688 case llvm::Triple::mipsel:
7689 case llvm::Triple::mips64:
7690 case llvm::Triple::mips64el: {
Joerg Sonnenberger21baded2013-12-08 13:54:58 +00007691 StringRef CPUName;
7692 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00007693 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Joerg Sonnenberger21baded2013-12-08 13:54:58 +00007694
7695 CmdArgs.push_back("-march");
7696 CmdArgs.push_back(CPUName.data());
7697
7698 CmdArgs.push_back("-mabi");
7699 CmdArgs.push_back(getGnuCompatibleMipsABIName(ABIName).data());
7700
7701 if (getToolChain().getArch() == llvm::Triple::mips ||
7702 getToolChain().getArch() == llvm::Triple::mips64)
7703 CmdArgs.push_back("-EB");
7704 else
7705 CmdArgs.push_back("-EL");
7706
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007707 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007708 break;
7709 }
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00007710
7711 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00007712 case llvm::Triple::sparcel:
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00007713 CmdArgs.push_back("-32");
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007714 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00007715 break;
7716
7717 case llvm::Triple::sparcv9:
7718 CmdArgs.push_back("-64");
7719 CmdArgs.push_back("-Av9");
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007720 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00007721 break;
7722
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007723 default:
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007724 break;
Joerg Sonnenberger21baded2013-12-08 13:54:58 +00007725 }
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007726
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007727 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007728
7729 CmdArgs.push_back("-o");
7730 CmdArgs.push_back(Output.getFilename());
7731
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007732 for (const auto &II : Inputs)
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007733 CmdArgs.push_back(II.getFilename());
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007734
David Chisnallddbd68f2011-09-27 22:03:18 +00007735 const char *Exec = Args.MakeArgString((getToolChain().GetProgramPath("as")));
Justin Bognerd3371d82015-07-17 03:35:54 +00007736 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007737}
7738
Douglas Katzman95354292015-06-23 20:42:09 +00007739void netbsd::Linker::ConstructJob(Compilation &C, const JobAction &JA,
7740 const InputInfo &Output,
7741 const InputInfoList &Inputs,
7742 const ArgList &Args,
7743 const char *LinkingOutput) const {
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007744 const Driver &D = getToolChain().getDriver();
7745 ArgStringList CmdArgs;
7746
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00007747 if (!D.SysRoot.empty())
7748 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
7749
Joerg Sonnenberger52be0b42014-03-13 00:42:01 +00007750 CmdArgs.push_back("--eh-frame-hdr");
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007751 if (Args.hasArg(options::OPT_static)) {
7752 CmdArgs.push_back("-Bstatic");
7753 } else {
7754 if (Args.hasArg(options::OPT_rdynamic))
7755 CmdArgs.push_back("-export-dynamic");
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007756 if (Args.hasArg(options::OPT_shared)) {
7757 CmdArgs.push_back("-Bshareable");
7758 } else {
7759 CmdArgs.push_back("-dynamic-linker");
7760 CmdArgs.push_back("/libexec/ld.elf_so");
7761 }
7762 }
7763
Joerg Sonnenberger6cd7deb2014-02-02 22:50:34 +00007764 // Many NetBSD architectures support more than one ABI.
7765 // Determine the correct emulation for ld.
7766 switch (getToolChain().getArch()) {
7767 case llvm::Triple::x86:
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007768 CmdArgs.push_back("-m");
7769 CmdArgs.push_back("elf_i386");
Joerg Sonnenberger6cd7deb2014-02-02 22:50:34 +00007770 break;
7771 case llvm::Triple::arm:
7772 case llvm::Triple::thumb:
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00007773 CmdArgs.push_back("-m");
7774 switch (getToolChain().getTriple().getEnvironment()) {
7775 case llvm::Triple::EABI:
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00007776 case llvm::Triple::GNUEABI:
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00007777 CmdArgs.push_back("armelf_nbsd_eabi");
7778 break;
Joerg Sonnenberger83a33c02014-02-06 21:04:32 +00007779 case llvm::Triple::EABIHF:
7780 case llvm::Triple::GNUEABIHF:
7781 CmdArgs.push_back("armelf_nbsd_eabihf");
7782 break;
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00007783 default:
7784 CmdArgs.push_back("armelf_nbsd");
7785 break;
7786 }
Joerg Sonnenberger6cd7deb2014-02-02 22:50:34 +00007787 break;
Joerg Sonnenbergerb7045342014-08-14 19:12:41 +00007788 case llvm::Triple::armeb:
7789 case llvm::Triple::thumbeb:
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007790 arm::appendEBLinkFlags(
7791 Args, CmdArgs,
John Brawn94fd9632015-05-21 12:19:49 +00007792 llvm::Triple(getToolChain().ComputeEffectiveClangTriple(Args)));
Joerg Sonnenbergerb7045342014-08-14 19:12:41 +00007793 CmdArgs.push_back("-m");
7794 switch (getToolChain().getTriple().getEnvironment()) {
7795 case llvm::Triple::EABI:
7796 case llvm::Triple::GNUEABI:
7797 CmdArgs.push_back("armelfb_nbsd_eabi");
7798 break;
7799 case llvm::Triple::EABIHF:
7800 case llvm::Triple::GNUEABIHF:
7801 CmdArgs.push_back("armelfb_nbsd_eabihf");
7802 break;
7803 default:
7804 CmdArgs.push_back("armelfb_nbsd");
7805 break;
7806 }
7807 break;
Joerg Sonnenbergere7f97592014-02-02 22:59:16 +00007808 case llvm::Triple::mips64:
7809 case llvm::Triple::mips64el:
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00007810 if (mips::hasMipsAbiArg(Args, "32")) {
Joerg Sonnenbergere7f97592014-02-02 22:59:16 +00007811 CmdArgs.push_back("-m");
7812 if (getToolChain().getArch() == llvm::Triple::mips64)
7813 CmdArgs.push_back("elf32btsmip");
7814 else
7815 CmdArgs.push_back("elf32ltsmip");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007816 } else if (mips::hasMipsAbiArg(Args, "64")) {
7817 CmdArgs.push_back("-m");
7818 if (getToolChain().getArch() == llvm::Triple::mips64)
7819 CmdArgs.push_back("elf64btsmip");
7820 else
7821 CmdArgs.push_back("elf64ltsmip");
7822 }
7823 break;
Joerg Sonnenbergerdd13b302014-08-13 14:17:32 +00007824 case llvm::Triple::ppc:
7825 CmdArgs.push_back("-m");
7826 CmdArgs.push_back("elf32ppc_nbsd");
7827 break;
7828
7829 case llvm::Triple::ppc64:
7830 case llvm::Triple::ppc64le:
7831 CmdArgs.push_back("-m");
7832 CmdArgs.push_back("elf64ppc");
7833 break;
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00007834
7835 case llvm::Triple::sparc:
7836 CmdArgs.push_back("-m");
7837 CmdArgs.push_back("elf32_sparc");
7838 break;
7839
7840 case llvm::Triple::sparcv9:
7841 CmdArgs.push_back("-m");
7842 CmdArgs.push_back("elf64_sparc");
7843 break;
7844
Joerg Sonnenberger6cd7deb2014-02-02 22:50:34 +00007845 default:
7846 break;
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00007847 }
7848
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007849 if (Output.isFilename()) {
7850 CmdArgs.push_back("-o");
7851 CmdArgs.push_back(Output.getFilename());
7852 } else {
7853 assert(Output.isNothing() && "Invalid output.");
7854 }
7855
7856 if (!Args.hasArg(options::OPT_nostdlib) &&
7857 !Args.hasArg(options::OPT_nostartfiles)) {
7858 if (!Args.hasArg(options::OPT_shared)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007859 CmdArgs.push_back(
7860 Args.MakeArgString(getToolChain().GetFilePath("crt0.o")));
7861 CmdArgs.push_back(
7862 Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
7863 CmdArgs.push_back(
7864 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007865 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007866 CmdArgs.push_back(
7867 Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
7868 CmdArgs.push_back(
7869 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.o")));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007870 }
7871 }
7872
7873 Args.AddAllArgs(CmdArgs, options::OPT_L);
7874 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
7875 Args.AddAllArgs(CmdArgs, options::OPT_e);
7876 Args.AddAllArgs(CmdArgs, options::OPT_s);
7877 Args.AddAllArgs(CmdArgs, options::OPT_t);
7878 Args.AddAllArgs(CmdArgs, options::OPT_Z_Flag);
7879 Args.AddAllArgs(CmdArgs, options::OPT_r);
7880
7881 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
7882
Joerg Sonnenbergera4435632013-10-14 20:13:05 +00007883 unsigned Major, Minor, Micro;
7884 getToolChain().getTriple().getOSVersion(Major, Minor, Micro);
7885 bool useLibgcc = true;
Joerg Sonnenbergerc8887572014-07-25 20:57:24 +00007886 if (Major >= 7 || (Major == 6 && Minor == 99 && Micro >= 49) || Major == 0) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007887 switch (getToolChain().getArch()) {
Joerg Sonnenberger323cea92014-08-09 18:28:36 +00007888 case llvm::Triple::aarch64:
Joerg Sonnenberger1ea66472014-05-07 08:45:26 +00007889 case llvm::Triple::arm:
7890 case llvm::Triple::armeb:
7891 case llvm::Triple::thumb:
7892 case llvm::Triple::thumbeb:
Joerg Sonnenbergerc8887572014-07-25 20:57:24 +00007893 case llvm::Triple::ppc:
Joerg Sonnenbergerdd13b302014-08-13 14:17:32 +00007894 case llvm::Triple::ppc64:
7895 case llvm::Triple::ppc64le:
Joerg Sonnenbergerd769a1e2014-01-18 00:50:49 +00007896 case llvm::Triple::x86:
7897 case llvm::Triple::x86_64:
Joerg Sonnenbergera4435632013-10-14 20:13:05 +00007898 useLibgcc = false;
Joerg Sonnenbergerd769a1e2014-01-18 00:50:49 +00007899 break;
7900 default:
7901 break;
7902 }
Joerg Sonnenbergera4435632013-10-14 20:13:05 +00007903 }
7904
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007905 if (!Args.hasArg(options::OPT_nostdlib) &&
7906 !Args.hasArg(options::OPT_nodefaultlibs)) {
Joerg Sonnenberger27a69a22015-09-23 20:11:00 +00007907 addOpenMPRuntime(CmdArgs, getToolChain(), Args);
Hans Wennborg70850d82013-07-18 20:29:38 +00007908 if (D.CCCIsCXX()) {
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007909 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
7910 CmdArgs.push_back("-lm");
7911 }
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007912 if (Args.hasArg(options::OPT_pthread))
7913 CmdArgs.push_back("-lpthread");
7914 CmdArgs.push_back("-lc");
7915
Joerg Sonnenbergera4435632013-10-14 20:13:05 +00007916 if (useLibgcc) {
7917 if (Args.hasArg(options::OPT_static)) {
7918 // libgcc_eh depends on libc, so resolve as much as possible,
7919 // pull in any new requirements from libc and then get the rest
7920 // of libgcc.
7921 CmdArgs.push_back("-lgcc_eh");
7922 CmdArgs.push_back("-lc");
7923 CmdArgs.push_back("-lgcc");
7924 } else {
7925 CmdArgs.push_back("-lgcc");
7926 CmdArgs.push_back("--as-needed");
7927 CmdArgs.push_back("-lgcc_s");
7928 CmdArgs.push_back("--no-as-needed");
7929 }
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007930 }
7931 }
7932
7933 if (!Args.hasArg(options::OPT_nostdlib) &&
7934 !Args.hasArg(options::OPT_nostartfiles)) {
7935 if (!Args.hasArg(options::OPT_shared))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007936 CmdArgs.push_back(
7937 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007938 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007939 CmdArgs.push_back(
7940 Args.MakeArgString(getToolChain().GetFilePath("crtendS.o")));
7941 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007942 }
7943
Alexey Samsonov7811d192014-02-20 13:57:37 +00007944 addProfileRT(getToolChain(), Args, CmdArgs);
Nick Lewycky82fe5f42011-05-24 21:54:59 +00007945
Logan Chieneb9162f2014-06-26 14:23:45 +00007946 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007947 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007948}
7949
Douglas Katzman95354292015-06-23 20:42:09 +00007950void gnutools::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
7951 const InputInfo &Output,
7952 const InputInfoList &Inputs,
7953 const ArgList &Args,
7954 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007955 claimNoWarnArgs(Args);
7956
James Y Knight2db38f32015-08-15 03:45:25 +00007957 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
7958 llvm::Triple Triple = llvm::Triple(TripleStr);
7959
Rafael Espindola92b00932010-08-10 00:25:48 +00007960 ArgStringList CmdArgs;
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00007961 bool NeedsKPIC = false;
Rafael Espindola92b00932010-08-10 00:25:48 +00007962
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007963 llvm::Reloc::Model RelocationModel;
7964 unsigned PICLevel;
7965 bool IsPIE;
7966 std::tie(RelocationModel, PICLevel, IsPIE) =
7967 ParsePICArgs(getToolChain(), Triple, Args);
7968
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007969 switch (getToolChain().getArch()) {
7970 default:
7971 break;
Rafael Espindola92b00932010-08-10 00:25:48 +00007972 // Add --32/--64 to make sure we get the format we want.
7973 // This is incomplete
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007974 case llvm::Triple::x86:
Rafael Espindola92b00932010-08-10 00:25:48 +00007975 CmdArgs.push_back("--32");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007976 break;
7977 case llvm::Triple::x86_64:
Zinovy Nis1db95732014-07-10 15:27:19 +00007978 if (getToolChain().getTriple().getEnvironment() == llvm::Triple::GNUX32)
7979 CmdArgs.push_back("--x32");
7980 else
7981 CmdArgs.push_back("--64");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007982 break;
7983 case llvm::Triple::ppc:
Eli Friedman4a4932c2011-11-28 23:46:52 +00007984 CmdArgs.push_back("-a32");
7985 CmdArgs.push_back("-mppc");
7986 CmdArgs.push_back("-many");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007987 break;
7988 case llvm::Triple::ppc64:
Eli Friedman4a4932c2011-11-28 23:46:52 +00007989 CmdArgs.push_back("-a64");
7990 CmdArgs.push_back("-mppc64");
7991 CmdArgs.push_back("-many");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007992 break;
7993 case llvm::Triple::ppc64le:
Bill Schmidt778d3872013-07-26 01:36:11 +00007994 CmdArgs.push_back("-a64");
Will Schmidtc1fc1902014-03-24 17:10:37 +00007995 CmdArgs.push_back("-mppc64");
Bill Schmidt778d3872013-07-26 01:36:11 +00007996 CmdArgs.push_back("-many");
Will Schmidtc1fc1902014-03-24 17:10:37 +00007997 CmdArgs.push_back("-mlittle-endian");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007998 break;
7999 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00008000 case llvm::Triple::sparcel:
Jakob Stoklund Olesen2490e552014-01-10 03:51:29 +00008001 CmdArgs.push_back("-32");
Jakob Stoklund Olesen58801bf2014-01-11 18:25:01 +00008002 CmdArgs.push_back("-Av8plusa");
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00008003 NeedsKPIC = true;
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008004 break;
8005 case llvm::Triple::sparcv9:
Jakob Stoklund Olesen2490e552014-01-10 03:51:29 +00008006 CmdArgs.push_back("-64");
Jakob Stoklund Olesen58801bf2014-01-11 18:25:01 +00008007 CmdArgs.push_back("-Av9a");
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00008008 NeedsKPIC = true;
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008009 break;
8010 case llvm::Triple::arm:
8011 case llvm::Triple::armeb:
8012 case llvm::Triple::thumb:
8013 case llvm::Triple::thumbeb: {
James Y Knight2db38f32015-08-15 03:45:25 +00008014 const llvm::Triple &Triple2 = getToolChain().getTriple();
8015 switch (Triple2.getSubArch()) {
Scott Douglass3205f522015-03-23 10:54:24 +00008016 case llvm::Triple::ARMSubArch_v7:
Rafael Espindola92b00932010-08-10 00:25:48 +00008017 CmdArgs.push_back("-mfpu=neon");
Scott Douglass3205f522015-03-23 10:54:24 +00008018 break;
8019 case llvm::Triple::ARMSubArch_v8:
Bernard Ogdena58ef052013-10-24 18:32:41 +00008020 CmdArgs.push_back("-mfpu=crypto-neon-fp-armv8");
Scott Douglass3205f522015-03-23 10:54:24 +00008021 break;
8022 default:
8023 break;
8024 }
Evgeniy Stepanoved943f62012-04-20 09:03:40 +00008025
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00008026 switch (arm::getARMFloatABI(getToolChain(), Args)) {
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +00008027 case arm::FloatABI::Invalid: llvm_unreachable("must have an ABI!");
8028 case arm::FloatABI::Soft:
8029 CmdArgs.push_back(Args.MakeArgString("-mfloat-abi=soft"));
8030 break;
8031 case arm::FloatABI::SoftFP:
8032 CmdArgs.push_back(Args.MakeArgString("-mfloat-abi=softfp"));
8033 break;
8034 case arm::FloatABI::Hard:
8035 CmdArgs.push_back(Args.MakeArgString("-mfloat-abi=hard"));
8036 break;
8037 }
Evgeniy Stepanov582911a2012-04-24 09:05:31 +00008038
8039 Args.AddLastArg(CmdArgs, options::OPT_march_EQ);
Ana Pazosdd6068d2013-12-06 22:43:17 +00008040
8041 // FIXME: remove krait check when GNU tools support krait cpu
8042 // for now replace it with -march=armv7-a to avoid a lower
8043 // march from being picked in the absence of a cpu flag.
8044 Arg *A;
8045 if ((A = Args.getLastArg(options::OPT_mcpu_EQ)) &&
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008046 StringRef(A->getValue()).lower() == "krait")
8047 CmdArgs.push_back("-march=armv7-a");
Ana Pazosdd6068d2013-12-06 22:43:17 +00008048 else
8049 Args.AddLastArg(CmdArgs, options::OPT_mcpu_EQ);
Evgeniy Stepanov582911a2012-04-24 09:05:31 +00008050 Args.AddLastArg(CmdArgs, options::OPT_mfpu_EQ);
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008051 break;
8052 }
8053 case llvm::Triple::mips:
8054 case llvm::Triple::mipsel:
8055 case llvm::Triple::mips64:
8056 case llvm::Triple::mips64el: {
Simon Atanasyan571d7bd2012-04-07 22:31:29 +00008057 StringRef CPUName;
8058 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00008059 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Daniel Sanders379d44b2014-07-16 11:52:23 +00008060 ABIName = getGnuCompatibleMipsABIName(ABIName);
Akira Hatanaka5e9dde32011-11-30 19:31:38 +00008061
Simon Atanasyan571d7bd2012-04-07 22:31:29 +00008062 CmdArgs.push_back("-march");
8063 CmdArgs.push_back(CPUName.data());
8064
Simon Atanasyan571d7bd2012-04-07 22:31:29 +00008065 CmdArgs.push_back("-mabi");
Daniel Sanders379d44b2014-07-16 11:52:23 +00008066 CmdArgs.push_back(ABIName.data());
8067
Daniel Sanders54d8ee62014-07-23 12:06:13 +00008068 // -mno-shared should be emitted unless -fpic, -fpie, -fPIC, -fPIE,
8069 // or -mshared (not implemented) is in effect.
James Y Knight5bdf7ab2015-08-19 15:12:02 +00008070 if (RelocationModel == llvm::Reloc::Static)
Daniel Sanders54d8ee62014-07-23 12:06:13 +00008071 CmdArgs.push_back("-mno-shared");
8072
Daniel Sanders379d44b2014-07-16 11:52:23 +00008073 // LLVM doesn't support -mplt yet and acts as if it is always given.
8074 // However, -mplt has no effect with the N64 ABI.
8075 CmdArgs.push_back(ABIName == "64" ? "-KPIC" : "-call_nonpic");
Simon Atanasyan2390aa12012-04-06 19:15:24 +00008076
8077 if (getToolChain().getArch() == llvm::Triple::mips ||
8078 getToolChain().getArch() == llvm::Triple::mips64)
8079 CmdArgs.push_back("-EB");
8080 else
8081 CmdArgs.push_back("-EL");
Simon Atanasyan217dc2d2012-05-29 19:07:33 +00008082
Simon Atanasyan22127ce2013-09-24 09:09:16 +00008083 if (Arg *A = Args.getLastArg(options::OPT_mnan_EQ)) {
8084 if (StringRef(A->getValue()) == "2008")
8085 CmdArgs.push_back(Args.MakeArgString("-mnan=2008"));
8086 }
8087
Daniel Sanders379d44b2014-07-16 11:52:23 +00008088 // Add the last -mfp32/-mfpxx/-mfp64 or -mfpxx if it is enabled by default.
8089 if (Arg *A = Args.getLastArg(options::OPT_mfp32, options::OPT_mfpxx,
8090 options::OPT_mfp64)) {
8091 A->claim();
8092 A->render(Args, CmdArgs);
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00008093 } else if (mips::shouldUseFPXX(
8094 Args, getToolChain().getTriple(), CPUName, ABIName,
8095 getMipsFloatABI(getToolChain().getDriver(), Args)))
Daniel Sanders379d44b2014-07-16 11:52:23 +00008096 CmdArgs.push_back("-mfpxx");
8097
8098 // Pass on -mmips16 or -mno-mips16. However, the assembler equivalent of
8099 // -mno-mips16 is actually -no-mips16.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008100 if (Arg *A =
8101 Args.getLastArg(options::OPT_mips16, options::OPT_mno_mips16)) {
Daniel Sanders379d44b2014-07-16 11:52:23 +00008102 if (A->getOption().matches(options::OPT_mips16)) {
8103 A->claim();
8104 A->render(Args, CmdArgs);
8105 } else {
8106 A->claim();
8107 CmdArgs.push_back("-no-mips16");
8108 }
8109 }
8110
Simon Atanasyan036d16d2013-04-30 07:47:13 +00008111 Args.AddLastArg(CmdArgs, options::OPT_mmicromips,
8112 options::OPT_mno_micromips);
8113 Args.AddLastArg(CmdArgs, options::OPT_mdsp, options::OPT_mno_dsp);
8114 Args.AddLastArg(CmdArgs, options::OPT_mdspr2, options::OPT_mno_dspr2);
8115
Simon Atanasyanbd986632013-11-26 11:58:04 +00008116 if (Arg *A = Args.getLastArg(options::OPT_mmsa, options::OPT_mno_msa)) {
8117 // Do not use AddLastArg because not all versions of MIPS assembler
8118 // support -mmsa / -mno-msa options.
8119 if (A->getOption().matches(options::OPT_mmsa))
8120 CmdArgs.push_back(Args.MakeArgString("-mmsa"));
8121 }
8122
Daniel Sanders379d44b2014-07-16 11:52:23 +00008123 Args.AddLastArg(CmdArgs, options::OPT_mhard_float,
8124 options::OPT_msoft_float);
8125
Toma Tabacub36d6102015-06-11 12:13:18 +00008126 Args.AddLastArg(CmdArgs, options::OPT_mdouble_float,
8127 options::OPT_msingle_float);
8128
Daniel Sanders379d44b2014-07-16 11:52:23 +00008129 Args.AddLastArg(CmdArgs, options::OPT_modd_spreg,
8130 options::OPT_mno_odd_spreg);
8131
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00008132 NeedsKPIC = true;
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008133 break;
8134 }
8135 case llvm::Triple::systemz: {
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00008136 // Always pass an -march option, since our default of z10 is later
8137 // than the GNU assembler's default.
8138 StringRef CPUName = getSystemZTargetCPU(Args);
8139 CmdArgs.push_back(Args.MakeArgString("-march=" + CPUName));
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008140 break;
8141 }
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00008142 }
8143
James Y Knight5bdf7ab2015-08-19 15:12:02 +00008144 if (NeedsKPIC) {
8145 if (RelocationModel != llvm::Reloc::Static)
8146 CmdArgs.push_back("-KPIC");
8147 }
Rafael Espindola92b00932010-08-10 00:25:48 +00008148
Renato Golina74bbc72015-07-22 15:32:36 +00008149 Args.AddAllArgs(CmdArgs, options::OPT_I);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008150 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Rafael Espindola92b00932010-08-10 00:25:48 +00008151
8152 CmdArgs.push_back("-o");
8153 CmdArgs.push_back(Output.getFilename());
8154
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008155 for (const auto &II : Inputs)
Rafael Espindola92b00932010-08-10 00:25:48 +00008156 CmdArgs.push_back(II.getFilename());
Rafael Espindola92b00932010-08-10 00:25:48 +00008157
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008158 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00008159 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eric Christopher30aa6b62013-06-05 23:58:15 +00008160
8161 // Handle the debug info splitting at object creation time if we're
8162 // creating an object.
8163 // TODO: Currently only works on linux with newer objcopy.
8164 if (Args.hasArg(options::OPT_gsplit_dwarf) &&
Cameron Esfahani556d91e2013-09-14 01:09:11 +00008165 getToolChain().getTriple().isOSLinux())
Eric Christopher30aa6b62013-06-05 23:58:15 +00008166 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output,
Artem Belevichba558952015-05-06 18:20:23 +00008167 SplitDebugName(Args, Inputs[0]));
Rafael Espindola92b00932010-08-10 00:25:48 +00008168}
8169
Benjamin Kramer9299637dc2014-03-04 19:31:42 +00008170static void AddLibgcc(const llvm::Triple &Triple, const Driver &D,
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008171 ArgStringList &CmdArgs, const ArgList &Args) {
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00008172 bool isAndroid = Triple.isAndroid();
Reid Kleckner0213a472015-07-22 16:01:38 +00008173 bool isCygMing = Triple.isOSCygMing();
Chandler Carruth58d6eb62013-03-04 02:07:55 +00008174 bool StaticLibgcc = Args.hasArg(options::OPT_static_libgcc) ||
8175 Args.hasArg(options::OPT_static);
Hans Wennborg70850d82013-07-18 20:29:38 +00008176 if (!D.CCCIsCXX())
Rafael Espindolacc354322011-10-17 21:39:04 +00008177 CmdArgs.push_back("-lgcc");
8178
Logan Chien3d3373c2012-11-19 12:04:11 +00008179 if (StaticLibgcc || isAndroid) {
Hans Wennborg70850d82013-07-18 20:29:38 +00008180 if (D.CCCIsCXX())
Rafael Espindolacc354322011-10-17 21:39:04 +00008181 CmdArgs.push_back("-lgcc");
8182 } else {
Reid Kleckner0213a472015-07-22 16:01:38 +00008183 if (!D.CCCIsCXX() && !isCygMing)
Rafael Espindolacc354322011-10-17 21:39:04 +00008184 CmdArgs.push_back("--as-needed");
8185 CmdArgs.push_back("-lgcc_s");
Reid Kleckner0213a472015-07-22 16:01:38 +00008186 if (!D.CCCIsCXX() && !isCygMing)
Rafael Espindolacc354322011-10-17 21:39:04 +00008187 CmdArgs.push_back("--no-as-needed");
8188 }
8189
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008190 if (StaticLibgcc && !isAndroid)
Rafael Espindolacc354322011-10-17 21:39:04 +00008191 CmdArgs.push_back("-lgcc_eh");
Hans Wennborg70850d82013-07-18 20:29:38 +00008192 else if (!Args.hasArg(options::OPT_shared) && D.CCCIsCXX())
Rafael Espindolacc354322011-10-17 21:39:04 +00008193 CmdArgs.push_back("-lgcc");
Logan Chien3d3373c2012-11-19 12:04:11 +00008194
8195 // According to Android ABI, we have to link with libdl if we are
8196 // linking with non-static libgcc.
8197 //
8198 // NOTE: This fixes a link error on Android MIPS as well. The non-static
8199 // libgcc for MIPS relies on _Unwind_Find_FDE and dl_iterate_phdr from libdl.
8200 if (isAndroid && !StaticLibgcc)
8201 CmdArgs.push_back("-ldl");
Rafael Espindolacc354322011-10-17 21:39:04 +00008202}
8203
Simon Atanasyan2c590ff2014-08-04 12:57:52 +00008204static std::string getLinuxDynamicLinker(const ArgList &Args,
8205 const toolchains::Linux &ToolChain) {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008206 const llvm::Triple::ArchType Arch = ToolChain.getArch();
8207
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00008208 if (ToolChain.getTriple().isAndroid()) {
Alexey Bataevcf7ae302014-01-23 09:08:32 +00008209 if (ToolChain.getTriple().isArch64Bit())
8210 return "/system/bin/linker64";
8211 else
8212 return "/system/bin/linker";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008213 } else if (Arch == llvm::Triple::x86 || Arch == llvm::Triple::sparc ||
8214 Arch == llvm::Triple::sparcel)
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008215 return "/lib/ld-linux.so.2";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008216 else if (Arch == llvm::Triple::aarch64)
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008217 return "/lib/ld-linux-aarch64.so.1";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008218 else if (Arch == llvm::Triple::aarch64_be)
Christian Pirkera74c7912014-03-14 12:15:45 +00008219 return "/lib/ld-linux-aarch64_be.so.1";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008220 else if (Arch == llvm::Triple::arm || Arch == llvm::Triple::thumb) {
Renato Golin24ba3e92015-07-27 09:56:37 +00008221 if (ToolChain.getTriple().getEnvironment() == llvm::Triple::GNUEABIHF ||
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00008222 arm::getARMFloatABI(ToolChain, Args) == arm::FloatABI::Hard)
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008223 return "/lib/ld-linux-armhf.so.3";
8224 else
8225 return "/lib/ld-linux.so.3";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008226 } else if (Arch == llvm::Triple::armeb || Arch == llvm::Triple::thumbeb) {
8227 // TODO: check which dynamic linker name.
Renato Golin24ba3e92015-07-27 09:56:37 +00008228 if (ToolChain.getTriple().getEnvironment() == llvm::Triple::GNUEABIHF ||
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00008229 arm::getARMFloatABI(ToolChain, Args) == arm::FloatABI::Hard)
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008230 return "/lib/ld-linux-armhf.so.3";
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00008231 else
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008232 return "/lib/ld-linux.so.3";
8233 } else if (Arch == llvm::Triple::mips || Arch == llvm::Triple::mipsel ||
8234 Arch == llvm::Triple::mips64 || Arch == llvm::Triple::mips64el) {
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00008235 StringRef CPUName;
8236 StringRef ABIName;
8237 mips::getMipsCPUAndABI(Args, ToolChain.getTriple(), CPUName, ABIName);
Vasileios Kalintiris69675272015-10-05 09:12:36 +00008238 bool IsNaN2008 = mips::isNaN2008(Args, ToolChain.getTriple());
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00008239
8240 StringRef LibDir = llvm::StringSwitch<llvm::StringRef>(ABIName)
8241 .Case("o32", "/lib")
8242 .Case("n32", "/lib32")
8243 .Case("n64", "/lib64")
8244 .Default("/lib");
8245 StringRef LibName;
Simon Atanasyand95c67d2014-08-13 14:34:14 +00008246 if (mips::isUCLibc(Args))
8247 LibName = IsNaN2008 ? "ld-uClibc-mipsn8.so.0" : "ld-uClibc.so.0";
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00008248 else
Simon Atanasyand95c67d2014-08-13 14:34:14 +00008249 LibName = IsNaN2008 ? "ld-linux-mipsn8.so.1" : "ld.so.1";
Simon Atanasyan2c590ff2014-08-04 12:57:52 +00008250
8251 return (LibDir + "/" + LibName).str();
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008252 } else if (Arch == llvm::Triple::ppc)
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008253 return "/lib/ld.so.1";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008254 else if (Arch == llvm::Triple::ppc64) {
Ulrich Weigand8afad612014-07-28 13:17:52 +00008255 if (ppc::hasPPCAbiArg(Args, "elfv2"))
8256 return "/lib64/ld64.so.2";
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008257 return "/lib64/ld64.so.1";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008258 } else if (Arch == llvm::Triple::ppc64le) {
Ulrich Weigand8afad612014-07-28 13:17:52 +00008259 if (ppc::hasPPCAbiArg(Args, "elfv1"))
8260 return "/lib64/ld64.so.1";
Ulrich Weigand68e902c2014-06-20 14:19:02 +00008261 return "/lib64/ld64.so.2";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008262 } else if (Arch == llvm::Triple::systemz)
Sylvestre Ledruc0babf22015-08-28 12:26:09 +00008263 return "/lib/ld64.so.1";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008264 else if (Arch == llvm::Triple::sparcv9)
Jakob Stoklund Olesen73cb84c2014-01-10 08:18:34 +00008265 return "/lib64/ld-linux.so.2";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008266 else if (Arch == llvm::Triple::x86_64 &&
Zinovy Nis1db95732014-07-10 15:27:19 +00008267 ToolChain.getTriple().getEnvironment() == llvm::Triple::GNUX32)
8268 return "/libx32/ld-linux-x32.so.2";
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008269 else
8270 return "/lib64/ld-linux-x86-64.so.2";
8271}
8272
Renato Golinc4b49242014-02-13 10:01:16 +00008273static void AddRunTimeLibs(const ToolChain &TC, const Driver &D,
Saleem Abdulrasool2e46ebe2014-12-30 22:52:06 +00008274 ArgStringList &CmdArgs, const ArgList &Args) {
Renato Golinc4b49242014-02-13 10:01:16 +00008275 // Make use of compiler-rt if --rtlib option is used
8276 ToolChain::RuntimeLibType RLT = TC.GetRuntimeLibType(Args);
8277
Saleem Abdulrasool8d7ade72014-12-30 02:10:36 +00008278 switch (RLT) {
Renato Golinc4b49242014-02-13 10:01:16 +00008279 case ToolChain::RLT_CompilerRT:
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00008280 switch (TC.getTriple().getOS()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008281 default:
8282 llvm_unreachable("unsupported OS");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00008283 case llvm::Triple::Win32:
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00008284 case llvm::Triple::Linux:
Saleem Abdulrasool8d7ade72014-12-30 02:10:36 +00008285 addClangRT(TC, Args, CmdArgs);
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00008286 break;
8287 }
Renato Golinc4b49242014-02-13 10:01:16 +00008288 break;
8289 case ToolChain::RLT_Libgcc:
8290 AddLibgcc(TC.getTriple(), D, CmdArgs, Args);
8291 break;
Renato Golinc4b49242014-02-13 10:01:16 +00008292 }
8293}
8294
Rafael Espindola1e085772014-08-15 17:14:35 +00008295static const char *getLDMOption(const llvm::Triple &T, const ArgList &Args) {
8296 switch (T.getArch()) {
8297 case llvm::Triple::x86:
8298 return "elf_i386";
8299 case llvm::Triple::aarch64:
8300 return "aarch64linux";
8301 case llvm::Triple::aarch64_be:
8302 return "aarch64_be_linux";
8303 case llvm::Triple::arm:
8304 case llvm::Triple::thumb:
8305 return "armelf_linux_eabi";
8306 case llvm::Triple::armeb:
8307 case llvm::Triple::thumbeb:
8308 return "armebelf_linux_eabi"; /* TODO: check which NAME. */
8309 case llvm::Triple::ppc:
8310 return "elf32ppclinux";
8311 case llvm::Triple::ppc64:
8312 return "elf64ppc";
8313 case llvm::Triple::ppc64le:
8314 return "elf64lppc";
8315 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00008316 case llvm::Triple::sparcel:
Rafael Espindola1e085772014-08-15 17:14:35 +00008317 return "elf32_sparc";
8318 case llvm::Triple::sparcv9:
8319 return "elf64_sparc";
8320 case llvm::Triple::mips:
8321 return "elf32btsmip";
8322 case llvm::Triple::mipsel:
8323 return "elf32ltsmip";
8324 case llvm::Triple::mips64:
8325 if (mips::hasMipsAbiArg(Args, "n32"))
8326 return "elf32btsmipn32";
8327 return "elf64btsmip";
8328 case llvm::Triple::mips64el:
8329 if (mips::hasMipsAbiArg(Args, "n32"))
8330 return "elf32ltsmipn32";
8331 return "elf64ltsmip";
8332 case llvm::Triple::systemz:
8333 return "elf64_s390";
8334 case llvm::Triple::x86_64:
8335 if (T.getEnvironment() == llvm::Triple::GNUX32)
8336 return "elf32_x86_64";
8337 return "elf_x86_64";
8338 default:
8339 llvm_unreachable("Unexpected arch");
8340 }
8341}
8342
Douglas Katzman95354292015-06-23 20:42:09 +00008343void gnutools::Linker::ConstructJob(Compilation &C, const JobAction &JA,
8344 const InputInfo &Output,
8345 const InputInfoList &Inputs,
8346 const ArgList &Args,
8347 const char *LinkingOutput) const {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008348 const toolchains::Linux &ToolChain =
8349 static_cast<const toolchains::Linux &>(getToolChain());
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008350 const Driver &D = ToolChain.getDriver();
James Y Knight2db38f32015-08-15 03:45:25 +00008351
8352 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
8353 llvm::Triple Triple = llvm::Triple(TripleStr);
8354
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008355 const llvm::Triple::ArchType Arch = ToolChain.getArch();
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00008356 const bool isAndroid = ToolChain.getTriple().isAndroid();
Peter Collingbourne54d770c2013-04-09 04:35:11 +00008357 const bool IsPIE =
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008358 !Args.hasArg(options::OPT_shared) && !Args.hasArg(options::OPT_static) &&
8359 (Args.hasArg(options::OPT_pie) || ToolChain.isPIEDefault());
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008360
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008361 ArgStringList CmdArgs;
8362
Rafael Espindolad1002f62010-11-15 18:28:16 +00008363 // Silence warning for "clang -g foo.o -o foo"
8364 Args.ClaimAllArgs(options::OPT_g_Group);
Rafael Espindolad95a8122011-03-01 05:25:27 +00008365 // and "clang -emit-llvm foo.o -o foo"
8366 Args.ClaimAllArgs(options::OPT_emit_llvm);
David Chisnall5f99f482012-07-29 15:24:44 +00008367 // and for "clang -w foo.o -o foo". Other warning options are already
Rafael Espindolaf92614c2010-11-17 20:37:10 +00008368 // handled somewhere else.
8369 Args.ClaimAllArgs(options::OPT_w);
Rafael Espindolad1002f62010-11-15 18:28:16 +00008370
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00008371 if (!D.SysRoot.empty())
8372 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008373
Peter Collingbourne54d770c2013-04-09 04:35:11 +00008374 if (IsPIE)
Rafael Espindolad47ac232010-11-17 22:26:15 +00008375 CmdArgs.push_back("-pie");
8376
Rafael Espindola1c76c592010-11-07 22:57:16 +00008377 if (Args.hasArg(options::OPT_rdynamic))
8378 CmdArgs.push_back("-export-dynamic");
8379
Rafael Espindola34d77dc2010-11-11 19:34:42 +00008380 if (Args.hasArg(options::OPT_s))
8381 CmdArgs.push_back("-s");
8382
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008383 if (Arch == llvm::Triple::armeb || Arch == llvm::Triple::thumbeb)
James Y Knight2db38f32015-08-15 03:45:25 +00008384 arm::appendEBLinkFlags(Args, CmdArgs, Triple);
Joerg Sonnenberger1689d3f2015-01-28 23:30:39 +00008385
NAKAMURA Takumi557fb622014-06-29 16:00:11 +00008386 for (const auto &Opt : ToolChain.ExtraOpts)
8387 CmdArgs.push_back(Opt.c_str());
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008388
8389 if (!Args.hasArg(options::OPT_static)) {
8390 CmdArgs.push_back("--eh-frame-hdr");
8391 }
8392
8393 CmdArgs.push_back("-m");
Rafael Espindola1e085772014-08-15 17:14:35 +00008394 CmdArgs.push_back(getLDMOption(ToolChain.getTriple(), Args));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008395
8396 if (Args.hasArg(options::OPT_static)) {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008397 if (Arch == llvm::Triple::arm || Arch == llvm::Triple::armeb ||
8398 Arch == llvm::Triple::thumb || Arch == llvm::Triple::thumbeb)
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008399 CmdArgs.push_back("-Bstatic");
8400 else
8401 CmdArgs.push_back("-static");
8402 } else if (Args.hasArg(options::OPT_shared)) {
8403 CmdArgs.push_back("-shared");
8404 }
8405
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008406 if (Arch == llvm::Triple::arm || Arch == llvm::Triple::armeb ||
8407 Arch == llvm::Triple::thumb || Arch == llvm::Triple::thumbeb ||
NAKAMURA Takumi557fb622014-06-29 16:00:11 +00008408 (!Args.hasArg(options::OPT_static) &&
8409 !Args.hasArg(options::OPT_shared))) {
8410 CmdArgs.push_back("-dynamic-linker");
8411 CmdArgs.push_back(Args.MakeArgString(
8412 D.DyldPrefix + getLinuxDynamicLinker(Args, ToolChain)));
8413 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008414
8415 CmdArgs.push_back("-o");
8416 CmdArgs.push_back(Output.getFilename());
8417
Rafael Espindola81937ec2010-12-01 01:52:43 +00008418 if (!Args.hasArg(options::OPT_nostdlib) &&
8419 !Args.hasArg(options::OPT_nostartfiles)) {
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008420 if (!isAndroid) {
Craig Topper92fc2df2014-05-17 16:56:41 +00008421 const char *crt1 = nullptr;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008422 if (!Args.hasArg(options::OPT_shared)) {
Eric Christopherac021742013-06-07 23:25:01 +00008423 if (Args.hasArg(options::OPT_pg))
8424 crt1 = "gcrt1.o";
8425 else if (IsPIE)
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008426 crt1 = "Scrt1.o";
8427 else
8428 crt1 = "crt1.o";
8429 }
8430 if (crt1)
8431 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crt1)));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008432
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008433 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
8434 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008435
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008436 const char *crtbegin;
8437 if (Args.hasArg(options::OPT_static))
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008438 crtbegin = isAndroid ? "crtbegin_static.o" : "crtbeginT.o";
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00008439 else if (Args.hasArg(options::OPT_shared))
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008440 crtbegin = isAndroid ? "crtbegin_so.o" : "crtbeginS.o";
Peter Collingbourne54d770c2013-04-09 04:35:11 +00008441 else if (IsPIE)
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00008442 crtbegin = isAndroid ? "crtbegin_dynamic.o" : "crtbeginS.o";
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008443 else
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008444 crtbegin = isAndroid ? "crtbegin_dynamic.o" : "crtbegin.o";
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00008445 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtbegin)));
Benjamin Kramer058666a2012-10-04 19:42:20 +00008446
8447 // Add crtfastmath.o if available and fast math is enabled.
8448 ToolChain.AddFastMathRuntimeIfAvailable(Args, CmdArgs);
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008449 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008450
8451 Args.AddAllArgs(CmdArgs, options::OPT_L);
Reid Kleckner69071442014-06-26 01:08:54 +00008452 Args.AddAllArgs(CmdArgs, options::OPT_u);
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008453
Benjamin Kramer22c68ef2014-09-11 14:13:49 +00008454 const ToolChain::path_list &Paths = ToolChain.getFilePaths();
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008455
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008456 for (const auto &Path : Paths)
8457 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008458
Alexey Samsonov907880e2015-06-19 19:57:46 +00008459 if (D.IsUsingLTO(Args))
Alp Tokerce365ca2013-12-02 12:43:03 +00008460 AddGoldPlugin(ToolChain, Args, CmdArgs);
Chandler Carruth953fb082013-01-13 11:46:33 +00008461
Nick Lewycky2fe6aab2012-08-17 03:39:16 +00008462 if (Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
8463 CmdArgs.push_back("--no-demangle");
8464
Alexey Samsonov52550342014-09-15 19:58:40 +00008465 bool NeedsSanitizerDeps = addSanitizerRuntimes(ToolChain, Args, CmdArgs);
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008466 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
Chandler Carruthe4458b32013-06-24 09:38:45 +00008467 // The profile runtime also needs access to system libraries.
Alexey Samsonov7811d192014-02-20 13:57:37 +00008468 addProfileRT(getToolChain(), Args, CmdArgs);
Chandler Carruthe4458b32013-06-24 09:38:45 +00008469
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008470 if (D.CCCIsCXX() && !Args.hasArg(options::OPT_nostdlib) &&
Chandler Carruth94a32012012-05-14 18:31:18 +00008471 !Args.hasArg(options::OPT_nodefaultlibs)) {
Rafael Espindola70b8d762011-10-17 22:14:51 +00008472 bool OnlyLibstdcxxStatic = Args.hasArg(options::OPT_static_libstdcxx) &&
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008473 !Args.hasArg(options::OPT_static);
Rafael Espindola70b8d762011-10-17 22:14:51 +00008474 if (OnlyLibstdcxxStatic)
8475 CmdArgs.push_back("-Bstatic");
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008476 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
Rafael Espindola70b8d762011-10-17 22:14:51 +00008477 if (OnlyLibstdcxxStatic)
8478 CmdArgs.push_back("-Bdynamic");
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008479 CmdArgs.push_back("-lm");
8480 }
Chandler Carruth7e7dd472015-03-07 10:01:29 +00008481 // Silence warnings when linking C code with a C++ '-stdlib' argument.
8482 Args.ClaimAllArgs(options::OPT_stdlib_EQ);
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008483
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008484 if (!Args.hasArg(options::OPT_nostdlib)) {
Chandler Carruth94a32012012-05-14 18:31:18 +00008485 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
8486 if (Args.hasArg(options::OPT_static))
8487 CmdArgs.push_back("--start-group");
Nick Lewycky97864da2011-06-04 06:27:06 +00008488
Alexey Samsonov52550342014-09-15 19:58:40 +00008489 if (NeedsSanitizerDeps)
8490 linkSanitizerRuntimeDeps(ToolChain, CmdArgs);
8491
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00008492 bool WantPthread = Args.hasArg(options::OPT_pthread) ||
8493 Args.hasArg(options::OPT_pthreads);
8494
8495 if (Args.hasFlag(options::OPT_fopenmp, options::OPT_fopenmp_EQ,
8496 options::OPT_fno_openmp, false)) {
8497 // OpenMP runtimes implies pthreads when using the GNU toolchain.
8498 // FIXME: Does this really make sense for all GNU toolchains?
8499 WantPthread = true;
8500
8501 // Also link the particular OpenMP runtimes.
8502 switch (getOpenMPRuntime(ToolChain, Args)) {
8503 case OMPRT_OMP:
8504 CmdArgs.push_back("-lomp");
8505 break;
8506 case OMPRT_GOMP:
Richard Smith31d1de22015-05-20 22:48:44 +00008507 CmdArgs.push_back("-lgomp");
8508
8509 // FIXME: Exclude this for platforms with libgomp that don't require
8510 // librt. Most modern Linux platforms require it, but some may not.
8511 CmdArgs.push_back("-lrt");
8512 break;
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00008513 case OMPRT_IOMP5:
Richard Smith31d1de22015-05-20 22:48:44 +00008514 CmdArgs.push_back("-liomp5");
8515 break;
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00008516 case OMPRT_Unknown:
8517 // Already diagnosed.
Richard Smith31d1de22015-05-20 22:48:44 +00008518 break;
8519 }
Chandler Carruth01538002013-01-17 13:19:29 +00008520 }
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00008521
Renato Golinc4b49242014-02-13 10:01:16 +00008522 AddRunTimeLibs(ToolChain, D, CmdArgs, Args);
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008523
Richard Smith31d1de22015-05-20 22:48:44 +00008524 if (WantPthread && !isAndroid)
Chandler Carruth94a32012012-05-14 18:31:18 +00008525 CmdArgs.push_back("-lpthread");
8526
8527 CmdArgs.push_back("-lc");
8528
8529 if (Args.hasArg(options::OPT_static))
8530 CmdArgs.push_back("--end-group");
8531 else
Renato Golinc4b49242014-02-13 10:01:16 +00008532 AddRunTimeLibs(ToolChain, D, CmdArgs, Args);
Chandler Carruth94a32012012-05-14 18:31:18 +00008533 }
Rafael Espindolad47ac232010-11-17 22:26:15 +00008534
Rafael Espindola81937ec2010-12-01 01:52:43 +00008535 if (!Args.hasArg(options::OPT_nostartfiles)) {
8536 const char *crtend;
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00008537 if (Args.hasArg(options::OPT_shared))
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008538 crtend = isAndroid ? "crtend_so.o" : "crtendS.o";
Peter Collingbourne54d770c2013-04-09 04:35:11 +00008539 else if (IsPIE)
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00008540 crtend = isAndroid ? "crtend_android.o" : "crtendS.o";
Rafael Espindola81937ec2010-12-01 01:52:43 +00008541 else
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008542 crtend = isAndroid ? "crtend_android.o" : "crtend.o";
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008543
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00008544 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtend)));
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008545 if (!isAndroid)
8546 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
Rafael Espindola81937ec2010-12-01 01:52:43 +00008547 }
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00008548 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008549
Justin Bognerd3371d82015-07-17 03:35:54 +00008550 C.addCommand(llvm::make_unique<Command>(JA, *this, ToolChain.Linker.c_str(),
8551 CmdArgs, Inputs));
Saleem Abdulrasoola4a474b2014-06-29 06:11:14 +00008552}
8553
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008554// NaCl ARM assembly (inline or standalone) can be written with a set of macros
8555// for the various SFI requirements like register masking. The assembly tool
8556// inserts the file containing the macros as an input into all the assembly
8557// jobs.
Douglas Katzman95354292015-06-23 20:42:09 +00008558void nacltools::AssemblerARM::ConstructJob(Compilation &C, const JobAction &JA,
8559 const InputInfo &Output,
8560 const InputInfoList &Inputs,
8561 const ArgList &Args,
8562 const char *LinkingOutput) const {
Douglas Katzman54366072015-07-27 16:53:08 +00008563 const toolchains::NaClToolChain &ToolChain =
8564 static_cast<const toolchains::NaClToolChain &>(getToolChain());
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008565 InputInfo NaClMacros(ToolChain.GetNaClArmMacrosPath(), types::TY_PP_Asm,
8566 "nacl-arm-macros.s");
8567 InputInfoList NewInputs;
8568 NewInputs.push_back(NaClMacros);
8569 NewInputs.append(Inputs.begin(), Inputs.end());
Douglas Katzman95354292015-06-23 20:42:09 +00008570 gnutools::Assembler::ConstructJob(C, JA, Output, NewInputs, Args,
8571 LinkingOutput);
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008572}
8573
Douglas Katzman750cfc52015-06-29 18:42:16 +00008574// This is quite similar to gnutools::Linker::ConstructJob with changes that
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008575// we use static by default, do not yet support sanitizers or LTO, and a few
8576// others. Eventually we can support more of that and hopefully migrate back
Douglas Katzman750cfc52015-06-29 18:42:16 +00008577// to gnutools::Linker.
Douglas Katzman95354292015-06-23 20:42:09 +00008578void nacltools::Linker::ConstructJob(Compilation &C, const JobAction &JA,
8579 const InputInfo &Output,
8580 const InputInfoList &Inputs,
8581 const ArgList &Args,
8582 const char *LinkingOutput) const {
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008583
Douglas Katzman54366072015-07-27 16:53:08 +00008584 const toolchains::NaClToolChain &ToolChain =
8585 static_cast<const toolchains::NaClToolChain &>(getToolChain());
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008586 const Driver &D = ToolChain.getDriver();
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008587 const llvm::Triple::ArchType Arch = ToolChain.getArch();
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008588 const bool IsStatic =
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008589 !Args.hasArg(options::OPT_dynamic) && !Args.hasArg(options::OPT_shared);
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008590
8591 ArgStringList CmdArgs;
8592
8593 // Silence warning for "clang -g foo.o -o foo"
8594 Args.ClaimAllArgs(options::OPT_g_Group);
8595 // and "clang -emit-llvm foo.o -o foo"
8596 Args.ClaimAllArgs(options::OPT_emit_llvm);
8597 // and for "clang -w foo.o -o foo". Other warning options are already
8598 // handled somewhere else.
8599 Args.ClaimAllArgs(options::OPT_w);
8600
8601 if (!D.SysRoot.empty())
8602 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
8603
8604 if (Args.hasArg(options::OPT_rdynamic))
8605 CmdArgs.push_back("-export-dynamic");
8606
8607 if (Args.hasArg(options::OPT_s))
8608 CmdArgs.push_back("-s");
8609
Douglas Katzman54366072015-07-27 16:53:08 +00008610 // NaClToolChain doesn't have ExtraOpts like Linux; the only relevant flag
8611 // from there is --build-id, which we do want.
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008612 CmdArgs.push_back("--build-id");
8613
8614 if (!IsStatic)
8615 CmdArgs.push_back("--eh-frame-hdr");
8616
8617 CmdArgs.push_back("-m");
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008618 if (Arch == llvm::Triple::x86)
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008619 CmdArgs.push_back("elf_i386_nacl");
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008620 else if (Arch == llvm::Triple::arm)
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008621 CmdArgs.push_back("armelf_nacl");
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008622 else if (Arch == llvm::Triple::x86_64)
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008623 CmdArgs.push_back("elf_x86_64_nacl");
Petar Jovanovic26a4a402015-07-08 13:07:31 +00008624 else if (Arch == llvm::Triple::mipsel)
8625 CmdArgs.push_back("mipselelf_nacl");
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008626 else
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008627 D.Diag(diag::err_target_unsupported_arch) << ToolChain.getArchName()
8628 << "Native Client";
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008629
8630 if (IsStatic)
8631 CmdArgs.push_back("-static");
8632 else if (Args.hasArg(options::OPT_shared))
8633 CmdArgs.push_back("-shared");
8634
8635 CmdArgs.push_back("-o");
8636 CmdArgs.push_back(Output.getFilename());
8637 if (!Args.hasArg(options::OPT_nostdlib) &&
8638 !Args.hasArg(options::OPT_nostartfiles)) {
8639 if (!Args.hasArg(options::OPT_shared))
8640 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crt1.o")));
8641 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
8642
8643 const char *crtbegin;
8644 if (IsStatic)
8645 crtbegin = "crtbeginT.o";
8646 else if (Args.hasArg(options::OPT_shared))
8647 crtbegin = "crtbeginS.o";
8648 else
8649 crtbegin = "crtbegin.o";
8650 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtbegin)));
8651 }
8652
8653 Args.AddAllArgs(CmdArgs, options::OPT_L);
8654 Args.AddAllArgs(CmdArgs, options::OPT_u);
8655
8656 const ToolChain::path_list &Paths = ToolChain.getFilePaths();
8657
8658 for (const auto &Path : Paths)
8659 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
8660
8661 if (Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
8662 CmdArgs.push_back("--no-demangle");
8663
8664 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
8665
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008666 if (D.CCCIsCXX() && !Args.hasArg(options::OPT_nostdlib) &&
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008667 !Args.hasArg(options::OPT_nodefaultlibs)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008668 bool OnlyLibstdcxxStatic =
8669 Args.hasArg(options::OPT_static_libstdcxx) && !IsStatic;
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008670 if (OnlyLibstdcxxStatic)
8671 CmdArgs.push_back("-Bstatic");
8672 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
8673 if (OnlyLibstdcxxStatic)
8674 CmdArgs.push_back("-Bdynamic");
8675 CmdArgs.push_back("-lm");
8676 }
8677
8678 if (!Args.hasArg(options::OPT_nostdlib)) {
8679 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
8680 // Always use groups, since it has no effect on dynamic libraries.
8681 CmdArgs.push_back("--start-group");
8682 CmdArgs.push_back("-lc");
8683 // NaCl's libc++ currently requires libpthread, so just always include it
8684 // in the group for C++.
8685 if (Args.hasArg(options::OPT_pthread) ||
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008686 Args.hasArg(options::OPT_pthreads) || D.CCCIsCXX()) {
Petar Jovanovic26a4a402015-07-08 13:07:31 +00008687 // Gold, used by Mips, handles nested groups differently than ld, and
8688 // without '-lnacl' it prefers symbols from libpthread.a over libnacl.a,
8689 // which is not a desired behaviour here.
8690 // See https://sourceware.org/ml/binutils/2015-03/msg00034.html
8691 if (getToolChain().getArch() == llvm::Triple::mipsel)
8692 CmdArgs.push_back("-lnacl");
8693
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008694 CmdArgs.push_back("-lpthread");
8695 }
8696
8697 CmdArgs.push_back("-lgcc");
8698 CmdArgs.push_back("--as-needed");
8699 if (IsStatic)
8700 CmdArgs.push_back("-lgcc_eh");
8701 else
8702 CmdArgs.push_back("-lgcc_s");
8703 CmdArgs.push_back("--no-as-needed");
Petar Jovanovic26a4a402015-07-08 13:07:31 +00008704
8705 // Mips needs to create and use pnacl_legacy library that contains
8706 // definitions from bitcode/pnaclmm.c and definitions for
8707 // __nacl_tp_tls_offset() and __nacl_tp_tdb_offset().
8708 if (getToolChain().getArch() == llvm::Triple::mipsel)
8709 CmdArgs.push_back("-lpnacl_legacy");
8710
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008711 CmdArgs.push_back("--end-group");
8712 }
8713
8714 if (!Args.hasArg(options::OPT_nostartfiles)) {
8715 const char *crtend;
8716 if (Args.hasArg(options::OPT_shared))
8717 crtend = "crtendS.o";
8718 else
8719 crtend = "crtend.o";
8720
8721 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtend)));
8722 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
8723 }
8724 }
8725
Justin Bognerd3371d82015-07-17 03:35:54 +00008726 C.addCommand(llvm::make_unique<Command>(JA, *this, ToolChain.Linker.c_str(),
8727 CmdArgs, Inputs));
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008728}
8729
Douglas Katzman95354292015-06-23 20:42:09 +00008730void minix::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
8731 const InputInfo &Output,
8732 const InputInfoList &Inputs,
8733 const ArgList &Args,
8734 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00008735 claimNoWarnArgs(Args);
Chris Lattner3e2ee142010-07-07 16:01:42 +00008736 ArgStringList CmdArgs;
8737
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008738 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Chris Lattner3e2ee142010-07-07 16:01:42 +00008739
8740 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00008741 CmdArgs.push_back(Output.getFilename());
Chris Lattner3e2ee142010-07-07 16:01:42 +00008742
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008743 for (const auto &II : Inputs)
Daniel Dunbarb440f562010-08-02 02:38:21 +00008744 CmdArgs.push_back(II.getFilename());
Chris Lattner3e2ee142010-07-07 16:01:42 +00008745
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008746 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00008747 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Chris Lattner3e2ee142010-07-07 16:01:42 +00008748}
8749
Douglas Katzman95354292015-06-23 20:42:09 +00008750void minix::Linker::ConstructJob(Compilation &C, const JobAction &JA,
8751 const InputInfo &Output,
8752 const InputInfoList &Inputs,
8753 const ArgList &Args,
8754 const char *LinkingOutput) const {
Chris Lattner3e2ee142010-07-07 16:01:42 +00008755 const Driver &D = getToolChain().getDriver();
8756 ArgStringList CmdArgs;
8757
Daniel Dunbarb440f562010-08-02 02:38:21 +00008758 if (Output.isFilename()) {
Chris Lattner3e2ee142010-07-07 16:01:42 +00008759 CmdArgs.push_back("-o");
8760 CmdArgs.push_back(Output.getFilename());
8761 } else {
8762 assert(Output.isNothing() && "Invalid output.");
8763 }
8764
8765 if (!Args.hasArg(options::OPT_nostdlib) &&
Eli Friedman83de5132011-12-08 23:54:21 +00008766 !Args.hasArg(options::OPT_nostartfiles)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008767 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crt1.o")));
8768 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
8769 CmdArgs.push_back(
8770 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
8771 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
Eli Friedman83de5132011-12-08 23:54:21 +00008772 }
Chris Lattner3e2ee142010-07-07 16:01:42 +00008773
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00008774 Args.AddAllArgs(CmdArgs,
8775 {options::OPT_L, options::OPT_T_Group, options::OPT_e});
Chris Lattner3e2ee142010-07-07 16:01:42 +00008776
Daniel Dunbar54423b22010-09-17 00:24:54 +00008777 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Chris Lattner3e2ee142010-07-07 16:01:42 +00008778
Alexey Samsonov7811d192014-02-20 13:57:37 +00008779 addProfileRT(getToolChain(), Args, CmdArgs);
Eli Friedman83de5132011-12-08 23:54:21 +00008780
Chris Lattner3e2ee142010-07-07 16:01:42 +00008781 if (!Args.hasArg(options::OPT_nostdlib) &&
8782 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00008783 if (D.CCCIsCXX()) {
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00008784 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Chris Lattner3e2ee142010-07-07 16:01:42 +00008785 CmdArgs.push_back("-lm");
8786 }
Chris Lattner3e2ee142010-07-07 16:01:42 +00008787 }
8788
8789 if (!Args.hasArg(options::OPT_nostdlib) &&
8790 !Args.hasArg(options::OPT_nostartfiles)) {
Eli Friedman83de5132011-12-08 23:54:21 +00008791 if (Args.hasArg(options::OPT_pthread))
8792 CmdArgs.push_back("-lpthread");
8793 CmdArgs.push_back("-lc");
8794 CmdArgs.push_back("-lCompilerRT-Generic");
8795 CmdArgs.push_back("-L/usr/pkg/compiler-rt/lib");
8796 CmdArgs.push_back(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008797 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Chris Lattner3e2ee142010-07-07 16:01:42 +00008798 }
8799
Logan Chieneb9162f2014-06-26 14:23:45 +00008800 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00008801 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Chris Lattner3e2ee142010-07-07 16:01:42 +00008802}
8803
Daniel Dunbarcc912342009-05-02 18:28:39 +00008804/// DragonFly Tools
8805
8806// For now, DragonFly Assemble does just about the same as for
8807// FreeBSD, but this may change soon.
Douglas Katzman95354292015-06-23 20:42:09 +00008808void dragonfly::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
8809 const InputInfo &Output,
8810 const InputInfoList &Inputs,
8811 const ArgList &Args,
8812 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00008813 claimNoWarnArgs(Args);
Daniel Dunbarcc912342009-05-02 18:28:39 +00008814 ArgStringList CmdArgs;
8815
8816 // When building 32-bit code on DragonFly/pc64, we have to explicitly
8817 // instruct as in the base system to assemble 32-bit code.
Rafael Espindola35ca7d92012-10-07 04:44:33 +00008818 if (getToolChain().getArch() == llvm::Triple::x86)
Daniel Dunbarcc912342009-05-02 18:28:39 +00008819 CmdArgs.push_back("--32");
8820
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008821 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbarcc912342009-05-02 18:28:39 +00008822
8823 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00008824 CmdArgs.push_back(Output.getFilename());
Daniel Dunbarcc912342009-05-02 18:28:39 +00008825
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008826 for (const auto &II : Inputs)
Daniel Dunbarb440f562010-08-02 02:38:21 +00008827 CmdArgs.push_back(II.getFilename());
Daniel Dunbarcc912342009-05-02 18:28:39 +00008828
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008829 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00008830 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbarcc912342009-05-02 18:28:39 +00008831}
8832
Douglas Katzman95354292015-06-23 20:42:09 +00008833void dragonfly::Linker::ConstructJob(Compilation &C, const JobAction &JA,
8834 const InputInfo &Output,
8835 const InputInfoList &Inputs,
8836 const ArgList &Args,
8837 const char *LinkingOutput) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00008838 const Driver &D = getToolChain().getDriver();
Daniel Dunbarcc912342009-05-02 18:28:39 +00008839 ArgStringList CmdArgs;
Rafael Espindola611505f2014-09-11 18:10:13 +00008840 bool UseGCC47 = llvm::sys::fs::exists("/usr/lib/gcc47");
John McCall65b8da02013-04-11 22:55:55 +00008841
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00008842 if (!D.SysRoot.empty())
8843 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
8844
John McCall65b8da02013-04-11 22:55:55 +00008845 CmdArgs.push_back("--eh-frame-hdr");
Daniel Dunbarcc912342009-05-02 18:28:39 +00008846 if (Args.hasArg(options::OPT_static)) {
8847 CmdArgs.push_back("-Bstatic");
8848 } else {
John McCall65b8da02013-04-11 22:55:55 +00008849 if (Args.hasArg(options::OPT_rdynamic))
8850 CmdArgs.push_back("-export-dynamic");
Daniel Dunbarcc912342009-05-02 18:28:39 +00008851 if (Args.hasArg(options::OPT_shared))
8852 CmdArgs.push_back("-Bshareable");
8853 else {
8854 CmdArgs.push_back("-dynamic-linker");
8855 CmdArgs.push_back("/usr/libexec/ld-elf.so.2");
8856 }
John McCall65b8da02013-04-11 22:55:55 +00008857 CmdArgs.push_back("--hash-style=both");
Daniel Dunbarcc912342009-05-02 18:28:39 +00008858 }
8859
8860 // When building 32-bit code on DragonFly/pc64, we have to explicitly
8861 // instruct ld in the base system to link 32-bit code.
Rafael Espindola35ca7d92012-10-07 04:44:33 +00008862 if (getToolChain().getArch() == llvm::Triple::x86) {
Daniel Dunbarcc912342009-05-02 18:28:39 +00008863 CmdArgs.push_back("-m");
8864 CmdArgs.push_back("elf_i386");
8865 }
8866
Daniel Dunbarb440f562010-08-02 02:38:21 +00008867 if (Output.isFilename()) {
Daniel Dunbarcc912342009-05-02 18:28:39 +00008868 CmdArgs.push_back("-o");
8869 CmdArgs.push_back(Output.getFilename());
8870 } else {
8871 assert(Output.isNothing() && "Invalid output.");
8872 }
8873
8874 if (!Args.hasArg(options::OPT_nostdlib) &&
8875 !Args.hasArg(options::OPT_nostartfiles)) {
8876 if (!Args.hasArg(options::OPT_shared)) {
John McCall65b8da02013-04-11 22:55:55 +00008877 if (Args.hasArg(options::OPT_pg))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008878 CmdArgs.push_back(
8879 Args.MakeArgString(getToolChain().GetFilePath("gcrt1.o")));
John McCall65b8da02013-04-11 22:55:55 +00008880 else {
8881 if (Args.hasArg(options::OPT_pie))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008882 CmdArgs.push_back(
8883 Args.MakeArgString(getToolChain().GetFilePath("Scrt1.o")));
John McCall65b8da02013-04-11 22:55:55 +00008884 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008885 CmdArgs.push_back(
8886 Args.MakeArgString(getToolChain().GetFilePath("crt1.o")));
John McCall65b8da02013-04-11 22:55:55 +00008887 }
Daniel Dunbarcc912342009-05-02 18:28:39 +00008888 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008889 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
John McCall65b8da02013-04-11 22:55:55 +00008890 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_pie))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008891 CmdArgs.push_back(
8892 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.o")));
John McCall65b8da02013-04-11 22:55:55 +00008893 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008894 CmdArgs.push_back(
8895 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
Daniel Dunbarcc912342009-05-02 18:28:39 +00008896 }
8897
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00008898 Args.AddAllArgs(CmdArgs,
8899 {options::OPT_L, options::OPT_T_Group, options::OPT_e});
Daniel Dunbarcc912342009-05-02 18:28:39 +00008900
Daniel Dunbar54423b22010-09-17 00:24:54 +00008901 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Daniel Dunbarcc912342009-05-02 18:28:39 +00008902
8903 if (!Args.hasArg(options::OPT_nostdlib) &&
8904 !Args.hasArg(options::OPT_nodefaultlibs)) {
8905 // FIXME: GCC passes on -lgcc, -lgcc_pic and a whole lot of
8906 // rpaths
John McCall65b8da02013-04-11 22:55:55 +00008907 if (UseGCC47)
8908 CmdArgs.push_back("-L/usr/lib/gcc47");
8909 else
8910 CmdArgs.push_back("-L/usr/lib/gcc44");
Daniel Dunbarcc912342009-05-02 18:28:39 +00008911
8912 if (!Args.hasArg(options::OPT_static)) {
John McCall65b8da02013-04-11 22:55:55 +00008913 if (UseGCC47) {
8914 CmdArgs.push_back("-rpath");
8915 CmdArgs.push_back("/usr/lib/gcc47");
8916 } else {
8917 CmdArgs.push_back("-rpath");
8918 CmdArgs.push_back("/usr/lib/gcc44");
8919 }
Daniel Dunbarcc912342009-05-02 18:28:39 +00008920 }
8921
Hans Wennborg70850d82013-07-18 20:29:38 +00008922 if (D.CCCIsCXX()) {
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00008923 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Rafael Espindola38360b32010-07-20 12:59:03 +00008924 CmdArgs.push_back("-lm");
8925 }
8926
Daniel Dunbarcc912342009-05-02 18:28:39 +00008927 if (Args.hasArg(options::OPT_pthread))
Mike Stump0a65b632009-10-31 20:11:46 +00008928 CmdArgs.push_back("-lpthread");
Daniel Dunbarcc912342009-05-02 18:28:39 +00008929
8930 if (!Args.hasArg(options::OPT_nolibc)) {
8931 CmdArgs.push_back("-lc");
8932 }
8933
John McCall65b8da02013-04-11 22:55:55 +00008934 if (UseGCC47) {
8935 if (Args.hasArg(options::OPT_static) ||
8936 Args.hasArg(options::OPT_static_libgcc)) {
8937 CmdArgs.push_back("-lgcc");
8938 CmdArgs.push_back("-lgcc_eh");
8939 } else {
8940 if (Args.hasArg(options::OPT_shared_libgcc)) {
8941 CmdArgs.push_back("-lgcc_pic");
8942 if (!Args.hasArg(options::OPT_shared))
8943 CmdArgs.push_back("-lgcc");
8944 } else {
8945 CmdArgs.push_back("-lgcc");
8946 CmdArgs.push_back("--as-needed");
8947 CmdArgs.push_back("-lgcc_pic");
8948 CmdArgs.push_back("--no-as-needed");
8949 }
8950 }
Daniel Dunbarcc912342009-05-02 18:28:39 +00008951 } else {
John McCall65b8da02013-04-11 22:55:55 +00008952 if (Args.hasArg(options::OPT_shared)) {
8953 CmdArgs.push_back("-lgcc_pic");
8954 } else {
8955 CmdArgs.push_back("-lgcc");
8956 }
Daniel Dunbarcc912342009-05-02 18:28:39 +00008957 }
8958 }
8959
8960 if (!Args.hasArg(options::OPT_nostdlib) &&
8961 !Args.hasArg(options::OPT_nostartfiles)) {
John McCall65b8da02013-04-11 22:55:55 +00008962 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_pie))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008963 CmdArgs.push_back(
8964 Args.MakeArgString(getToolChain().GetFilePath("crtendS.o")));
John McCall65b8da02013-04-11 22:55:55 +00008965 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008966 CmdArgs.push_back(
8967 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
8968 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
Daniel Dunbarcc912342009-05-02 18:28:39 +00008969 }
8970
Alexey Samsonov7811d192014-02-20 13:57:37 +00008971 addProfileRT(getToolChain(), Args, CmdArgs);
Nick Lewycky82fe5f42011-05-24 21:54:59 +00008972
Logan Chieneb9162f2014-06-26 14:23:45 +00008973 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00008974 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbarcc912342009-05-02 18:28:39 +00008975}
Michael J. Spencerb186bc32010-08-21 21:55:07 +00008976
Zachary Turner0eaf8fc2014-10-22 20:40:28 +00008977// Try to find Exe from a Visual Studio distribution. This first tries to find
8978// an installed copy of Visual Studio and, failing that, looks in the PATH,
8979// making sure that whatever executable that's found is not a same-named exe
8980// from clang itself to prevent clang from falling back to itself.
8981static std::string FindVisualStudioExecutable(const ToolChain &TC,
8982 const char *Exe,
8983 const char *ClangProgramPath) {
8984 const auto &MSVC = static_cast<const toolchains::MSVCToolChain &>(TC);
8985 std::string visualStudioBinDir;
8986 if (MSVC.getVisualStudioBinariesFolder(ClangProgramPath,
8987 visualStudioBinDir)) {
8988 SmallString<128> FilePath(visualStudioBinDir);
8989 llvm::sys::path::append(FilePath, Exe);
8990 if (llvm::sys::fs::can_execute(FilePath.c_str()))
8991 return FilePath.str();
8992 }
8993
8994 return Exe;
8995}
8996
Douglas Katzman95354292015-06-23 20:42:09 +00008997void visualstudio::Linker::ConstructJob(Compilation &C, const JobAction &JA,
8998 const InputInfo &Output,
8999 const InputInfoList &Inputs,
9000 const ArgList &Args,
9001 const char *LinkingOutput) const {
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009002 ArgStringList CmdArgs;
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009003 const ToolChain &TC = getToolChain();
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009004
Saleem Abdulrasool9a215462014-12-19 23:56:31 +00009005 assert((Output.isFilename() || Output.isNothing()) && "invalid output");
9006 if (Output.isFilename())
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009007 CmdArgs.push_back(
9008 Args.MakeArgString(std::string("-out:") + Output.getFilename()));
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009009
9010 if (!Args.hasArg(options::OPT_nostdlib) &&
Saleem Abdulrasool9a215462014-12-19 23:56:31 +00009011 !Args.hasArg(options::OPT_nostartfiles) && !C.getDriver().IsCLMode())
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009012 CmdArgs.push_back("-defaultlib:libcmt");
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009013
Zachary Turner10d75b22014-10-22 20:40:43 +00009014 if (!llvm::sys::Process::GetEnv("LIB")) {
9015 // If the VC environment hasn't been configured (perhaps because the user
9016 // did not run vcvarsall), try to build a consistent link environment. If
Nico Webere93bcd12015-03-11 00:05:26 +00009017 // the environment variable is set however, assume the user knows what
9018 // they're doing.
Zachary Turner10d75b22014-10-22 20:40:43 +00009019 std::string VisualStudioDir;
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009020 const auto &MSVC = static_cast<const toolchains::MSVCToolChain &>(TC);
Zachary Turner10d75b22014-10-22 20:40:43 +00009021 if (MSVC.getVisualStudioInstallDir(VisualStudioDir)) {
9022 SmallString<128> LibDir(VisualStudioDir);
9023 llvm::sys::path::append(LibDir, "VC", "lib");
9024 switch (MSVC.getArch()) {
9025 case llvm::Triple::x86:
9026 // x86 just puts the libraries directly in lib
9027 break;
9028 case llvm::Triple::x86_64:
9029 llvm::sys::path::append(LibDir, "amd64");
9030 break;
9031 case llvm::Triple::arm:
9032 llvm::sys::path::append(LibDir, "arm");
9033 break;
9034 default:
9035 break;
9036 }
9037 CmdArgs.push_back(
9038 Args.MakeArgString(std::string("-libpath:") + LibDir.c_str()));
Reid Kleckner7531f7d2015-09-11 00:09:39 +00009039
9040 if (MSVC.useUniversalCRT(VisualStudioDir)) {
9041 std::string UniversalCRTLibPath;
9042 if (MSVC.getUniversalCRTLibraryPath(UniversalCRTLibPath))
9043 CmdArgs.push_back(Args.MakeArgString(std::string("-libpath:") +
9044 UniversalCRTLibPath.c_str()));
9045 }
Zachary Turner10d75b22014-10-22 20:40:43 +00009046 }
9047
9048 std::string WindowsSdkLibPath;
9049 if (MSVC.getWindowsSDKLibraryPath(WindowsSdkLibPath))
9050 CmdArgs.push_back(Args.MakeArgString(std::string("-libpath:") +
9051 WindowsSdkLibPath.c_str()));
9052 }
9053
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009054 CmdArgs.push_back("-nologo");
9055
Reid Kleckner124955a2015-08-05 18:51:13 +00009056 if (Args.hasArg(options::OPT_g_Group, options::OPT__SLASH_Z7))
Hans Wennborgbbb5f072014-04-25 16:24:19 +00009057 CmdArgs.push_back("-debug");
Hans Wennborgbbb5f072014-04-25 16:24:19 +00009058
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009059 bool DLL = Args.hasArg(options::OPT__SLASH_LD, options::OPT__SLASH_LDd,
Hans Wennborge4c47f22015-03-04 23:16:21 +00009060 options::OPT_shared);
Hans Wennborgf1a74252013-09-10 20:18:04 +00009061 if (DLL) {
9062 CmdArgs.push_back(Args.MakeArgString("-dll"));
9063
9064 SmallString<128> ImplibName(Output.getFilename());
9065 llvm::sys::path::replace_extension(ImplibName, "lib");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009066 CmdArgs.push_back(Args.MakeArgString(std::string("-implib:") + ImplibName));
Hans Wennborgf1a74252013-09-10 20:18:04 +00009067 }
9068
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009069 if (TC.getSanitizerArgs().needsAsanRt()) {
Hans Wennborg0517e752013-08-28 17:36:07 +00009070 CmdArgs.push_back(Args.MakeArgString("-debug"));
Hans Wennborgd024c1c2013-08-30 10:50:52 +00009071 CmdArgs.push_back(Args.MakeArgString("-incremental:no"));
Timur Iskhodzhanov6903e102014-08-26 10:08:24 +00009072 if (Args.hasArg(options::OPT__SLASH_MD, options::OPT__SLASH_MDd)) {
Saleem Abdulrasool1d59f492015-01-02 20:00:55 +00009073 static const char *CompilerRTComponents[] = {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009074 "asan_dynamic", "asan_dynamic_runtime_thunk",
Saleem Abdulrasool1d59f492015-01-02 20:00:55 +00009075 };
9076 for (const auto &Component : CompilerRTComponents)
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00009077 CmdArgs.push_back(getCompilerRTArgString(TC, Args, Component));
Timur Iskhodzhanov651725e2014-09-12 14:01:30 +00009078 // Make sure the dynamic runtime thunk is not optimized out at link time
9079 // to ensure proper SEH handling.
9080 CmdArgs.push_back(Args.MakeArgString("-include:___asan_seh_interceptor"));
Timur Iskhodzhanov6903e102014-08-26 10:08:24 +00009081 } else if (DLL) {
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00009082 CmdArgs.push_back(getCompilerRTArgString(TC, Args, "asan_dll_thunk"));
Alexey Samsonov6424e022014-05-12 20:20:20 +00009083 } else {
Saleem Abdulrasool1d59f492015-01-02 20:00:55 +00009084 static const char *CompilerRTComponents[] = {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009085 "asan", "asan_cxx",
Saleem Abdulrasool1d59f492015-01-02 20:00:55 +00009086 };
9087 for (const auto &Component : CompilerRTComponents)
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00009088 CmdArgs.push_back(getCompilerRTArgString(TC, Args, Component));
Alexey Samsonov6424e022014-05-12 20:20:20 +00009089 }
Hans Wennborg65f17522013-08-27 18:10:21 +00009090 }
9091
Hans Wennborg2e274592013-08-13 23:38:57 +00009092 Args.AddAllArgValues(CmdArgs, options::OPT__SLASH_link);
Michael J. Spencere2f49362012-06-18 16:56:04 +00009093
Alexey Bataevc7e84352015-08-19 04:49:01 +00009094 if (Args.hasFlag(options::OPT_fopenmp, options::OPT_fopenmp_EQ,
9095 options::OPT_fno_openmp, false)) {
9096 CmdArgs.push_back("-nodefaultlib:vcomp.lib");
9097 CmdArgs.push_back("-nodefaultlib:vcompd.lib");
9098 CmdArgs.push_back(Args.MakeArgString(std::string("-libpath:") +
9099 TC.getDriver().Dir + "/../lib"));
9100 switch (getOpenMPRuntime(getToolChain(), Args)) {
9101 case OMPRT_OMP:
9102 CmdArgs.push_back("-defaultlib:libomp.lib");
9103 break;
9104 case OMPRT_IOMP5:
9105 CmdArgs.push_back("-defaultlib:libiomp5md.lib");
9106 break;
9107 case OMPRT_GOMP:
9108 break;
9109 case OMPRT_Unknown:
9110 // Already diagnosed.
9111 break;
9112 }
9113 }
9114
Reid Kleckner337188f2014-09-16 19:22:00 +00009115 // Add filenames, libraries, and other linker inputs.
9116 for (const auto &Input : Inputs) {
9117 if (Input.isFilename()) {
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009118 CmdArgs.push_back(Input.getFilename());
Reid Kleckner337188f2014-09-16 19:22:00 +00009119 continue;
9120 }
9121
9122 const Arg &A = Input.getInputArg();
9123
9124 // Render -l options differently for the MSVC linker.
9125 if (A.getOption().matches(options::OPT_l)) {
9126 StringRef Lib = A.getValue();
9127 const char *LinkLibArg;
9128 if (Lib.endswith(".lib"))
9129 LinkLibArg = Args.MakeArgString(Lib);
9130 else
9131 LinkLibArg = Args.MakeArgString(Lib + ".lib");
9132 CmdArgs.push_back(LinkLibArg);
9133 continue;
9134 }
9135
9136 // Otherwise, this is some other kind of linker input option like -Wl, -z,
9137 // or -L. Render it, even if MSVC doesn't understand it.
9138 A.renderAsInput(Args, CmdArgs);
9139 }
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009140
Zachary Turner719f58c2014-12-01 23:06:47 +00009141 // We need to special case some linker paths. In the case of lld, we need to
9142 // translate 'lld' into 'lld-link', and in the case of the regular msvc
9143 // linker, we need to use a special search algorithm.
9144 llvm::SmallString<128> linkPath;
9145 StringRef Linker = Args.getLastArgValue(options::OPT_fuse_ld_EQ, "link");
9146 if (Linker.equals_lower("lld"))
9147 Linker = "lld-link";
9148
9149 if (Linker.equals_lower("link")) {
9150 // If we're using the MSVC linker, it's not sufficient to just use link
9151 // from the program PATH, because other environments like GnuWin32 install
9152 // their own link.exe which may come first.
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009153 linkPath = FindVisualStudioExecutable(TC, "link.exe",
Zachary Turner719f58c2014-12-01 23:06:47 +00009154 C.getDriver().getClangProgramPath());
9155 } else {
9156 linkPath = Linker;
9157 llvm::sys::path::replace_extension(linkPath, "exe");
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009158 linkPath = TC.GetProgramPath(linkPath.c_str());
Zachary Turner719f58c2014-12-01 23:06:47 +00009159 }
9160
Zachary Turner0eaf8fc2014-10-22 20:40:28 +00009161 const char *Exec = Args.MakeArgString(linkPath);
Justin Bognerd3371d82015-07-17 03:35:54 +00009162 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009163}
Hans Wennborg87cfa712013-09-19 20:32:16 +00009164
Douglas Katzman95354292015-06-23 20:42:09 +00009165void visualstudio::Compiler::ConstructJob(Compilation &C, const JobAction &JA,
9166 const InputInfo &Output,
9167 const InputInfoList &Inputs,
9168 const ArgList &Args,
9169 const char *LinkingOutput) const {
Hans Wennborg87cfa712013-09-19 20:32:16 +00009170 C.addCommand(GetCommand(C, JA, Output, Inputs, Args, LinkingOutput));
9171}
9172
Douglas Katzman95354292015-06-23 20:42:09 +00009173std::unique_ptr<Command> visualstudio::Compiler::GetCommand(
David Blaikiec11bf802014-09-04 16:04:28 +00009174 Compilation &C, const JobAction &JA, const InputInfo &Output,
9175 const InputInfoList &Inputs, const ArgList &Args,
9176 const char *LinkingOutput) const {
Hans Wennborg87cfa712013-09-19 20:32:16 +00009177 ArgStringList CmdArgs;
Hans Wennborg263c2132013-09-24 17:36:21 +00009178 CmdArgs.push_back("/nologo");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009179 CmdArgs.push_back("/c"); // Compile only.
Hans Wennborg87cfa712013-09-19 20:32:16 +00009180 CmdArgs.push_back("/W0"); // No warnings.
9181
9182 // The goal is to be able to invoke this tool correctly based on
9183 // any flag accepted by clang-cl.
9184
9185 // These are spelled the same way in clang and cl.exe,.
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00009186 Args.AddAllArgs(CmdArgs, {options::OPT_D, options::OPT_U, options::OPT_I});
Hans Wennborgb6331dc2013-09-24 18:17:21 +00009187
9188 // Optimization level.
David Majnemer015ce0f2015-07-27 07:32:11 +00009189 if (Arg *A = Args.getLastArg(options::OPT_fbuiltin, options::OPT_fno_builtin))
9190 CmdArgs.push_back(A->getOption().getID() == options::OPT_fbuiltin ? "/Oi"
9191 : "/Oi-");
Hans Wennborgb6331dc2013-09-24 18:17:21 +00009192 if (Arg *A = Args.getLastArg(options::OPT_O, options::OPT_O0)) {
9193 if (A->getOption().getID() == options::OPT_O0) {
9194 CmdArgs.push_back("/Od");
9195 } else {
David Majnemer015ce0f2015-07-27 07:32:11 +00009196 CmdArgs.push_back("/Og");
9197
Hans Wennborgb6331dc2013-09-24 18:17:21 +00009198 StringRef OptLevel = A->getValue();
David Majnemer015ce0f2015-07-27 07:32:11 +00009199 if (OptLevel == "s" || OptLevel == "z")
9200 CmdArgs.push_back("/Os");
9201 else
9202 CmdArgs.push_back("/Ot");
9203
9204 CmdArgs.push_back("/Ob2");
Hans Wennborgb6331dc2013-09-24 18:17:21 +00009205 }
9206 }
David Majnemer015ce0f2015-07-27 07:32:11 +00009207 if (Arg *A = Args.getLastArg(options::OPT_fomit_frame_pointer,
9208 options::OPT_fno_omit_frame_pointer))
9209 CmdArgs.push_back(A->getOption().getID() == options::OPT_fomit_frame_pointer
9210 ? "/Oy"
9211 : "/Oy-");
9212 if (!Args.hasArg(options::OPT_fwritable_strings))
9213 CmdArgs.push_back("/GF");
Hans Wennborg87cfa712013-09-19 20:32:16 +00009214
Nico Weber3f8dafb2015-03-12 19:37:10 +00009215 // Flags for which clang-cl has an alias.
Hans Wennborg87cfa712013-09-19 20:32:16 +00009216 // FIXME: How can we ensure this stays in sync with relevant clang-cl options?
9217
David Majnemerf6072342014-07-01 22:24:56 +00009218 if (Args.hasFlag(options::OPT__SLASH_GR_, options::OPT__SLASH_GR,
9219 /*default=*/false))
9220 CmdArgs.push_back("/GR-");
Hans Wennborg5149a3b2014-03-25 14:48:54 +00009221 if (Arg *A = Args.getLastArg(options::OPT_ffunction_sections,
9222 options::OPT_fno_function_sections))
9223 CmdArgs.push_back(A->getOption().getID() == options::OPT_ffunction_sections
9224 ? "/Gy"
9225 : "/Gy-");
David Majnemerdc7a47c2014-04-07 16:14:38 +00009226 if (Arg *A = Args.getLastArg(options::OPT_fdata_sections,
9227 options::OPT_fno_data_sections))
David Majnemer6c684a72014-04-07 16:19:27 +00009228 CmdArgs.push_back(
9229 A->getOption().getID() == options::OPT_fdata_sections ? "/Gw" : "/Gw-");
Hans Wennborg87cfa712013-09-19 20:32:16 +00009230 if (Args.hasArg(options::OPT_fsyntax_only))
9231 CmdArgs.push_back("/Zs");
Reid Kleckner124955a2015-08-05 18:51:13 +00009232 if (Args.hasArg(options::OPT_g_Flag, options::OPT_gline_tables_only,
9233 options::OPT__SLASH_Z7))
Reid Klecknerc688daf2014-02-19 22:05:59 +00009234 CmdArgs.push_back("/Z7");
Hans Wennborg87cfa712013-09-19 20:32:16 +00009235
Nico Weber3f8dafb2015-03-12 19:37:10 +00009236 std::vector<std::string> Includes =
9237 Args.getAllArgValues(options::OPT_include);
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009238 for (const auto &Include : Includes)
9239 CmdArgs.push_back(Args.MakeArgString(std::string("/FI") + Include));
Hans Wennborg260ff402013-09-27 17:54:18 +00009240
Hans Wennborg87cfa712013-09-19 20:32:16 +00009241 // Flags that can simply be passed through.
9242 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_LD);
9243 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_LDd);
Reid Klecknerc542d372014-06-27 17:02:02 +00009244 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_EH);
David Majnemerbac941c2015-07-25 06:07:59 +00009245 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_Zl);
Hans Wennborg87cfa712013-09-19 20:32:16 +00009246
9247 // The order of these flags is relevant, so pick the last one.
9248 if (Arg *A = Args.getLastArg(options::OPT__SLASH_MD, options::OPT__SLASH_MDd,
9249 options::OPT__SLASH_MT, options::OPT__SLASH_MTd))
9250 A->render(Args, CmdArgs);
9251
Hans Wennborg87cfa712013-09-19 20:32:16 +00009252 // Input filename.
9253 assert(Inputs.size() == 1);
9254 const InputInfo &II = Inputs[0];
9255 assert(II.getType() == types::TY_C || II.getType() == types::TY_CXX);
9256 CmdArgs.push_back(II.getType() == types::TY_C ? "/Tc" : "/Tp");
9257 if (II.isFilename())
9258 CmdArgs.push_back(II.getFilename());
9259 else
9260 II.getInputArg().renderAsInput(Args, CmdArgs);
9261
9262 // Output filename.
9263 assert(Output.getType() == types::TY_Object);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009264 const char *Fo =
9265 Args.MakeArgString(std::string("/Fo") + Output.getFilename());
Hans Wennborg87cfa712013-09-19 20:32:16 +00009266 CmdArgs.push_back(Fo);
9267
Hans Wennborg188382e2013-09-20 18:16:35 +00009268 const Driver &D = getToolChain().getDriver();
Zachary Turner0eaf8fc2014-10-22 20:40:28 +00009269 std::string Exec = FindVisualStudioExecutable(getToolChain(), "cl.exe",
9270 D.getClangProgramPath());
David Blaikiec11bf802014-09-04 16:04:28 +00009271 return llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Exec),
Justin Bognerd3371d82015-07-17 03:35:54 +00009272 CmdArgs, Inputs);
Hans Wennborg87cfa712013-09-19 20:32:16 +00009273}
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009274
Yaron Keren1c0070c2015-07-02 04:45:27 +00009275/// MinGW Tools
9276void MinGW::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
9277 const InputInfo &Output,
9278 const InputInfoList &Inputs,
9279 const ArgList &Args,
9280 const char *LinkingOutput) const {
9281 claimNoWarnArgs(Args);
9282 ArgStringList CmdArgs;
9283
9284 if (getToolChain().getArch() == llvm::Triple::x86) {
9285 CmdArgs.push_back("--32");
9286 } else if (getToolChain().getArch() == llvm::Triple::x86_64) {
9287 CmdArgs.push_back("--64");
9288 }
9289
9290 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
9291
9292 CmdArgs.push_back("-o");
9293 CmdArgs.push_back(Output.getFilename());
9294
9295 for (const auto &II : Inputs)
9296 CmdArgs.push_back(II.getFilename());
9297
9298 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009299 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Yaron Keren1c0070c2015-07-02 04:45:27 +00009300
9301 if (Args.hasArg(options::OPT_gsplit_dwarf))
9302 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output,
9303 SplitDebugName(Args, Inputs[0]));
9304}
9305
9306void MinGW::Linker::AddLibGCC(const ArgList &Args,
9307 ArgStringList &CmdArgs) const {
9308 if (Args.hasArg(options::OPT_mthreads))
9309 CmdArgs.push_back("-lmingwthrd");
9310 CmdArgs.push_back("-lmingw32");
Reid Kleckner0213a472015-07-22 16:01:38 +00009311
Yaron Kerenaa281332015-08-09 00:24:07 +00009312 // Make use of compiler-rt if --rtlib option is used
9313 ToolChain::RuntimeLibType RLT = getToolChain().GetRuntimeLibType(Args);
9314 if (RLT == ToolChain::RLT_Libgcc) {
9315 bool Static = Args.hasArg(options::OPT_static_libgcc) ||
9316 Args.hasArg(options::OPT_static);
9317 bool Shared = Args.hasArg(options::OPT_shared);
9318 bool CXX = getToolChain().getDriver().CCCIsCXX();
9319
9320 if (Static || (!CXX && !Shared)) {
9321 CmdArgs.push_back("-lgcc");
9322 CmdArgs.push_back("-lgcc_eh");
9323 } else {
9324 CmdArgs.push_back("-lgcc_s");
9325 CmdArgs.push_back("-lgcc");
9326 }
9327 } else {
9328 AddRunTimeLibs(getToolChain(), getToolChain().getDriver(), CmdArgs, Args);
9329 }
Reid Kleckner0213a472015-07-22 16:01:38 +00009330
Yaron Keren1c0070c2015-07-02 04:45:27 +00009331 CmdArgs.push_back("-lmoldname");
9332 CmdArgs.push_back("-lmingwex");
9333 CmdArgs.push_back("-lmsvcrt");
9334}
9335
9336void MinGW::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9337 const InputInfo &Output,
9338 const InputInfoList &Inputs,
9339 const ArgList &Args,
9340 const char *LinkingOutput) const {
9341 const ToolChain &TC = getToolChain();
9342 const Driver &D = TC.getDriver();
9343 // const SanitizerArgs &Sanitize = TC.getSanitizerArgs();
9344
9345 ArgStringList CmdArgs;
9346
9347 // Silence warning for "clang -g foo.o -o foo"
9348 Args.ClaimAllArgs(options::OPT_g_Group);
9349 // and "clang -emit-llvm foo.o -o foo"
9350 Args.ClaimAllArgs(options::OPT_emit_llvm);
9351 // and for "clang -w foo.o -o foo". Other warning options are already
9352 // handled somewhere else.
9353 Args.ClaimAllArgs(options::OPT_w);
9354
Yaron Keren2ffb36e2015-07-14 05:23:34 +00009355 StringRef LinkerName = Args.getLastArgValue(options::OPT_fuse_ld_EQ, "ld");
9356 if (LinkerName.equals_lower("lld")) {
9357 CmdArgs.push_back("-flavor");
9358 CmdArgs.push_back("gnu");
9359 }
9360
Yaron Keren1c0070c2015-07-02 04:45:27 +00009361 if (!D.SysRoot.empty())
9362 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
9363
9364 if (Args.hasArg(options::OPT_s))
9365 CmdArgs.push_back("-s");
9366
9367 CmdArgs.push_back("-m");
9368 if (TC.getArch() == llvm::Triple::x86)
9369 CmdArgs.push_back("i386pe");
9370 if (TC.getArch() == llvm::Triple::x86_64)
9371 CmdArgs.push_back("i386pep");
Yaron Keren2ffb36e2015-07-14 05:23:34 +00009372 if (TC.getArch() == llvm::Triple::arm)
9373 CmdArgs.push_back("thumb2pe");
Yaron Keren1c0070c2015-07-02 04:45:27 +00009374
9375 if (Args.hasArg(options::OPT_mwindows)) {
9376 CmdArgs.push_back("--subsystem");
9377 CmdArgs.push_back("windows");
9378 } else if (Args.hasArg(options::OPT_mconsole)) {
9379 CmdArgs.push_back("--subsystem");
9380 CmdArgs.push_back("console");
9381 }
9382
9383 if (Args.hasArg(options::OPT_static))
9384 CmdArgs.push_back("-Bstatic");
9385 else {
9386 if (Args.hasArg(options::OPT_mdll))
9387 CmdArgs.push_back("--dll");
9388 else if (Args.hasArg(options::OPT_shared))
9389 CmdArgs.push_back("--shared");
9390 CmdArgs.push_back("-Bdynamic");
9391 if (Args.hasArg(options::OPT_mdll) || Args.hasArg(options::OPT_shared)) {
9392 CmdArgs.push_back("-e");
9393 if (TC.getArch() == llvm::Triple::x86)
9394 CmdArgs.push_back("_DllMainCRTStartup@12");
9395 else
9396 CmdArgs.push_back("DllMainCRTStartup");
9397 CmdArgs.push_back("--enable-auto-image-base");
9398 }
9399 }
9400
9401 CmdArgs.push_back("-o");
9402 CmdArgs.push_back(Output.getFilename());
9403
9404 Args.AddAllArgs(CmdArgs, options::OPT_e);
9405 // FIXME: add -N, -n flags
9406 Args.AddLastArg(CmdArgs, options::OPT_r);
9407 Args.AddLastArg(CmdArgs, options::OPT_s);
9408 Args.AddLastArg(CmdArgs, options::OPT_t);
9409 Args.AddAllArgs(CmdArgs, options::OPT_u_Group);
9410 Args.AddLastArg(CmdArgs, options::OPT_Z_Flag);
9411
9412 if (!Args.hasArg(options::OPT_nostdlib) &&
9413 !Args.hasArg(options::OPT_nostartfiles)) {
9414 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_mdll)) {
9415 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("dllcrt2.o")));
9416 } else {
9417 if (Args.hasArg(options::OPT_municode))
9418 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crt2u.o")));
9419 else
9420 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crt2.o")));
9421 }
9422 if (Args.hasArg(options::OPT_pg))
9423 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("gcrt2.o")));
9424 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crtbegin.o")));
9425 }
9426
9427 Args.AddAllArgs(CmdArgs, options::OPT_L);
9428 const ToolChain::path_list Paths = TC.getFilePaths();
9429 for (const auto &Path : Paths)
9430 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
9431
9432 AddLinkerInputs(TC, Inputs, Args, CmdArgs);
9433
9434 // TODO: Add ASan stuff here
9435
9436 // TODO: Add profile stuff here
9437
9438 if (D.CCCIsCXX() && !Args.hasArg(options::OPT_nostdlib) &&
9439 !Args.hasArg(options::OPT_nodefaultlibs)) {
9440 bool OnlyLibstdcxxStatic = Args.hasArg(options::OPT_static_libstdcxx) &&
9441 !Args.hasArg(options::OPT_static);
9442 if (OnlyLibstdcxxStatic)
9443 CmdArgs.push_back("-Bstatic");
9444 TC.AddCXXStdlibLibArgs(Args, CmdArgs);
9445 if (OnlyLibstdcxxStatic)
9446 CmdArgs.push_back("-Bdynamic");
9447 }
9448
9449 if (!Args.hasArg(options::OPT_nostdlib)) {
9450 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
9451 if (Args.hasArg(options::OPT_static))
9452 CmdArgs.push_back("--start-group");
9453
9454 if (Args.hasArg(options::OPT_fstack_protector) ||
9455 Args.hasArg(options::OPT_fstack_protector_strong) ||
9456 Args.hasArg(options::OPT_fstack_protector_all)) {
9457 CmdArgs.push_back("-lssp_nonshared");
9458 CmdArgs.push_back("-lssp");
9459 }
9460 if (Args.hasArg(options::OPT_fopenmp))
9461 CmdArgs.push_back("-lgomp");
9462
9463 AddLibGCC(Args, CmdArgs);
9464
9465 if (Args.hasArg(options::OPT_pg))
9466 CmdArgs.push_back("-lgmon");
9467
Yaron Kerenadce68e2015-07-06 18:52:19 +00009468 if (Args.hasArg(options::OPT_pthread))
9469 CmdArgs.push_back("-lpthread");
Yaron Keren1c0070c2015-07-02 04:45:27 +00009470
9471 // add system libraries
9472 if (Args.hasArg(options::OPT_mwindows)) {
9473 CmdArgs.push_back("-lgdi32");
9474 CmdArgs.push_back("-lcomdlg32");
9475 }
9476 CmdArgs.push_back("-ladvapi32");
9477 CmdArgs.push_back("-lshell32");
9478 CmdArgs.push_back("-luser32");
9479 CmdArgs.push_back("-lkernel32");
9480
9481 if (Args.hasArg(options::OPT_static))
9482 CmdArgs.push_back("--end-group");
Yaron Keren2ffb36e2015-07-14 05:23:34 +00009483 else if (!LinkerName.equals_lower("lld"))
Yaron Keren1c0070c2015-07-02 04:45:27 +00009484 AddLibGCC(Args, CmdArgs);
9485 }
9486
9487 if (!Args.hasArg(options::OPT_nostartfiles)) {
9488 // Add crtfastmath.o if available and fast math is enabled.
9489 TC.AddFastMathRuntimeIfAvailable(Args, CmdArgs);
9490
9491 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crtend.o")));
9492 }
9493 }
Yaron Keren2ffb36e2015-07-14 05:23:34 +00009494 const char *Exec = Args.MakeArgString(TC.GetProgramPath(LinkerName.data()));
Justin Bognerd3371d82015-07-17 03:35:54 +00009495 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Yaron Keren1c0070c2015-07-02 04:45:27 +00009496}
9497
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009498/// XCore Tools
9499// We pass assemble and link construction to the xcc tool.
9500
Douglas Katzman95354292015-06-23 20:42:09 +00009501void XCore::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
9502 const InputInfo &Output,
9503 const InputInfoList &Inputs,
9504 const ArgList &Args,
9505 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00009506 claimNoWarnArgs(Args);
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009507 ArgStringList CmdArgs;
9508
9509 CmdArgs.push_back("-o");
9510 CmdArgs.push_back(Output.getFilename());
9511
9512 CmdArgs.push_back("-c");
9513
Robert Lytton9e8c1a42014-02-13 10:40:12 +00009514 if (Args.hasArg(options::OPT_v))
9515 CmdArgs.push_back("-v");
9516
Robert Lytton894d25c2014-05-02 09:33:25 +00009517 if (Arg *A = Args.getLastArg(options::OPT_g_Group))
9518 if (!A->getOption().matches(options::OPT_g0))
9519 CmdArgs.push_back("-g");
Robert Lytton9e8c1a42014-02-13 10:40:12 +00009520
Robert Lytton8e95d4e2014-02-11 10:34:45 +00009521 if (Args.hasFlag(options::OPT_fverbose_asm, options::OPT_fno_verbose_asm,
9522 false))
9523 CmdArgs.push_back("-fverbose-asm");
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009524
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009525 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009526
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009527 for (const auto &II : Inputs)
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009528 CmdArgs.push_back(II.getFilename());
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009529
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009530 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("xcc"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009531 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009532}
9533
Douglas Katzman95354292015-06-23 20:42:09 +00009534void XCore::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9535 const InputInfo &Output,
9536 const InputInfoList &Inputs,
9537 const ArgList &Args,
9538 const char *LinkingOutput) const {
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009539 ArgStringList CmdArgs;
9540
9541 if (Output.isFilename()) {
9542 CmdArgs.push_back("-o");
9543 CmdArgs.push_back(Output.getFilename());
9544 } else {
9545 assert(Output.isNothing() && "Invalid output.");
9546 }
9547
Robert Lytton9e8c1a42014-02-13 10:40:12 +00009548 if (Args.hasArg(options::OPT_v))
9549 CmdArgs.push_back("-v");
9550
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00009551 // Pass -fexceptions through to the linker if it was present.
9552 if (Args.hasFlag(options::OPT_fexceptions, options::OPT_fno_exceptions,
9553 false))
Robert Lyttonf7e03c12014-02-13 10:34:44 +00009554 CmdArgs.push_back("-fexceptions");
9555
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009556 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
9557
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009558 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("xcc"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009559 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009560}
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009561
Douglas Katzman95354292015-06-23 20:42:09 +00009562void CrossWindows::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
9563 const InputInfo &Output,
9564 const InputInfoList &Inputs,
9565 const ArgList &Args,
9566 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00009567 claimNoWarnArgs(Args);
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009568 const auto &TC =
9569 static_cast<const toolchains::CrossWindowsToolChain &>(getToolChain());
9570 ArgStringList CmdArgs;
9571 const char *Exec;
9572
9573 switch (TC.getArch()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009574 default:
9575 llvm_unreachable("unsupported architecture");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009576 case llvm::Triple::arm:
9577 case llvm::Triple::thumb:
9578 break;
9579 case llvm::Triple::x86:
9580 CmdArgs.push_back("--32");
9581 break;
9582 case llvm::Triple::x86_64:
9583 CmdArgs.push_back("--64");
9584 break;
9585 }
9586
9587 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
9588
9589 CmdArgs.push_back("-o");
9590 CmdArgs.push_back(Output.getFilename());
9591
9592 for (const auto &Input : Inputs)
9593 CmdArgs.push_back(Input.getFilename());
9594
9595 const std::string Assembler = TC.GetProgramPath("as");
9596 Exec = Args.MakeArgString(Assembler);
9597
Justin Bognerd3371d82015-07-17 03:35:54 +00009598 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009599}
9600
Douglas Katzman95354292015-06-23 20:42:09 +00009601void CrossWindows::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9602 const InputInfo &Output,
9603 const InputInfoList &Inputs,
9604 const ArgList &Args,
9605 const char *LinkingOutput) const {
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009606 const auto &TC =
9607 static_cast<const toolchains::CrossWindowsToolChain &>(getToolChain());
9608 const llvm::Triple &T = TC.getTriple();
9609 const Driver &D = TC.getDriver();
9610 SmallString<128> EntryPoint;
9611 ArgStringList CmdArgs;
9612 const char *Exec;
9613
9614 // Silence warning for "clang -g foo.o -o foo"
9615 Args.ClaimAllArgs(options::OPT_g_Group);
9616 // and "clang -emit-llvm foo.o -o foo"
9617 Args.ClaimAllArgs(options::OPT_emit_llvm);
9618 // and for "clang -w foo.o -o foo"
9619 Args.ClaimAllArgs(options::OPT_w);
9620 // Other warning options are already handled somewhere else.
9621
9622 if (!D.SysRoot.empty())
9623 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
9624
9625 if (Args.hasArg(options::OPT_pie))
9626 CmdArgs.push_back("-pie");
9627 if (Args.hasArg(options::OPT_rdynamic))
9628 CmdArgs.push_back("-export-dynamic");
9629 if (Args.hasArg(options::OPT_s))
9630 CmdArgs.push_back("--strip-all");
9631
9632 CmdArgs.push_back("-m");
9633 switch (TC.getArch()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009634 default:
9635 llvm_unreachable("unsupported architecture");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009636 case llvm::Triple::arm:
9637 case llvm::Triple::thumb:
9638 // FIXME: this is incorrect for WinCE
9639 CmdArgs.push_back("thumb2pe");
9640 break;
9641 case llvm::Triple::x86:
9642 CmdArgs.push_back("i386pe");
9643 EntryPoint.append("_");
9644 break;
9645 case llvm::Triple::x86_64:
9646 CmdArgs.push_back("i386pep");
9647 break;
9648 }
9649
9650 if (Args.hasArg(options::OPT_shared)) {
9651 switch (T.getArch()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009652 default:
9653 llvm_unreachable("unsupported architecture");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009654 case llvm::Triple::arm:
9655 case llvm::Triple::thumb:
9656 case llvm::Triple::x86_64:
9657 EntryPoint.append("_DllMainCRTStartup");
9658 break;
9659 case llvm::Triple::x86:
9660 EntryPoint.append("_DllMainCRTStartup@12");
9661 break;
9662 }
9663
9664 CmdArgs.push_back("-shared");
9665 CmdArgs.push_back("-Bdynamic");
9666
9667 CmdArgs.push_back("--enable-auto-image-base");
9668
9669 CmdArgs.push_back("--entry");
9670 CmdArgs.push_back(Args.MakeArgString(EntryPoint));
9671 } else {
9672 EntryPoint.append("mainCRTStartup");
9673
9674 CmdArgs.push_back(Args.hasArg(options::OPT_static) ? "-Bstatic"
9675 : "-Bdynamic");
9676
9677 if (!Args.hasArg(options::OPT_nostdlib) &&
9678 !Args.hasArg(options::OPT_nostartfiles)) {
9679 CmdArgs.push_back("--entry");
9680 CmdArgs.push_back(Args.MakeArgString(EntryPoint));
9681 }
9682
9683 // FIXME: handle subsystem
9684 }
9685
9686 // NOTE: deal with multiple definitions on Windows (e.g. COMDAT)
Saleem Abdulrasool56dd1ac2014-10-28 03:15:02 +00009687 CmdArgs.push_back("--allow-multiple-definition");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009688
9689 CmdArgs.push_back("-o");
9690 CmdArgs.push_back(Output.getFilename());
9691
9692 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_rdynamic)) {
9693 SmallString<261> ImpLib(Output.getFilename());
9694 llvm::sys::path::replace_extension(ImpLib, ".lib");
9695
9696 CmdArgs.push_back("--out-implib");
9697 CmdArgs.push_back(Args.MakeArgString(ImpLib));
9698 }
9699
9700 if (!Args.hasArg(options::OPT_nostdlib) &&
9701 !Args.hasArg(options::OPT_nostartfiles)) {
9702 const std::string CRTPath(D.SysRoot + "/usr/lib/");
9703 const char *CRTBegin;
9704
9705 CRTBegin =
9706 Args.hasArg(options::OPT_shared) ? "crtbeginS.obj" : "crtbegin.obj";
9707 CmdArgs.push_back(Args.MakeArgString(CRTPath + CRTBegin));
9708 }
9709
9710 Args.AddAllArgs(CmdArgs, options::OPT_L);
9711
9712 const auto &Paths = TC.getFilePaths();
9713 for (const auto &Path : Paths)
9714 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
9715
9716 AddLinkerInputs(TC, Inputs, Args, CmdArgs);
9717
9718 if (D.CCCIsCXX() && !Args.hasArg(options::OPT_nostdlib) &&
9719 !Args.hasArg(options::OPT_nodefaultlibs)) {
9720 bool StaticCXX = Args.hasArg(options::OPT_static_libstdcxx) &&
9721 !Args.hasArg(options::OPT_static);
9722 if (StaticCXX)
9723 CmdArgs.push_back("-Bstatic");
9724 TC.AddCXXStdlibLibArgs(Args, CmdArgs);
9725 if (StaticCXX)
9726 CmdArgs.push_back("-Bdynamic");
9727 }
9728
9729 if (!Args.hasArg(options::OPT_nostdlib)) {
9730 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
9731 // TODO handle /MT[d] /MD[d]
9732 CmdArgs.push_back("-lmsvcrt");
9733 AddRunTimeLibs(TC, D, CmdArgs, Args);
9734 }
9735 }
9736
9737 const std::string Linker = TC.GetProgramPath("ld");
9738 Exec = Args.MakeArgString(Linker);
9739
Justin Bognerd3371d82015-07-17 03:35:54 +00009740 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009741}
Douglas Katzman84a75642015-06-19 14:55:19 +00009742
Douglas Katzman95354292015-06-23 20:42:09 +00009743void tools::SHAVE::Compiler::ConstructJob(Compilation &C, const JobAction &JA,
9744 const InputInfo &Output,
9745 const InputInfoList &Inputs,
9746 const ArgList &Args,
9747 const char *LinkingOutput) const {
Douglas Katzman84a75642015-06-19 14:55:19 +00009748
9749 ArgStringList CmdArgs;
9750
9751 assert(Inputs.size() == 1);
9752 const InputInfo &II = Inputs[0];
9753 assert(II.getType() == types::TY_C || II.getType() == types::TY_CXX);
9754 assert(Output.getType() == types::TY_PP_Asm); // Require preprocessed asm.
9755
Douglas Katzman84a75642015-06-19 14:55:19 +00009756 CmdArgs.push_back("-DMYRIAD2");
9757 CmdArgs.push_back("-mcpu=myriad2");
9758 CmdArgs.push_back("-S");
9759
Douglas Katzmanf6071112015-08-03 14:34:22 +00009760 // Append all -I, -iquote, -isystem paths, defines/undefines,
9761 // 'f' flags, optimize flags, and warning options.
9762 // These are spelled the same way in clang and moviCompile.
Douglas Katzman38dca882015-09-08 19:29:55 +00009763 Args.AddAllArgs(CmdArgs, {options::OPT_I_Group, options::OPT_clang_i_Group,
9764 options::OPT_D, options::OPT_U,
9765 options::OPT_f_Group, options::OPT_f_clang_Group,
9766 options::OPT_g_Group, options::OPT_M_Group,
9767 options::OPT_O_Group, options::OPT_W_Group});
9768
9769 // If we're producing a dependency file, and assembly is the final action,
9770 // then the name of the target in the dependency file should be the '.o'
9771 // file, not the '.s' file produced by this step. For example, instead of
9772 // /tmp/mumble.s: mumble.c .../someheader.h
9773 // the filename on the lefthand side should be "mumble.o"
9774 if (Args.getLastArg(options::OPT_MF) && !Args.getLastArg(options::OPT_MT) &&
9775 C.getActions().size() == 1 &&
9776 C.getActions()[0]->getKind() == Action::AssembleJobClass) {
9777 Arg *A = Args.getLastArg(options::OPT_o);
9778 if (A) {
9779 CmdArgs.push_back("-MT");
9780 CmdArgs.push_back(Args.MakeArgString(A->getValue()));
9781 }
9782 }
9783
Douglas Katzman84a75642015-06-19 14:55:19 +00009784 CmdArgs.push_back("-fno-exceptions"); // Always do this even if unspecified.
9785
9786 CmdArgs.push_back(II.getFilename());
9787 CmdArgs.push_back("-o");
9788 CmdArgs.push_back(Output.getFilename());
9789
9790 std::string Exec =
9791 Args.MakeArgString(getToolChain().GetProgramPath("moviCompile"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009792 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Exec),
9793 CmdArgs, Inputs));
Douglas Katzman84a75642015-06-19 14:55:19 +00009794}
9795
Douglas Katzman95354292015-06-23 20:42:09 +00009796void tools::SHAVE::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
9797 const InputInfo &Output,
9798 const InputInfoList &Inputs,
9799 const ArgList &Args,
9800 const char *LinkingOutput) const {
Douglas Katzman84a75642015-06-19 14:55:19 +00009801 ArgStringList CmdArgs;
9802
9803 assert(Inputs.size() == 1);
9804 const InputInfo &II = Inputs[0];
9805 assert(II.getType() == types::TY_PP_Asm); // Require preprocessed asm input.
9806 assert(Output.getType() == types::TY_Object);
9807
9808 CmdArgs.push_back("-no6thSlotCompression");
Douglas Katzmanae2f3582015-09-11 21:13:46 +00009809 CmdArgs.push_back("-cv:myriad2"); // Chip Version
Douglas Katzman84a75642015-06-19 14:55:19 +00009810 CmdArgs.push_back("-noSPrefixing");
9811 CmdArgs.push_back("-a"); // Mystery option.
Douglas Katzmanae2f3582015-09-11 21:13:46 +00009812 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
9813 for (const Arg *A : Args.filtered(options::OPT_I, options::OPT_isystem)) {
9814 A->claim();
Douglas Katzman84a75642015-06-19 14:55:19 +00009815 CmdArgs.push_back(
Douglas Katzmanae2f3582015-09-11 21:13:46 +00009816 Args.MakeArgString(std::string("-i:") + A->getValue(0)));
Douglas Katzman84a75642015-06-19 14:55:19 +00009817 }
9818 CmdArgs.push_back("-elf"); // Output format.
9819 CmdArgs.push_back(II.getFilename());
9820 CmdArgs.push_back(
9821 Args.MakeArgString(std::string("-o:") + Output.getFilename()));
9822
9823 std::string Exec =
9824 Args.MakeArgString(getToolChain().GetProgramPath("moviAsm"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009825 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Exec),
9826 CmdArgs, Inputs));
Douglas Katzman84a75642015-06-19 14:55:19 +00009827}
Douglas Katzmand6e597c2015-09-17 19:56:40 +00009828
9829void tools::Myriad::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9830 const InputInfo &Output,
9831 const InputInfoList &Inputs,
9832 const ArgList &Args,
9833 const char *LinkingOutput) const {
9834 const auto &TC =
9835 static_cast<const toolchains::MyriadToolChain &>(getToolChain());
9836 const llvm::Triple &T = TC.getTriple();
9837 ArgStringList CmdArgs;
9838 bool UseStartfiles = !Args.hasArg(options::OPT_nostartfiles);
Douglas Katzman9e31cb92015-10-02 18:39:08 +00009839 bool UseDefaultLibs = !Args.hasArg(options::OPT_nostdlib) &&
9840 !Args.hasArg(options::OPT_nodefaultlibs);
Douglas Katzmand6e597c2015-09-17 19:56:40 +00009841
9842 std::string StartFilesDir, BuiltinLibDir;
9843 TC.getCompilerSupportDir(StartFilesDir);
9844 TC.getBuiltinLibDir(BuiltinLibDir);
9845
9846 if (T.getArch() == llvm::Triple::sparc)
9847 CmdArgs.push_back("-EB");
9848 else // SHAVE assumes little-endian, and sparcel is expressly so.
9849 CmdArgs.push_back("-EL");
9850
9851 // The remaining logic is mostly like gnutools::Linker::ConstructJob,
9852 // but we never pass through a --sysroot option and various other bits.
9853 // For example, there are no sanitizers (yet) nor gold linker.
9854
9855 // Eat some arguments that may be present but have no effect.
9856 Args.ClaimAllArgs(options::OPT_g_Group);
9857 Args.ClaimAllArgs(options::OPT_w);
9858 Args.ClaimAllArgs(options::OPT_static_libgcc);
9859
9860 if (Args.hasArg(options::OPT_s)) // Pass the 'strip' option.
9861 CmdArgs.push_back("-s");
9862
9863 CmdArgs.push_back("-o");
9864 CmdArgs.push_back(Output.getFilename());
9865
9866 if (UseStartfiles) {
9867 // If you want startfiles, it means you want the builtin crti and crtbegin,
9868 // but not crt0. Myriad link commands provide their own crt0.o as needed.
9869 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crti.o"));
9870 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crtbegin.o"));
9871 }
9872
9873 Args.AddAllArgs(CmdArgs, {options::OPT_L, options::OPT_T_Group,
9874 options::OPT_e, options::OPT_s, options::OPT_t,
9875 options::OPT_Z_Flag, options::OPT_r});
9876
Douglas Katzman9e31cb92015-10-02 18:39:08 +00009877 if (UseDefaultLibs) {
9878 // The linker doesn't use these builtin paths unless directed to,
9879 // because it was not compiled for support with sysroots, nor does
9880 // it have a default of little-endian with FPU.
9881 CmdArgs.push_back(Args.MakeArgString("-L" + BuiltinLibDir));
9882 CmdArgs.push_back(Args.MakeArgString("-L" + StartFilesDir));
9883 }
Douglas Katzmand6e597c2015-09-17 19:56:40 +00009884
9885 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
9886
Douglas Katzman9e31cb92015-10-02 18:39:08 +00009887 if (UseDefaultLibs) {
Douglas Katzman795f57f2015-10-09 20:26:20 +00009888 if (C.getDriver().CCCIsCXX())
9889 CmdArgs.push_back("-lstdc++");
Douglas Katzman9e31cb92015-10-02 18:39:08 +00009890 if (T.getOS() == llvm::Triple::RTEMS) {
9891 CmdArgs.push_back("--start-group");
9892 CmdArgs.push_back("-lc");
9893 // You must provide your own "-L" option to enable finding these.
9894 CmdArgs.push_back("-lrtemscpu");
9895 CmdArgs.push_back("-lrtemsbsp");
9896 CmdArgs.push_back("--end-group");
9897 } else {
9898 CmdArgs.push_back("-lc");
9899 }
Douglas Katzman9e31cb92015-10-02 18:39:08 +00009900 CmdArgs.push_back("-lgcc");
Douglas Katzmand6e597c2015-09-17 19:56:40 +00009901 }
Douglas Katzmand6e597c2015-09-17 19:56:40 +00009902 if (UseStartfiles) {
9903 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crtend.o"));
9904 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crtn.o"));
9905 }
9906
9907 std::string Exec =
9908 Args.MakeArgString(TC.GetProgramPath("sparc-myriad-elf-ld"));
9909 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Exec),
9910 CmdArgs, Inputs));
9911}